nixos/dhcpcd: don't solicit or accept ipv6 router advertisements if use static addresses

This commit is contained in:
Izorkin 2023-01-04 18:05:13 +03:00
parent 83ba52e31a
commit 0e9cb9fcfd
No known key found for this signature in database
GPG key ID: 1436C1B3F3679F09
3 changed files with 18 additions and 0 deletions

View file

@ -377,6 +377,13 @@
security. security.
</para> </para>
</listitem> </listitem>
<listitem>
<para>
<literal>services.dhcpcd</literal> service now dont solicit
or accept IPv6 Router Advertisements on interfaces that use
static IPv6 addresses.
</para>
</listitem>
<listitem> <listitem>
<para> <para>
The module <literal>services.headscale</literal> was The module <literal>services.headscale</literal> was

View file

@ -104,6 +104,8 @@ In addition to numerous new and upgraded packages, this release has the followin
- `services.chronyd` is now started with additional systemd sandbox/hardening options for better security. - `services.chronyd` is now started with additional systemd sandbox/hardening options for better security.
- `services.dhcpcd` service now don't solicit or accept IPv6 Router Advertisements on interfaces that use static IPv6 addresses.
- The module `services.headscale` was refactored to be compliant with [RFC 0042](https://github.com/NixOS/rfcs/blob/master/rfcs/0042-config-option.md). To be precise, this means that the following things have changed: - The module `services.headscale` was refactored to be compliant with [RFC 0042](https://github.com/NixOS/rfcs/blob/master/rfcs/0042-config-option.md). To be precise, this means that the following things have changed:
- Most settings has been migrated under [services.headscale.settings](#opt-services.headscale.settings) which is an attribute-set that - Most settings has been migrated under [services.headscale.settings](#opt-services.headscale.settings) which is an attribute-set that

View file

@ -33,6 +33,13 @@ let
(if !config.networking.useDHCP && enableDHCP then (if !config.networking.useDHCP && enableDHCP then
map (i: i.name) (filter (i: i.useDHCP == true) interfaces) else null); map (i: i.name) (filter (i: i.useDHCP == true) interfaces) else null);
staticIPv6Addresses = map (i: i.name) (filter (i: i.ipv6.addresses != [ ]) interfaces);
noIPv6rs = concatStringsSep "\n" (map (name: ''
interface ${name}
noipv6rs
'') staticIPv6Addresses);
# Config file adapted from the one that ships with dhcpcd. # Config file adapted from the one that ships with dhcpcd.
dhcpcdConf = pkgs.writeText "dhcpcd.conf" dhcpcdConf = pkgs.writeText "dhcpcd.conf"
'' ''
@ -75,6 +82,8 @@ let
''} ''}
${cfg.extraConfig} ${cfg.extraConfig}
${optionalString config.networking.enableIPv6 noIPv6rs}
''; '';
exitHook = pkgs.writeText "dhcpcd.exit-hook" exitHook = pkgs.writeText "dhcpcd.exit-hook"