Commentaires statiques avec Jekyll
09 Jan 2017Pour ce blog, j’ai abandonné Wordpress pour Jekyll, un moteur de blog statique.
Ainsi, j’écris mes articles en markdown dans mon éditeur favori, je les commite dans un dépôt git, et je génère le blog avec :
jekyll build
Le contenu hébergé étant statique, les pages ainsi générées à partir des sources sont renvoyées telles quelles.
Ce fonctionnement a beaucoup d’avantages :
- le temps de réponse est minimal ;
- la sécurité est largement accrue ;
- la maintenance est simplifiée (pas de mises à jour de sécurité régulières) ;
- le backup est trivial (
git clone
, pas de base de données).
Sans commentaires
L’inconvénient, c’est qu’un contenu statique est difficilement conciliable avec le support des commentaires (il faut bien d’une manière ou d’une autre exécuter du code lors de la réception d’un commentaire).
Il y a plusieurs manières de contourner le problème.
Il est par exemple possible d’en déporter la gestion (sur un service en ligne comme Disqus ou un équivalent libre – isso – à héberger soi-même). Ainsi, les commentaires peuvent être chargés séparément par le client en Javascript.
Au lieu de cela, j’ai choisi d’intégrer les commentaires aux sources du blog. Voici comment.
L’objectif est d’une part de pouvoir stocker et afficher les commentaires existants, et d’autre part de fournir aux lecteurs la possibilité d’en soumettre de nouveaux, qui me seront envoyés par e-mail.
Je me suis principalement inspiré du contenu de Jekyll::StaticComments, même si, comme nous allons le voir, je n’utilise pas le plug-in lui-même.
Stockage
L’idée est de stocker les commentaires quelque part dans les sources du site au format YAML.
Le plugin Jekyll::StaticComments nécessite de stocker un fichier par
commentaire dans un dossier spécial (_comments
) parsé par un
script à insérer dans le répertoire _plugins
.
Personnellement, je préfère avoir tous les commentaires d’un même post regroupés
au sein d’un même fichier. Et pour cela, pas besoin de plug-in : nous pouvons
faire correspondre à chaque post dans _posts
une liste de
commentaires dans _data
(un répertoire géré nativement par Jekyll).
Par exemple, ce billet est stocké dans :
_posts/2017-01-09-commentaires-statiques-avec-jekyll.md
Dans l’idéal, je voudrais que les commentaires associés soient stockés dans :
_data/comments-2017-01-09-commentaires-statiques-avec-jekyll.yaml
En pratique, pour des raisons techniques (Jekyll ne donne pas accès au nom du fichier), le nom du fichier ne contient pas le numéro du jour :
_data/comments-2017-01-commentaires-statiques-avec-jekyll.yaml
Il suffit alors de stocker dans ces fichiers les commentaires sous cette forme :
Pour des exemples réels, voir les sources des commentaires de ce blog.
Affichage
Maintenant que nous avons les données des commentaires, nous devons les afficher.
Il faut d’abord trouver la liste des commentaires associée à la page courante.
Comme nous ne pouvons pas récupérer directement le nom du fichier d’une page,
nous devons reconstruire la chaîne à partir de la variable page.id
, qui
ici vaut :
/2017/01/commentaires-statiques-avec-jekyll
Cette ligne de Liquid :
donne la valeur :
comments-2017-01-commentaires-statiques-avec-jekyll
Nous avons donc tout ce dont nous avons besoin pour créer le template de
commentaires (à stocker dans _include/comments.html
) :
Il suffit alors d’inclure cette page à l’endroit où vous souhaitez insérer les
commentaires (typiquement dans _layout/post.html
) :
Formulaire
Pour proposer aux utilisateurs de poster de nouveaux commentaires, il nous faut un formulaire.
À titre d’exemple, voici le mien (intégré à
_include/comments.html
) :
Ce formulaire est affiché sous les commentaires existants.
Traitement
L’action
du formulaire précédent pointait sur
comments/submit.php
. Il nous reste donc à écrire dans ce fichier
le code à exécuter lorsqu’un utilisateur envoie un commentaire au serveur.
Ce sera la seule partie “dynamique” du site.
Voici les parties importantes de comments/submit.php
(basé sur
la version de Jekyll::StaticComments) :
Quand un commentaire est envoyé avec succès, la page
comments/sent.html
est affichée à l’utilisateur.
Ainsi, lorsqu’un commentaire est posté, je reçois un mail :
post_id: /2017/01/commentaires-statiques-avec-jekyll
email: my@email
---
- id: ?
author: ®om
author-url: http://blog.rom1v.com
date: 2017-01-09 19:27:10+01:00
contents: |
Ceci est un test.
J’ai d’ailleurs ajouté une règle procmail pour que ces mails arrivent dans un dossier dédié.
Je peux alors copier le contenu dans le .yaml
correspondant, formatter le
commentaire (entre autres l’indenter de 4 espaces, ce qu’on pourrait
automatiser), et le commiter.
Résumé
Une fois mis en place, vous devriez donc avoir les fichiers suivants :
_data/comments-*.yaml
_include/comments.html
comments/submit.php
comments/sent.html
Conclusion
Je souhaitais depuis longtemps migrer vers un moteur de blog statique, qui correspond davantage à ma façon d’écrire des articles, et offre beaucoup d’avantages (légèreté, sécurité, maintenance…).
Je suis très content d’y être parvenu sans perdre les commentaires ni la possibilité d’en poster de nouveaux.
Certes, la validation est très manuelle, mais c’est le prix à payer pour avoir des commentaires statiques. Pour un blog avec une fréquence de commentaires assez faible, je pense que ce n’est pas très gênant.
Salut,
Je découvre ton blog et ta solution pour les commentaires m’intéresse vraiment. Malheureusement je n’utilise pas Jekyll mais Hugo alors je vais essayer de bidouiller un peu ça pour qu’il marche sur mon blog.
En tout cas bravo car c’est d’une simplicité remarquable.