wgengine/magicsock: update set of DERP nodes

This commit is contained in:
Brad Fitzpatrick 2020-03-05 07:58:16 -08:00
parent 551964c562
commit 848a2bddf0
2 changed files with 13 additions and 6 deletions

View File

@ -25,13 +25,17 @@
) )
const ( const (
derpNYC = 1 derpUSNY = 1
derpSF = 2 derpUSSF = 2
derpSG = 3
derpDE = 4
) )
func init() { func init() {
addDerper(derpNYC, "derp.tailscale.com") addDerper(derpUSNY, "derp1.tailscale.com")
addDerper(derpSF, "derp2.tailscale.com") addDerper(derpUSSF, "derp2.tailscale.com")
addDerper(derpSG, "derp3.tailscale.com")
addDerper(derpDE, "derp4.tailscale.com")
} }
func addDerper(i int, host string) { func addDerper(i int, host string) {
@ -47,7 +51,7 @@ func addDerper(i int, host string) {
} }
// derpHost returns the hostname of a DERP server index (a fake port // derpHost returns the hostname of a DERP server index (a fake port
// number used with derpMagicIP). It always returns a non-empty string. // number used with derpMagicIP).
func derpHost(i int) string { func derpHost(i int) string {
if h, ok := derpHostOfIndex[i]; ok { if h, ok := derpHostOfIndex[i]; ok {
return h return h
@ -55,5 +59,5 @@ func derpHost(i int) string {
if 1 <= i && i <= 64<<10 { if 1 <= i && i <= 64<<10 {
return fmt.Sprintf("derp%v.tailscale.com", i) return fmt.Sprintf("derp%v.tailscale.com", i)
} }
return "derp.tailscale.com" return ""
} }

View File

@ -626,6 +626,9 @@ func (c *Conn) derpWriteChanOfAddr(addr *net.UDPAddr) chan<- derpWriteRequest {
c.derpCancel = make(map[int]context.CancelFunc) c.derpCancel = make(map[int]context.CancelFunc)
} }
host := derpHost(addr.Port) host := derpHost(addr.Port)
if host == "" {
return nil
}
dc, err := derphttp.NewClient(c.privateKey, "https://"+host+"/derp", log.Printf) dc, err := derphttp.NewClient(c.privateKey, "https://"+host+"/derp", log.Printf)
if err != nil { if err != nil {
c.logf("derphttp.NewClient: port %d, host %q invalid? err: %v", addr.Port, host, err) c.logf("derphttp.NewClient: port %d, host %q invalid? err: %v", addr.Port, host, err)