]> git.immae.eu Git - perso/Immae/Config/Nix.git/blobdiff - modules/private/websites/capitaines/landing_pages.nix
Refactor websites
[perso/Immae/Config/Nix.git] / modules / private / websites / capitaines / landing_pages.nix
diff --git a/modules/private/websites/capitaines/landing_pages.nix b/modules/private/websites/capitaines/landing_pages.nix
new file mode 100644 (file)
index 0000000..b94a398
--- /dev/null
@@ -0,0 +1,60 @@
+{ lib, config,  ... }:
+let
+  cfg = config.myServices.websites.capitaines.landing_pages;
+  webappdirs = config.services.websites.webappDirsPaths;
+  certName = "capitaines";
+  domain = "capitaines.fr";
+in {
+  options.myServices.websites.capitaines.landing_pages.enable = lib.mkEnableOption "enable Capitaines's landing pages";
+
+  config = lib.mkIf cfg.enable {
+    services.websites.webappDirs.capitaines_mastodon = ./mastodon_static;
+    services.websites.env.production.vhostConfs.capitaines_mastodon = rec {
+      inherit certName;
+      certMainHost = "mastodon.${domain}";
+      hosts        = [ certMainHost ];
+      root         = webappdirs.capitaines_mastodon;
+      extraConfig  = [
+        ''
+        ErrorDocument 404 /index.html
+        <Directory ${webappdirs.capitaines_mastodon}>
+          DirectoryIndex index.html
+          Options Indexes FollowSymLinks MultiViews Includes
+          Require all granted
+        </Directory>
+          ''
+      ];
+    };
+
+    services.websites.webappDirs.capitaines_discourse = ./discourse_static;
+    services.websites.env.production.vhostConfs.capitaines_discourse = {
+      inherit certName;
+      addToCerts   = true;
+      hosts        = [ "discourse.${domain}" ];
+      root         = webappdirs.capitaines_discourse;
+      extraConfig  = [
+        ''
+        ErrorDocument 404 /index.html
+        <Directory ${webappdirs.capitaines_discourse}>
+          DirectoryIndex index.html
+          Options Indexes FollowSymLinks MultiViews Includes
+          Require all granted
+        </Directory>
+          ''
+      ];
+    };
+
+    services.websites.env.production.vhostConfs.capitaines = {
+      inherit certName;
+      addToCerts = true;
+      hosts      = [ domain ];
+      root       = webappdirs._www;
+      extraConfig = [ ''
+        <Directory ${webappdirs._www}>
+          DirectoryIndex index.htm
+          Require all granted
+        </Directory>
+        '' ];
+    };
+  };
+}