aboutsummaryrefslogtreecommitdiff
path: root/nixops/modules/websites/tools
diff options
context:
space:
mode:
authorIsmaël Bouya <ismael.bouya@normalesup.org>2019-04-14 23:58:56 +0200
committerIsmaël Bouya <ismael.bouya@normalesup.org>2019-04-14 23:58:56 +0200
commit981634865c275c1f35e78a27c6d76cd9708fd7ef (patch)
treec4902578bdf9facf3452c1eca8b0031ece865d1a /nixops/modules/websites/tools
parentbf74850963eeba3efc755bb517aba0197df80493 (diff)
downloadNix-981634865c275c1f35e78a27c6d76cd9708fd7ef.tar.gz
Nix-981634865c275c1f35e78a27c6d76cd9708fd7ef.tar.zst
Nix-981634865c275c1f35e78a27c6d76cd9708fd7ef.zip
Move kanboard passwords to secure location
Related issue: https://git.immae.eu/mantisbt/view.php?id=122
Diffstat (limited to 'nixops/modules/websites/tools')
-rw-r--r--nixops/modules/websites/tools/tools/default.nix3
-rw-r--r--nixops/modules/websites/tools/tools/kanboard.nix49
2 files changed, 31 insertions, 21 deletions
diff --git a/nixops/modules/websites/tools/tools/default.nix b/nixops/modules/websites/tools/tools/default.nix
index aa59e28..14b5934 100644
--- a/nixops/modules/websites/tools/tools/default.nix
+++ b/nixops/modules/websites/tools/tools/default.nix
@@ -46,6 +46,8 @@ in {
46 security.acme.certs."eldiron".extraDomains."tools.immae.eu" = null; 46 security.acme.certs."eldiron".extraDomains."tools.immae.eu" = null;
47 security.acme.certs."eldiron".extraDomains."devtools.immae.eu" = null; 47 security.acme.certs."eldiron".extraDomains."devtools.immae.eu" = null;
48 48
49 deployment.keys = kanboard.keys;
50
49 services.myWebsites.integration.modules = 51 services.myWebsites.integration.modules =
50 rainloop.apache.modules; 52 rainloop.apache.modules;
51 53
@@ -129,6 +131,7 @@ in {
129 ]; 131 ];
130 }; 132 };
131 133
134 services.myPhpfpm.serviceDependencies.kanboard = kanboard.phpFpm.serviceDeps;
132 services.myPhpfpm.poolPhpConfigs.roundcubemail = roundcubemail.phpFpm.phpConfig; 135 services.myPhpfpm.poolPhpConfigs.roundcubemail = roundcubemail.phpFpm.phpConfig;
133 services.myPhpfpm.poolConfigs = { 136 services.myPhpfpm.poolConfigs = {
134 adminer = adminer.phpFpm.pool; 137 adminer = adminer.phpFpm.pool;
diff --git a/nixops/modules/websites/tools/tools/kanboard.nix b/nixops/modules/websites/tools/tools/kanboard.nix
index 8408ffa..35ed2aa 100644
--- a/nixops/modules/websites/tools/tools/kanboard.nix
+++ b/nixops/modules/websites/tools/tools/kanboard.nix
@@ -10,33 +10,39 @@ rec {
10 install -TDm644 ${webRoot}/dataold/web.config ${varDir}/data/web.config 10 install -TDm644 ${webRoot}/dataold/web.config ${varDir}/data/web.config
11 ''; 11 '';
12 }; 12 };
13 config = writeText "config.php" '' 13 keys.tools-kanboard = {
14 <?php 14 destDir = "/run/keys/webapps";
15 define('MAIL_FROM', 'kanboard@tools.immae.eu'); 15 user = apache.user;
16 group = apache.group;
17 permissions = "0700";
18 text = ''
19 <?php
20 define('MAIL_FROM', 'kanboard@tools.immae.eu');
16 21
17 define('DB_DRIVER', 'postgres'); 22 define('DB_DRIVER', 'postgres');
18 define('DB_USERNAME', '${env.postgresql.user}'); 23 define('DB_USERNAME', '${env.postgresql.user}');
19 define('DB_PASSWORD', '${env.postgresql.password}'); 24 define('DB_PASSWORD', '${env.postgresql.password}');
20 define('DB_HOSTNAME', '${env.postgresql.socket}'); 25 define('DB_HOSTNAME', '${env.postgresql.socket}');
21 define('DB_NAME', '${env.postgresql.database}'); 26 define('DB_NAME', '${env.postgresql.database}');
22 27
23 define('LDAP_AUTH', true); 28 define('LDAP_AUTH', true);
24 define('LDAP_SERVER', '${env.ldap.host}'); 29 define('LDAP_SERVER', '${env.ldap.host}');
25 define('LDAP_START_TLS', true); 30 define('LDAP_START_TLS', true);
26 31
27 define('LDAP_BIND_TYPE', 'proxy'); 32 define('LDAP_BIND_TYPE', 'proxy');
28 define('LDAP_USERNAME', '${env.ldap.dn}'); 33 define('LDAP_USERNAME', '${env.ldap.dn}');
29 define('LDAP_PASSWORD', '${env.ldap.password}'); 34 define('LDAP_PASSWORD', '${env.ldap.password}');
30 define('LDAP_USER_BASE_DN', '${env.ldap.base}'); 35 define('LDAP_USER_BASE_DN', '${env.ldap.base}');
31 define('LDAP_USER_FILTER', '(&(memberOf=cn=users,cn=kanboard,ou=services,dc=immae,dc=eu)(uid=%s))'); 36 define('LDAP_USER_FILTER', '(&(memberOf=cn=users,cn=kanboard,ou=services,dc=immae,dc=eu)(uid=%s))');
32 define('LDAP_GROUP_ADMIN_DN', 'cn=admins,cn=kanboard,ou=services,dc=immae,dc=eu'); 37 define('LDAP_GROUP_ADMIN_DN', 'cn=admins,cn=kanboard,ou=services,dc=immae,dc=eu');
33 ?> 38 ?>
34 ''; 39 '';
40 };
35 webRoot = stdenv.mkDerivation (fetchedGithub ./kanboard.json // rec { 41 webRoot = stdenv.mkDerivation (fetchedGithub ./kanboard.json // rec {
36 dontBuild = true; 42 dontBuild = true;
37 installPhase = '' 43 installPhase = ''
38 cp -a . $out 44 cp -a . $out
39 ln -s ${config} $out/config.php 45 ln -s /run/keys/webapps/tools-kanboard $out/config.php
40 mv $out/data $out/dataold 46 mv $out/data $out/dataold
41 ln -s ${varDir}/data $out/data 47 ln -s ${varDir}/data $out/data
42 ''; 48 '';
@@ -65,7 +71,8 @@ rec {
65 ''; 71 '';
66 }; 72 };
67 phpFpm = rec { 73 phpFpm = rec {
68 basedir = builtins.concatStringsSep ":" [ webRoot varDir config ]; 74 serviceDeps = [ "postgresql.service" "openldap.service" "tools-kanboard-key.service" ];
75 basedir = builtins.concatStringsSep ":" [ webRoot varDir "/run/keys/webapps/tools-kanboard" ];
69 socket = "/var/run/phpfpm/kanboard.sock"; 76 socket = "/var/run/phpfpm/kanboard.sock";
70 pool = '' 77 pool = ''
71 listen = ${socket} 78 listen = ${socket}