tailscale/wgengine/monitor
James Tucker f4aad61e67 wgengine/monitor: ignore duplicate RTM_NEWADDRs
Ignoring the events at this layer is the simpler path for right now, a
broader change should follow to suppress irrelevant change events in a
higher layer so as to avoid related problems with other monitoring paths
on other platforms.  This approach may also carry a small risk that it
applies an at-most-once invariant low in the chain that could be assumed
otherwise higher in the code.

I adjusted the newAddrMessage type to include interface index rather
than a label, as labels are not always supplied, and in particular on my
test hosts they were consistently missing for ipv6 address messages.

I adjusted the newAddrMessage.Addr field to be populated from
Attributes.Address rather than Attributes.Local, as again for ipv6
.Local was always empty, and with ipv4 the .Address and .Local contained
the same contents in each of my test environments.

Update #4282

Signed-off-by: James Tucker <james@tailscale.com>
2022-04-11 14:35:19 -07:00
..
monitor.go all: use any instead of interface{} 2022-03-17 11:35:09 -07:00
monitor_darwin.go all: use any instead of interface{} 2022-03-17 11:35:09 -07:00
monitor_darwin_test.go wgengine/monitor: add skipped failing test for Darwin route message bug 2021-03-02 09:53:36 -08:00
monitor_freebsd.go support running in a FreeBSD jail 2021-12-05 21:42:52 -08:00
monitor_linux.go wgengine/monitor: ignore duplicate RTM_NEWADDRs 2022-04-11 14:35:19 -07:00
monitor_linux_test.go wgengine/monitor: ignore duplicate RTM_NEWADDRs 2022-04-11 14:35:19 -07:00
monitor_polling.go all: gofmt with Go 1.17 2021-08-05 15:54:00 -07:00
monitor_test.go wgengine{,/monitor}: restore Engine.LinkChange, add Mon.InjectEvent 2021-03-03 22:09:02 -08:00
monitor_windows.go wgengine/monitor: reduce Windows log spam 2021-11-18 10:57:27 -08:00
polling.go support running in a FreeBSD jail 2021-12-05 21:42:52 -08:00