blob: 1aa2d877eca702481767d10cfdbf0a63f247f135 (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
|
{ lib, checkEnv, writeText, stdenv, fetchurl }:
let
roundcubemail = let
plugins = {};
in rec {
varDir = "/var/lib/roundcubemail";
# FIXME: initial sync
activationScript = {
deps = [ "wrappers" ];
text = ''
install -m 0755 -o ${apache.user} -g ${apache.group} -d ${varDir} \
${varDir}/cache
install -m 0750 -o ${apache.user} -g ${apache.group} -d ${varDir}/phpSessions
'';
};
config =
# FIXME: LOG_DESTINATION syslog?
assert checkEnv "NIXOPS_ROUNDCUBEMAIL_PSQL_URL";
assert checkEnv "NIXOPS_ROUNDCUBEMAIL_SECRET";
writeText "config.php" ''
<?php
$config['db_dsnw'] = '${builtins.getEnv "NIXOPS_ROUNDCUBEMAIL_PSQL_URL"}';
$config['default_host'] = 'ssl://mail.immae.eu';
$config['imap_conn_options'] = array("ssl" => array("verify_peer" => false));
$config['smtp_server'] = 'tls://mail.immae.eu';
$config['imap_cache'] = 'db';
$config['messages_cache'] = 'db';
$config['support_url'] = ''';
$config['des_key'] = '${builtins.getEnv "NIXOPS_ROUNDCUBEMAIL_SECRET"}';
$config['plugins'] = array();
$config['language'] = 'fr_FR';
$config['drafts_mbox'] = 'Mail/Drafts';
$config['junk_mbox'] = 'Mail/Spam';
$config['sent_mbox'] = 'Mail/sent';
$config['trash_mbox'] = ''';
$config['default_folders'] = array('INBOX', 'Mail/Drafts', 'Mail/sent', 'Mail/Spam', ''');
$config['draft_autosave'] = 60;
$config['enable_installer'] = false;
$config['log_driver'] = 'stdout';
$config['temp_dir'] = '${varDir}/cache';
$config['debug_level'] = 1;
'';
webRoot = stdenv.mkDerivation rec {
version = "1.3.8";
name = "roundcubemail-${version}";
src= fetchurl {
url = "https://github.com/roundcube/roundcubemail/releases/download/${version}/${name}-complete.tar.gz";
sha256 = "018djad7ygfl9c9f2l2j42qkg31ml3hs2f01f0dk361zckwk77n4";
};
buildPhase = ''
sed -i \
-e "s|RCUBE_INSTALL_PATH . 'temp.*|'${varDir}/cache';|" \
config/defaults.inc.php
'';
installPhase = ''
cp -a . $out
ln -s ${config} $out/config/config.inc.php
${builtins.concatStringsSep "\n" (
lib.attrsets.mapAttrsToList (name: value: "ln -sf ${value} $out/plugins/${name}") plugins
)}
'';
};
apache = {
user = "wwwrun";
group = "wwwrun";
modules = [ "proxy_fcgi" ];
vhostConf = ''
Alias /roundcube "${webRoot}"
<Directory "${webRoot}">
DirectoryIndex index.php
AllowOverride All
Options FollowSymlinks
Require all granted
<FilesMatch "\.php$">
SetHandler "proxy:unix:${phpFpm.socket}|fcgi://localhost"
</FilesMatch>
</Directory>
'';
};
phpFpm = rec {
basedir = builtins.concatStringsSep ":" (
[ webRoot config varDir ]
++ lib.attrsets.mapAttrsToList (name: value: value) plugins);
socket = "/var/run/phpfpm/roundcubemail.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] = RoundcubemailPHPSESSID
php_admin_value[open_basedir] = "${basedir}:/tmp"
php_admin_value[session.save_path] = "${varDir}/phpSessions"
'';
};
};
in
roundcubemail
|