Featured image of post Cryptpad : le cloud zero knowledge

Cryptpad : le cloud zero knowledge

Ecrit par ~ zwindler ~

Je vous ai déjà beaucoup parlé d’un projet que j’aime beaucoup, XWiki (si vous n’êtes pas encore gavé que j’en parle tout le temps, allez jeter un œil, c’est vraiment cool ce qu’ils font). Eh bien, il y a quelques années, des membres de l’équipe se sont lancé dans un projet en parallèle nommé CryptPad.

Et plutôt que mal décrire ce que ça fait, voilà comment eux présentent leur projet :

CryptPad est une alternative respectant la vie privée aux outils office et aux services cloud populaires. Tout le contenu stocké dans CryptPad est chiffré avant d’être envoyé, ce qui signifie que personne ne peut accéder à vos données à moins que vous ne leur donniez les clés (même pas nous).

Grosso modo, l’idée est de fournir une liste d’outils en ligne, collaboratifs :

  • Traitement de texte
  • Éditeur de code (texte avec coloration syntaxique)
  • Présentation (slides)
  • Tableur
  • Sondage en ligne
  • Kanban
  • Whiteboard

C’est très similaire à ce qu’on pourrait le faire avec un Nextcloud, mais avec deux différences majeures :

  • tout est chiffré, même l’admin n’y a pas accès.
  • l’outil est prévu pour être utilisé avec inscription, mais sans inscription (et les pads “anonymes” peuvent être a posteriori rattachés à un compte)

Dans quel cas c’est intéressant

On pourrait se dire que finalement le projet est concurrent des solutions collaboratives comme Nextcloud que je cite juste avant. Cependant je pense que la cible n’est pas la même.

Dans le cas où j’héberge moi-même mes données et celle de ma famille, je n’ai pas forcément besoin que les données soient chiffrées (encore que ça se discute, surtout si je les héberge sur un serveur que je loue). Il y a un lien de confiance implicite (enfin j’espère que c’est le cas pour vous). Et je n’ai pas non plus besoin de pads anonymes. Je suis logué en permanence sur ma plateforme.

En revanche, dans le cas où j’utilise/loue un service d’outils collaboratifs administré par quelqu’un d’autre (tout le monde n’a pas envie d’héberger soit-même ses services, comme moi), le stockage chiffré non accessible de l’admin prend tout son sens. Que ce soit pour un usage pro ou un usage perso d’ailleurs, je ne le connais pas forcément, j’ai donc du mal à faire confiance.

Pour un hébergement de ce genre de services reposant sur le respect de la vie privée, on peut se diriger vers les CHATONS.

En théorie, la charte des CHATONS impose aux fournisseurs de contenus de respecter les libertés des utilisateurs et notamment de ne pas exploiter leurs données. Mais je serai quand même vachement plus rassuré en sachant que même l’admin du CHATONS n’a pas accès à mes données, car moi seul en détient la clé.

Je pense donc que CryptPad est un super outil pour les gens qui veulent fournir un service de type cloud éthique (comme les CHATONS) tout en garantissant un certaine confiance sur la sûreté des données stockée sur le cloud en question.

Assez bavassé

Vous êtes convaincu ? Vous voulez jeter un œil ?

Si vous voulez faire un test de l’outil, sachez qu’il existe une instance officielle portée par le projet lui-même. L’inscription est ouverte à tous et vous obtiendrez un Cryptpad disposant de toutes les fonctionnalités, limité à un stockage de 50 Mo (1 Go pendant la période COVID, en geste de soutien à tous ceux qui ont dû trouver des solutions alternatives et vertueuses pendant le confinement). Ça se passe sur cryptpad.fr.

Et si je veux l’installer ?

Vous vous doutez bien que je n’allais pas faire un article sur Cryptpad sans vous donner la procédure d’installation du biniou ;)

Pour cette procédure, je me suis basé sur la documentation officielle, disponible ici, et que j’ai adapté à mon cas (à savoir une VM avec Ubuntu 18.04).

On commence bien évidemment par mettre à jour le système… Et on installe quelques prérequis.

sudo apt update
sudo apt upgrade
sudo apt install git curl

Configuration préalable

Pour éviter de donner les droits root à CryptPad, j’ai créé un utilisateur cryptpad` (hyper original).

sudo useradd -m -d /opt/cryptpad -s /bin/bash cryptpad

Du coup, si vous n’avez pas les droits root, ça marchera quand même (avec l’utilisateur non-root que vous avez).

Cryptpad repose sur un serveur NodeJS. Sauf que la version par défaut disponible sur les répos Ubuntu est antédiluvienne. C’est pour cette raison que la documentation officielle conseille d’utiliser NVM pour installer une version à jour de NodeJS.

Pour ceux qui comme moi, n’y connaissent rien à NodeJS, voilà la doc pour installer nvm.

curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.35.3/install.sh | bash

Bon… faire confiance à un curl | bash trouvé sur Internet… ça craint du boudin en termes de sécu, il faudra que je regarde comment faire plus propre :/.

Une fois installé, vous pouvez tester la commande nvm` de la façon suivante, et elle doit renvoyer “nvm” :

export NVM_DIR="$HOME/.nvm"
[ -s "$NVM_DIR/nvm.sh" ] && \. "$NVM_DIR/nvm.sh"  # This loads nvm
[ -s "$NVM_DIR/bash_completion" ] && \. "$NVM_DIR/bash_completion"  # This loads nvm bash_completion

command -v nvm
#renvoie "nvm" si tout fonctionne correctement

Installation

OK. Maintenant on a tous nos prérequis, on peut récupérer les sources de Cryptpad, et commencer à installer le tout.

git clone https://github.com/xwiki-labs/cryptpad.git cryptpad && cd cryptpad
nvm install node
npm install -g bower
npm install 
bower install

A partir de là, on a un NodeJS à jour dans le dossier de nos sources, avec les dépendances (npm install).

Configuration

Les gens de Cryptpad ont été assez sympa pour fournir des exemples de fichiers de configuration si votre Cryptpad n’est pas directement accessible sur Internet (c’est probablement mieux ;-p). Par exemple, voilà celui pour nginx.

In a production instance this should be available ONLY over HTTPS using the default port for HTTPS (443) ie. https://cryptpad.fr. In such a case this should be handled by NGINX, as documented in cryptpad/docs/example.nginx.conf (see the $main_domain variable)

Dans mon cas, j’ai justement un nginx qui me sert de reverse proxy et qui est sur une autre machine. Si comme moi, votre reverse proxy n’est pas sur la même machine, vous voudrez probablement changer l’adresse d’écoute (par défaut localhost uniquement) dans la configuration de Cryptpad. Vous trouverez plus de détails là dessus sur cette page de la documentation.

Une fois votre reverse configuré, vous pouvez maintenat vous attaquer à la configuration de Cryptpad. Ici c’est relativement trivial, ça marche en changeant assez peu de valeurs.

cd config
cp config.example.js config.js
vi config.js
[...]
  httpSafeOrigin: "https://cryptpad.domain.tld", //décommenter la ligne httpSafeOrigin et mettre l URL finale
  httpAddress: '192.168.1.100',//décommenter et changer la httpAddress si votre reverse proxy n est pas sur la même machine
  adminEmail: 'admin@domain.tld', //changer l email de l admin

Démarrer Cryptpad

Je suis presque triste, c’est DÉJÀ fini. C’est pour ça que pour une fois, je n’ai pas pris le temps de créer un playbook Ansible => c’est beaucoup trop simple, ahaha ;-).

[Edit]Heureusement que je n’ai pas fais de playbook, il y en a déjà un ici, c’est écrit en gros dans la doc officielle de Cryptpad ;)

On démarre le serveur simplement avec un node server` dans le dossier des sources.

cd ..
node server &

Une fois le serveur démarré pour la première fois, il faudra s’y connecter, créer un compte, puis mettre à jour la configuration avec le paramètre adminKeys dans config.js`

vi config.js
[...]
adminKeys: [
        //"https://my.domain.tld/user/#/1/cryptpad-user1/YZgXQxKR0Rcb6r6CmxHPdAGLVludrAF2lEnkbx1vVOo=",
    ],

Une fois fait, redémarrer une dernière fois nodejs.

And voilà

Un exemple de service, ici la mire pour la création d’un tableau blanc

Démarrage automatique

Si vous avez un accès root à la machine qui héberge Cryptpad, vous allez sûrement vouloir créer un service pour démarrer/arrêter facilement (et automatiquement) votre Cryptpad.

Pour ce faire, on commence par récupérer le path de node qui va bien (càd, celle installée par nvm)

cryptpad@crypt:~$ which node
/opt/cryptpad/.nvm/versions/node/v13.11.0/bin/node

Et on crée le petit fichier systemd` qui va bien (n’oubliez pas de mettre le bon path dans NODEPATH):

# NODEPATH=/opt/cryptpad/.nvm/versions/node/v13.11.0/bin/node
# cat > /etc/systemd/system/cryptpad.service << EOF
[Unit]
Description=CryptPad

[Service]
ExecStart=$NODEPATH server
WorkingDirectory=/opt/cryptpad/cryptpad
Restart=always
RestartSec=10
# Output to syslog
StandardOutput=syslog
StandardError=syslog
SyslogIdentifier=cryptpad
User=cryptpad
Group=cryptpad
Environment=NODE_ENV=production

[Install]
WantedBy=multi-user.target
EOF

# systemctl start cryptpad
# systemctl status cryptpad.service
* cryptpad.service - CryptPad
   Loaded: loaded (/etc/systemd/system/cryptpad.service; disabled; vendor preset: enabled)
   Active: active (running) since Thu 2020-06-25 13:08:29 UTC; 2s ago
 Main PID: 1248 (node)
    Tasks: 11 (limit: 4915)
   CGroup: /system.slice/cryptpad.service
           `-1248 /opt/cryptpad/.nvm/versions/node/v13.11.0/bin/node server

Jun 25 13:08:29 crypt systemd[1]: Started CryptPad.
Jun 25 13:08:30 crypt cryptpad[1248]: FRESH MODE ENABLED
Jun 25 13:08:30 crypt cryptpad[1248]: Cryptpad is customizable, see customize.dist/readme.md for details
Jun 25 13:08:30 crypt cryptpad[1248]: [2020-06-25T13:08:30.826Z] server available http://192.168.10.209:3000

# systemctl enable cryptpad
Created symlink /etc/systemd/system/multi-user.target.wants/cryptpad.service -> /etc/systemd/system/cryptpad.service.

Administrer le serveur

Une fois le service systemd` configuré, vous aurez donc une instance fonctionnelle. Dans l’hypothèse où vous auriez besoin de débuguer un problème, les logs sont collectés par syslog, et donc visibles dans /var/log/syslog dans Ubuntu.

Jun 25 13:08:30 crypt cryptpad[1248]: FRESH MODE ENABLED
Jun 25 13:08:30 crypt cryptpad[1248]: Cryptpad is customizable, see customize.dist/readme.md for details
Jun 25 13:08:30 crypt cryptpad[1248]: [2020-06-25T13:08:30.826Z] server available http://192.168.10.209:3000

Et en cas de maintenance (backup, restauration, migration), sachez que le stockage persistant est contenu par défaut dans le sous dossier datastore de votre installation de cryptpad.

Vous pouvez changer cette valeur, présente dans votre config/config.js (filePath pour le datastore, archivePath pour les archives temporaires après suppression)

filePath: './datastore/',
    /*  CryptPad offers the ability to archive data for a configurable period before deleting it, allowing a means of recovering data in the event that it was deleted accidentally. µ/
    archivePath: './data/archive',

Le mot de la fin

Si le projet vous intéresse, je vous encourage à aller voir le site officiel de CryptPad et à tester sans compte ou en créant un compte gratuit.

Si vous pouvez les soutenir, n’hésitez pas à faire souscrire à une offre premium chez eux, ou à faire un don au projet si vous installé votre propre instance.

Licensed under CC BY-SA 4.0
Dernière mise à jour le 29 Jun 2020 06:35 CEST

Vous aimez ce blog ou cet article ? Partagez-le avec vos amis !   Twitter Linkedin email Facebook

Vous pouvez également vous abonner à la mailing list des articles ici

L'intégralité du contenu appartenant à Denis Germain (alias zwindler) présent sur ce blog, incluant les textes, le code, les images, les schémas et les supports de talks de conf, sont distribués sous la licence CC BY-SA 4.0.

Les autres contenus (thème du blog, police de caractères, logos d'entreprises, articles invités...) restent soumis à leur propre licence ou à défaut, au droit d'auteur. Plus d'informations dans les Mentions Légales

Généré avec Hugo
Thème Stack conçu par Jimmy