wiki/HowtoVdirsyncer.md

117 lines
3 KiB
Markdown
Raw Normal View History

---
2022-07-29 16:01:25 +02:00
categories: sysadmin Zimbra zimbra Nextcloud nextcloud sync synchro synchronisation vdirsyncer
title: Howto Vdirsyncer
...
* Documentation: <https://vdirsyncer.pimutils.org/en/stable/>
2022-07-29 16:01:25 +02:00
Vdirsyncer est un outils de synchronisation de calendriers et de carnets d'adresses avec une gestion de droits et de priorités en cas de conflits.
2022-07-25 16:48:13 +02:00
## Installation
2022-07-29 16:01:25 +02:00
Installer les paquets sur votre poste :
~~~
2022-07-25 16:48:13 +02:00
# apt install vdirsyncer libpam-systemd
~~~
2022-07-29 16:01:25 +02:00
Avec votre compte Unix, créer le répertoire de configuration de Vdirsyncer :
~~~
2022-07-25 16:48:13 +02:00
$ mkdir -vp ~/.config/vdirsyncer/
~~~
## Configuration
2022-07-29 16:01:25 +02:00
Pour synchroniser un calendrier et un carnet d'adresse d'un serveur Zimbra vers un serveur Nextcloud, il faut spécifier dans la configuration les identifiants et les noms des calendriers et carnets d'adresses des deux instances.
2022-07-29 16:01:25 +02:00
Renseigner les variables shell suivantes :
~~~
2022-07-19 18:02:53 +02:00
ZIMBRA_URL=
ZIMBRA_USER=
ZIMBRA_MDP=
ZIMBRA_NOM_CALENDRIER=Calendar
ZIMBRA_NOM_CONTACT=Contacts
NEXTCLOUD_URL=
NEXTCLOUD_USER=
NEXTCLOUD_MDP=
NEXTCLOUD_NOM_CALENDRIER=personal
NEXTCLOUD_NOM_CONTACT=Contacts
~~~
2022-07-29 16:01:25 +02:00
Puis, créer le fichier de configuration :
2022-07-19 18:02:53 +02:00
~~~
2022-07-25 16:48:13 +02:00
$ cat > ~/.config/vdirsyncer/config <<EOF
[general]
# Emplacement où se trouve la base des métadonnées
status_path = "~/.local/state/vdirsyncer/status/"
#### Calendar
[pair pull2push_calendar]
a = "remote_zimbra"
b = "remote_nextcloud"
2022-07-25 16:48:13 +02:00
conflict_resolution = "a wins"
collections = null
[storage remote_zimbra]
type = "caldav"
# On précise le calendrier :
2022-07-19 18:02:53 +02:00
url = "https://$ZIMBRA_URL/dav/$ZIMBRA_USER/$ZIMBRA_NOM_CALENDRIER"
username = "$ZIMBRA_USER"
password = "$ZIMBRA_MDP"
# Pas d'écriture sur cette instance :
read_only = true
[storage remote_nextcloud]
type = "caldav"
# On précise le calendrier :
2022-07-19 18:02:53 +02:00
url = "https://$NEXTCLOUD_URL/remote.php/dav/calendars/$NEXTCLOUD_USER/$NEXTCLOUD_NOM_CALENDRIER/"
username = "$NEXTCLOUD_USER"
password = "$NEXTCLOUD_MDP"
#### Contacts
[pair pull2push_contacts]
a = "remote_zimbra_contacts"
b = "remote_nextcloud_contacts"
2022-07-25 16:48:13 +02:00
conflict_resolution = "a wins"
collections = null
[storage remote_zimbra_contacts]
type = "carddav"
# On précise le nom du carnet
2022-07-19 18:02:53 +02:00
url = "https://$ZIMBRA_URL/dav/$ZIMBRA_USER/$ZIMBRA_NOM_CONTACT/"
username = "$ZIMBRA_USER"
password = "$ZIMBRA_MDP"
# Pas d'écriture sur cette instance :
read_only = true
[storage remote_nextcloud_contacts]
type = "carddav"
# On précise le nom du carnet
2022-07-19 18:02:53 +02:00
url = "https://$NEXTCLOUD_URL/remote.php/dav/addressbooks/users/$NEXTCLOUD_USER/$NEXTCLOUD_NOM_CONTACT/"
username = "$NEXTCLOUD_USER"
password = "$NEXTCLOUD_MDP"
EOF
~~~
2022-07-29 16:01:25 +02:00
Ensuite, vérifier la syntaxe de la configuration avec la commande suivante (il faut lancer à chaque modification) :
~~~
vdirsyncer discover
~~~
2022-07-29 16:01:25 +02:00
Lancer le timer systemd fournit par la paquet `vdirsyncer` avec un compte [utilisateur](https://wiki.evolix.org/HowtoSystemd#systemd-par-utilisateur) :
~~~
2022-07-25 16:48:13 +02:00
# loginctl enable-linger foo
# su - foo
$ systemctl --user enable vdirsyncer.timer
~~~
2022-07-29 16:01:25 +02:00
Ainsi, la commande `vdirsyncer sync` sera lancée toutes les 15 minutes.