mirror of
				https://github.com/tailscale/tailscale.git
				synced 2025-10-25 10:09:17 +00:00 
			
		
		
		
	tailcfg: add Endpoint, EndpointType, MapRequest.EndpointType
Track endpoints internally with a new tailcfg.Endpoint type that includes a typed netaddr.IPPort (instead of just a string) and includes a type for how that endpoint was discovered (STUN, local, etc). Use []tailcfg.Endpoint instead of []string internally. At the last second, send it to the control server as the existing []string for endpoints, but also include a new parallel MapRequest.EndpointType []tailcfg.EndpointType, so the control server can start filtering out less-important endpoint changes from new-enough clients. Notably, STUN-discovered endpoints can be filtered out from 1.6+ clients, as they can discover them amongst each other via CallMeMaybe disco exchanges started over DERP. And STUN endpoints change a lot, causing a lot of MapResposne updates. But portmapped endpoints are worth keeping for now, as they they work right away without requiring the firewall traversal extra RTT dance. End result will be less control->client bandwidth. (despite negligible increase in client->control bandwidth) Updates tailscale/corp#1543 Signed-off-by: Brad Fitzpatrick <bradfitz@tailscale.com>
This commit is contained in:
		 Brad Fitzpatrick
					Brad Fitzpatrick
				
			
				
					committed by
					
						 Brad Fitzpatrick
						Brad Fitzpatrick
					
				
			
			
				
	
			
			
			 Brad Fitzpatrick
						Brad Fitzpatrick
					
				
			
						parent
						
							b91f3c4191
						
					
				
				
					commit
					34d2f5a3d9
				
			| @@ -111,7 +111,7 @@ type LocalBackend struct { | ||||
| 	nodeByAddr       map[netaddr.IP]*tailcfg.Node | ||||
| 	activeLogin      string // last logged LoginName from netMap | ||||
| 	engineStatus     ipn.EngineStatus | ||||
| 	endpoints        []string | ||||
| 	endpoints        []tailcfg.Endpoint | ||||
| 	blocked          bool | ||||
| 	authURL          string | ||||
| 	interact         bool | ||||
| @@ -544,7 +544,7 @@ func (b *LocalBackend) setWgengineStatus(s *wgengine.Status, err error) { | ||||
| 	es := b.parseWgStatusLocked(s) | ||||
| 	cc := b.cc | ||||
| 	b.engineStatus = es | ||||
| 	b.endpoints = append([]string{}, s.LocalAddrs...) | ||||
| 	b.endpoints = append([]tailcfg.Endpoint{}, s.LocalAddrs...) | ||||
| 	b.mu.Unlock() | ||||
|  | ||||
| 	if cc != nil { | ||||
|   | ||||
		Reference in New Issue
	
	Block a user