nixos/routinator: init module
This commit is contained in:
parent
fd527aacc0
commit
c468f4e261
@ -79,6 +79,8 @@
|
|||||||
|
|
||||||
- [networking.modemmanager](options.html#opt-networking.modemmanager) has been split out of [networking.networkmanager](options.html#opt-networking.networkmanager). NetworkManager still enables ModemManager by default, but options exist now to run NetworkManager without ModemManager.
|
- [networking.modemmanager](options.html#opt-networking.modemmanager) has been split out of [networking.networkmanager](options.html#opt-networking.networkmanager). NetworkManager still enables ModemManager by default, but options exist now to run NetworkManager without ModemManager.
|
||||||
|
|
||||||
|
- [Routinator 3000](https://nlnetlabs.nl/projects/routing/routinator/), a full-featured RPKI Relying Party software package that runs as a service which periodically downloads and verifies RPKI data.
|
||||||
|
|
||||||
- [doh-server](https://github.com/m13253/dns-over-https), a high performance DNS over HTTPS server. Available as [services.doh-server](options.html#opt-services.doh-server.enable).
|
- [doh-server](https://github.com/m13253/dns-over-https), a high performance DNS over HTTPS server. Available as [services.doh-server](options.html#opt-services.doh-server.enable).
|
||||||
|
|
||||||
- [ncps](https://github.com/kalbasit/ncps), a Nix binary cache proxy service implemented in Go using [go-nix](https://github.com/nix-community/go-nix). Available as [services.ncps](options.html#opt-services.ncps.enable).
|
- [ncps](https://github.com/kalbasit/ncps), a Nix binary cache proxy service implemented in Go using [go-nix](https://github.com/nix-community/go-nix). Available as [services.ncps](options.html#opt-services.ncps.enable).
|
||||||
|
@ -1242,6 +1242,7 @@
|
|||||||
./services/networking/robustirc-bridge.nix
|
./services/networking/robustirc-bridge.nix
|
||||||
./services/networking/rosenpass.nix
|
./services/networking/rosenpass.nix
|
||||||
./services/networking/routedns.nix
|
./services/networking/routedns.nix
|
||||||
|
./services/networking/routinator.nix
|
||||||
./services/networking/rpcbind.nix
|
./services/networking/rpcbind.nix
|
||||||
./services/networking/rxe.nix
|
./services/networking/rxe.nix
|
||||||
./services/networking/sabnzbd.nix
|
./services/networking/sabnzbd.nix
|
||||||
|
192
nixos/modules/services/networking/routinator.nix
Normal file
192
nixos/modules/services/networking/routinator.nix
Normal file
@ -0,0 +1,192 @@
|
|||||||
|
{
|
||||||
|
config,
|
||||||
|
lib,
|
||||||
|
pkgs,
|
||||||
|
utils,
|
||||||
|
...
|
||||||
|
}:
|
||||||
|
let
|
||||||
|
inherit (lib)
|
||||||
|
filterAttrsRecursive
|
||||||
|
getExe
|
||||||
|
maintainers
|
||||||
|
mkEnableOption
|
||||||
|
mkPackageOption
|
||||||
|
mkOption
|
||||||
|
types
|
||||||
|
;
|
||||||
|
inherit (utils) escapeSystemdExecArgs;
|
||||||
|
cfg = config.services.routinator;
|
||||||
|
settingsFormat = pkgs.formats.toml { };
|
||||||
|
in
|
||||||
|
{
|
||||||
|
options.services.routinator = {
|
||||||
|
enable = mkEnableOption "Routinator 3000";
|
||||||
|
|
||||||
|
package = mkPackageOption pkgs "routinator" { };
|
||||||
|
|
||||||
|
extraArgs = mkOption {
|
||||||
|
description = ''
|
||||||
|
Extra arguments passed to routinator, see <https://routinator.docs.nlnetlabs.nl/en/stable/manual-page.html#options> for options.";
|
||||||
|
'';
|
||||||
|
type = types.listOf types.str;
|
||||||
|
default = [ ];
|
||||||
|
example = [ "--no-rir-tals" ];
|
||||||
|
};
|
||||||
|
|
||||||
|
extraServerArgs = mkOption {
|
||||||
|
description = ''
|
||||||
|
Extra arguments passed to the server subcommand, see <https://routinator.docs.nlnetlabs.nl/en/stable/manual-page.html#subcmd-server> for options.";
|
||||||
|
'';
|
||||||
|
type = types.listOf types.str;
|
||||||
|
default = [ ];
|
||||||
|
example = [ "--rtr-client-metrics" ];
|
||||||
|
};
|
||||||
|
|
||||||
|
settings = mkOption {
|
||||||
|
type = types.submodule {
|
||||||
|
freeformType = settingsFormat.type;
|
||||||
|
options = {
|
||||||
|
repository-dir = mkOption {
|
||||||
|
type = types.path;
|
||||||
|
description = ''
|
||||||
|
The path where the collected RPKI data is stored.
|
||||||
|
'';
|
||||||
|
default = "/var/lib/routinator/rpki-cache";
|
||||||
|
};
|
||||||
|
log-level = mkOption {
|
||||||
|
type = types.nullOr (
|
||||||
|
types.enum [
|
||||||
|
"error"
|
||||||
|
"warn"
|
||||||
|
"info"
|
||||||
|
"debug"
|
||||||
|
]
|
||||||
|
);
|
||||||
|
description = ''
|
||||||
|
A string value specifying the maximum log level for which log messages should be emitted.
|
||||||
|
See, <https://routinator.docs.nlnetlabs.nl/en/stable/manual-page.html#logging>
|
||||||
|
'';
|
||||||
|
default = "warn";
|
||||||
|
};
|
||||||
|
log = mkOption {
|
||||||
|
type = types.nullOr (
|
||||||
|
types.enum [
|
||||||
|
"default"
|
||||||
|
"stderr"
|
||||||
|
"syslog"
|
||||||
|
"file"
|
||||||
|
]
|
||||||
|
);
|
||||||
|
description = ''
|
||||||
|
A string specifying where to send log messages to.
|
||||||
|
See, <https://routinator.docs.nlnetlabs.nl/en/stable/manual-page.html#term-log>
|
||||||
|
'';
|
||||||
|
default = "default";
|
||||||
|
};
|
||||||
|
log-file = mkOption {
|
||||||
|
type = types.nullOr types.path;
|
||||||
|
description = ''
|
||||||
|
A string value containing the path to a file to which log messages will be appended if the log configuration value is set to file. In this case, the value is mandatory.
|
||||||
|
'';
|
||||||
|
default = null;
|
||||||
|
};
|
||||||
|
http-listen = mkOption {
|
||||||
|
type = types.nullOr (types.listOf types.str);
|
||||||
|
description = ''
|
||||||
|
An array of string values each providing an address and port on which the HTTP server should listen. Address and port should be separated by a colon. IPv6 address should be enclosed in square brackets.
|
||||||
|
'';
|
||||||
|
default = null;
|
||||||
|
};
|
||||||
|
rtr-listen = mkOption {
|
||||||
|
type = types.nullOr (types.listOf types.str);
|
||||||
|
description = ''
|
||||||
|
An array of string values each providing an address and port on which the RTR server should listen in TCP mode. Address and port should be separated by a colon. IPv6 address should be enclosed in square brackets.
|
||||||
|
'';
|
||||||
|
default = null;
|
||||||
|
};
|
||||||
|
refresh = mkOption {
|
||||||
|
type = types.nullOr types.int;
|
||||||
|
description = ''
|
||||||
|
An integer value specifying the number of seconds Routinator should wait between consecutive validation runs in server mode. The next validation run will happen earlier, if objects expire earlier.
|
||||||
|
'';
|
||||||
|
default = 600;
|
||||||
|
};
|
||||||
|
retry = mkOption {
|
||||||
|
type = types.nullOr types.int;
|
||||||
|
description = ''
|
||||||
|
An integer value specifying the number of seconds an RTR client is requested to wait after it failed to receive a data set.
|
||||||
|
'';
|
||||||
|
default = 600;
|
||||||
|
};
|
||||||
|
expire = mkOption {
|
||||||
|
type = types.nullOr types.int;
|
||||||
|
description = ''
|
||||||
|
An integer value specifying the number of seconds an RTR client is requested to use a data set if it cannot get an update before throwing it away and continuing with no data at all.
|
||||||
|
'';
|
||||||
|
default = 7200;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
description = ''
|
||||||
|
Configuration for Routinator 3000, see <https://routinator.docs.nlnetlabs.nl/en/stable/manual-page.html#configuration-file> for options.
|
||||||
|
'';
|
||||||
|
default = { };
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
config = {
|
||||||
|
systemd.services.routinator = {
|
||||||
|
description = "Routinator 3000 is free, open-source RPKI Relying Party software made by NLnet Labs.";
|
||||||
|
wantedBy = [ "multi-user.target" ];
|
||||||
|
after = [ "network.target" ];
|
||||||
|
path = with pkgs; [ rsync ];
|
||||||
|
serviceConfig = {
|
||||||
|
Type = "exec";
|
||||||
|
ExecStart = escapeSystemdExecArgs (
|
||||||
|
[
|
||||||
|
(getExe cfg.package)
|
||||||
|
"--config=${
|
||||||
|
settingsFormat.generate "routinator.conf" (filterAttrsRecursive (n: v: v != null) cfg.settings)
|
||||||
|
}"
|
||||||
|
]
|
||||||
|
++ cfg.extraArgs
|
||||||
|
++ [
|
||||||
|
"server"
|
||||||
|
]
|
||||||
|
++ cfg.extraServerArgs
|
||||||
|
);
|
||||||
|
Restart = "on-failure";
|
||||||
|
CapabilityBoundingSet = [ "" ];
|
||||||
|
DynamicUser = true;
|
||||||
|
LockPersonality = true;
|
||||||
|
MemoryDenyWriteExecute = true;
|
||||||
|
NoNewPrivileges = true;
|
||||||
|
PrivateDevices = true;
|
||||||
|
PrivateTmp = true;
|
||||||
|
ProtectClock = true;
|
||||||
|
ProtectControlGroups = true;
|
||||||
|
ProtectHome = true;
|
||||||
|
ProtectHostname = true;
|
||||||
|
ProtectKernelLogs = true;
|
||||||
|
ProtectKernelModules = true;
|
||||||
|
ProtectKernelTunables = true;
|
||||||
|
ProtectSystem = "strict";
|
||||||
|
RestrictAddressFamilies = [
|
||||||
|
"AF_INET"
|
||||||
|
"AF_INET6"
|
||||||
|
"AF_UNIX"
|
||||||
|
];
|
||||||
|
RestrictNamespaces = true;
|
||||||
|
RestrictRealtime = true;
|
||||||
|
StateDirectory = "routinator";
|
||||||
|
SystemCallArchitectures = "native";
|
||||||
|
SystemCallErrorNumber = "EPERM";
|
||||||
|
SystemCallFilter = "@system-service";
|
||||||
|
UMask = "0027";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
meta.maintainers = with maintainers; [ xgwq ];
|
||||||
|
}
|
@ -918,6 +918,7 @@ in {
|
|||||||
rmfakecloud = runTest ./rmfakecloud.nix;
|
rmfakecloud = runTest ./rmfakecloud.nix;
|
||||||
robustirc-bridge = handleTest ./robustirc-bridge.nix {};
|
robustirc-bridge = handleTest ./robustirc-bridge.nix {};
|
||||||
roundcube = handleTest ./roundcube.nix {};
|
roundcube = handleTest ./roundcube.nix {};
|
||||||
|
routinator = handleTest ./routinator.nix {};
|
||||||
rosenpass = handleTest ./rosenpass.nix {};
|
rosenpass = handleTest ./rosenpass.nix {};
|
||||||
rshim = handleTest ./rshim.nix {};
|
rshim = handleTest ./rshim.nix {};
|
||||||
rspamd = handleTest ./rspamd.nix {};
|
rspamd = handleTest ./rspamd.nix {};
|
||||||
|
35
nixos/tests/routinator.nix
Normal file
35
nixos/tests/routinator.nix
Normal file
@ -0,0 +1,35 @@
|
|||||||
|
{
|
||||||
|
system ? builtins.currentSystem,
|
||||||
|
pkgs ? import ../.. {
|
||||||
|
inherit system;
|
||||||
|
config = { };
|
||||||
|
},
|
||||||
|
}:
|
||||||
|
|
||||||
|
let
|
||||||
|
inherit (import ../lib/testing-python.nix { inherit system pkgs; }) makeTest;
|
||||||
|
in
|
||||||
|
makeTest {
|
||||||
|
name = "routinator";
|
||||||
|
|
||||||
|
nodes.server =
|
||||||
|
{ pkgs, ... }:
|
||||||
|
{
|
||||||
|
services.routinator = {
|
||||||
|
enable = true;
|
||||||
|
extraArgs = [ "--no-rir-tals" ];
|
||||||
|
settings = {
|
||||||
|
http-listen = [ "[::]:8382" ];
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
testScript = ''
|
||||||
|
start_all()
|
||||||
|
|
||||||
|
server.wait_for_unit("routinator.service")
|
||||||
|
|
||||||
|
with subtest("Check if routinator reports the correct version"):
|
||||||
|
server.wait_until_succeeds("[[ \"$(curl http://localhost:8382/version)\" = \"${pkgs.routinator.version}\" ]]")
|
||||||
|
'';
|
||||||
|
}
|
@ -4,6 +4,7 @@
|
|||||||
fetchFromGitHub,
|
fetchFromGitHub,
|
||||||
stdenv,
|
stdenv,
|
||||||
darwin,
|
darwin,
|
||||||
|
nixosTests,
|
||||||
}:
|
}:
|
||||||
|
|
||||||
rustPlatform.buildRustPackage rec {
|
rustPlatform.buildRustPackage rec {
|
||||||
@ -36,4 +37,8 @@ rustPlatform.buildRustPackage rec {
|
|||||||
maintainers = with maintainers; [ _0x4A6F ];
|
maintainers = with maintainers; [ _0x4A6F ];
|
||||||
mainProgram = "routinator";
|
mainProgram = "routinator";
|
||||||
};
|
};
|
||||||
|
|
||||||
|
passthru.tests = {
|
||||||
|
basic-functioniality = nixosTests.routinator;
|
||||||
|
};
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user