{ modulesPath, lib, pkgs, config, pubkeys, ... }: { imports = [ (modulesPath + "/profiles/qemu-guest.nix") ./disk-config.nix ./container-root.nix ./rustypaste ./forgejo ./obsidian-livesync ./headscale.nix ../../modules/nix ]; age.secrets = { couchdb.file = ../../secrets/couchdb.age; rustypaste.file = ../../secrets/rustypaste.age; }; device.type = { vm.enable = true; server.enable = true; }; boot.loader.grub = { efiSupport = true; efiInstallAsRemovable = true; }; services.headscale.enable = true; networking.firewall = lib.mkForce { enable = true; allowedTCPPorts = [ 80 # for acme challenges 443 5984 # couchdb 3000 # forgejo 8000 # rustypaste ] ++ config.services.openssh.ports ++ [ config.services.endlessh.port ]; }; age.identityPaths = [ "/etc/ssh/ssh_host_ed25519_key" ]; security.acme.defaults.email = "admin@ccnlc.eu"; security.acme.acceptTerms = true; services.nginx = { enable = true; recommendedProxySettings = true; recommendedTlsSettings = true; clientMaxBodySize = "50M"; virtualHosts = let mkVHost = name: port: { inherit name; value = { enableACME = true; forceSSL = true; locations."/" = { proxyPass = "http://127.0.0.1:${toString port}"; extraConfig = '' proxy_ssl_server_name on; proxy_pass_header Authorization;''; }; }; }; in builtins.listToAttrs [ (mkVHost "rusty.ccnlc.eu" 8000) (mkVHost "git.ccnlc.eu" 3000) ]; }; services.openssh = { enable = true; ports = [ 56528 ]; }; services.endlessh = { enable = true; port = 22; }; environment.systemPackages = map lib.lowPrio [ pkgs.curl pkgs.gitMinimal ]; users.users.root.openssh.authorizedKeys.keys = [ pubkeys.ny ]; system.stateVersion = "24.11"; }