💾 Archived View for lord.re › posts › 181-deploiement-hugo › index.gmi captured on 2022-06-03 at 23:04:16. Gemini links have been rewritten to link to archived content
➡️ Next capture (2024-08-18)
-=-=-=-=-=-=-
-------------------------------------------------
[18/09/2019] - ~4mins - #hugo #git #adminsys
-------------------------------------------------
Je génère mon blog avec le logiciel *Hugo* directement sur mon ordi.
Un site ouaib c'est au final qu'un ensemble de fichiers textes et des images en plus.
Ça fait maintenant deux ans que j'utilise Hugo.
J'ai désormais dépassé
ref "/posts/57-hugo-www" >}} la phase de découverte
et je suis passé à une utilisation un peu plus avancée.
J'ai un peu changé ma façon de l'utiliser.
Du coup à chaque fois que je rédige un nouvel article voilà ce qu'il y a à faire :
1. Création de l'article : <kbd>hugo new posts/super-article/index.md</kbd>
2. Édition du fichier : <kbd>kak content/posts/super-article/index.md</kbd>
3. Ajout des Ă©ventuelles illustrations : <kbd>cp /une/image.jpg ~/www/content/posts/super-article/</kbd>
4. Ajout des fichiers dans git : <kbd>git add content/posts/super-article</kbd>
5. Commit dans git : <kbd>git commit -m "[POST] publication : super-article"</kbd>
6. Pousser les modifs sur le dépot git : <kbd>git push</kbd>
7. Générer les <abbr title="Un script shell qui trouve les jpg et png, les recompresse et génère une version plus petite">miniatures</abbr> : <kbd>thumbnailer.sh ~/www/content</kbd>
8. Générer le <abbr title="Les extraits vers des blogs extérieurs que l'on voit à droite">blogroll</abbr> : <kbd>openring/openring.sh</kbd>
9. Génération du site en lui-même : <kbd>hugo</kbd>
10. Compression des fichiers textes en gzip : <kbd>static-compress -c zopfli -e gz …</kbd>
11. Compression des fichiers textes en brotli : <kbd>static-compress -c zopfli -e br …</kbd>
12. Transfert du site fr vers le serveur web : <kbd>rsync -av ~/www/public/fr/ user@serveur:/destination/fr</kbd>
13. Transfert du site en vers le serveur web : <kbd>rsync -av ~/www/public/en/ user@serveur:/destination/en</kbd>
Bon c'est des ptits trucs simples mais en gros les étapes 6 à 13 sont toujours les mêmes avec aucune intervention nécessaire.
Du coup j'ai automatisé tout ça.
Dans *git, on peut lancer des scripts automatiquement lors de certaines actions, on appelle ça un hook*.
Du coup, dans le hook qui s'exécute lors d'un push j'ai mis toutes les actions de 7 à 13.
Comme ça, lors du <kbd>git push</kbd> elles sont toutes lancées, je n'ai plus rien à faire.
Ça évite d'en oublier une, de se planter sur la syntaxe ou autre connerie du genre.
Pour faire ça, il suffit d'éditer le fichier .git/hooks/pre-push (qui se trouve à la racine de votre repo) et d'y mettre tout ce que vous souhaitez et c'est tout bon.
Tout d'abord le hook qui lance un peu tout.
<details><summary>.git/hooks/pre-push</summary>
{{< highlight "shell" >}}
/usr/local/bin/thumbnailer.sh /home/lord/www/content
/home/lord/www/openring/openring.sh
/usr/bin/hugo
static-compress -c zopfli -e gz -j 16 "/home/lord/www/public/*/.svg" "/home/lord/www/public/*/.html" "/home/lord/www/public/*/.csv" "/home/lord/www/public/*/.css" "/home/lord/www/public/*/.txt" "/home/lord/www/public/*/.xml"
static-compress -c brotli -e br -j 16 "/home/lord/www/public/*/.svg" "/home/lord/www/public/*/.html" "/home/lord/www/public/*/.csv" "/home/lord/www/public/*/.css" "/home/lord/www/public/*/.txt" "/home/lord/www/public/*/.xml"
rsync -av /home/lord/www/public/fr/ www@n2:/var/www/lord.re/.
rsync -av /home/lord/www/public/en/ www@n2:/var/www/lord.re/en/
{{< / highlight >}}
</details>
Ensuite le script de génération des miniatures qui me sert aussi globalement et pas uniquement pour le blog.
<details><summary>/usr/local/bin/thumbnailer.sh</summary>
{{< highlight "shell" >}}
check_replace(){
size_orig=$(stat -c %s $1)
size_thumb=$(stat -c %s $2)
if [ "$size_orig" -lt "$size_thumb" ]; then
rm "$2"
cp "$1" "$2"
fi
}
thumbnail(){
echo -en "Processing image \e[0;34m$1\e[0m :"
extension="$(echo $1 | awk -F\. '{print $NF}')"
thumbname="$(dirname $1)/$(basename -s .$extension $1).thumb.$extension"
if [[ $1 == ".thumb." ]]; then
echo -e " \e[0;31m est un thumb !\e[0m"
return 0
fi
if [ -f "$(dirname $1)/$(basename -s .$extension $1).thumb.$extension" ]; then
echo -e " \e[0;31ma déjà un thumb !\e[0m"
return 0
fi
case "$extension" in
jpg | jpeg | JPG | JPEG )
/usr/bin/convert -resize 1224\> -quality 55 "$1" "$thumbname"
jpegoptim -s "$1"
check_replace "$1" "$thumbname"
;;
png | PNG)
pngcrush -warn "$1" "$1.tmp"
mv -f "$1.tmp" "$1"
/usr/bin/convert -resize 1224\> "$1" "$thumbname"
pngcrush -warn "$thumbname" "$thumbname.tmp"
mv -f "$thumbname.tmp" "$thumbname"
check_replace "$1" "$thumbname"
;;
esac
echo -e "\e[0;32mOK\e[0;m"
}
export -f thumbnail
export -f check_replace
find $1 -name '.jpg' -or -name '.jpeg' -or -name '.JPG' -or -name '.JPEG' -or -name '.png' -or -name '.PNG' | parallel --jobs 16 thumbnail
{{< / highlight >}}
</details>
Et enfin le script de génération du blogroll.
<details><summary>openring/openring.sh</summary>
{{< highlight "bash" >}}
feeds=( 'https:// … feed.xml' 'https:// … index.xml' )
rand_feeds=( $(shuf -e "${feeds[@]}") )
choose_feeds(){
for index in 0 1 2 3 4 5
do
selected_feeds="-s ${rand_feeds[$index]} $selected_feeds"
done
}
choose_feeds
echo $selected_feeds
/home/lord/www/openring/openring -n 6 \
$selected_feeds \
< /home/lord/www/openring/in.html \
/home/lord/www/layouts/partials/openring.html
{{< / highlight >}}
</details>
Donc maintenant, je me farcis les 5 premières étapes manuellement.
Quand je lance la sixième manuellement, les dernières se déroulent toutes seules.
Me reste plus qu'à ouvrir https://lord.re pour vérifier que ça a bien été poussé comme il faut et de constater les typos que j'ai ratées lors des relectures (toujours pareil).
------------------------------------
------------------------------------
[18/09/2019] [hugo git adminsys]
------------------------------------