mirror of
				https://github.com/yggdrasil-network/yggdrasil-go.git
				synced 2025-11-04 11:15:07 +03:00 
			
		
		
		
	Move Linux-specific ifname logic to tun_linux.go and place a generic in tun_other.go
This commit is contained in:
		
							parent
							
								
									1c799b305d
								
							
						
					
					
						commit
						ae7b07ae6a
					
				
					 3 changed files with 25 additions and 13 deletions
				
			
		| 
						 | 
					@ -18,16 +18,6 @@ func (tun *tunDevice) init(core *Core) {
 | 
				
			||||||
  tun.core = core
 | 
					  tun.core = core
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
func (tun *tunDevice) setup(ifname string, addr string, mtu int) error {
 | 
					 | 
				
			||||||
        config := water.Config{ DeviceType: water.TUN }
 | 
					 | 
				
			||||||
        if ifname != "" && ifname != "auto" { config.Name = ifname }
 | 
					 | 
				
			||||||
	iface, err := water.New(config)
 | 
					 | 
				
			||||||
	if err != nil { panic(err) }
 | 
					 | 
				
			||||||
  tun.iface = iface
 | 
					 | 
				
			||||||
  tun.mtu = mtu //1280 // Lets default to the smallest thing allowed for now
 | 
					 | 
				
			||||||
  return tun.setupAddress(addr)
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
func (tun *tunDevice) write() error {
 | 
					func (tun *tunDevice) write() error {
 | 
				
			||||||
  for {
 | 
					  for {
 | 
				
			||||||
    data := <-tun.recv
 | 
					    data := <-tun.recv
 | 
				
			||||||
| 
						 | 
					@ -55,4 +45,3 @@ func (tun *tunDevice) read() error {
 | 
				
			||||||
func (tun *tunDevice) close() error {
 | 
					func (tun *tunDevice) close() error {
 | 
				
			||||||
  return tun.iface.Close()
 | 
					  return tun.iface.Close()
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -7,6 +7,20 @@ import "fmt"
 | 
				
			||||||
import "os/exec"
 | 
					import "os/exec"
 | 
				
			||||||
import "strings"
 | 
					import "strings"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import water "github.com/songgao/water"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					func (tun *tunDevice) setup(ifname string, addr string, mtu int) error {
 | 
				
			||||||
 | 
					        config := water.Config{ DeviceType: water.TUN }
 | 
				
			||||||
 | 
					        if ifname != "" && ifname != "auto" {
 | 
				
			||||||
 | 
					          config.Name = ifname
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
						iface, err := water.New(config)
 | 
				
			||||||
 | 
						if err != nil { panic(err) }
 | 
				
			||||||
 | 
					  tun.iface = iface
 | 
				
			||||||
 | 
					  tun.mtu = mtu //1280 // Lets default to the smallest thing allowed for now
 | 
				
			||||||
 | 
					  return tun.setupAddress(addr)
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
func (tun *tunDevice) setupAddress(addr string) error {
 | 
					func (tun *tunDevice) setupAddress(addr string) error {
 | 
				
			||||||
  // Set address
 | 
					  // Set address
 | 
				
			||||||
  cmd := exec.Command("ip", "-f", "inet6",
 | 
					  cmd := exec.Command("ip", "-f", "inet6",
 | 
				
			||||||
| 
						 | 
					@ -33,4 +47,3 @@ func (tun *tunDevice) setupAddress(addr string) error {
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
  return nil
 | 
					  return nil
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -2,11 +2,21 @@
 | 
				
			||||||
 | 
					
 | 
				
			||||||
package yggdrasil
 | 
					package yggdrasil
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import water "github.com/songgao/water"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
// This is to catch unsupported platforms
 | 
					// This is to catch unsupported platforms
 | 
				
			||||||
// If your platform supports tun devices, you could try configuring it manually
 | 
					// If your platform supports tun devices, you could try configuring it manually
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					func (tun *tunDevice) setup(ifname string, addr string, mtu int) error {
 | 
				
			||||||
 | 
					        config := water.Config{ DeviceType: water.TUN }
 | 
				
			||||||
 | 
						iface, err := water.New(config)
 | 
				
			||||||
 | 
						if err != nil { panic(err) }
 | 
				
			||||||
 | 
					  tun.iface = iface
 | 
				
			||||||
 | 
					  tun.mtu = mtu //1280 // Lets default to the smallest thing allowed for now
 | 
				
			||||||
 | 
					  return tun.setupAddress(addr)
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
func (tun *tunDevice) setupAddress(addr string) error {
 | 
					func (tun *tunDevice) setupAddress(addr string) error {
 | 
				
			||||||
  tun.core.log.Println("Platform not supported, you must set the address of", tun.iface.Name(), "to", addr)
 | 
					  tun.core.log.Println("Platform not supported, you must set the address of", tun.iface.Name(), "to", addr)
 | 
				
			||||||
  return nil
 | 
					  return nil
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue