diff options
Diffstat (limited to 'modules/private/websites/tools/tools/roundcubemail.nix')
-rw-r--r-- | modules/private/websites/tools/tools/roundcubemail.nix | 121 |
1 files changed, 121 insertions, 0 deletions
diff --git a/modules/private/websites/tools/tools/roundcubemail.nix b/modules/private/websites/tools/tools/roundcubemail.nix new file mode 100644 index 0000000..8974d1b --- /dev/null +++ b/modules/private/websites/tools/tools/roundcubemail.nix | |||
@@ -0,0 +1,121 @@ | |||
1 | { env, roundcubemail, roundcubemail-plugins, roundcubemail-skins, phpPackages, apacheHttpd }: | ||
2 | rec { | ||
3 | varDir = "/var/lib/roundcubemail"; | ||
4 | activationScript = { | ||
5 | deps = [ "wrappers" ]; | ||
6 | text = '' | ||
7 | install -m 0755 -o ${apache.user} -g ${apache.group} -d ${varDir} \ | ||
8 | ${varDir}/cache ${varDir}/logs | ||
9 | install -m 0750 -o ${apache.user} -g ${apache.group} -d ${varDir}/phpSessions | ||
10 | ''; | ||
11 | }; | ||
12 | keys = [{ | ||
13 | dest = "webapps/tools-roundcube"; | ||
14 | user = apache.user; | ||
15 | group = apache.group; | ||
16 | permissions = "0400"; | ||
17 | text = '' | ||
18 | <?php | ||
19 | $config['db_dsnw'] = '${env.psql_url}'; | ||
20 | $config['default_host'] = 'ssl://mail.immae.eu'; | ||
21 | $config['imap_conn_options'] = array("ssl" => array("verify_peer" => false)); | ||
22 | $config['smtp_server'] = 'tls://mail.immae.eu'; | ||
23 | $config['smtp_port'] = '25'; | ||
24 | $config['managesieve_host'] = 'mail.immae.eu'; | ||
25 | $config['managesieve_port'] = '4190'; | ||
26 | $config['managesieve_usetls'] = true; | ||
27 | $config['managesieve_conn_options'] = array("ssl" => array("verify_peer" => false)); | ||
28 | |||
29 | $config['imap_cache'] = 'db'; | ||
30 | $config['messages_cache'] = 'db'; | ||
31 | |||
32 | $config['support_url'] = '''; | ||
33 | |||
34 | $config['des_key'] = '${env.secret}'; | ||
35 | |||
36 | $config['skin'] = 'elastic'; | ||
37 | $config['plugins'] = array( | ||
38 | 'attachment_reminder', | ||
39 | 'emoticons', | ||
40 | 'filesystem_attachments', | ||
41 | 'hide_blockquote', | ||
42 | 'identicon', | ||
43 | 'identity_select', | ||
44 | 'jqueryui', | ||
45 | 'managesieve', | ||
46 | 'newmail_notifier', | ||
47 | 'vcard_attachments', | ||
48 | 'zipdownload', | ||
49 | |||
50 | 'automatic_addressbook', | ||
51 | 'message_highlight', | ||
52 | 'carddav', | ||
53 | // Ne marche pas ?: 'ident_switch', | ||
54 | // Ne marche pas ?: 'thunderbird_labels', | ||
55 | ); | ||
56 | |||
57 | $config['language'] = 'fr_FR'; | ||
58 | |||
59 | $config['drafts_mbox'] = 'Mail/Drafts'; | ||
60 | $config['junk_mbox'] = 'Mail/Spam'; | ||
61 | $config['sent_mbox'] = 'Mail/sent'; | ||
62 | $config['trash_mbox'] = '''; | ||
63 | $config['default_folders'] = array('INBOX', 'Mail/Drafts', 'Mail/sent', 'Mail/Spam', '''); | ||
64 | $config['draft_autosave'] = 60; | ||
65 | $config['enable_installer'] = false; | ||
66 | $config['log_driver'] = 'file'; | ||
67 | $config['temp_dir'] = '${varDir}/cache'; | ||
68 | $config['mime_types'] = '${apacheHttpd}/conf/mime.types'; | ||
69 | ''; | ||
70 | }]; | ||
71 | webRoot = (roundcubemail.override { roundcube_config = "/var/secrets/webapps/tools-roundcube"; }).withPlugins | ||
72 | (builtins.attrValues roundcubemail-plugins) (builtins.attrValues roundcubemail-skins); | ||
73 | apache = rec { | ||
74 | user = "wwwrun"; | ||
75 | group = "wwwrun"; | ||
76 | modules = [ "proxy_fcgi" ]; | ||
77 | webappName = "tools_roundcubemail"; | ||
78 | root = "/run/current-system/webapps/${webappName}"; | ||
79 | vhostConf = '' | ||
80 | Alias /roundcube "${root}" | ||
81 | <Directory "${root}"> | ||
82 | DirectoryIndex index.php | ||
83 | AllowOverride All | ||
84 | Options FollowSymlinks | ||
85 | Require all granted | ||
86 | |||
87 | <FilesMatch "\.php$"> | ||
88 | SetHandler "proxy:unix:${phpFpm.socket}|fcgi://localhost" | ||
89 | </FilesMatch> | ||
90 | </Directory> | ||
91 | ''; | ||
92 | }; | ||
93 | phpFpm = rec { | ||
94 | serviceDeps = [ "postgresql.service" ]; | ||
95 | basedir = builtins.concatStringsSep ":" ( | ||
96 | [ webRoot "/var/secrets/webapps/tools-roundcube" varDir ] | ||
97 | ++ webRoot.plugins | ||
98 | ++ webRoot.skins); | ||
99 | phpConfig = '' | ||
100 | date.timezone = 'CET' | ||
101 | extension=${phpPackages.imagick}/lib/php/extensions/imagick.so | ||
102 | ''; | ||
103 | socket = "/var/run/phpfpm/roundcubemail.sock"; | ||
104 | pool = '' | ||
105 | user = ${apache.user} | ||
106 | group = ${apache.group} | ||
107 | listen.owner = ${apache.user} | ||
108 | listen.group = ${apache.group} | ||
109 | pm = ondemand | ||
110 | pm.max_children = 60 | ||
111 | pm.process_idle_timeout = 60 | ||
112 | |||
113 | ; Needed to avoid clashes in browser cookies (same domain) | ||
114 | php_value[session.name] = RoundcubemailPHPSESSID | ||
115 | php_admin_value[upload_max_filesize] = 200M | ||
116 | php_admin_value[post_max_size] = 200M | ||
117 | php_admin_value[open_basedir] = "${basedir}:${apacheHttpd}/conf/mime.types:/tmp" | ||
118 | php_admin_value[session.save_path] = "${varDir}/phpSessions" | ||
119 | ''; | ||
120 | }; | ||
121 | } | ||