From 349ce5d074cb774913d458b27a45ae2053dd935f Mon Sep 17 00:00:00 2001 From: Caroline Larimore Date: Mon, 14 Apr 2025 23:30:30 -0700 Subject: copenhagen: status server --- modules/nixos/services/web/status/default.nix | 46 +++++++++++++++++++++++++++ 1 file changed, 46 insertions(+) create mode 100644 modules/nixos/services/web/status/default.nix (limited to 'modules/nixos/services/web/status/default.nix') diff --git a/modules/nixos/services/web/status/default.nix b/modules/nixos/services/web/status/default.nix new file mode 100644 index 0000000..b5a949f --- /dev/null +++ b/modules/nixos/services/web/status/default.nix @@ -0,0 +1,46 @@ +{ options, config, lib, pkgs, namespace, ... }: + +with lib; with lib.${namespace}; let + cfg = config.${namespace}.services.web.status; + impermanence = config.${namespace}.system.impermanence; +in { + options.${namespace}.services.web.status = with types; { + enable = mkEnableOption "status webserver"; + }; + + config = mkIf cfg.enable { + cxl.services.web.enable = true; + + environment.persistence.${impermanence.location} = { + directories = [ + "/srv/web/status" + ]; + }; + + networking.firewall.allowedTCPPorts = [ 80 443 ]; + + services.nginx = { + enable = true; + virtualHosts = { + "status.cxl.sh" = { + addSSL = true; + enableACME = true; + + locations."/" = { + recommendedProxySettings = true; + proxyPass = "http://127.0.0.1:6969/"; + }; + }; + }; + }; + + systemd.services."cxl.web.status" = { + enable = true; + wantedBy = [ "multi-user.target" ]; + + serviceConfig = { + ExecStart = "${pkgs.cxl.status}/bin/status 6969 /srv/web/status/auth"; + }; + }; + }; +} -- cgit v1.2.3