X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=nixops%2Fmodules%2Fwebsites%2Ftools%2Ftools%2Fdokuwiki.nix;h=c61d15f2547a0e91410240b855b99ad675c350f0;hb=c9d13ae319b4f01202a1afad046c3c1add1cc7ba;hp=ad1497f16179291a44145b80d9afdfb388c7adc8;hpb=a95ab089420d6edf24f22500dabf7876d329dc91;p=perso%2FImmae%2FConfig%2FNix.git
diff --git a/nixops/modules/websites/tools/tools/dokuwiki.nix b/nixops/modules/websites/tools/tools/dokuwiki.nix
index ad1497f..c61d15f 100644
--- a/nixops/modules/websites/tools/tools/dokuwiki.nix
+++ b/nixops/modules/websites/tools/tools/dokuwiki.nix
@@ -1,101 +1,61 @@
-{ lib, php, stdenv, writeText, fetchedGithub }:
-let
- dokuwiki = let
- plugins = {
- farmer = stdenv.mkDerivation (fetchedGithub ./dokuwiki-plugin-farmer.json // rec {
- installPhase = ''
- mkdir $out
- cp -a * $out/
- '';
- });
- todo = stdenv.mkDerivation (fetchedGithub ./dokuwiki-plugin-todo.json // rec {
- installPhase = ''
- mkdir $out
- cp -a * $out/
- '';
- });
- };
- preload = writeText "preload.php" ''
-
- DirectoryIndex index.php
-
- SetHandler "proxy:unix:${phpFpm.socket}|fcgi://localhost"
-
+{ lib, stdenv, dokuwiki, dokuwiki-plugins }:
+rec {
+ varDir = "/var/lib/dokuwiki";
+ activationScript = {
+ deps = [ "wrappers" ];
+ text = ''
+ if [ ! -d ${varDir} ]; then
+ install -m 0755 -o ${apache.user} -g ${apache.group} -d ${varDir} \
+ ${varDir}/animals
+ cp -a ${webRoot}/conf.dist ${varDir}/conf
+ cp -a ${webRoot}/data.dist ${varDir}/data
+ cp -a ${webRoot}/
+ chown -R ${apache.user}:${apache.user} ${varDir}/config ${varDir}/data
+ chmod -R 755 ${varDir}/config ${varDir}/data
+ fi
+ install -m 0750 -o ${apache.user} -g ${apache.group} -d ${varDir}/phpSessions
+ '';
+ };
+ webRoot = dokuwiki.withPlugins (builtins.attrValues dokuwiki-plugins);
+ apache = rec {
+ user = "wwwrun";
+ group = "wwwrun";
+ modules = [ "proxy_fcgi" ];
+ webappName = "tools_dokuwiki";
+ root = "/run/current-system/webapps/${webappName}";
+ vhostConf = ''
+ Alias /dokuwiki "${root}"
+
+ DirectoryIndex index.php
+
+ SetHandler "proxy:unix:${phpFpm.socket}|fcgi://localhost"
+
- AllowOverride All
- Options +FollowSymlinks
- Require all granted
-
- '';
- };
- phpFpm = rec {
- basedir = builtins.concatStringsSep ":" (
- [ webRoot varDir ]
- ++ lib.attrsets.mapAttrsToList (name: value: value) plugins);
- socket = "/var/run/phpfpm/dokuwiki.sock";
- pool = ''
- listen = ${socket}
- user = ${apache.user}
- group = ${apache.group}
- listen.owner = ${apache.user}
- listen.group = ${apache.group}
- pm = ondemand
- pm.max_children = 60
- pm.process_idle_timeout = 60
+ AllowOverride All
+ Options +FollowSymlinks
+ Require all granted
+
+ '';
+ };
+ phpFpm = rec {
+ serviceDeps = [ "openldap.service" ];
+ basedir = builtins.concatStringsSep ":" (
+ [ webRoot varDir ] ++ webRoot.plugins);
+ socket = "/var/run/phpfpm/dokuwiki.sock";
+ pool = ''
+ listen = ${socket}
+ user = ${apache.user}
+ group = ${apache.group}
+ listen.owner = ${apache.user}
+ listen.group = ${apache.group}
+ pm = ondemand
+ pm.max_children = 60
+ pm.process_idle_timeout = 60
- ; Needed to avoid clashes in browser cookies (same domain)
- php_value[session.name] = DokuwikiPHPSESSID
- php_admin_value[open_basedir] = "${basedir}:/tmp"
- php_admin_value[session.save_path] = "${varDir}/phpSessions"
- '';
- };
+ ; Needed to avoid clashes in browser cookies (same domain)
+ php_value[session.name] = DokuwikiPHPSESSID
+ php_admin_value[open_basedir] = "${basedir}:/tmp"
+ php_admin_value[session.save_path] = "${varDir}/phpSessions"
+ '';
};
-in
- dokuwiki
+}