ipn/ipnlocal: respect ExitNodeAllowLANAccess on iOS (#10230)

Updates tailscale/corp#15783

Change-Id: I1082fbfff61a241ebd3b8275be0f45e329b67561

Signed-off-by: Brad Fitzpatrick <bradfitz@tailscale.com>
pull/10232/head
Brad Fitzpatrick 1 year ago committed by GitHub
parent c9bfb7c683
commit 1825d2337b
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

@ -3906,7 +3906,8 @@ func (b *LocalBackend) routerConfig(cfg *wgcfg.Config, prefs ipn.PrefsView, oneC
if err != nil { if err != nil {
b.logf("failed to discover interface ips: %v", err) b.logf("failed to discover interface ips: %v", err)
} }
if runtime.GOOS == "linux" || runtime.GOOS == "darwin" || runtime.GOOS == "windows" { switch runtime.GOOS {
case "linux", "windows", "darwin", "ios":
rs.LocalRoutes = internalIPs // unconditionally allow access to guest VM networks rs.LocalRoutes = internalIPs // unconditionally allow access to guest VM networks
if prefs.ExitNodeAllowLANAccess() { if prefs.ExitNodeAllowLANAccess() {
rs.LocalRoutes = append(rs.LocalRoutes, externalIPs...) rs.LocalRoutes = append(rs.LocalRoutes, externalIPs...)
@ -3916,6 +3917,10 @@ func (b *LocalBackend) routerConfig(cfg *wgcfg.Config, prefs ipn.PrefsView, oneC
rs.Routes = append(rs.Routes, externalIPs...) rs.Routes = append(rs.Routes, externalIPs...)
} }
b.logf("allowing exit node access to local IPs: %v", rs.LocalRoutes) b.logf("allowing exit node access to local IPs: %v", rs.LocalRoutes)
default:
if prefs.ExitNodeAllowLANAccess() {
b.logf("warning: ExitNodeAllowLANAccess has no effect on " + runtime.GOOS)
}
} }
} }

Loading…
Cancel
Save