1

Compare commits

..

21 Commits

Author SHA1 Message Date
cbdd378c4b Une façon créative de bloquer les indésirables 2026-03-07 16:56:12 +01:00
c9fa92923e Ajouter une clé Meilisearch factice au script de test 2026-03-06 22:58:51 +01:00
3ec52dfc71 Préserver les GIF animés lors des transformations d'images 2026-03-06 22:54:15 +01:00
d16c29fc5d Charge la clé de recherche via l'environnement 2026-03-06 22:37:05 +01:00
fa72fea745 Ajoute des métadonnées de partage et d'indexation 2026-03-06 21:55:05 +01:00
88927a6343 Ajoute des icônes Apple Touch générées proprement 2026-03-06 21:24:20 +01:00
a203120e21 Améliore les accroches des oeuvres 2026-03-06 15:50:44 +01:00
08036b566d Ordre des blocs 2026-03-06 15:31:03 +01:00
84af2115be Optimisation des images++ 2026-03-06 00:16:17 +01:00
3b3733cb96 Optimisation des images 2026-03-05 23:53:53 +01:00
ea8aa8f3ec Obfuscation 2026-03-05 16:44:11 +01:00
fde4e5f5e6 Affichage des images non intégrées 2026-03-05 14:42:12 +01:00
ce22aae00f Jurassic World Evolution 3 2026-03-05 11:00:09 +01:00
0d1ef97aba Gérer le statut draft pour Lemmy et la météo 2026-03-04 23:51:12 +01:00
b21f7038ab Grammaire 2026-03-04 21:01:55 +01:00
36bae28f6d Ajout de l'article 'Free, IPv6 et OPNsense' 2026-03-04 17:01:53 +01:00
518ca65e29 Correction concernant les guillemets 2026-03-03 23:33:19 +01:00
8a1ce77c17 Ajoute un mode de centrage des figures et améliore les légendes 2026-03-03 01:10:02 +01:00
16b95458f1 Nouveautés du blog 2026-02-24 00:26:38 +01:00
4e99c13f18 Lien vers IRC 2026-02-23 15:12:53 +01:00
d33d7459ef Formulaire de recherche 2026-02-23 15:10:11 +01:00
132 changed files with 3516 additions and 76 deletions

View File

@@ -83,7 +83,7 @@ Il s'agit d'un site statique généré avec Hugo, dont la version peut être vé
## Instructions relatives aux articles
- Ne pas utiliser les apostrophes et les guillemets typographiques dans le markdown (mais garder les caractères accentués)
- Utiliser exclusivement les apostrophes (`'`) et les guillemets (`"`) non-typographiques
- Une phrase par ligne
- Ne jamais terminer une ligne par un double-espace
@@ -162,13 +162,10 @@ Il s'agit d'un site statique généré avec Hugo, dont la version peut être vé
- `title` : Titre que je donne à mon article
- `date` : Si possible avec l'heure, mais la majorité de mes articles actuels ne contiennent que la date
- Le frontmatter peut contenir d'autres attributs optionnels, autres que les taxonomies :
- `cover` : Chemin vers l'image illustrant l'article. Cette image doit être stockée dans le dossier `{chemin du bundle}/images/`. Elle sera utilisée pour générer la vignette de l'article, et affichée en en-tête de l'article. Je la désigne par _cover_, _image de couverture_, ou _image d'en-tête_
- `dossier` : Plusieurs bundles partageant une même valeur pour l'attribut `dossier` seront regroupés dans un _dossier virtuel_ tout en résidant physiquement dans leurs dossiers _physiques_ respectifs
- Exemple : `dossier: [ "Exploitation de mes données météo" ]`
- Cet attribut devrait être complété par un attribut `weight`
- Par exemple :
```json

View File

@@ -7,6 +7,12 @@ disableHugoGeneratorInject: true
enableEmoji: true
timeZone: Europe/Paris
theme: ["2026"]
security:
funcs:
getenv:
- "^HUGO_"
- "^CI$"
- "^MEILI_SEARCH_API_KEY$"
params:
lists:
layout: spotlight

View File

@@ -1,6 +1,9 @@
goldmark:
parser:
wrapStandAloneImageWithinParagraph: false
attribute:
block: true
title: true
renderer:
unsafe: true
tableOfContents:

View File

@@ -2,12 +2,12 @@ favicon: /favicon.png
# Pas de / pour les ressources qui seront transformées
# Et les placer dans /assets et non dans /static
logo: logo-large.png
description: "et ses opinions impopulaires"
description: "Richard Dern et ses opinions impopulaires"
themeColor: "#060c14"
search:
action: /recherche/
param: q
meilisearch:
endpoint: /api/search
indexUid: blog_posts
apiKey: "cf49bcdb1b08e5c502c41956d38ce0be80d5e79e9f084e6f15f4485f87d63c30"
hitsPerPage: 20

View File

@@ -0,0 +1,4 @@
#title: ""
#attribution: ""
description: "L'écran d'accueil du jeu est à la hauteur de tout le reste : magnifique"
#prompt: ""

View File

@@ -0,0 +1,4 @@
#title: ""
#attribution: ""
description: "Première page de mes réglages graphiques"
#prompt: ""

View File

@@ -0,0 +1,4 @@
#title: ""
#attribution: ""
description: "Deuxième page de mes réglages graphiques"
#prompt: ""

View File

@@ -0,0 +1,4 @@
#title: ""
#attribution: ""
description: "Les écrans de chargement sont agrémentés du clin d'oeil à ces pauvres chèvres qui servent de repas."
#prompt: ""

View File

@@ -0,0 +1,4 @@
#title: ""
#attribution: ""
description: "La nouvelle carte de la campagne, partiellement révélée."
#prompt: ""

View File

@@ -0,0 +1,4 @@
#title: ""
#attribution: ""
description: "Couché de soleil sur une volière à Vegas."
#prompt: ""

View File

@@ -0,0 +1,4 @@
#title: ""
#attribution: ""
description: "Restaurants, boutiques de souvenirs et stands de boissons forment toujours le trio de base pour contenter les visiteurs."
#prompt: ""

View File

@@ -0,0 +1,4 @@
#title: ""
#attribution: ""
description: "Ils n'ont toujours pas de plumes, mais je les emmènerai bien en balade quand même..."
#prompt: ""

View File

@@ -0,0 +1,4 @@
#title: ""
#attribution: ""
description: "_JWE3_ a fait monter d'un cran l'aspect organique des parcs, mêlant objets naturels et constructions artificielles. On pourrait presque respirer la poussière et sentir le métal et le béton chauffés par le soleil."
#prompt: ""

View File

@@ -0,0 +1,4 @@
#title: ""
#attribution: ""
description: "Les _Diplodocus_ dans leur enclôs du Montana."
#prompt: ""

View File

@@ -0,0 +1,4 @@
#title: ""
#attribution: ""
#description: ""
#prompt: ""

View File

@@ -0,0 +1,4 @@
#title: ""
#attribution: ""
description: "Sur l'île de Kauai."
#prompt: ""

View File

@@ -0,0 +1,4 @@
#title: ""
#attribution: ""
description: "Et certaines parties sont mobiles ! Ici, l'antenne s'anime !"
#prompt: ""

View File

@@ -0,0 +1,4 @@
#title: ""
#attribution: ""
#description: ""
#prompt: ""

View File

@@ -0,0 +1,4 @@
#title: ""
#attribution: ""
description: "Là aussi, belle photo qui met en évidence la robe des _Parasaurolophus_, prise alors que je chutais de mon piédestal rocheux."
#prompt: ""

View File

@@ -0,0 +1,4 @@
#title: ""
#attribution: ""
description: "Katsuyama, au Japon."
#prompt: ""

View File

@@ -0,0 +1,4 @@
#title: ""
#attribution: ""
#description: ""
#prompt: ""

View File

@@ -0,0 +1,4 @@
#title: ""
#attribution: ""
#description: ""
#prompt: ""

View File

@@ -0,0 +1,4 @@
#title: ""
#attribution: ""
description: "Dire que je n'ai encore vu qu'un cinquième de la campagne à ce stade !"
#prompt: ""

View File

@@ -0,0 +1,4 @@
#title: ""
#attribution: ""
description: "Katsuyama, au Japon."
#prompt: ""

View File

@@ -0,0 +1,4 @@
#title: ""
#attribution: ""
description: "Je suis plutôt content de cette capture, même si j'étais en train de me casser la gueule entre les rochers..."
#prompt: ""

View File

@@ -0,0 +1,4 @@
#title: ""
#attribution: ""
description: "Plus près et... on commence à voir les faiblesses de certaines textures."
#prompt: ""

View File

@@ -0,0 +1,4 @@
#title: ""
#attribution: ""
description: "Jouant avec son frère."
#prompt: ""

View File

@@ -0,0 +1,4 @@
#title: ""
#attribution: ""
description: "Câliné par sa mère."
#prompt: ""

View File

@@ -0,0 +1,4 @@
#title: ""
#attribution: ""
#description: ""
#prompt: ""

View File

@@ -0,0 +1,4 @@
#title: ""
#attribution: ""
description: "Il y a quantité d'éléments de décor dans le catalogue, même sans compter sur le _marketplace_ du _workshop_."
#prompt: ""

View File

@@ -0,0 +1,4 @@
#title: ""
#attribution: ""
description: "Je n'ai pas résisté à la tentation, si déjà j'ai les éléments à portée de main. J'avoue, la composition aurait pu être bien meilleure."
#prompt: ""

View File

@@ -0,0 +1,4 @@
#title: ""
#attribution: ""
#description: ""
#prompt: ""

View File

@@ -0,0 +1,4 @@
#title: ""
#attribution: ""
description: "Le bateau de _Jurassic Park III_."
#prompt: ""

View File

@@ -0,0 +1,4 @@
#title: ""
#attribution: ""
description: "De quoi se faire un manoir musée, façon Lockwood."
#prompt: ""

View File

@@ -0,0 +1,4 @@
#title: ""
#attribution: ""
#description: ""
#prompt: ""

Binary file not shown.

After

Width:  |  Height:  |  Size: 11 MiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 3.2 MiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 3.3 MiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 5.0 MiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 4.9 MiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 11 MiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 10 MiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 13 MiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 14 MiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 13 MiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 10 MiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 13 MiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 11 MiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 13 MiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 12 MiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 13 MiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 11 MiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 11 MiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 13 MiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 14 MiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 15 MiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 12 MiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 14 MiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 14 MiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 15 MiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 13 MiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 12 MiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 8.3 MiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 5.8 MiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 5.6 MiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 5.8 MiB

View File

@@ -0,0 +1,182 @@
---
title: Jurassic World Evolution 3
date: "2026-03-05 01:38:12"
cover: images/2958130_20260302225758_1.png
genres:
- jeu de gestion économique
entreprises:
- Epic Games Store
- Frontier Developments
- Microsoft Store
- PlayStation Store
- Steam
links:
- name: Page Wikipédia
url: https://en.wikipedia.org/wiki/Jurassic_World_Evolution_3
lang: en
- name: Site officiel
url: https://www.frontier.co.uk/games/jurassic-world-evolution-3
wikidata_id: Q134723499
weather:
temperature: 7.77777777777778
humidity: 62
pressure: 1024.38256370315
wind_speed: 3.5405568
wind_direction: 108
illuminance: 0
precipitations: false
source:
- influxdb
comments_url: https://com.richard-dern.fr/post/479
---
## En bref
- Le meilleur de la saga
- Bravo à Frontier qui a écouté les critiques des joueurs
## Configuration
Ma [machine de jeu](/interets/informatique/2022/04/15/mon-nouveau-pc-de-jeu-est-arrive/) est un Ryzen 9 5900X, 32G de mémoire vive, et une RTX3080 10G.
Elle tourne sous [NixOS](https://nixos.org/) 25.11.
Je joue sur un téléviseur [4K@120Hz](/interets/informatique/2024/01/15/2024-l-annee-du-changement/) (LG C3 55 pouces).
![](images/2958130_20260302225811_1.png)
![](images/2958130_20260302225818_1.png)
## Rappels
[Le premier opus](/critiques/jeux-video/jurassic-world-evolution/) était excellent, mais il manquait cruellement de contenu, en particulier concernant les objets et les options pour personnaliser les parcs.
J'estimais qu'il était beaucoup plus accessible que _Planet Coaster_ que j'avais acheté en même temps.
[Le deuxième volet](/critiques/jeux-video/jurassic-world-evolution-2/) a un peu étoffé le contenu, mais se trouvait grevé par d'autres défauts qui l'ont rendu, à mes yeux, moins intéressant au fil du temps, malgré ma conclusion originale.
## Critique
La campagne s'est largement étoffée, et nous offre l'accès à des contrées encore jamais explorées, pas même dans la saga cinématographique ou ses _spin-offs_.
Mais avant d'y évoluer, il faudra passer par des lieux déjà connus.
Un bon moyen de s'ancrer dans le canon avant d'introduire des nouveautés bienvenues, tout en permettant au joueur de se familiariser avec son environnement de gestion de parc.
Les habitués de la série de jeux-vidéo trouveront sans doute ces présentations un peu laborieuses, considérant que les mécaniques sous-jacentes n'ont pas vraiment changé.
Il s'agit toujours de recruter des scientifiques, d'envoyer des expéditions chercher des fossiles, en extraire l'ADN ou les vendre, jusqu'à pouvoir incuber des œufs, relâchés dans un enclos approprié, tout en s'assurant que les visiteurs sont contents du parc.
![](images/2958130_20260302230629_1.png)
Mais cette redondance apparente avec les deux volets précédents n'est finalement que la mécanique de base d'un jeu de gestion de parc à dinosaures, et _Jurassic World Evolution 3_ a beaucoup plus à offrir.
Et c'est tout l'intérêt de commencer par la campagne, même si on maîtrise le jeu de bout en bout.
![](images/2958130_20260302225950_1.png)
Il n'est plus question ici d'épisodes indépendants à achever séquentiellement.
Ici, les allers-retours seront fréquents, et l'histoire conduira le joueur à switcher d'un parc à un autre dès le début de la campagne.
Heureusement, ce papillonnage n'a pas de conséquence négative sur les parcs laissés en attente.
Ces interruptions, ces voyages d'un parc à un autre, permettent une rupture visuelle ponctuelle, ce qui n'est pas pour me déplaire, compte tenu de la diversité des lieux visités.
![](images/2958130_20260302230305_1.png)
![](images/2958130_20260302231244_1.png)
![](images/2958130_20260302231655_1.png)
{.center }
La beauté du jeu est phénoménale, et je crois qu'elle est notamment due à l'introduction du [ray-tracing](https://fr.wikipedia.org/wiki/Ray_tracing).
La lumière et les ombres sont beaucoup plus naturelles, apportent plus de contraste, et contribuent finalement à une immersion que je n'attendais pas d'un jeu de gestion de parc.
![](images/2958130_20260302231458_1.png)
![](images/2958130_20260302234755_1.png)
{.center }
![](images/2958130_20260302234356_1.png)
![](images/2958130_20260302234701_1.png)
La caméra à la première personne offre un point de vue rapproché.
Accessible à tout moment depuis le menu principal, elle permet de visiter littéralement son parc.
Ce n'est pas une nouveauté de _Jurassic World Evolution 3_, mais c'est dans ce nouvel opus que j'en fais le plus usage.
La raison ?
La richesse et la diversité de la faune, de la flore, des paysages et des structures, qui atteignent des sommets.
On est comme Sarah Harding dans [_The Lost World_](/critiques/films/the-lost-world-jurassic-park/) : on ne peut se contenter de regarder, il faut qu'on "touche".
![](images/2958130_20260302234506_1.png)
![](images/2958130_20260302235320_1.png)
![](images/2958130_20260302231149_1.png)
![](images/2958130_20260302231821_1.png)
Mais cette vue à la première personne est quelque peu frustrante : instinctivement, je reprends mes réflexes dans [_ARK: Survival Evolved_](/critiques/jeux-video/ark-survival-evolved/), je veux bondir, aller partout, gratouiller un dinosaure, interagir avec eux.
J'oublie que je suis dans un jeu de gestion de parc, principalement parce qu'à la première personne, je peux aller là où je ne suis pas censé aller en tant que _visiteur_ : à l'intérieur des enclos.
Pourtant, les déplacements sont à la fois contraints et hasardeux : il n'est pas rare de rester coincé dans les rochers, à la recherche de l'emplacement parfait pour une photo.
Et nul saut ne viendra nous aider, sinon les sauts épileptiques de la caméra qui tente de suivre un chemin qui n'a pas été prévu pour elle.
![](images/2958130_20260302235235_1.png)
Donc, pour parfaitement apprécier la vue à la première personne : restez dans les chemins prévus à cet effet !
![](images/2958130_20260302231731_1.png)
![](images/2958130_20260302231341_1.png)
![](images/2958130_20260302232056_1.png)
Malgré la complexité visuelle, apportée par la diversification des lieux visités, je ne me sens pas comme d'habitude, surchargé, incapable de reproduire ou enrichir ce que je vois.
Je n'ai pas l'impression que les outils mis à ma disposition sont trop compliqués pour que je puisse assembler correctement deux formes.
Pourtant, c'est le point qui me faisait le plus peur avec ce nouveau volet : j'ai eu vent de la diversification des outils de constructions, plus proches de _Planet Coaster_ que de _Jurassic World Evolution_.
Et si j'ai si peu joué à _Planet Coaster_, c'est parce que cette complexité me faisait peur.
Dans les deux épisodes précédents, je posais mes routes, mes bâtiments, mes clôtures, je m'occupais de mes animaux, et je ne me préoccupais pas du tout de l'aspect esthétique de mes parcs.
Mais ici, ça serait une trahison intellectuelle de ne pas exploiter tout ce que le jeu peut nous offrir.
![](images/2958130_20260302234545_1.png)
![](images/2958130_20260305002008_1.png)
![](images/2958130_20260305002508_1.png)
Et, maintenant que le jeu offre un _workshop_ (malheureusement pas intégré à celui de Steam), on peut télécharger des _blueprints_ qui sont, pour certains, de toute beauté.
Il y a de gros, gros fans _hardcore_ qui ont déjà accompli un travail absolument  positivement monstrueux.
![](images/2958130_20260305002732_1.png)
![](images/2958130_20260305002836_1.png)
![](images/2958130_20260305002858_1.png)
![](images/2958130_20260305002940_1.png)
Tout cela ferait presque oublier la vue classique d'un jeu de gestion de parc, alors qu'elle n'est pas moins méritante.
![](images/2958130_20260305001637_1.png)
L'optimisation du jeu est excellente.
Je peux zoomer ou dézoomer comme un porc, me balader aux quatres coins d'une immense carte en mode créatif, je n'ai à déplorer que de rares ralentissements, parfaitement compréhensibles sur des cartes très fournies.
Il est très clair que, sur ce point aussi, _JWE3_ a bénéficié d'améliorations considérables.
![](images/2958130_20260302225905_1.png)
On pourra toutefois reprocher des temps de chargement relativement longs, mais, surtout, l'absence apparente de sauvegarde automatique en quittant le jeu.
On doit sauvegarder manuellement, puis quitter.
Mais la grande nouveauté de cet épisode est l'introduction des bébés dinosaures.
![](images/2958130_20260302235531_1.png)
![](images/2958130_20260302235840_1.png)
Réunissez un mâle et une femelle, offrez-leur un petit nid d'amour (littéralement), et quelques instants plus tard, vous pourriez y découvrir un œuf, duquel sortira un juvénile, et tout ce qu'il a à offrir de plus "kawaï".
Après, vous le gardez ou vous le vendez...
## Appréciation
Le jeu a atteint une maturité insoupçonnée.
Je compare ici avec la saga _Civilization_, qui a trébuché avec le sixième épisode et qui s'est franchement viandé avec le septième, au point qu'on se demande si la série peut y survivre.
C'est rare qu'un épisode ultérieur soit meilleur que les précédents.
Mais c'est indéniablement le cas pour _Jurassic World Evolution 3_ qui comble tous les déficits de ses prédécesseurs.
À part pouvoir visiter l'intérieur des laboratoires et observer les scientifiques travailler, j'ignore ce qu'il pourrait manquer à ce jeu.

View File

@@ -152,6 +152,6 @@ Jai abandonné la souris pour un TrackPad.
## Consommation électrique
Je dispose dun onduleur Eaton Ellipse 1200 Pro qui présente la caractéristique intéressante de me fournir la consommation réelle de ce qui est branché dessus. Ainsi, je peux dire que lensemble de mon réseau consomment au total moins de 40W en moyenne. Je trouve que cest très satisfaisant. Londuleur pourrait ainsi fonctionner pendant deux heures sur batterie si une coupure de courant devait survenir. Largement de quoi voir venir…
Je dispose dun onduleur Eaton Ellipse 1200 Pro qui présente la caractéristique intéressante de me fournir la consommation réelle de ce qui est branché dessus. Ainsi, je peux dire que lensemble de mon réseau consomme au total moins de 40W en moyenne. Je trouve que cest très satisfaisant. Londuleur pourrait ainsi fonctionner pendant deux heures sur batterie si une coupure de courant devait survenir. Largement de quoi voir venir…
[^deadlink-1]: Lien inaccessible depuis le 1 novembre 2025

View File

@@ -0,0 +1,4 @@
#title: ""
attribution: "ChatGPT 5.3"
description: "ChatGPT a été mon seul espoir."
prompt: "Une illustration numérique vivante racontant une histoire de chaos numérique puis de sauvetage. À gauche, un enchevêtrement de câbles Ethernet serpente et étouffe une Freebox abîmée tandis que linscription IPv6 apparaît comme une tempête de feu au-dessus. Le logo flocon de NixOS est en train de sombrer dans une mer agitée faite de vagues et de pluie de code binaire. La scène est sombre et chaotique. À droite, la situation est lumineuse et paisible : un robot amical représentant ChatGPT, baigné de lumière, tend la main pour aider une personne soulagée qui sort de leau. Un arc-en-ciel traverse le ciel et une petite île technologique stable avec un symbole NixOS apparaît en arrière-plan. Dans le ciel est écrit Merci ChatGPT !. Style illustration numérique détaillée, composition narrative gauche-chaos / droite-sauvetage."

View File

@@ -0,0 +1,4 @@
#title: ""
#attribution: ""
description: "On reporte alors cette adresse de lien local dans le premier **Préfixe secondaire** de la Freebox"
#prompt: ""

View File

@@ -0,0 +1,4 @@
#title: ""
#attribution: ""
#description: ""
#prompt: ""

View File

@@ -0,0 +1,4 @@
#title: ""
#attribution: ""
#description: ""
#prompt: ""

View File

@@ -0,0 +1,4 @@
#title: ""
#attribution: ""
#description: ""
#prompt: ""

View File

@@ -0,0 +1,4 @@
#title: ""
#attribution: ""
#description: ""
#prompt: ""

View File

@@ -0,0 +1,4 @@
#title: ""
#attribution: ""
#description: ""
#prompt: ""

View File

@@ -0,0 +1,4 @@
#title: ""
#attribution: ""
description: "Obtention de l'adresse de lien local depuis l'interface d'OPNsense. C'est la deuxième adresse de la ligne `IPv6 Addresses`, qui commence toujours par `fe80`."
#prompt: ""

View File

@@ -0,0 +1,4 @@
#title: ""
#attribution: ""
#description: ""
#prompt: ""

Binary file not shown.

After

Width:  |  Height:  |  Size: 2.8 MiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 593 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 76 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 56 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 158 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 88 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 166 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 40 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 40 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 238 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 408 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 165 KiB

View File

@@ -0,0 +1,321 @@
---
title: Free, IPv6 et OPNsense
date: "2026-03-04 16:50:00"
cover: images/cover.png
tags:
- Administration réseau
- OPNsense
- ChatGPT
- Intelligence artificielle
- IPv6
weather:
temperature: 14.1666666666667
humidity: 52
pressure: 1025.73711915929
illuminance: 11254.8
wind_speed: 3.8624256
wind_direction: 89
precipitations: false
source:
- influxdb
comments_url: https://com.richard-dern.fr/post/478
---
## Contexte
Bien conscient de la [pénurie d'adresses IPv4](https://fr.wikipedia.org/wiki/Épuisement_des_adresses_IPv4) depuis très longtemps, cela fait des années que j'essayais de mettre en place [IPv6](https://fr.wikipedia.org/wiki/IPv6) sur mon réseau, sans que j'y parvienne.
Et très honnêtement, c'est largement à cause de ma méconnaissance des implications techniques d'IPv6 qui me faisait craindre pour la sécurité de mon réseau si je m'y prenais mal.
J'ai finalement décidé de donner les clés de mon château ([OPNsense](https://opnsense.org)) à [ChatGPT](https://chatgpt.com), qui s'est occupé de tout pour moi [^1].
Et je ne regrette pas un instant de l'avoir fait : il a **tout** mis en place, et tout fonctionne parfaitement bien.
[^1]:
J'ai créé un utilisateur sur mon serveur principal à usage exclusif de _ChatGPT-5.3-Codex_, créé une paire de clés envoyée à mon routeur, et démarré une session `codex` à partir de laquelle ChatGPT pouvait se connecter en `root` via SSH vers le routeur.
Une fois qu'il a accompli ses objectifs, il n'y avait plus qu'à supprimer l'utilisateur dédié et les clés SSH associées sur le routeur.
## Objectifs
Mes objectifs sont de fournir la double connectivité IPv4 et IPv6 aux clients de mon _LAN_, et que mes serveurs et services soient joignables en IPv4 ou IPv6.
## Mon réseau
Je le détaille dans [cet article](/interets/informatique/2021/03/09/mon-reseau/), mais en substance :
- J'ai une [Freebox Pop](https://www.free.fr/freebox/freebox-pop) Fibre en mode _bridge_
- Un réseau local
- Un routeur sous OPNsense qui fait le lien entre les deux
J'ai installé le [plugin](https://docs.opnsense.org/manual/how-tos/caddy.html) [caddy](https://caddyserver.com) sur OPNsense : il fait office de _reverse-proxy_ pour tout service que je veux exposer.
Les services qui ne passent pas par un serveur web font l'objet de règles de [NAT](https://fr.wikipedia.org/wiki/Network_address_translation).
## Mise en place
Par souci de confidentialité, j'ai anonymisé les adresses IP et les identifiants matériels dans les extraits et les captures d'écran.
![](images/wan-link-local.png)
### Freebox
Dans [l'interface de configuration de la Freebox](http://mafreebox.freebox.fr/), on active le _Next Hop_ IPv6 du **premier préfixe secondaire** en indiquant l'adresse _lien local_ du routeur.
> [Une adresse IPv6](https://fr.wikipedia.org/wiki/Adresse_IPv6) de lien-local (préfixe `fe80::/10`) est une adresse valable uniquement sur le lien où elle a été émise, et qui n'est pas routée sur Internet. Une machine a une adresse de lien-local par interface, ce qui explique pourquoi on parle de l'adresse lien-local de l'interface _WAN_.
> Un préfixe IPv6 (notation `.../64`) désigne un bloc d'adresses, l'équivalent d'un réseau en IPv4.
> Le _Next Hop_ (le "prochain saut") revient à indiquer à la Freebox vers quel voisin elle doit [envoyer les paquets](https://fr.wikipedia.org/wiki/Table_de_routage) destinés à ce préfixe.
![](images/freebox.png)
Mon erreur était de renseigner l'adresse _lien local_ de l'interface _WAN_ de mon routeur comme _Next Hop_ du préfixe _principal_, et l'adresse _lien local_ de l'interface _LAN_ de mon routeur dans le _Next Hop_ du premier préfixe secondaire.
Je me suis laissé influencer [par ce post](https://lafibre.info/remplacer-freebox/freebox-delta-pop-mode-bridge-onpsense-freeplayer/), dont je n'ai lu que les images et pas le texte...
Il n'y a rien de plus à faire sur la Freebox.
En pratique, je devrais activer le serveur DHCPv6 pour que mon serveur se voit attribuer une adresse fixe, mais pour le moment, je veux juste m'assurer que tout fonctionne avant d'activer des options.
### OPNsense
C'est à partir de là que ChatGPT a pris le contrôle de mon routeur.
Je tiens à souligner que je l'ai laissé en totale autonomie après lui avoir donné mes instructions, et qu'à aucun moment je n'ai subi de déconnexion intempestive.
Il a assuré, du début à la fin, en procédant à des sauvegardes avant chaque commande potentiellement destructive.
Ma session de codex me permettait de voir en direct toutes les commandes qu'il exécutait, d'où la confiance que je lui ai accordée.
Les commandes utilisées pour la vérification sont données plus loin à titre informatif, mais ces vérifications peuvent aussi être effectuées directement dans l'interface web de OPNsense.
Je précise aussi que je ne sauve pas des vies : si mon blog est hors-ligne pendant une grosse demi-heure (le temps de restaurer ma configuration initiale), ça ne va gêner personne, en particulier en plein milieu de la nuit.
#### Activation IPv6 WAN/LAN
Dans _Interfaces_, _[WAN]_, on active le mode `SLAAC` pour l'interface _WAN_.
[`SLAAC`](https://en.wikipedia.org/wiki/Stateless_address_autoconfiguration) (_Stateless Address Autoconfiguration_) est le mécanisme standard d'auto-configuration IPv6 à partir des messages _Router Advertisement_.
Je le choisis sur le _WAN_ car la Freebox annonce déjà ce qu'il faut (route par défaut et préfixe), et cela simplifie le diagnostic tant que la connectivité de base n'est pas validée.
![](images/wan-slaac.png)
Dans _Interfaces_, _[LAN]_, on configure une IPv6 statique pour l'interface _LAN_ dans le préfixe secondaire.
Traditionnellement, c'est le préfixe IPv6, suivi par `::1` (un peu comme `10.0.0.1` en IPv4).
![](images/lan-static.png)
![](images/lan-ipv6.png)
Et on applique la configuration.
#### Router Advertisements (RA) sur LAN
Dans _Services_, _Router Advertisements_, on active _RA_ pour le _LAN_.
![](images/ra-unmanaged.png)
Les [_Router Advertisements_](https://fr.wikipedia.org/wiki/Radvd) (RA) sont des messages envoyés par le routeur aux clients pour annoncer la passerelle par défaut, les préfixes disponibles, et les indicateurs liés à DHCPv6.
Sans RA, un client ne peut pas apprendre sa route par défaut IPv6, même si un serveur DHCPv6 est présent.
Les modes de RA d'OPNsense servent essentiellement à indiquer aux clients s'ils doivent utiliser `SLAAC`, [`DHCPv6`](https://fr.wikipedia.org/wiki/DHCPv6), ou une combinaison des deux.
Ils correspondent à des combinaisons de drapeaux standards des RA, notamment `AdvManagedFlag` (le drapeau `M`) et `AdvOtherConfigFlag` (le drapeau `O`), ainsi que le drapeau "autonomous" associé au préfixe qui autorise `SLAAC`.
La [documentation](https://docs.opnsense.org/manual/radvd.html) d'OPNsense récapitule précisément ces modes et leurs drapeaux.
- `Router only` : le routeur n'annonce que la passerelle par défaut, ce qui suppose que les clients aient déjà une adresse IPv6 (par exemple via une configuration statique).
- `Unmanaged` : les clients obtiennent leur adresse via `SLAAC`, sans que les RA ne signalent de service DHCPv6.
- `Managed` : les clients sont censés obtenir leur adresse via DHCPv6 (configuration _stateful_), ce qui implique de ne pas utiliser `SLAAC` pour l'adressage.
- `Assisted` : les clients peuvent obtenir une adresse via DHCPv6 tout en pouvant aussi utiliser `SLAAC`, ce qui peut aboutir à plusieurs adresses IPv6 globales sur une même interface.
- `Stateless` : les clients utilisent `SLAAC` pour l'adressage, et peuvent utiliser DHCPv6 uniquement pour des informations "annexes" (par exemple les serveurs DNS).
Dans un premier temps, on le configure en `Unmanaged`.
Une fois DHCPv6 (Kea) activé et le DNS correctement publié, je basculerai en `Assisted` afin que RA et DHCPv6 puissent cohabiter sans ambiguïté (expliqué plus bas).
#### DHCPv6 (Kea) sur LAN
Dans _Services_, _Kea DHCP_, _Kea DHCPv6_, on active DHCPv6 dans Kea pour le _LAN_.
![](images/kea.png)
On enregistre le _subnet_ (celui du préfixe pour lequel on a ajouté un _Next Hop_ dans la Freebox).
![](images/kea-subnet.png)
Je prévois ici d'utiliser l'adresse `...::53` pour mon serveur DNS, avec _fallback_ sur le serveur DNS du routeur (`...::1`).
#### Réservation IPv6 stable pour le serveur DNS
À ce stade, j'ai demandé à ChatGPT de fiabiliser l'adresse IPv6 de mon serveur DNS.
Il s'agit de récupérer son _DUID_ depuis les baux déjà attribués dynamiquement et de l'ajouter aux réservations.
C'est le même principe que pour IPv4, sauf que le _DUID_ est plus fiable que l'adresse _MAC_.
Après un redémarrage de mon pi-hole (`dns-1`), j'obtiens bien l'adresse en `...::53` qui a été configurée dans les baux statiques.
#### Mise à jour du RA
Dans _Services_, _Router Advertisements_, on peut maintenant passer au mode `Assisted`.
![](images/ra-assisted.png)
#### Vérifications techniques
##### Connectivité IPv6 depuis dns-1
`dns-1` a bien reçu l'IPv6 réservée :
```bash
inet6 ...::53/128 scope global dynamic noprefixroute
```
##### Résolution DNS via dns-1 en IPv6
Depuis OPNsense :
```bash
drill @...::53 one.one.one.one AAAA
```
Résultat attendu : réponse `NOERROR` avec des `AAAA` (ex. : Cloudflare).
##### Vérifier les annonces RA
```bash
grep -nE 'RDNSS|AdvManagedFlag|AdvOtherConfigFlag' /var/etc/radvd.conf
```
Résultat attendu :
- `AdvManagedFlag on`
- `AdvOtherConfigFlag on`
- `RDNSS ...::53 ...::1`
##### Vérifier les annonces DHCPv6
```bash
sed -n '30,55p' /usr/local/etc/kea/kea-dhcp6.conf
```
Résultat attendu :
- Serveurs DNS : `...::53,...::1`
- Réservation `...::53` pour `dns-1`
##### Vérifier les règles IPv6 WAN (phase LAN uniquement)
Ici, "phase LAN uniquement" signifie que je valide d'abord l'IPv6 sortant pour les machines du _LAN_, sans encore exposer de services en IPv6 vers Internet.
Je m'attends donc à ne voir, sur _WAN_, que les règles indispensables au fonctionnement côté routeur, et aucune règle `pass` destinée à des services.
```bash
pfctl -sr | awk 'tolower($0) ~ /pass/ && $0 ~ / on igc1 / && tolower($0) ~ /inet6/ {print}'
```
Résultat attendu : uniquement les règles DHCPv6 client.
À ce stade, n'importe quel client devrait pouvoir faire un [test d'IPv6](https://test-ipv6.com/) et obtenir un 10/10.
![](images/test-ipv6.png)
### Publication d'un site web en IPv6
#### Créer le AAAA public
Ajouter une entrée `AAAA` chez mon registrar ([OVH](https://www.ovhcloud.com/fr/)) avec l'adresse IP globale de l'interface _WAN_ obtenue depuis la Freebox.
Cette adresse IP est dans le préfixe principal (celui dont le _Next Hop_ reste vide).
#### Ouvrir le firewall WAN en IPv6 pour le web
Ajouter l'équivalent IPv6 des règles IPv4 existantes, autrement dit :
- WAN `inet6` TCP `80` vers `wanip`
- WAN `inet6` TCP `443` vers `wanip`
Rien de compliqué ici, c'est rigoureusement la même chose que pour IPv4.
#### Recharger et vérifier
Recharger le filtre :
```bash
configctl filter reload
```
Vérifier les règles actives :
```bash
pfctl -sr | grep -E 'inet6 proto tcp.*port = http|inet6 proto tcp.*port = https'
```
Résultat attendu : deux règles `pass in` WAN en IPv6 pour `80` et `443`.
Vérifier la résolution DNS AAAA :
```bash
drill @1.1.1.1 AAAA richard-dern.fr
```
Résultat attendu :
- `richard-dern.fr. ... AAAA ...:6789`
Vérifier l'accès HTTPS en IPv6 :
```bash
curl -6 -I https://richard-dern.fr
```
Résultat attendu : réponse `HTTP/2 200` (ou redirection HTTP vers HTTPS selon la politique du site).
### IRC en IPv6 : NAT ou routage ?
En IPv4, la publication d'un service passe très souvent par une [redirection de port](https://fr.wikipedia.org/wiki/Network_address_translation) (NAT) depuis l'IP publique du routeur vers une IP privée du serveur.
En IPv6, un serveur du _LAN_ peut avoir une adresse globale routable, et la publication devient principalement une question de DNS (`AAAA`) et de filtrage firewall, pas de traduction d'adresse.
Autrement dit, ce qui "protège" le _LAN_ n'est pas le NAT, mais le fait que, par défaut, rien n'est autorisé en entrée tant qu'aucune règle `pass` n'est ajoutée sur _WAN_.
Dans certains cas, on peut néanmoins conserver une logique de redirection IPv6 -> IPv6 (NAT66), par exemple quand un même nom de domaine doit pointer vers le routeur pour le web (reverse-proxy) tout en exposant d'autres ports vers un hôte interne.
Dans mon cas, je veux que `irc.dern.ovh` pointe vers le routeur pour servir le [client web](https://irc.dern.ovh/) via Caddy, et je redirige les ports [IRC](https://fr.wikipedia.org/wiki/Internet_Relay_Chat) vers `server-main` (la machine sur laquelle le serveur IRC est hébergé).
#### Pré-requis côté hôte (`server-main` sous NixOS)
Activer IPv6 dans la config NixOS de l'hôte :
```nix
{
networking = {
enableIPv6 = true;
tempAddresses = "disabled";
};
systemd.services.dhcpcd.serviceConfig.SystemCallFilter = lib.mkForce [
"@system-service"
"~@aio"
"~@keyring"
"~@memlock"
"~@mount"
"~@resources"
];
}
```
Ces lignes sont un ajustement **spécifique à ma configuration**, et non un prérequis générique à IPv6.
Dans mon cas, `dhcpcd` était trop durci côté `systemd`, ce qui l'empêchait d'appliquer correctement la configuration réseau (adresses et routes).
Forcer un `SystemCallFilter` compatible a permis à `dhcpcd` de fonctionner, tout en conservant des restrictions sur des familles d'appels système inutiles ici (comme `@mount`).
#### Mise en place
J'ai affecté un nom de domaine à l'usage d'IRC : `irc.dern.ovh`.
Or, cet usage est double :
- c'est l'adresse du serveur IRC
- c'est aussi l'adresse que l'on peut ouvrir dans un navigateur pour accéder au client web
C'est un cas d'usage idéal pour justifier le NAT en IPv6.
Donc, lorsque j'ai créé une entrée DNS `AAAA` pour `irc.dern.ovh`, je l'ai fait pointer non pas vers mon serveur IRC mais _vers mon routeur_, puis j'ai créé une règle de NAT pour le serveur IRC.
De cette façon, le reverse-proxy répond pour servir le client web, et on NAT vers le serveur IRC quand on cherche à joindre le port approprié.
![](images/irc-nat.png)
## Conclusion
Je le redis : j'ai laissé les clés du château à ChatGPT.
Je lui ai fait confiance, et j'ai eu raison de le faire.
Il m'a épargné des jours de prises de tête pour une tâche face à laquelle j'ai souvent échoué.
En outre, au cours de nos échanges, il m'a expliqué ce que je ne comprenais pas.
Et comme je suis chiant, je lui ai posé plein de questions.
Maintenant, j'ai un réseau IPv6 fonctionnel et j'ai compris ce que j'ai fait.
Merci ChatGPT, et **merci à ceux qui ont permis que ces informations se retrouvent dans ce qu'il m'a proposé**.

View File

@@ -0,0 +1,4 @@
#title: ""
#attribution: ""
description: "L'alias `comportement_suspect` se remplit tout seul désormais."
#prompt: ""

View File

@@ -0,0 +1,4 @@
#title: ""
#attribution: ""
description: "Vue simplifiée de mon architecture réseau."
#prompt: ""

View File

@@ -0,0 +1,4 @@
#title: ""
attribution: "ChatGPT Auto"
description: "Collaboration entre Caddy et OPNsense pour filtrer les comportements suspects sur mon site."
prompt: "Dynamic digital illustration showing collaboration between a Caddy web server and an OPNsense firewall to block suspicious IP addresses while remaining bot-friendly. Split cyber-security themed scene: on the left a modern server rack with the Caddy logo and a glowing blue protective shield, friendly small robot bots representing legitimate crawlers; on the right an OPNsense firewall server emitting an orange security shield. In the center a digital warning panel reading Access Denied Suspicious IP with network traffic being filtered. Dark cyber-security environment with world map, network lines, glowing circuits, blue vs orange lighting contrast, cinematic lighting, high-detail, wide banner illustration suitable as a blog header."

View File

@@ -0,0 +1,4 @@
#title: ""
#attribution: ""
description: "Ce petit malotru vérifie si je fais tourner WordPress. Pour la dernière fois."
#prompt: ""

View File

@@ -0,0 +1,15 @@
flowchart LR
internet[Internet]
freebox[Freebox<br/>mode bridge]
opnsense[Routeur<br/>OPNsense + Caddy]
internet --> freebox --> opnsense
subgraph lan[Réseau local]
direction TB
server[server-main<br/>NixOS + Caddy<br/>Héberge mon blog]
others[Autres machines physiques<br/>Autres services web]
end
opnsense -->|Reverse-proxy| server
opnsense -->|Reverse-proxy| others

Binary file not shown.

After

Width:  |  Height:  |  Size: 90 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 2.4 MiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 371 KiB

Some files were not shown because too many files have changed in this diff Show More