<rss xmlns:atom="http://www.w3.org/2005/Atom" version="2.0"><channel><title>Content - Balise - arleo.eu</title><link>https://www.arleo.eu/tags/content/</link><description>Content - Balise - arleo.eu</description><generator>Hugo -- gohugo.io</generator><language>fr</language><lastBuildDate>Sat, 09 May 2026 12:48:49 +0200</lastBuildDate><atom:link href="https://www.arleo.eu/tags/content/" rel="self" type="application/rss+xml"/><item><title>Roadmap : faut-il migrer les 16 articles vers content/posts/ ?</title><link>https://www.arleo.eu/posts/roadmap-migration-content-posts/</link><pubDate>Sat, 09 May 2026 12:48:49 +0200</pubDate><author>Jmr</author><guid>https://www.arleo.eu/posts/roadmap-migration-content-posts/</guid><description><![CDATA[<div class="featured-image">
                <img src="/images/roadmap-migration-content-posts-featured.jpg" referrerpolicy="no-referrer">
            </div><h2 id="statut---réflexion--décision-en-attente">Statut : 🤔 RÉFLEXION — décision en attente</h2>
<p>Cette page documente une question d&rsquo;architecture de contenu Hugo pour laquelle je n&rsquo;ai pas encore tranché.</p>
<h2 id="le-contexte">Le contexte</h2>
<p>Le thème LoveIt (que utilise arleo.eu) suit la convention Hugo recommandée : les articles de blog vont dans <code>content/posts/</code>. La home filtre <code>where .Site.RegularPages &quot;Type&quot; &quot;posts&quot;</code>.</p>
<p>Or, par historique de migration depuis Grav, mes 16 articles éditoriaux sont à la <strong>racine</strong> de <code>content/</code>, pas dans <code>content/posts/</code> :</p>
<div class="code-block code-line-numbers open" data-start="0">
    <div class="code-header language-">
        <span class="code-title"><i class="arrow fas fa-angle-right" aria-hidden="true"></i></span>
        <span class="ellipses"><i class="fas fa-ellipsis-h" aria-hidden="true"></i></span>
        <span class="copy" title="Copier dans le presse-papiers"><i class="far fa-copy" aria-hidden="true"></i></span>
    </div><pre tabindex="0"><code>content/
├── csp-nonce/index.fr.md          ← article
├── post-mortem-522-wan-failover/  ← article
├── jquery-migration/              ← article
├── ...
├── privacy-policies/              ← page de référence (footer)
├── documentation/                 ← page de référence (menu)
└── scripts/                       ← page de référence (menu)</code></pre></div>
<p>Hugo considère par défaut tous ces dossiers comme des pages de &ldquo;Type: page&rdquo;, pas &ldquo;Type: posts&rdquo;. Donc le filtre LoveIt sur la home ne les voit pas, et je dois soit overrider <code>layouts/index.html</code>, soit filtrer manuellement.</p>
<h2 id="la-question">La question</h2>
<p>Faut-il migrer les 16 articles vers <code>content/posts/</code> pour suivre la convention LoveIt, ou les laisser à la racine ?</p>
<h2 id="option-a--migrer-vers-contentposts">Option A — Migrer vers <code>content/posts/</code></h2>
<div class="code-block code-line-numbers open" data-start="0">
    <div class="code-header language-">
        <span class="code-title"><i class="arrow fas fa-angle-right" aria-hidden="true"></i></span>
        <span class="ellipses"><i class="fas fa-ellipsis-h" aria-hidden="true"></i></span>
        <span class="copy" title="Copier dans le presse-papiers"><i class="far fa-copy" aria-hidden="true"></i></span>
    </div><pre tabindex="0"><code>content/
├── posts/
│   ├── csp-nonce/index.fr.md
│   ├── post-mortem-522-wan-failover/
│   ├── jquery-migration/
│   └── ...
├── privacy-policies/
├── documentation/
└── scripts/</code></pre></div>
<h3 id="avantages">Avantages</h3>
<ul>
<li><strong>Conformité au thème</strong> : pas d&rsquo;override de layouts nécessaire</li>
<li><strong>Lisibilité repo</strong> : on voit immédiatement quels dossiers sont des articles vs des pages de référence</li>
<li><strong>Évolutivité</strong> : si LoveIt évolue (nouvelles features sur Type=posts), elles s&rsquo;appliquent gratuitement</li>
<li><strong>Mental model</strong> standard : tout dev Hugo qui découvre le repo comprend instantanément</li>
</ul>
<h3 id="inconvénients">Inconvénients</h3>
<ul>
<li><strong>Changement d&rsquo;URL</strong> : <code>/csp-nonce/</code> deviendrait <code>/posts/csp-nonce/</code> par défaut. Casse tous les liens entrants (Google, Reddit, hackernews, mes propres articles internes)</li>
<li><strong>Mitigation possible</strong> via <code>url:</code> explicite dans le front matter : <code>url: /csp-nonce/</code> — Hugo génère alors la page à <code>/csp-nonce/</code> même si le source est dans <code>posts/</code>. Les URLs sont préservées.</li>
<li><strong>Friction migration</strong> : 16 dossiers à déplacer, 16 fichiers à éditer pour ajouter <code>url:</code></li>
<li><strong>Liens internes</strong> dans le contenu Markdown — nombreux articles se citent les uns les autres. À auditer pour s&rsquo;assurer qu&rsquo;ils restent corrects.</li>
</ul>
<h2 id="option-b--garder-la-racine">Option B — Garder la racine</h2>
<div class="code-block code-line-numbers open" data-start="0">
    <div class="code-header language-">
        <span class="code-title"><i class="arrow fas fa-angle-right" aria-hidden="true"></i></span>
        <span class="ellipses"><i class="fas fa-ellipsis-h" aria-hidden="true"></i></span>
        <span class="copy" title="Copier dans le presse-papiers"><i class="far fa-copy" aria-hidden="true"></i></span>
    </div><pre tabindex="0"><code>content/
├── csp-nonce/index.fr.md
├── post-mortem-522-wan-failover/
├── ...
├── privacy-policies/
├── documentation/
└── scripts/</code></pre></div>
<h3 id="avantages-1">Avantages</h3>
<ul>
<li><strong>URLs identiques</strong> sans rien faire — <code>/csp-nonce/</code> reste <code>/csp-nonce/</code></li>
<li><strong>Pas de migration</strong> : 0 fichier touché</li>
<li><strong>Liens internes</strong> : intacts par définition</li>
<li><strong>Override <code>layouts/home.html</code> déjà en place</strong> : 1 ligne de différence, ça marche</li>
</ul>
<h3 id="inconvénients-1">Inconvénients</h3>
<ul>
<li><strong>Override custom</strong> à maintenir si LoveIt évolue</li>
<li><strong>Lisibilité repo</strong> : pages de référence et articles mélangés à la racine</li>
<li><strong>Convention bizarre</strong> : un dev Hugo découvrant le repo se demande pourquoi pas de <code>posts/</code></li>
</ul>
<h2 id="considérations-seo">Considérations SEO</h2>
<p>Le SEO craint le changement d&rsquo;URL. Si je migre vers <code>posts/</code> SANS <code>url:</code> override, les 16 articles passent de <code>arleo.eu/csp-nonce/</code> à <code>arleo.eu/posts/csp-nonce/</code>. Cloudflare cache, Google indexe, robots.txt connaît la map du site… tout doit être ré-indexé.</p>
<p>Avec <code>url:</code> override (Option A v2), aucun changement d&rsquo;URL. Mais alors quel est l&rsquo;intérêt de migrer ? Juste la lisibilité du repo. Le coût (16 fichiers à éditer) vs le bénéfice (lisibilité interne) → probablement pas rentable.</p>
<h2 id="considérations-hugo-mcp">Considérations Hugo MCP</h2>
<p>Les outils MCP que j&rsquo;utilise pour éditer le contenu (<code>hugo-mcp</code> v1.8.1) acceptent une route comme paramètre : <code>create_page(route=&quot;/csp-nonce&quot;)</code>. Le mapping route → fichier est défini par Hugo.</p>
<p>Si je migre vers <code>posts/</code> :</p>
<ul>
<li>Avec <code>url:</code> override : MCP appelle <code>create_page(route=&quot;/csp-nonce&quot;)</code>, le fichier est créé à <code>content/posts/csp-nonce/index.fr.md</code> mais la page est servie à <code>/csp-nonce/</code>. Workflow inchangé pour l&rsquo;utilisateur.</li>
<li>Sans <code>url:</code> override : MCP doit appeler <code>create_page(route=&quot;/posts/csp-nonce&quot;)</code>. Workflow différent. Tous les articles existants tombent sur des routes inconnues.</li>
</ul>
<p>Je penche fortement pour l&rsquo;Option A v2 (migration + <code>url:</code> override) si je migre.</p>
<h2 id="la-décision-provisoire">La décision (provisoire)</h2>]]></description></item></channel></rss>