<rss xmlns:atom="http://www.w3.org/2005/Atom" version="2.0"><channel><title>Webhook - Balise - arleo.eu</title><link>https://www.arleo.eu/tags/webhook/</link><description>Webhook - Balise - arleo.eu</description><generator>Hugo -- gohugo.io</generator><language>fr</language><lastBuildDate>Sat, 09 May 2026 12:47:17 +0200</lastBuildDate><atom:link href="https://www.arleo.eu/tags/webhook/" rel="self" type="application/rss+xml"/><item><title>Roadmap : Webhook Git → rebuild Hugo automatique</title><link>https://www.arleo.eu/posts/roadmap-webhook-git-rebuild/</link><pubDate>Sat, 09 May 2026 12:47:17 +0200</pubDate><author>Jmr</author><guid>https://www.arleo.eu/posts/roadmap-webhook-git-rebuild/</guid><description><![CDATA[<div class="featured-image">
                <img src="/images/roadmap-webhook-git-rebuild-featured.jpg" referrerpolicy="no-referrer">
            </div><h2 id="statut---backlog--pas-encore-implémenté">Statut : 🗂️ BACKLOG — pas encore implémenté</h2>
<p>Cette page documente une intention d&rsquo;architecture qui sera implémentée dans une prochaine itération. Le code n&rsquo;est pas encore en prod.</p>
<h2 id="contexte">Contexte</h2>
<p>Dans la <a href="/posts/strategie-4-mcp-vs-git/" rel="">Stratégie 4 (séparation MCP / Git)</a>, j&rsquo;ai expliqué pourquoi <code>content/</code> est dans <code>.gitignore</code> côté repo arleo.eu : pour qu&rsquo;aucun conflit ne soit possible entre l&rsquo;écriture MCP et l&rsquo;écriture Git.</p>
<p>Concrètement, ça veut dire que quand je push depuis VS Code une nouvelle version de <code>layouts/</code>, <code>themes/</code>, <code>static/</code>, <code>hugo.toml</code>, ou <code>deploy.sh</code>, <strong>rien ne se passe automatiquement</strong> côté serveur. Je dois SSH dans la VM Hugo et faire <code>git pull &amp;&amp; hugo --minify &amp;&amp; rsync</code> à la main.</p>
<p>C&rsquo;est pas critique (push de structure = ~1× par semaine), mais c&rsquo;est de la friction inutile. Donc : webhook GitHub → rebuild auto.</p>
<h2 id="architecture-cible">Architecture cible</h2>]]></description></item><item><title>Post-mortem : Cloudflare Bot Management bloquait les webhooks MCP</title><link>https://www.arleo.eu/posts/postmortem-cf-bot-blocking-mcp/</link><pubDate>Sat, 09 May 2026 12:46:28 +0200</pubDate><author>Jmr</author><guid>https://www.arleo.eu/posts/postmortem-cf-bot-blocking-mcp/</guid><description><![CDATA[<div class="featured-image">
                <img src="/images/postmortem-cf-bot-blocking-mcp-featured.jpg" referrerpolicy="no-referrer">
            </div><h2 id="le-symptôme">Le symptôme</h2>
<p>Je viens de finaliser un endpoint webhook dans le <code>hugo-mcp-proxy</code> qui recevra des notifications de GitHub à chaque push sur le repo <code>arleo.eu</code>. Implementation propre : HMAC-SHA256, rate limiting, IPAddressAllow GitHub ranges côté systemd.</p>
<p>Test fonctionnel depuis un client externe :</p>
<div class="code-block code-line-numbers open" data-start="0">
    <div class="code-header language-bash">
        <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><div class="highlight"><pre tabindex="0" class="chroma"><code class="language-bash" data-lang="bash"><span class="line"><span class="cl">$ curl -X POST https://mcp-hugo.arleo.eu/webhook/test <span class="se">\
</span></span></span><span class="line"><span class="cl"><span class="se"></span>    -H <span class="s2">&#34;Content-Type: application/json&#34;</span> <span class="se">\
</span></span></span><span class="line"><span class="cl"><span class="se"></span>    -d <span class="s1">&#39;{&#34;test&#34;: true}&#39;</span></span></span></code></pre></div></div>
<p>Réponse : <strong>403 Forbidden</strong>.</p>
<p>Curieux. Le service tourne, l&rsquo;IP source de mon test est dans le whitelist, le HMAC est correct. Pourquoi 403 ?</p>
<h2 id="investigation-côté-serveur">Investigation côté serveur</h2>
<p>Logs nginx côté NUC :</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>$ sudo tail -100 /var/log/nginx/mcp-hugo.access.log | grep webhook</code></pre></div>
<p>Vide. Aucune requête n&rsquo;arrive sur nginx.</p>
<p>Logs <code>mcp-oauth-proxy</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>$ sudo journalctl -u mcp-oauth-proxy -n 100 | grep webhook</code></pre></div>
<p>Vide aussi. La requête n&rsquo;arrive pas jusqu&rsquo;au service.</p>
<p>Soit elle est bloquée par firewall avant nginx (CrowdSec ou ufw), soit en amont par Cloudflare.</p>
<h2 id="la-vérité-côté-cloudflare">La vérité côté Cloudflare</h2>]]></description></item></channel></rss>