Documentation ¶
Overview ¶
Package wireguardctrl enables control of WireGuard devices on multiple platforms.
For more information on WireGuard, please see https://www.wireguard.com/.
Overview ¶
wireguardctrl can control multiple types of WireGuard devices, including:
- Linux kernel module devices, via generic netlink
- userspace devices (e.g. wireguard-go), via the userspace configuration protocol
In the future, if non-Linux operating systems choose to implement WireGuard natively, this package should also be extended to support the native interfaces of those operating systems.
If you are aware of any efforts on this front, please file an issue: https://github.com/mdlayher/wireguardctrl/issues/new.
This package implements WireGuard configuration protocol operations, enabling the configuration of existing WireGuard devices. Operations such as creating WireGuard devices, or applying IP addresses to those devices, are out of scope for this package.
Index ¶
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type Client ¶
type Client struct {
// contains filtered or unexported fields
}
A Client provides access to WireGuard device information.
func (*Client) ConfigureDevice ¶
ConfigureDevice configures a WireGuard device by its interface name.
Because the zero value of some Go types may be significant to WireGuard for Config fields, only fields which are not nil will be applied when configuring a device.
If the device specified by name does not exist or is not a WireGuard device, an error is returned which can be checked using os.IsNotExist.
Directories ¶
Path | Synopsis |
---|---|
cmd
|
|
wgctrl
Command wgctrl is a testing utility for interacting with WireGuard via package wireguardctrl.
|
Command wgctrl is a testing utility for interacting with WireGuard via package wireguardctrl. |
internal
|
|
wglinux
Package wglinux provides internal access to Linux's WireGuard generic netlink interface.
|
Package wglinux provides internal access to Linux's WireGuard generic netlink interface. |
wglinux/internal/wgh
Package wgh is an auto-generated package which contains constants and types used to access WireGuard information using generic netlink.
|
Package wgh is an auto-generated package which contains constants and types used to access WireGuard information using generic netlink. |
wgtest
Package wgtest contains shared testing utilities for package wireguardctrl.
|
Package wgtest contains shared testing utilities for package wireguardctrl. |
wguser
Package wguser provides internal access to the userspace WireGuard configuration protocol interface.
|
Package wguser provides internal access to the userspace WireGuard configuration protocol interface. |
Package wgtypes provides shared types for the wireguardctrl family of packages.
|
Package wgtypes provides shared types for the wireguardctrl family of packages. |