diff --git a/hosts/nixos-server-reid/hardware.nix b/hosts/nixos-server-reid/hardware.nix index 9d69a64..567f737 100755 --- a/hosts/nixos-server-reid/hardware.nix +++ b/hosts/nixos-server-reid/hardware.nix @@ -24,7 +24,7 @@ boot.loader.generic-extlinux-compatible.enable = true; fileSystems."/" = - { device = "/dev/disk/by-uuid/44444444-4444-4444-8888-888888888888"; + { device = "/dev/disk/by-uuid/27851c93-5389-4fcb-abe0-5372b1190bc4"; fsType = "ext4"; options = [ "noatime" "nodiratime" "discard" ]; }; diff --git a/hosts/nixos-server-reid/webapps/default.nix b/hosts/nixos-server-reid/webapps/default.nix index 56beee5..6828e6a 100755 --- a/hosts/nixos-server-reid/webapps/default.nix +++ b/hosts/nixos-server-reid/webapps/default.nix @@ -35,6 +35,11 @@ in { enable = true; domain = "amdl.reidlab.pink"; }; + + uptime = { + enable = true; + domain = "status.reidlab.pink"; + }; }; }; diff --git a/modules/services/uptime.nix b/modules/services/uptime.nix new file mode 100644 index 0000000..54d0a81 --- /dev/null +++ b/modules/services/uptime.nix @@ -0,0 +1,33 @@ +{ config, lib, pkgs, options, ... }: + +with lib; +let + cfg = config.modules.services.uptime; +in { + options.modules.services.uptime = { + enable = mkEnableOption "enable uptime kuma, a self-hosted uptime website"; + port = mkOption { + type = types.int; + default = 3002; + }; + domain = mkOption { + type = types.str; + default = "status.reidlab.pink"; + }; + }; + + config = mkIf cfg.enable { + services.uptime-kuma = { + enable = true; + settings.PORT = toString cfg.port; + }; + + services.nginx.virtualHosts."${cfg.domain}" = { + forceSSL = true; + enableACME = true; + locations."/" = { + proxyPass = "http://127.0.0.1:${toString cfg.port}"; + }; + }; + }; +}