]> git.immae.eu Git - perso/Immae/Config/Nix.git/blame - nixops/modules/websites/tools/tools/shaarli.nix
Improve shaarli keys handling
[perso/Immae/Config/Nix.git] / nixops / modules / websites / tools / tools / shaarli.nix
CommitLineData
95b20e17
IB
1{ lib, env, stdenv, fetchurl }:
2
3let
4 varDir = "/var/lib/shaarli";
5 shaarli = stdenv.mkDerivation rec {
6 name = "shaarli-${version}";
7 version = "0.10.2";
8
9 src = fetchurl {
10 url = "https://github.com/shaarli/Shaarli/releases/download/v${version}/shaarli-v${version}-full.tar.gz";
11 sha256 = "0h8sspj7siy3vgpi2i3gdrjcr5935fr4dfwq2zwd70sjx2sh9s78";
12 };
13
14 outputs = [ "out" "doc" ];
15
16 patches = [ ./shaarli_ldap.patch ];
17
18 installPhase = ''
19 rm -r {cache,pagecache,tmp,data}/
3c8d7f87 20 ln -sf ${varDir}/{cache,pagecache,tmp,data} .
95b20e17
IB
21 mkdir -p $doc/share/doc
22 mv doc/ $doc/share/doc/shaarli
23 mkdir $out/
24 cp -R ./* $out
25 cp .htaccess $out/
26 '';
27
28 meta = with stdenv.lib; {
29 description = "The personal, minimalist, super-fast, database free, bookmarking service";
30 license = licenses.gpl3Plus;
31 homepage = https://github.com/shaarli/Shaarli;
32 maintainers = with maintainers; [ schneefux ];
33 platforms = platforms.all;
34 };
35 };
36in rec {
37 activationScript = ''
38 install -m 0755 -o ${apache.user} -g ${apache.group} -d ${varDir} \
39 ${varDir}/cache ${varDir}/pagecache ${varDir}/tmp ${varDir}/data \
40 ${varDir}/phpSessions
41 '';
42 webRoot = shaarli;
a95ab089 43 apache = rec {
95b20e17
IB
44 user = "wwwrun";
45 group = "wwwrun";
46 modules = [ "proxy_fcgi" "rewrite" "env" ];
a95ab089
IB
47 webappName = "tools_shaarli";
48 root = "/run/current-system/webapps/${webappName}";
95b20e17 49 vhostConf = ''
a95ab089 50 Alias /Shaarli "${root}"
95b20e17 51
0962f4e8 52 Include /run/keys/webapps/tools-shaarli
a95ab089 53 <Directory "${root}">
95b20e17
IB
54 DirectoryIndex index.php index.htm index.html
55 Options Indexes FollowSymLinks MultiViews Includes
56 AllowOverride All
57 Require all granted
58 <FilesMatch "\.php$">
59 SetHandler "proxy:unix:${phpFpm.socket}|fcgi://localhost"
60 </FilesMatch>
61 </Directory>
62 '';
63 };
5f08b34c
IB
64 keys.tools-shaarli = {
65 destDir = "/run/keys/webapps";
66 user = apache.user;
67 group = apache.group;
68 permissions = "0700";
69 text = ''
0962f4e8
IB
70 SetEnv SHAARLI_LDAP_PASSWORD "${env.ldap.password}"
71 SetEnv SHAARLI_LDAP_DN "${env.ldap.dn}"
72 SetEnv SHAARLI_LDAP_HOST "ldaps://${env.ldap.host}"
73 SetEnv SHAARLI_LDAP_BASE "${env.ldap.base}"
74 SetEnv SHAARLI_LDAP_FILTER "${env.ldap.search}"
5f08b34c
IB
75 '';
76 };
95b20e17 77 phpFpm = rec {
0962f4e8 78 serviceDeps = [ "openldap.service" ];
95b20e17
IB
79 basedir = builtins.concatStringsSep ":" [ webRoot varDir ];
80 socket = "/var/run/phpfpm/shaarli.sock";
81 pool = ''
82 listen = ${socket}
83 user = ${apache.user}
84 group = ${apache.group}
85 listen.owner = ${apache.user}
86 listen.group = ${apache.group}
87 pm = ondemand
88 pm.max_children = 60
89 pm.process_idle_timeout = 60
90
91 ; Needed to avoid clashes in browser cookies (same domain)
92 php_value[session.name] = ShaarliPHPSESSID
93 php_admin_value[open_basedir] = "${basedir}:/tmp"
94 php_admin_value[session.save_path] = "${varDir}/phpSessions"
95 '';
96 };
97}