mirror of
				https://github.com/yggdrasil-network/water.git
				synced 2025-10-26 06:45:09 +03:00 
			
		
		
		
	Add support for Windows to allow selecting between multiple tap0901 adapters on the same system
				
					
				
			Co-authored-by: Neil Alexander <neilalexander@users.noreply.github.com>
This commit is contained in:
		
							parent
							
								
									f6122f5b2f
								
							
						
					
					
						commit
						86871951e7
					
				
					 3 changed files with 30 additions and 3 deletions
				
			
		|  | @ -10,3 +10,4 @@ ajee cai <ajee.cai@gmail.com> | ||||||
| yinheli <hi@yinheli.com> | yinheli <hi@yinheli.com> | ||||||
| Paul Querna <pquerna@apache.org> | Paul Querna <pquerna@apache.org> | ||||||
| Cuong Manh Le <cuong.manhle.vn@gmail.com> | Cuong Manh Le <cuong.manhle.vn@gmail.com> | ||||||
|  | Neil Alexander <neilalexander@users.noreply.github.com> | ||||||
|  |  | ||||||
|  | @ -9,6 +9,10 @@ type PlatformSpecificParams struct { | ||||||
| 	// use the default ComponentId. The default ComponentId is set to tap0901, | 	// use the default ComponentId. The default ComponentId is set to tap0901, | ||||||
| 	// the one used by OpenVPN. | 	// the one used by OpenVPN. | ||||||
| 	ComponentID string | 	ComponentID string | ||||||
|  | 	// Of course, you may have multiple tap0901 adapters on the system, in which | ||||||
|  | 	// case we need a friendlier way to identify them. In that case we can use | ||||||
|  | 	// the friendly name of the network adapter as set in Control Panel. | ||||||
|  | 	InterfaceName string | ||||||
| 	// Network is required when creating a TUN interface. The library will call | 	// Network is required when creating a TUN interface. The library will call | ||||||
| 	// net.ParseCIDR() to parse this string into LocalIP, RemoteNetaddr, | 	// net.ParseCIDR() to parse this string into LocalIP, RemoteNetaddr, | ||||||
| 	// RemoteNetmask. The underlying driver will need those to generate ARP | 	// RemoteNetmask. The underlying driver will need those to generate ARP | ||||||
|  | @ -25,6 +29,7 @@ type PlatformSpecificParams struct { | ||||||
| func defaultPlatformSpecificParams() PlatformSpecificParams { | func defaultPlatformSpecificParams() PlatformSpecificParams { | ||||||
| 	return PlatformSpecificParams{ | 	return PlatformSpecificParams{ | ||||||
| 		ComponentID: "tap0901", | 		ComponentID: "tap0901", | ||||||
|  | 		InterfaceName: "", | ||||||
| 		Network:     "192.168.1.10/24", | 		Network:     "192.168.1.10/24", | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -139,7 +139,7 @@ func tap_control_code(request, method uint32) uint32 { | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| // getdeviceid finds out a TAP device from registry, it *may* requires privileged right to prevent some weird issue. | // getdeviceid finds out a TAP device from registry, it *may* requires privileged right to prevent some weird issue. | ||||||
| func getdeviceid(componentID string) (deviceid string, err error) { | func getdeviceid(componentID string, interfaceName string) (deviceid string, err error) { | ||||||
| 	// TAP driver key location | 	// TAP driver key location | ||||||
| 	regkey := `SYSTEM\CurrentControlSet\Control\Class\{4D36E972-E325-11CE-BFC1-08002BE10318}` | 	regkey := `SYSTEM\CurrentControlSet\Control\Class\{4D36E972-E325-11CE-BFC1-08002BE10318}` | ||||||
| 	k, err := registry.OpenKey(registry.LOCAL_MACHINE, regkey, registry.READ) | 	k, err := registry.OpenKey(registry.LOCAL_MACHINE, regkey, registry.READ) | ||||||
|  | @ -169,12 +169,33 @@ func getdeviceid(componentID string) (deviceid string, err error) { | ||||||
| 				key.Close() | 				key.Close() | ||||||
| 				continue | 				continue | ||||||
| 			} | 			} | ||||||
|  | 			if len(interfaceName) > 0 { | ||||||
|  | 				key2 := `SYSTEM\CurrentControlSet\Control\Network\{4D36E972-E325-11CE-BFC1-08002BE10318}\`+val+`\Connection` | ||||||
|  | 				k2, err := registry.OpenKey(registry.LOCAL_MACHINE, key2, registry.READ) | ||||||
|  | 				if err != nil { | ||||||
|  | 					fmt.Println("Unable to open", key2) | ||||||
|  | 					continue | ||||||
|  | 				} | ||||||
|  | 				defer k2.Close() | ||||||
|  | 				val, _, err := k2.GetStringValue("Name") | ||||||
|  | 				if err != nil { | ||||||
|  | 					fmt.Println("Unable to get Name value from", key2) | ||||||
|  | 					continue | ||||||
|  | 				} | ||||||
|  | 				if val != interfaceName { | ||||||
|  | 					continue | ||||||
|  | 				} | ||||||
|  | 			} | ||||||
| 			key.Close() | 			key.Close() | ||||||
| 			return val, nil | 			return val, nil | ||||||
| 		} | 		} | ||||||
| 		key.Close() | 		key.Close() | ||||||
| 	} | 	} | ||||||
| 	return "", fmt.Errorf("Failed to find the tap device in registry with specified ComponentId(%s), TAP driver may be not installed", componentID) | 	if len(interfaceName) > 0 { | ||||||
|  | 		return "", fmt.Errorf("Failed to find the tap device in registry with specified ComponentId '%s' and InterfaceName '%s', TAP driver may be not installed or you may have specified an interface name that doesn't exist", componentID) | ||||||
|  | 	} else { | ||||||
|  | 		return "", fmt.Errorf("Failed to find the tap device in registry with specified ComponentId '%s', TAP driver may be not installed", componentID) | ||||||
|  | 	} | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| // setStatus is used to bring up or bring down the interface | // setStatus is used to bring up or bring down the interface | ||||||
|  | @ -216,7 +237,7 @@ func setTUN(fd syscall.Handle, network string) error { | ||||||
| // openDev find and open an interface. | // openDev find and open an interface. | ||||||
| func openDev(config Config) (ifce *Interface, err error) { | func openDev(config Config) (ifce *Interface, err error) { | ||||||
| 	// find the device in registry. | 	// find the device in registry. | ||||||
| 	deviceid, err := getdeviceid(config.PlatformSpecificParams.ComponentID) | 	deviceid, err := getdeviceid(config.PlatformSpecificParams.ComponentID, config.PlatformSpecificParams.InterfaceName) | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		return nil, err | 		return nil, err | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Dmitry Shihovtsev
						Dmitry Shihovtsev