2024-09-08 19:22:14 -05:00
|
|
|
{
|
|
|
|
config,
|
|
|
|
inputs,
|
|
|
|
lib,
|
|
|
|
pkgs,
|
|
|
|
...
|
|
|
|
}:
|
2024-09-12 20:50:53 -05:00
|
|
|
with lib; let
|
2024-09-08 19:22:14 -05:00
|
|
|
cat = "${pkgs.coreutils}/bin/cat";
|
|
|
|
tailscale = "${config.services.tailscale.package}/bin/tailscale";
|
|
|
|
|
|
|
|
cfg = config.custom.services.tailscale;
|
2024-09-12 20:50:53 -05:00
|
|
|
in {
|
2024-09-08 19:22:14 -05:00
|
|
|
# TODO: Enact recommendations
|
|
|
|
# https://tailscale.com/kb/1320/performance-best-practices
|
|
|
|
# https://github.com/tailscale/tailscale
|
|
|
|
#!! Configuration is imperative
|
|
|
|
#?? sudo tailscale up --ssh --advertise-exit-node --accept-routes --operator=$USER --reset --qr
|
|
|
|
options.custom.services.tailscale = {
|
2024-09-12 20:50:53 -05:00
|
|
|
enable = mkOption {default = false;};
|
|
|
|
cert = mkOption {default = false;};
|
2024-09-08 19:22:14 -05:00
|
|
|
};
|
|
|
|
|
|
|
|
# TODO: Use caddy plugin for provisioning when supported by NixOS
|
|
|
|
# https://github.com/NixOS/nixpkgs/pull/317881
|
|
|
|
# https://github.com/tailscale/caddy-tailscale
|
|
|
|
config = mkIf cfg.enable {
|
2024-09-12 20:50:53 -05:00
|
|
|
age.secrets = let
|
|
|
|
secret = filename: {
|
|
|
|
file = "${inputs.self}/secrets/${filename}";
|
2024-09-08 19:22:14 -05:00
|
|
|
};
|
2024-09-12 20:50:53 -05:00
|
|
|
in {
|
|
|
|
"common/tailscale/tailnet" = secret "common/tailscale/tailnet";
|
|
|
|
};
|
2024-09-08 19:22:14 -05:00
|
|
|
|
|
|
|
services.tailscale = {
|
|
|
|
enable = true;
|
|
|
|
#// permitCertUid = mkIf cfg.cert "caddy"; # Allow caddy to fetch TLS certificates
|
|
|
|
useRoutingFeatures = "both"; # Enable server/client exit nodes
|
|
|
|
};
|
|
|
|
|
|
|
|
# Provision Tailscale certificates in the background per machine
|
2024-09-12 20:50:53 -05:00
|
|
|
systemd = let
|
|
|
|
hostname = config.custom.hostname;
|
|
|
|
in
|
2024-09-08 19:22:14 -05:00
|
|
|
mkIf cfg.cert {
|
|
|
|
#!! Needs to be run on the machine
|
|
|
|
# tailscale cert always writes to /var/lib/tailscale/certs/ regardless of flags
|
|
|
|
services."tailscale-cert-${hostname}".script = concatStringsSep " " [
|
|
|
|
"${tailscale} cert"
|
|
|
|
"--cert-file -"
|
|
|
|
"--key-file -"
|
|
|
|
"${hostname}.\"$(${cat} ${config.age.secrets."common/tailscale/tailnet".path})\""
|
|
|
|
"> /dev/null"
|
|
|
|
];
|
|
|
|
|
|
|
|
timers."tailscale-cert-${hostname}" = {
|
2024-09-12 20:50:53 -05:00
|
|
|
wantedBy = ["timers.target"];
|
2024-09-08 19:22:14 -05:00
|
|
|
|
|
|
|
timerConfig = {
|
|
|
|
OnCalendar = "daily";
|
|
|
|
Persistent = true; # Retry if previous timer missed
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
}
|