]> git.immae.eu Git - perso/Immae/Config/Nix.git/commitdiff
Add dolibarr for Attilax
authorIsmaël Bouya <ismael.bouya@normalesup.org>
Tue, 28 Jun 2022 21:03:25 +0000 (23:03 +0200)
committerIsmaël Bouya <ismael.bouya@normalesup.org>
Sun, 9 Apr 2023 15:16:22 +0000 (17:16 +0200)
modules/private/default.nix
modules/private/websites/attilax/dolibarr.nix [new file with mode: 0644]
modules/private/websites/default.nix

index 2742ce116a6c139530b506d3264c030776c660c7..a0d795ea0284845122c5802890e4c4cae1ae9222 100644 (file)
@@ -21,6 +21,8 @@ set = {
 
 
   # Personal websites
+  attilaxDolibarr = ./websites/attilax/dolibarr.nix;
+
   bakeerCloud = ./websites/bakeer/cloud.nix;
 
   capitainesLandingPages = ./websites/capitaines/landing_pages.nix;
diff --git a/modules/private/websites/attilax/dolibarr.nix b/modules/private/websites/attilax/dolibarr.nix
new file mode 100644 (file)
index 0000000..3230193
--- /dev/null
@@ -0,0 +1,63 @@
+{ lib, config, pkgs, ... }:
+let
+  cfg = config.myServices.websites.attilax.dolibarr;
+  varDir = "/var/lib/ftp/attilax/dolibarr";
+  apacheUser = config.services.httpd.Prod.user;
+  apacheGroup = config.services.httpd.Prod.group;
+in {
+  options.myServices.websites.attilax.dolibarr.enable = lib.mkEnableOption "enable Dolibarr website";
+
+  config = lib.mkIf cfg.enable {
+    system.activationScripts.dolibarr = {
+      deps = [ "httpd" "users" ];
+      text = ''
+        install -m 0755 -o ${apacheUser} -g ${apacheGroup} -d /var/lib/php/sessions/attilax
+      '';
+    };
+    services.phpfpm.pools.attilax_dolibarr = {
+      user = apacheUser;
+      group = apacheGroup;
+      settings = {
+        "listen.owner" = apacheUser;
+        "listen.group" = apacheGroup;
+
+        "pm" = "ondemand";
+        "pm.max_children" = "5";
+        "pm.process_idle_timeout" = "60";
+
+        "php_admin_value[upload_max_filesize]" = "100M";
+        "php_admin_value[post_max_size]" = "100M";
+        "php_admin_value[open_basedir]" = "/var/lib/php/sessions/attilax:${varDir}:/tmp";
+        "php_admin_value[session.save_path]" = "/var/lib/php/sessions/attilax";
+      };
+      phpOptions = config.services.phpfpm.phpOptions + ''
+        disable_functions = "mail"
+      '';
+      phpPackage = pkgs.php74;
+    };
+    services.websites.env.production.modules = [ "proxy_fcgi" ];
+    services.websites.env.production.vhostConfs.attilax_dolibarr = {
+      certName     = "attilax";
+      addToCerts   = true;
+      certMainHost = "doli.attilax.fr";
+      hosts        = ["doli.attilax.fr"];
+      root         = "${varDir}/dolibarr/htdocs";
+      extraConfig  = [
+        ''
+        <FilesMatch "\.php$">
+          SetHandler "proxy:unix:${config.services.phpfpm.pools.attilax_dolibarr.socket}|fcgi://localhost"
+        </FilesMatch>
+
+        <Directory ${varDir}/dolibarr/htdocs>
+          DirectoryIndex index.php index.htm index.html
+          Options Indexes FollowSymLinks MultiViews Includes
+          AllowOverride All
+          Require all granted
+        </Directory>
+          ''
+      ];
+    };
+  };
+}
+
+
index 37e73338b919d785ca387e1ee1b87287ebed6696..b007a6e22696cb1d9bbd0e43994e898074e1c5dc 100644 (file)
@@ -215,6 +215,8 @@ in
     myServices.tools.kanboard.farm.instances.tonnelle = {};
     myServices.tools.kanboard.farm.instances.gebull = {};
     myServices.websites = {
+      attilax.dolibarr.enable = true;
+
       bakeer.cloud.enable = true;
       capitaines.landing_pages.enable = true;