summaryrefslogtreecommitdiff
path: root/modules/nixos/nofitications.linus.onl/default.nix
diff options
context:
space:
mode:
Diffstat (limited to 'modules/nixos/nofitications.linus.onl/default.nix')
-rw-r--r--modules/nixos/nofitications.linus.onl/default.nix44
1 files changed, 44 insertions, 0 deletions
diff --git a/modules/nixos/nofitications.linus.onl/default.nix b/modules/nixos/nofitications.linus.onl/default.nix
new file mode 100644
index 0000000..d77a0e7
--- /dev/null
+++ b/modules/nixos/nofitications.linus.onl/default.nix
@@ -0,0 +1,44 @@
+{
+ pkgs,
+ lib,
+ config,
+ ...
+}: let
+ inherit (lib) mkEnableOption mkOption types mkIf optional;
+
+ domain = "notifications.linus.onl";
+
+ # TODO: Make option internal-port.
+ internal-port = 13082;
+
+ cfg = config.modules."notifications.linus.onl";
+in {
+ options.modules."notifications.linus.onl" = {
+ enable = mkEnableOption "notifications.linus.onl static site";
+
+ useACME = mkEnableOption "built-in HTTPS stuff";
+ };
+
+ config = mkIf cfg.enable {
+ services.push-notification-api = {
+ enable = true;
+ # host = "notifications.linus.onl";
+ host = "0.0.0.0";
+ port = internal-port;
+ openFirewall = false; # We're using NGINX reverse proxy.
+ };
+
+ # Register domain name.
+ services.cloudflare-dyndns.domains = ["notifications.linus.onl"];
+
+ # Serve the generated page using NGINX.
+ services.nginx.virtualHosts."notifications.linus.onl" = {
+ enableACME = cfg.useACME;
+ forceSSL = cfg.useACME;
+ locations."/" = {
+ recommendedProxySettings = true;
+ proxyPass = "http://127.0.0.1:${toString internal-port}";
+ };
+ };
+ };
+}