Documentation ¶
Overview ¶
Package watcher keeps track and monitors for new, removed and modified WireGuard interfaces and peers.
Index ¶
- Constants
- Variables
- func RegisterFeature[I FeatureInterface](ctor func(i *Interface) (I, error), order int) func(*Interface) I
- type AllHandler
- type Daemon
- type Event
- type EventsHandler
- func (h *EventsHandler) OnInterfaceAdded(i *Interface)
- func (h *EventsHandler) OnInterfaceModified(i *Interface, old *wg.Interface, m InterfaceModifier)
- func (h *EventsHandler) OnInterfaceRemoved(i *Interface)
- func (h *EventsHandler) OnPeerAdded(p *Peer)
- func (h *EventsHandler) OnPeerModified(p *Peer, old *wgtypes.Peer, m PeerModifier, ipsAdded, ipsRemoved []net.IPNet)
- func (h *EventsHandler) OnPeerRemoved(p *Peer)
- type Feature
- type FeatureInterface
- type Interface
- func (i *Interface) AddModifiedHandler(h InterfaceModifiedHandler)
- func (i *Interface) AddPeer(pcfg *wgtypes.PeerConfig) error
- func (i *Interface) AddPeerHandler(h PeerHandler)
- func (i *Interface) AddPeerStateChangeHandler(h PeerStateChangedHandler)
- func (i *Interface) BindUpdate(listenPort int) error
- func (i *Interface) Close() error
- func (i *Interface) ConfigureDevice(cfg wgtypes.Config) error
- func (i *Interface) DumpConfig(wr io.Writer) error
- func (i *Interface) ForEachFeature(cb func(fi FeatureInterface) error) error
- func (i *Interface) IsUserspace() bool
- func (i *Interface) Marshal() *coreproto.Interface
- func (i *Interface) MarshalWithPeers(cb func(p *Peer) *coreproto.Peer) *coreproto.Interface
- func (i *Interface) Name() string
- func (i *Interface) OnInterfaceModified(_ *Interface, _ *wg.Interface, mod InterfaceModifier)
- func (i *Interface) PrivateKey() crypto.Key
- func (i *Interface) PublicKey() crypto.Key
- func (i *Interface) RemoveModifiedHandler(h InterfaceModifiedHandler)
- func (i *Interface) RemovePeer(pk crypto.Key) error
- func (i *Interface) RemovePeerHandler(h PeerHandler)
- func (i *Interface) RemovePeerStateChangeHandler(h PeerStateChangedHandler)
- func (i *Interface) Start() error
- func (i *Interface) String() string
- func (i *Interface) SyncFeatures() error
- func (i *Interface) UpdatePeer(pcfg *wgtypes.PeerConfig) error
- func (i *Interface) WireGuardConfig() *wgtypes.Config
- type InterfaceAddedEvent
- type InterfaceEvent
- type InterfaceEventOp
- type InterfaceFilterFunc
- type InterfaceHandler
- type InterfaceList
- type InterfaceModifiedEvent
- type InterfaceModifiedHandler
- type InterfaceModifier
- type InterfaceRemovedEvent
- type Peer
- func (p *Peer) AddAllowedIP(a net.IPNet) error
- func (p *Peer) AddModifiedHandler(h PeerModifiedHandler)
- func (p *Peer) IsControlling() bool
- func (p *Peer) Marshal() *coreproto.Peer
- func (p *Peer) PresharedKey() crypto.Key
- func (p *Peer) PublicKey() crypto.Key
- func (p *Peer) PublicKeyPair() *crypto.PublicKeyPair
- func (p *Peer) PublicPrivateKeyPair() *crypto.KeyPair
- func (p *Peer) Reachability() coreproto.ReachabilityType
- func (p *Peer) RemoveAllowedIP(a net.IPNet) error
- func (p *Peer) RemoveModifiedHandler(h PeerModifiedHandler)
- func (p *Peer) SetEndpoint(addr *net.UDPAddr) error
- func (p *Peer) SetPresharedKey(psk *crypto.Key) error
- func (p *Peer) SetStateIf(newState PeerState, prevStates ...PeerState) (PeerState, bool)
- func (p *Peer) SetStateIfNot(newState PeerState, prevStates ...PeerState) (PeerState, bool)
- func (p *Peer) State() PeerState
- func (p *Peer) String() string
- func (p *Peer) Sync(newPeer *wgtypes.Peer) (PeerModifier, []net.IPNet, []net.IPNet)
- func (p *Peer) WireGuardConfig() *wgtypes.PeerConfig
- type PeerAddedEvent
- type PeerHandler
- type PeerModifiedEvent
- type PeerModifiedHandler
- type PeerModifier
- type PeerRemovedEvent
- type PeerState
- type PeerStateChangedHandler
- type State
- type SyncableFeatureInterface
- type Watcher
- func (w *Watcher) AddAllHandler(h AllHandler)
- func (w *Watcher) AddInterfaceHandler(h InterfaceHandler)
- func (w *Watcher) AddPeerHandler(h PeerHandler)
- func (w *Watcher) Close() error
- func (w *Watcher) ForEachInterface(cb func(i *Interface) error) error
- func (w *Watcher) ForEachPeer(cb func(p *Peer) error) error
- func (w *Watcher) InterfaceByIndex(idx int) *Interface
- func (w *Watcher) InterfaceByName(name string) *Interface
- func (w *Watcher) InterfaceByPublicKey(pk crypto.Key) *Interface
- func (w *Watcher) Peer(intf string, pk *crypto.Key) *Peer
- func (w *Watcher) PeerByPublicKey(pk *crypto.Key) *Peer
- func (w *Watcher) Sync() error
- func (w *Watcher) Watch()
Constants ¶
const ( StateStarted = "started" StateInitializing = "initializing" StateReady = "ready" StateReloading = "reloading" StateStopping = "stoppping" StateSynchronizing = "syncing" )
const ( PeerStateNew = coreproto.PeerState_NEW PeerStateConnecting = coreproto.PeerState_CONNECTING PeerStateConnected = coreproto.PeerState_CONNECTED PeerStateFailed = coreproto.PeerState_FAILED PeerStateClosed = coreproto.PeerState_CLOSED )
Prettier aliases for the protobuf constants.
Variables ¶
var (
ErrFeatureDeactivated = errors.New("feature deactivated")
)
var InterfaceModifiersStrings = []string{
"name",
"type",
"private-key",
"listen-port",
"firewall-mark",
"peers",
}
var PeerModifiersStrings = []string{
"preshared-key",
"endpoint",
"keepalive-interval",
"handshake-time",
"receive-bytes",
"transmit-bytes",
"allowed-ips",
"protocol-version",
"name",
}
Functions ¶
func RegisterFeature ¶
func RegisterFeature[I FeatureInterface](ctor func(i *Interface) (I, error), order int, ) func(*Interface) I
Types ¶
type AllHandler ¶
type AllHandler interface { InterfaceHandler InterfaceModifiedHandler PeerHandler PeerModifiedHandler }
type Daemon ¶
type Daemon struct { *Watcher Backend *signaling.MultiBackend Client *wgctrl.Client Config *config.Config // contains filtered or unexported fields }
func (*Daemon) CreateDevices ¶
func (*Daemon) OnInterfaceAdded ¶
func (*Daemon) OnInterfaceRemoved ¶
type EventsHandler ¶
type EventsHandler struct {
Events chan Event
}
func NewEventsHandler ¶
func NewEventsHandler(length int) *EventsHandler
func (*EventsHandler) OnInterfaceAdded ¶
func (h *EventsHandler) OnInterfaceAdded(i *Interface)
func (*EventsHandler) OnInterfaceModified ¶
func (h *EventsHandler) OnInterfaceModified(i *Interface, old *wg.Interface, m InterfaceModifier)
func (*EventsHandler) OnInterfaceRemoved ¶
func (h *EventsHandler) OnInterfaceRemoved(i *Interface)
func (*EventsHandler) OnPeerAdded ¶
func (h *EventsHandler) OnPeerAdded(p *Peer)
func (*EventsHandler) OnPeerModified ¶
func (h *EventsHandler) OnPeerModified(p *Peer, old *wgtypes.Peer, m PeerModifier, ipsAdded, ipsRemoved []net.IPNet)
func (*EventsHandler) OnPeerRemoved ¶
func (h *EventsHandler) OnPeerRemoved(p *Peer)
type Feature ¶
type Feature struct { New func(i *Interface) (FeatureInterface, error) // contains filtered or unexported fields }
type FeatureInterface ¶
type Interface ¶
type Interface struct { // WireGuard handle of device *wg.Interface // OS abstractions for kernel device device.Device Peers map[crypto.Key]*Peer LastSync time.Time Daemon *Daemon Settings *config.InterfaceSettings // contains filtered or unexported fields }
func NewInterface ¶
func (*Interface) AddModifiedHandler ¶
func (i *Interface) AddModifiedHandler(h InterfaceModifiedHandler)
func (*Interface) AddPeerHandler ¶
func (i *Interface) AddPeerHandler(h PeerHandler)
func (*Interface) AddPeerStateChangeHandler ¶
func (i *Interface) AddPeerStateChangeHandler(h PeerStateChangedHandler)
func (*Interface) BindUpdate ¶
func (*Interface) ForEachFeature ¶
func (i *Interface) ForEachFeature(cb func(fi FeatureInterface) error) error
func (*Interface) IsUserspace ¶
func (*Interface) MarshalWithPeers ¶
func (*Interface) OnInterfaceModified ¶
func (i *Interface) OnInterfaceModified(_ *Interface, _ *wg.Interface, mod InterfaceModifier)
func (*Interface) PrivateKey ¶
PublicKey returns the Curve25519 private key of the WireGuard interface.
func (*Interface) PublicKey ¶
PublicKey returns the Curve25519 public key of the WireGuard interface.
func (*Interface) RemoveModifiedHandler ¶
func (i *Interface) RemoveModifiedHandler(h InterfaceModifiedHandler)
func (*Interface) RemovePeerHandler ¶
func (i *Interface) RemovePeerHandler(h PeerHandler)
func (*Interface) RemovePeerStateChangeHandler ¶
func (i *Interface) RemovePeerStateChangeHandler(h PeerStateChangedHandler)
func (*Interface) SyncFeatures ¶
func (*Interface) UpdatePeer ¶
func (i *Interface) UpdatePeer(pcfg *wgtypes.PeerConfig) error
func (*Interface) WireGuardConfig ¶
type InterfaceAddedEvent ¶
type InterfaceAddedEvent struct {
Interface *Interface
}
type InterfaceEvent ¶
type InterfaceEvent struct { Op InterfaceEventOp Name string }
func (InterfaceEvent) String ¶
func (e InterfaceEvent) String() string
type InterfaceEventOp ¶
type InterfaceEventOp int
const ( InterfaceAdded InterfaceEventOp = iota InterfaceDeleted )
func (InterfaceEventOp) String ¶
func (ls InterfaceEventOp) String() string
type InterfaceFilterFunc ¶
type InterfaceHandler ¶
type InterfaceList ¶
InterfaceList stores all WireGuard interfaces indexed by their unique ifindex.
func (*InterfaceList) ByIndex ¶
func (l *InterfaceList) ByIndex(index int) *Interface
func (*InterfaceList) ByName ¶
func (l *InterfaceList) ByName(name string) *Interface
func (*InterfaceList) ByPublicKey ¶
func (l *InterfaceList) ByPublicKey(pk crypto.Key) *Interface
type InterfaceModifiedEvent ¶
type InterfaceModifiedEvent struct { Interface *Interface Old *wg.Interface Modified InterfaceModifier }
type InterfaceModifiedHandler ¶
type InterfaceModifiedHandler interface {
OnInterfaceModified(i *Interface, old *wg.Interface, m InterfaceModifier)
}
type InterfaceModifier ¶
type InterfaceModifier int
const ( InterfaceModifiedName InterfaceModifier = (1 << iota) InterfaceModifiedType InterfaceModifiedPrivateKey InterfaceModifiedListenPort InterfaceModifiedFirewallMark InterfaceModifiedPeers InterfaceModifierCount = 6 InterfaceModifiedNone InterfaceModifier = 0 )
func (InterfaceModifier) Is ¶
func (i InterfaceModifier) Is(j InterfaceModifier) bool
func (InterfaceModifier) String ¶
func (i InterfaceModifier) String() string
func (InterfaceModifier) Strings ¶
func (i InterfaceModifier) Strings() []string
type InterfaceRemovedEvent ¶
type InterfaceRemovedEvent struct {
Interface *Interface
}
type Peer ¶
type Peer struct { *wgtypes.Peer Name string Hosts map[string][]net.IP Interface *Interface LastReceiveTime time.Time LastTransmitTime time.Time LastStateChangeTime time.Time // contains filtered or unexported fields }
func (*Peer) AddAllowedIP ¶
AddAllowedIP adds a new IP network to the allowed ip list of the WireGuard peer.
func (*Peer) AddModifiedHandler ¶
func (p *Peer) AddModifiedHandler(h PeerModifiedHandler)
AddModifiedHandler registers a new handler which is called whenever the peer has been modified.
func (*Peer) IsControlling ¶
IsControlling determines if the peer is controlling the ICE session by selecting the peer which has the smaller public key.
func (*Peer) PresharedKey ¶
PresharedKey returns the Curve25199 preshared key of the WireGuard peer.
func (*Peer) PublicKeyPair ¶
func (p *Peer) PublicKeyPair() *crypto.PublicKeyPair
PublicKeyPair returns both the public key of the local (our) and remote peer (theirs).
func (*Peer) PublicPrivateKeyPair ¶
PublicPrivateKeyPair returns both the public key of the local (our) and remote peer (theirs).
func (*Peer) Reachability ¶
func (p *Peer) Reachability() coreproto.ReachabilityType
func (*Peer) RemoveAllowedIP ¶
RemoveAllowedIP removes a new IP network from the allowed ip list of the WireGuard peer.
func (*Peer) RemoveModifiedHandler ¶
func (p *Peer) RemoveModifiedHandler(h PeerModifiedHandler)
func (*Peer) SetEndpoint ¶
SetEndpoint sets a new endpoint for the WireGuard peer.
func (*Peer) SetPresharedKey ¶
SetPresharedKey sets a new preshared key for the WireGuard peer.
func (*Peer) SetStateIf ¶
SetStateIf updates the connection state of the peer if the previous state matches one of the supplied previous states. It returns true if the state has been changed.
func (*Peer) SetStateIfNot ¶
SetStateIf updates the connection state of the peer if the previous state does not match any of the supplied previous states.
func (*Peer) WireGuardConfig ¶
func (p *Peer) WireGuardConfig() *wgtypes.PeerConfig
WireGuardConfig return the WireGuard peer configuration.
type PeerAddedEvent ¶
type PeerAddedEvent struct {
Peer *Peer
}
type PeerHandler ¶
type PeerModifiedEvent ¶
type PeerModifiedHandler ¶
type PeerModifier ¶
type PeerModifier uint32
const ( PeerModifiedEndpoint PeerModifiedKeepaliveInterval PeerModifiedHandshakeTime PeerModifiedReceiveBytes PeerModifiedTransmitBytes PeerModifiedAllowedIPs PeerModifiedProtocolVersion PeerModifiedName PeerModifierCount = 8 PeerModifiedNone PeerModifier = 0 )
func (PeerModifier) Is ¶
func (i PeerModifier) Is(j PeerModifier) bool
func (PeerModifier) String ¶
func (i PeerModifier) String() string
func (PeerModifier) Strings ¶
func (i PeerModifier) Strings() []string
type PeerRemovedEvent ¶
type PeerRemovedEvent struct {
Peer *Peer
}
type PeerStateChangedHandler ¶
type SyncableFeatureInterface ¶
type SyncableFeatureInterface interface {
Sync() error
}
type Watcher ¶
type Watcher struct {
// contains filtered or unexported fields
}
Watcher monitors both userspace and kernel for changes to WireGuard interfaces.
func NewWatcher ¶
func (*Watcher) AddAllHandler ¶
func (w *Watcher) AddAllHandler(h AllHandler)
AddAllHandler adds a new handler to all the events observed by the watcher.
func (*Watcher) AddInterfaceHandler ¶
func (w *Watcher) AddInterfaceHandler(h InterfaceHandler)
AddInterfaceHandler registers an handler for interface-related events.
func (*Watcher) AddPeerHandler ¶
func (w *Watcher) AddPeerHandler(h PeerHandler)
AddPeerHandler registers an handler for peer-related events.
func (*Watcher) ForEachInterface ¶
func (*Watcher) InterfaceByIndex ¶
func (*Watcher) InterfaceByName ¶
func (*Watcher) InterfaceByPublicKey ¶
Source Files ¶
Directories ¶
Path | Synopsis |
---|---|
feature
|
|
autocfg
Package autocfg handles initial auto-configuration of new interfaces and peers
|
Package autocfg handles initial auto-configuration of new interfaces and peers |
epdisc
Package epdisc implements endpoint (EP) discovery using Interactive Connection Establishment (ICE).
|
Package epdisc implements endpoint (EP) discovery using Interactive Connection Establishment (ICE). |
hsync
Package hsync synchronizes /etc/hosts with pairs of peer hostname and their respective IP addresses
|
Package hsync synchronizes /etc/hosts with pairs of peer hostname and their respective IP addresses |
pdisc
Package pdisc implements peer discovery based on a shared community passphrase.
|
Package pdisc implements peer discovery based on a shared community passphrase. |
rtsync
Package rtsync synchronizes the kernel routing table with the AllowedIPs of each WireGuard peer
|
Package rtsync synchronizes the kernel routing table with the AllowedIPs of each WireGuard peer |