A collection of BASH based utility scripts and support functions for use as NetworkManager dispatchers.
- Included Dispatch Scripts
- IPv6 Prefix Delegation
- Setup
- Support Functions
- Documentation
- SELinux
- Test Suite
- Support
- License
-
08-ipv6-prefix
- IPv6 Prefix Delegation
The dispatch script will spawn a DHCP client to request an IPv6 prefix (as well as WAN address), and then assign sub-prefixes from the delegated prefix to the LAN interfaces. Simple configuration allows fully automatic behavior, but can be configured to fully control sub-prefix and address creation by interface. Also supports Dynamic DNS based on prefix assignment similar to the interface state DNS script below. -
09-ddns
- Dynamic DNS
The dispatch script will usensupdate
to set or clear DNS entries based on interface state. Supports address assignment to A or AAAA records (with fallback values), and assignment of other records (such as CNAME or TXT) individually configurable for each interface. -
95-radvd-gen
- radvd.conf Generation
The dispatch script will create/etc/radvd.conf
based on the prefixes assigned to interfaces defined in the template/etc/NetworkManager/radvd.conf.templ
-
96-interface-action
- Interface action to Service action
Performs systemctl actions on designated services based on interface state changes (up, down, pre-down, dhcp-change etc).
The prefix delegation feature supports multiple address/prefix delegations from multiple upstream DHCP servers to multiple LAN interfaces. Features include
- address, prefix and route lifetimes
- DDNS update hooks
- both
dhclient
ordhcpcd
DHCP client support - flexible route metrics
- DHCP client monitoring with restart on stalls/failures
- DHCP client command options or config file overrides
WAN (dhcp server) interface supports
- duplicate address detection (with DHCP declines)
- default route monitoring and maintenance using
rdisc6
or linux kernel - static address, DNS or domain search assignments
- DNS server routes to source WAN (if needed)
- Legacy dhclient-script as option
LAN (delegated sub-prefixes) interfaces support
- per-LAN subnet prefix-size and "subnet #" pre-allocation
- radvd hooks
- prefix delegation size hints
- high-metric unreachable route for unassigned delegated prefixes
- RFC6603 DHCP Prefix
Exclude support (requires
dhcpcd
) - RFC8678 IPV6
Multihoming Support:
- source-based default routes created/maintained for each delegated prefix to it source WAN supporting multiple upstream WANs without policy-routing
- NMG_RADVD_TRIGGER assigned to
95-radvd-gen
supports fast router deprecation when all routable WANs are offline - delegated subnets quickly deprecated using radvd when:
- WAN down
- WAN default route lost
- any external trigger (via script command, see "help")
There are 2 NetworkManager ipv6 connection methods supported
- ipv6.method: ignore
- supports
dhcpcd
ordhclient
- uses
resolvectl
orresolvconf
for DNS management - WAN addresses/routes have lifetimes
- when using
dhcpcd
(which requiresrdisc6
):- supports DNS via Router Advertisements
- supports prefix-exclude option
- supports
- ipv6.method: link-local
- addresses and DNS managed with NetworkManager, but require "device reapply" (done automatically)
- requires
rdisc6
for default route management (unless never-default=yes) - not compatible with
dhcpcd
(or prefix-exclude) - WAN addresses/routes lack lifetimes (addresses cannot be deprecated)
Automated install requires GNU make
and meson
. There are two
independent modes of installation: packaged or development. Both
modes can be installed simultaneously, but development installs
completely mask packaged; both have independent config directories.
Type make help
for a list of supported "targets"
- NetworkManager
- bash
- required command-line tools:
pgrep
ip
- optional:
logger
radvd
dig
nsupdate
flock
- required for
08-ipv6-prefix
:nmcli
systemd
dhclient
ordhcpcd
- optional for
08-ipv6-prefix
:rdisc6
resolvectl
resolvconf
$ make
$ sudo make install
- Installs to
/etc/nmutils
and/etc/NetworkManager/dispatcher.d
- Configuration in
/etc/nmutils/conf
- Removal:
$ sudo make uninstall
$ make MESON_FLAGS='-Dpkg=true'
$ sudo make install
- Installs to
/usr/share/nmutils
and/usr/lib/NetworkManager/dispatcher.d
- Configuration in
/etc/nmutils
- Removal:
$ sudo make uninstall
Alternatively, if rpmbuild
and mock
are installed
$ make rpm
will create a source rpm (make srpm
), then use mock to build rpms
that can be installed on any rpm-based system.
Configuration files should be placed in /etc/nmutils/conf
(development) or /etc/nmutils
(packaged) - henceforth referred to
as "NMCONF"
All configuration for prefix delegation is documented in the file
etc/NetworkManager/dispatcher.d/08-ipv6-prefix
. Basic prefix
delegation is enabled as simply setting ipv6.method to
"link-local" or "ignore", and creating a configuration file for
the WAN interface the prefix will be queried on
NMCONF/ipv6-prefix-<WAN>.conf
WAN_LAN_INTFS="<LAN1> <LAN2>..."
Where <WAN>
and <LAN#>
should be replaced by the interface names (eth0
etc).
Optional per-LAN configuration can be set in the optional files, eg
NMCONF/ipv6-prefix-<LAN>-from-<WAN>.conf
# trigger the radvd.conf generation script
NMG_RADVD_TRIGGER="/etc/NetworkManager/dispatcher.d/95-radvd-gen"
There are many additional configuraion options. The script may be run directly supporting a few additional features
# display full documentation, explaining all config options
$ ./08-ipv6-prefix help
# prints configuration of all interfaces (or <interface>s if given)
# "-a" includes unset/empty configuration with defaults
$ ./08-ipv6-prefix config [ -a ] [ <interface>... ]
# prints runtime status of all interfaces (or <interface> if given)
$ ./08-ipv6-prefix status [ <interface> ]
# manually deprecate <wan> with tag <who> (w/o <reason> removes dep.)
$ ./08-ipv6-prefix deprecate <wan> <who> [ <reason> ]
More sample configurations can be found in the examples
directory.
DNS configuration is documented in etc/nmutils/ddns-functions
.
The etc/NetworkManager/dispatcher.d/09-ddns
dispatcher script
enables the DDNS features, eg
NMCONF/ddns-<WAN>.conf
DDNS_ZONE=example.net.
DDNS_RREC_A_NAME=wan.example.net.
which would set the A
record for wan.example.net to the public
IPv4 addresses on <WAN>
when it's up, and remove the record when the
interface is down.
Again, there are many more configuration options in the documentation,
including fallback addresses, setting TXT, CNAME, AAAA values,
assignment of IPv6 prefix addresses assigned by 08-ipv6-prefix
, and
configuration for locks and nsupdate
keys. Configuration for
DDNS addresses assigned by 08-ipv6-prefix
are placed in
NMCONF/ddns-<WAN>-from-<WAN>.conf
- for WAN addresses
NMCONF/ddns-<LAN>-from-<WAN>.conf
- for LAN delegated addresses from WAN
Optionally, the systemd service files ddns-onboot@.service
and
ddns-onboot@.timer
can be installed, and enabled with
$ systemctl daemon-reload
$ systemctl enable ddns-onboot@<INTERFACE>.timer
to perform late boot DDNS setup that may not have been possible during system boot.
There are many additional configuraion options. The script may be run directly supporting a few additional features
# display full documentation, explaining all config options
$ ./09-ddns help
# prints configuration of all interfaces (or <interface>s if given)
# "-a" includes unset/empty configuration with defaults
$ ./09-ddns config [ -a ] [ <interface>... ]
There are extensive configuration examples in the source under
examples/simple
and examples/complex
. In addition, refer
to the Documentation to see complete descriptions of all
the configuration options (there are lots).
By default, the scripts log minimal informational messages to syslog
under the daemon facility (info and error). To track down problems,
verbose debug messages may be enabled by adding the file
NMCONF/general.conf
containing
nmg_show_debug=1
Debug messages are logged as daemon.debug, so your syslog daemon
should be configured to direct those messages someplace useful.
Logging may be sent to stderr by setting nmg_log_stderr=1
to
ease tracing any problems.
In addition, the test
directory in the source includes "mock"
programs that can be used to simulate many programs such as
nmcli
, ip
, dig
and dhclient
and others (see the documentation
in those scripts for details). NOTE: configuration in
the test
directory is located in test/conf
The included support scripts general-functions
and ddns-functions
offer an extensive and well tested set of BASH functions which can be
useful in creating additional dispatch scripts. They include:
- Logging functions
- Configuration (optionally required) file parsing
- File creation/removal with error reporting
- Command/daemon execution with output capture
- Hex-decimal number conversion
- IPv4/IPv6 address query and assignment with error handling
- IPv6 network and host prefix creation and address creation
- Full configuration of all paths, prefixes and configuration locations
- Extensive debugging hooks to ease development with scripts, including stderr logging redirect and dry-run command execution.
- nsupdate-based Dynamic DNS (optionally asynchronous) and serialized with locking
To use the support functions in your own dispatch scripts, just include them; for example add the following to the start of your script (set default $NMUTILS based on install location)
NMUTILS="${NMUTILS:-/etc/nmutils}"
NMG="${NMG:-$NMUTILS/general-functions}"
[ -f "$NMG" -a -r "$NMG" ] && . "$NMG" || {
echo >&2 "Unable to load $NMG" && exit 2; }
Functions can be fully customized, either by setting file-local
defaults before including them, or creating a global configuration
file to set new defaults for all scripts (default:
NMCONF/general.conf
). All customization variables and
their defaults are documented in the scripts.
Each script fully documents all the functions it provides at the beginning of the script. To see the list of supported functions and configuration settings, please refer to the following files:
-
General utility functions:
etc/nmutils/general-functions
-
Dynamic DNS utility functions:
etc/nmutils/ddns-functions
The following utility scripts only document configuration, as they are are just executed by NetworkManager:
-
IPv6 Prefix Delegation trigger script:
etc/NetworkManager/dispatcher.d/08-ipv6-prefix
-
Dynamic DNS trigger script:
etc/NetworkManager/dispatcher.d/09-ddns
-
radvd.conf generation script:
etc/NetworkManager/dispatcher.d/95-radvd-gen
-
general action to service trigger script:
etc/NetworkManager/dispatcher.d/96-interface-action
-
Transmission config generation script:
etc/NetworkManager/dispatcher.d/90-transmission
A source module for SELinux is provided in the selinux directory.
The module provides rules allowing 08-ipv6-prefix
to manage the
dhcp client, manage radvd and perform DDNS functions.
sudo make -C selinux install
will build and install the module
(selinux-policy-devel
is required)
A complete test suite with over 1400 tests for all documented
functions, and most of the utility scripts can be found in the
test
directory. To run all tests (with detailed reporting),
simply run make check
.
nmutils is hosted at github.com/sshambar/nmutils. Please feel free to comment or send pull requests if you find bugs or want to contribute new features.
I can be reached via email at:
"Scott Shambarger" <devel [at] shambarger [dot] net>
nmutils is licensed under the GPLv3 and LGPLv3 (for library scripts)