Skip to content

Commit

Permalink
nixos/networkd: add PIE options
Browse files Browse the repository at this point in the history
  • Loading branch information
apfelkuchen6 committed Mar 16, 2023
1 parent d630353 commit 2784862
Showing 1 changed file with 25 additions and 0 deletions.
25 changes: 25 additions & 0 deletions nixos/modules/system/boot/networkd.nix
Original file line number Diff line number Diff line change
Expand Up @@ -1133,6 +1133,16 @@ let
"MTUBytes"
])
];

sectionPIE = checkUnitConfig "PIE" [
(assertOnlyFields [
"Parent"
"Handle"
"PacketLimit"
])
(assertInt "PacketLimit")
(assertRange "PacketLimit" 1 4294967294)
];
};
};

Expand Down Expand Up @@ -1834,6 +1844,17 @@ let
'';
};

pieConfig = mkOption {
default = {};
example = { Parent = "ingress"; PacketLimit = "3847"; };
type = types.addCheck (types.attrsOf unitOption) check.network.sectionPIE;
description = lib.mdDoc ''
Each attribute in this set specifies an option in the
`[PIE]` section of the unit. See
{manpage}`systemd.network(5)` for details.
'';
};

name = mkOption {
type = types.nullOr types.str;
default = null;
Expand Down Expand Up @@ -2277,6 +2298,10 @@ let
[TokenBucketFilter]
${attrsToSection def.tockenBucketFilterConfig}
''
+ optionalString (def.pieConfig != { }) ''
[PIE]
${attrsToSection def.pieConfig}
''
+ def.extraConfig;
};

Expand Down

0 comments on commit 2784862

Please sign in to comment.