2025-03-30 15:03:46 +00:00
|
|
|
{config, ...}: let
|
|
|
|
virtualHostName = "headscale.helveticanonstandard.net";
|
|
|
|
in {
|
|
|
|
services.headscale = {
|
|
|
|
enable = true;
|
|
|
|
address = "127.0.0.1";
|
|
|
|
port = 8010;
|
|
|
|
settings = {
|
2025-03-30 15:05:55 +00:00
|
|
|
server_url = "https://${virtualHostName}";
|
2025-03-30 15:10:19 +00:00
|
|
|
dns.base_domain = "tailnet.helveticanonstandard.net";
|
2025-03-30 15:03:46 +00:00
|
|
|
logtail.enabled = false;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
services.nginx.virtualHosts.${virtualHostName} = {
|
|
|
|
forceSSL = true;
|
|
|
|
enableACME = true;
|
|
|
|
locations."/" = {
|
2025-03-30 15:05:55 +00:00
|
|
|
proxyPass = let
|
|
|
|
host = config.services.headscale.address;
|
|
|
|
port = builtins.toString config.services.headscale.port;
|
|
|
|
in "http://${host}:${port}";
|
2025-03-30 15:03:46 +00:00
|
|
|
proxyWebsockets = true;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
}
|