wiki/HowtoMail/Roundcube.md

150 lines
4.4 KiB
Markdown
Raw Normal View History

2016-12-29 11:25:39 +01:00
# Howto Roundcube
2020-02-12 17:55:10 +01:00
Sous licence libre GPL, roundcube est un client de messagerie utilisant l'IMAP.
D'autres alternatives existent tel que rainloop, SOGo, Squirrelmail,...
## Installation
Rien de plus simple :
~~~
# apt install roundcube
~~~
Le fichier de configuration principale est `/etc/roundcube/defaults.inc.php`
2016-12-29 11:25:39 +01:00
## Plugin sieve
2020-02-12 17:55:10 +01:00
Celui-ci permet l'usage des filtres.
~~~
# apt install roundcube-plugins-extra
~~~
On pourra l'activer ainsi :
2016-12-29 11:25:39 +01:00
~~~
2020-02-12 17:55:10 +01:00
$config['plugins'] = array('sieverules');
2016-12-29 11:25:39 +01:00
~~~
2020-11-30 15:14:17 +01:00
La configuration des règles se feront dans `/etc/roundcube/plugins/sieverules/config.inc.php`.
2016-12-29 11:25:39 +01:00
## Plugin vacation
2020-02-12 17:55:10 +01:00
Il est utilisé lorsque l'utilisateur du compte mail est en vacances par exemple.
<https://github.com/gabor-toth/roundcube-vacation-plugin>
2020-11-30 15:14:17 +01:00
On utilise généralement ce plugin avec le driver FTP lorsque l'on est dans un setup avec les utilisateurs en compte Unix.
Il faut donc préalablement avoir installé Proftpd, avec le module ldap `proftpd-mod-ldap` et bien charger le module dans la configuration de proftpd.
Au niveau de proftpd on utilise la configuration ldap suivante, dans `/etc/proftpd/ldap.conf` :
~~~
<IfModule mod_ldap.c>
LDAPServer ldap://localhost/??sub
LDAPBindDN "cn=admin,dc=example,dc=com" "PASSWORD"
LDAPUsers "ou=people,dc=smsmode,dc=com" (uid=%u) (uidNumber=%u)
LDAPAuthBinds on
</IfModule>
~~~
Au niveau de la configuration du plugin vacation, on utilise la configuration suivante dans `/etc/roundcube/plugins/vacation/config.ini` :
~~~
[default]
driver = "ftp"
;server = "localhost"
subject = "Absence / Out of office"
body = "default.txt"
;disable_forward = true
[dotforward]
binary = "/usr/bin/vacation"
flags = ""
message = ".vacation.msg"
database = ".vacation.db"
alias_identities = true
set_envelop_sender = false
always_keep_message = true
~~~
Il ne faut pas oublier également d'installer le paquet *vacation*.
2016-12-29 11:25:39 +01:00
## Plugin password
2020-02-12 17:55:10 +01:00
Son utilisé résulte sur la possibilité de changer son propre mot de passe avec de nombreux connecteurs tel que dovecot, LDAP, etc.
On pourra l'activer ainsi :
~~~
2021-09-21 10:33:41 +02:00
$config['plugins'] = array('password');
2020-02-12 17:55:10 +01:00
~~~
2021-09-21 10:33:41 +02:00
Pour les comptes mails stockés dans LDAP il faudra installer `php7.3-ldap` et mettre en place le fichier `/etc/roundcube/plugins/password/config.inc.php` suivant :
2016-12-29 11:25:39 +01:00
~~~
<?php
2021-09-21 10:33:41 +02:00
$config=array();
$config['password_driver'] = 'ldap_simple';
$config['password_confirm_current'] = true;
$config['password_ldap_host'] = '127.0.0.1';
$config['password_ldap_userDN_mask'] = 'uid=%login,ou=people,dc=example,dc=com';
$config['password_ldap_encodage'] = 'ssha';
2016-12-29 11:25:39 +01:00
?>
~~~
2020-02-12 17:55:10 +01:00
## Mailbox doesnt exist
2016-12-29 11:25:39 +01:00
2020-02-12 17:55:10 +01:00
Si nous avons par exemple l'erreur suivante : "UID MOVE : Mailbox doesnt exist : Trash"
On devra activer cette option :
2016-12-29 11:25:39 +01:00
~~~
2020-02-12 17:55:10 +01:00
$config['create_default_folders'] = true;
2016-12-29 11:25:39 +01:00
~~~
2020-02-12 17:55:10 +01:00
## Mode debug
Activer la directive suivante :
~~~
$config['imap_debug'] = true;
2016-12-29 11:25:39 +01:00
~~~
2020-02-12 17:55:10 +01:00
2022-01-11 16:27:54 +01:00
Les messages d'erreurs seront dans le log /var/log/syslog
## Import de contacts en CSV
<https://www.pokorra.de/2017/01/import-contacts-via-csv-into-roundcube/>
2022-01-11 16:27:54 +01:00
## FAQ
### Problème denvoi de pièce jointe
2022-01-11 16:27:54 +01:00
Il n'y a aucune erreur affichée dans l'interface web de Rouncube, mais les pièces jointes ne sont plus envoyées.
2022-01-11 16:27:54 +01:00
Il y a des erreurs de ce genre dans les logs de Roundcube `/var/log/roundcube/errors` lorsquon essaye denvoyer une pièce jointe dans un e-mail :
```
[01-Jan-2020 00:00:00 +0200]: <abcd1234> PHP Error: compte@domaine.com can't read /tmp/rcmAttmntQ2clsS (not in temp_dir) in /usr/share/roundcube/plugins/filesystem_attachments/filesystem_attachments.php on line 216 (POST /?_task=mail&_unlock=loading1599225495530&_lang=undefined&_framed=1&_action=send)
```
2022-01-11 16:27:54 +01:00
Cela est causé par les versions de Roundcube sur Debian 9 (Stretch) et 10 (Bullseye). Lorsque les mises-à-jour sont gérées via apt, la mise-à-jour écrase les permissions de `/var/lib/roundcube/temp/`, ce qui a pour effet de bord de ne plus pouvoir envoyer de pièces-jointes pour les vhosts qui utilisent un AssignUserID dédié.
Le bug est corrigé dans la version 1.4.3+dfsg.1-1 du paquet roundcube (<https://bugs.debian.org/cgi-bin/bugreport.cgi?bug=951194#26>), disponible à partir de Debian 11 (Bullseye).
Sur Debian 10 (Buster), il est possible d'utiliser un backport du paquet.
Pour les version plus anciennes, il est préférable de les mettre à niveau vers Debian 10 ou 11.
Pour solutionner temporairement le problème :
```
# chown www-roundcube:roundcube /var/lib/roundcube/temp
2022-01-11 16:27:54 +01:00
```