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

index 4c556557bd2327a87b69229736e284582a98f7c1..d2a11d0c0f0c9c24e0df72b1af82613272775ddd 100644 (file)
@@ -79,6 +79,7 @@ set = {
   nicecoopGestionCompte = ./websites/nicecoop/gestion-compte.nix;
   nicecoopGestionCompteIntegration = ./websites/nicecoop/gestion-compte_integration.nix;
   nicecoopOdoo = ./websites/nicecoop/odoo.nix;
+  nicecoopDolibarrDev = ./websites/nicecoop/dolibarr_integration.nix;
   nicecoopCopanier = ./websites/nicecoop/copanier.nix;
 
   noctambulesCloud = ./websites/noctambules/cloud.nix;
index d636678d1b485f049ba1e1e4cad85e6e8735d127..5920fbe75a9ea29099e6bc1602ee6698f98681bf 100644 (file)
@@ -295,6 +295,7 @@ in
         gestion-compte.enable = true;
         gestion-compte-integration.enable = true;
         odoo.enable = true;
+        dolibarrDev.enable = true;
         copanier.enable = true;
       };
 
diff --git a/modules/private/websites/nicecoop/dolibarr_integration.nix b/modules/private/websites/nicecoop/dolibarr_integration.nix
new file mode 100644 (file)
index 0000000..f6cb03b
--- /dev/null
@@ -0,0 +1,62 @@
+{ lib, config, pkgs, ... }:
+let
+  cfg = config.myServices.websites.nicecoop.dolibarrDev;
+  varDir = "/var/lib/ftp/nicecoop/dolibarr_dev";
+  apacheUser = config.services.httpd.Inte.user;
+  apacheGroup = config.services.httpd.Inte.group;
+in {
+  options.myServices.websites.nicecoop.dolibarrDev.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/nicecoop
+      '';
+    };
+    services.phpfpm.pools.nicecoop_dolibarr_dev = {
+      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/nicecoop:${varDir}:/tmp";
+        "php_admin_value[session.save_path]" = "/var/lib/php/sessions/nicecoop";
+      };
+      phpOptions = config.services.phpfpm.phpOptions + ''
+        disable_functions = "mail"
+      '';
+      phpPackage = pkgs.php74;
+    };
+    services.websites.env.production.modules = [ "proxy_fcgi" ];
+    services.websites.env.integration.vhostConfs.nicecoop_dolibarr_dev = {
+      certName     = "integration";
+      addToCerts   = true;
+      hosts        = ["dolibarr.nc.immae.dev"];
+      root         = "${varDir}/dolibarr/htdocs";
+      extraConfig  = [
+        ''
+        <FilesMatch "\.php$">
+          SetHandler "proxy:unix:${config.services.phpfpm.pools.nicecoop_dolibarr_dev.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>
+          ''
+      ];
+    };
+  };
+}
+
+