]> git.immae.eu Git - perso/Immae/Config/Nix.git/blobdiff - nixops/modules/websites/capitaines/default.nix
Start moving websites configuration to modules
[perso/Immae/Config/Nix.git] / nixops / modules / websites / capitaines / default.nix
index 7f8f4c6370874d34ee5b97d1691d26f20920cf25..0d852667ee66e8c308953fe0fbb7894826a2311c 100644 (file)
@@ -1,7 +1,9 @@
-{ lib, pkgs, config, myconfig, mylibs, ... }:
+{ lib, pkgs, config, myconfig,  ... }:
 let
     cfg = config.services.myWebsites.Capitaines;
     env = myconfig.env.websites.capitaines;
+    webappName = "capitaines_mastodon";
+    root = "/run/current-system/webapps/${webappName}";
     siteDir = ./mastodon_static;
 in {
   options.services.myWebsites.Capitaines = {
@@ -11,18 +13,23 @@ in {
   };
 
   config = lib.mkIf cfg.production.enable {
-    security.acme.certs."capitaines_mastodon" = config.services.myCertificates.certConfig // {
+    security.acme.certs."capitaines" = config.services.myCertificates.certConfig // {
       domain = "mastodon.capitaines.fr";
+      extraDomains = { "capitaines.fr" = null; };
     };
+    system.extraSystemBuilderCmds = ''
+      mkdir -p $out/webapps
+      ln -s ${siteDir} $out/webapps/${webappName}
+      '';
 
-    services.myWebsites.production.vhostConfs.capitaines = {
-      certName    = "capitaines_mastodon";
+    services.websites.production.vhostConfs.capitaines_mastodon = {
+      certName    = "capitaines";
       hosts       = [ "mastodon.capitaines.fr" ];
-      root        = siteDir;
+      root        = root;
       extraConfig = [
         ''
         ErrorDocument 404 /index.html
-        <Directory ${siteDir}>
+        <Directory ${root}>
           DirectoryIndex index.html
           Options Indexes FollowSymLinks MultiViews Includes
           Require all granted
@@ -30,5 +37,17 @@ in {
           ''
       ];
     };
+
+    services.websites.production.vhostConfs.capitaines = {
+      certName = "capitaines";
+      hosts    = [ "capitaines.fr" ];
+      root     = "/run/current-system/webapps/_www";
+      extraConfig = [ ''
+        <Directory /run/current-system/webapps/_www>
+          DirectoryIndex index.htm
+          Require all granted
+        </Directory>
+        '' ];
+    };
   };
 }