2024-11-30 12:14:46 +00:00
|
|
|
{
|
|
|
|
lib,
|
|
|
|
config,
|
2024-11-30 21:48:30 +00:00
|
|
|
self,
|
2024-11-30 12:14:46 +00:00
|
|
|
...
|
|
|
|
}: {
|
2024-11-30 21:48:30 +00:00
|
|
|
options.pim.tailscale.advertiseExitNode = lib.mkOption {
|
|
|
|
type = lib.types.bool;
|
|
|
|
default = false;
|
|
|
|
};
|
|
|
|
|
2024-11-30 12:14:46 +00:00
|
|
|
config = lib.mkIf (builtins.elem "server" config.deployment.tags) {
|
2024-11-30 21:48:30 +00:00
|
|
|
networking = {
|
|
|
|
firewall.allowedTCPPorts = [config.services.prometheus.exporters.node.port];
|
|
|
|
domain = "dmz";
|
|
|
|
useDHCP = false;
|
|
|
|
nftables.enable = lib.mkDefault true;
|
|
|
|
firewall.enable = lib.mkDefault true;
|
|
|
|
};
|
|
|
|
|
|
|
|
systemd.network = {
|
|
|
|
enable = true;
|
|
|
|
|
|
|
|
networks = {
|
|
|
|
"30-main-nic" = {
|
|
|
|
matchConfig.Name = "en*";
|
|
|
|
networkConfig.DHCP = "yes";
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
services = {
|
|
|
|
openssh.enable = true;
|
|
|
|
prometheus.exporters.node.enable = true;
|
|
|
|
|
|
|
|
tailscale = {
|
|
|
|
authKeyFile = config.sops.secrets."tailscale/authKey".path;
|
|
|
|
useRoutingFeatures = "server";
|
|
|
|
openFirewall = true;
|
|
|
|
|
|
|
|
extraUpFlags =
|
|
|
|
[
|
|
|
|
"--accept-dns=false"
|
|
|
|
"--hostname=${config.networking.hostName}"
|
|
|
|
]
|
|
|
|
++ lib.lists.optional config.pim.tailscale.advertiseExitNode "--advertise-exit-node"
|
|
|
|
++ lib.lists.optional config.pim.tailscale.advertiseExitNode "--advertise-routes=192.168.30.0/24";
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
sops.secrets."tailscale/authKey" = {
|
|
|
|
sopsFile = "${self}/secrets/servers.sops.yaml";
|
|
|
|
};
|
2024-11-30 12:14:46 +00:00
|
|
|
};
|
|
|
|
}
|