Documentation ¶
Overview ¶
Package monitor provides facilities for monitoring network interface and route changes. It primarily exists to know when portable devices move between different networks.
Index ¶
- type Mon
- func (m *Mon) Close() error
- func (m *Mon) GatewayAndSelfIP() (gw, myIP netip.Addr, ok bool)
- func (m *Mon) InjectEvent()
- func (m *Mon) InterfaceState() *interfaces.State
- func (m *Mon) RegisterChangeCallback(callback interfaces.ChangeFunc) (unregister func())
- func (m *Mon) RegisterRuleDeleteCallback(callback RuleDeleteCallback) (unregister func())
- func (m *Mon) Start()
- type RuleDeleteCallback
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type Mon ¶
type Mon struct {
// contains filtered or unexported fields
}
Mon represents a monitoring instance.
func New ¶
New instantiates and starts a monitoring instance. The returned monitor is inactive until it's started by the Start method. Use RegisterChangeCallback to get notified of network changes.
func (*Mon) GatewayAndSelfIP ¶ added in v1.6.0
GatewayAndSelfIP returns the current network's default gateway, and the machine's default IP for that gateway.
It's the same as interfaces.LikelyHomeRouterIP, but it caches the result until the monitor detects a network change.
func (*Mon) InjectEvent ¶ added in v1.6.0
func (m *Mon) InjectEvent()
InjectEvent forces the monitor to pretend there was a network change and re-check the state of the network. Any registered ChangeFunc callbacks will be called within the event coalescing period (under a fraction of a second).
func (*Mon) InterfaceState ¶ added in v1.6.0
func (m *Mon) InterfaceState() *interfaces.State
InterfaceState returns the latest snapshot of the machine's network interfaces.
The returned value is owned by Mon; it must not be modified.
func (*Mon) RegisterChangeCallback ¶ added in v1.6.0
func (m *Mon) RegisterChangeCallback(callback interfaces.ChangeFunc) (unregister func())
RegisterChangeCallback adds callback to the set of parties to be notified (in their own goroutine) when the network state changes. To remove this callback, call unregister (or close the monitor).
func (*Mon) RegisterRuleDeleteCallback ¶ added in v1.12.0
func (m *Mon) RegisterRuleDeleteCallback(callback RuleDeleteCallback) (unregister func())
RegisterRuleDeleteCallback adds callback to the set of parties to be notified (in their own goroutine) when a Linux ip rule is deleted. To remove this callback, call unregister (or close the monitor).
type RuleDeleteCallback ¶ added in v1.12.0
RuleDeleteCallback is a callback when a Linux IP policy routing rule is deleted. The table is the table number (52, 253, 354) and priority is the priority order number (for Tailscale rules currently: 5210, 5230, 5250, 5270)