Compare commits

..

No commits in common. "fa7815612081e218fe19209a958f8c6f8a0bb9f6" and "78118c14dc7a26c7d2c5ea2de99285e0f9b7eda5" have entirely different histories.

8 changed files with 9 additions and 72 deletions

View file

@ -14,6 +14,5 @@
./sanoid.nix ./sanoid.nix
./security.nix ./security.nix
./steam.nix ./steam.nix
./tailscale.nix
]; ];
} }

View file

@ -1,8 +0,0 @@
{
services.tailscale = {
enable = true;
openFirewall = true;
extraUpFlags = [ "--login-server" "https://headscale.unspecified.systems" ]; # TODO: doesn't work (nixos bug); needs connecting/specifying manually
extraDaemonFlags = [ "--no-logs-no-support" ]; # disable telemetry
};
}

View file

@ -27,6 +27,7 @@ in
users.users = genAttrs cfg.admins users.users = genAttrs cfg.admins
(name: { (name: {
extraGroups = [ "wheel" ]; extraGroups = [ "wheel" ];
}); }
);
}; };
} }

View file

@ -15,9 +15,9 @@ in
networking.domain = "birdsong.network"; networking.domain = "birdsong.network";
fountain.users.qenya.enable = true; fountain.users.qenya.enable = true;
fountain.admins = [ "qenya" ];
fountain.users.randomcat.enable = true; fountain.users.randomcat.enable = true;
fountain.users.trungle.enable = true; fountain.users.trungle.enable = true;
fountain.admins = [ "qenya" "randomcat" ];
qenya.base-server.enable = true; qenya.base-server.enable = true;
@ -28,7 +28,6 @@ in
randomcat.services.zfs.datasets = { randomcat.services.zfs.datasets = {
"rpool_kalessin/state" = { mountpoint = "none"; }; "rpool_kalessin/state" = { mountpoint = "none"; };
"rpool_kalessin/state/headscale" = { mountpoint = "/var/lib/headscale"; };
"rpool_kalessin/state/owncast" = { mountpoint = "/var/lib/owncast"; }; "rpool_kalessin/state/owncast" = { mountpoint = "/var/lib/owncast"; };
}; };
@ -44,11 +43,5 @@ in
dataDir = "/var/lib/owncast"; dataDir = "/var/lib/owncast";
}; };
qenya.services.headscale = {
enable = true;
domain = "headscale.unspecified.systems";
dataDir = "/var/lib/headscale";
};
system.stateVersion = "23.11"; system.stateVersion = "23.11";
} }

View file

@ -21,7 +21,11 @@ in
enableACME = true; enableACME = true;
locations."/" = { locations."/" = {
proxyPass = "http://127.0.0.1:8234/"; proxyPass = "http://127.0.0.1:8234/";
proxyWebsockets = true; extraConfig = ''
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection "upgrade";
'';
}; };
}; };
}; };

View file

@ -4,7 +4,6 @@
./audiobookshelf.nix ./audiobookshelf.nix
./distributed-builds.nix ./distributed-builds.nix
./forgejo.nix ./forgejo.nix
./headscale.nix
./jellyfin.nix ./jellyfin.nix
./navidrome.nix ./navidrome.nix
./owncast.nix ./owncast.nix

View file

@ -1,50 +0,0 @@
{ config, lib, pkgs, ... }:
let
inherit (lib) mkIf mkOption mkEnableOption types;
cfg = config.qenya.services.headscale;
in
{
options.qenya.services.headscale = {
enable = mkEnableOption "Headscale";
domain = mkOption {
type = types.str;
};
dataDir = mkOption {
type = types.str;
};
};
config = mkIf cfg.enable {
services.nginx = {
enable = true;
virtualHosts = {
${cfg.domain} = {
forceSSL = true;
enableACME = true;
locations."/" = {
proxyPass = "http://127.0.0.1:32770/";
proxyWebsockets = true;
};
};
};
};
networking.firewall.allowedTCPPorts = [ 80 443 ];
services.headscale = {
enable = true;
address = "0.0.0.0"; # required to disable built-in ACME client for some reason
port = 32770;
settings = {
server_url = "https://${cfg.domain}:443";
prefixes.allocation = "random";
dns.magic_dns = false;
# disable built-in ACME client
tls_cert_path = null;
tls_key_path = null;
};
};
};
}

View file

@ -22,7 +22,7 @@ in
${cfg.domain} = { ${cfg.domain} = {
forceSSL = true; forceSSL = true;
enableACME = true; enableACME = true;
locations."/".proxyPass = "http://127.0.0.1:32769/"; locations."/".proxyPass = "http://127.0.0.1:8080/";
}; };
}; };
}; };
@ -30,7 +30,6 @@ in
networking.firewall.allowedTCPPorts = [ 80 443 1935 ]; # 1935 for rtmp networking.firewall.allowedTCPPorts = [ 80 443 1935 ]; # 1935 for rtmp
services.owncast.enable = true; services.owncast.enable = true;
services.owncast.port = 32769;
services.owncast.dataDir = cfg.dataDir; services.owncast.dataDir = cfg.dataDir;
}; };
} }