diff --git a/modules/module-list.nix b/modules/module-list.nix index 3d2a11db5bb..6dee2a4aad3 100644 --- a/modules/module-list.nix +++ b/modules/module-list.nix @@ -105,6 +105,7 @@ ./services/networking/portmap.nix ./services/networking/privoxy.nix ./services/networking/quassel.nix + ./services/networking/radvd.nix ./services/networking/sabnzbd.nix ./services/networking/ssh/lshd.nix ./services/networking/ssh/sshd.nix diff --git a/modules/services/networking/radvd.nix b/modules/services/networking/radvd.nix new file mode 100644 index 00000000000..4da60525e38 --- /dev/null +++ b/modules/services/networking/radvd.nix @@ -0,0 +1,77 @@ +# Module for the IPv6 Router Advertisement Daemon. + +{ config, pkgs, ... }: + +with pkgs.lib; + +let + + cfg = config.services.radvd; + + confFile = pkgs.writeText "radvd.conf" cfg.config; + +in + +{ + + ###### interface + + options = { + + services.radvd.enable = mkOption { + default = false; + description = + '' + Whether to enable the Router Advertisement Daemon + (radvd), which provides link-local + advertisements of IPv6 router addresses and prefixes using + the Neighbor Discovery Protocol (NDP). This enables + stateless address autoconfiguration in IPv6 clients on the + network. + ''; + }; + + services.radvd.config = mkOption { + example = + '' + interface eth0 { + AdvSendAdvert on; + prefix 2001:db8:1234:5678::/64 { }; + }; + ''; + description = + '' + The contents of the radvd configuration file. + ''; + }; + + }; + + + ###### implementation + + config = mkIf cfg.enable { + + environment.systemPackages = [ pkgs.radvd ]; + + jobs.radvd = + { description = "IPv6 Router Advertisement Daemon"; + + startOn = "started network-interfaces"; + + preStart = + '' + # !!! Radvd only works if IPv6 forwarding is enabled. But + # this should probably be done somewhere else (and not + # necessarily for all interfaces). + echo 1 > /proc/sys/net/ipv6/conf/all/forwarding + ''; + + exec = "${pkgs.radvd}/sbin/radvd -m syslog -s -C ${confFile}"; + + daemonType = "fork"; + }; + + }; + +} \ No newline at end of file