2022-01-01 23:43:37 +00:00
|
|
|
{ config, lib, pkgs, ... }:
|
|
|
|
|
|
|
|
{
|
2022-02-24 16:09:56 +00:00
|
|
|
options.services.tetrd.enable = lib.mkEnableOption (lib.mdDoc "tetrd");
|
2022-01-01 23:43:37 +00:00
|
|
|
|
|
|
|
config = lib.mkIf config.services.tetrd.enable {
|
|
|
|
environment = {
|
|
|
|
systemPackages = [ pkgs.tetrd ];
|
|
|
|
etc."resolv.conf".source = "/etc/tetrd/resolv.conf";
|
|
|
|
};
|
|
|
|
|
|
|
|
systemd = {
|
|
|
|
tmpfiles.rules = [ "f /etc/tetrd/resolv.conf - - -" ];
|
|
|
|
|
|
|
|
services.tetrd = {
|
|
|
|
description = pkgs.tetrd.meta.description;
|
|
|
|
wantedBy = [ "multi-user.target" ];
|
|
|
|
|
|
|
|
serviceConfig = {
|
|
|
|
ExecStart = "${pkgs.tetrd}/opt/Tetrd/bin/tetrd";
|
|
|
|
Restart = "always";
|
|
|
|
RuntimeDirectory = "tetrd";
|
|
|
|
RootDirectory = "/run/tetrd";
|
|
|
|
DynamicUser = true;
|
|
|
|
UMask = "006";
|
|
|
|
DeviceAllow = "usb_device";
|
|
|
|
LockPersonality = true;
|
|
|
|
MemoryDenyWriteExecute = true;
|
|
|
|
NoNewPrivileges = true;
|
|
|
|
PrivateMounts = true;
|
|
|
|
PrivateNetwork = lib.mkDefault false;
|
|
|
|
PrivateTmp = true;
|
|
|
|
PrivateUsers = lib.mkDefault false;
|
|
|
|
ProtectClock = lib.mkDefault false;
|
|
|
|
ProtectControlGroups = true;
|
|
|
|
ProtectHome = true;
|
|
|
|
ProtectHostname = true;
|
|
|
|
ProtectKernelLogs = true;
|
|
|
|
ProtectKernelModules = true;
|
|
|
|
ProtectKernelTunables = true;
|
|
|
|
ProtectProc = "invisible";
|
|
|
|
ProtectSystem = "strict";
|
|
|
|
RemoveIPC = true;
|
|
|
|
RestrictAddressFamilies = [ "AF_UNIX" "AF_INET" "AF_INET6" "AF_NETLINK" ];
|
|
|
|
RestrictNamespaces = true;
|
|
|
|
RestrictRealtime = true;
|
|
|
|
RestrictSUIDSGID = true;
|
|
|
|
SystemCallArchitectures = "native";
|
|
|
|
|
|
|
|
SystemCallFilter = [
|
|
|
|
"@system-service"
|
|
|
|
"~@aio"
|
|
|
|
"~@chown"
|
|
|
|
"~@clock"
|
|
|
|
"~@cpu-emulation"
|
|
|
|
"~@debug"
|
|
|
|
"~@keyring"
|
|
|
|
"~@memlock"
|
|
|
|
"~@module"
|
|
|
|
"~@mount"
|
|
|
|
"~@obsolete"
|
|
|
|
"~@pkey"
|
|
|
|
"~@raw-io"
|
|
|
|
"~@reboot"
|
|
|
|
"~@swap"
|
|
|
|
"~@sync"
|
|
|
|
];
|
|
|
|
|
|
|
|
BindReadOnlyPaths = [
|
|
|
|
builtins.storeDir
|
|
|
|
"/etc/ssl"
|
|
|
|
"/etc/static/ssl"
|
|
|
|
"${pkgs.nettools}/bin/route:/usr/bin/route"
|
|
|
|
"${pkgs.nettools}/bin/ifconfig:/usr/bin/ifconfig"
|
|
|
|
];
|
|
|
|
|
|
|
|
BindPaths = [
|
|
|
|
"/etc/tetrd/resolv.conf:/etc/resolv.conf"
|
|
|
|
"/run"
|
|
|
|
"/var/log"
|
|
|
|
];
|
|
|
|
|
|
|
|
CapabilityBoundingSet = [
|
|
|
|
"CAP_DAC_OVERRIDE"
|
|
|
|
"CAP_NET_ADMIN"
|
|
|
|
];
|
|
|
|
|
|
|
|
AmbientCapabilities = [
|
|
|
|
"CAP_DAC_OVERRIDE"
|
|
|
|
"CAP_NET_ADMIN"
|
|
|
|
];
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
}
|