<?xml version="1.0" encoding="utf-8" standalone="yes"?><rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom" xmlns:content="http://purl.org/rss/1.0/modules/content/"><channel><title>OAuth | The .NET Blog</title><link>https://thedotnetblog.com/fr/tags/oauth/</link><description>Articles, tutorials and insights from the .NET community.</description><generator>Hugo</generator><language>fr</language><managingEditor>@thedotnetblog (The .NET Blog)</managingEditor><webMaster>@thedotnetblog</webMaster><lastBuildDate>Wed, 20 May 2026 00:00:00 +0000</lastBuildDate><atom:link href="https://thedotnetblog.com/fr/tags/oauth/index.xml" rel="self" type="application/rss+xml"/><item><title>Votre Agent IA a un Problème d'Identité (Et Voici le Modèle qui le Résout)</title><link>https://thedotnetblog.com/fr/news/emiliano-montesdeoca/azd-least-privilege-ai-agents-oauth-token-pattern/</link><pubDate>Wed, 20 May 2026 00:00:00 +0000</pubDate><author>Emiliano Montesdeoca</author><guid>https://thedotnetblog.com/fr/news/emiliano-montesdeoca/azd-least-privilege-ai-agents-oauth-token-pattern/</guid><description>Un nouveau modèle azd de Curity et Microsoft montre comment créer des agents IA qui utilisent des tokens OAuth de courte durée avec des scopes à grain fin — pour que les agents ne puissent jamais voir des données qu'ils ne devraient pas voir.</description><content:encoded>&lt;p&gt;Il y a un moment dans chaque projet d&amp;rsquo;agent IA qui ressemble à ceci : la démo fonctionne parfaitement, l&amp;rsquo;agent interprète le langage naturel, appelle les bonnes API, retourne les bonnes données. Ensuite vous commencez à penser aux vrais utilisateurs.&lt;/p&gt;
&lt;p&gt;Qu&amp;rsquo;est-ce qui empêche la session d&amp;rsquo;agent d&amp;rsquo;un utilisateur de voir les données d&amp;rsquo;un autre utilisateur ? Et si l&amp;rsquo;agent est trompé par une injection de prompt ? Et s&amp;rsquo;il appelle un outil d&amp;rsquo;une manière inattendue ?&lt;/p&gt;
&lt;p&gt;Ce ne sont pas des cas limites. Ce sont des décisions de conception que vous devez prendre avant de livrer.&lt;/p&gt;
&lt;p&gt;Un nouveau modèle &lt;code&gt;azd&lt;/code&gt; de Curity et Microsoft vous donne une référence fonctionnelle pour exactement ce problème.&lt;/p&gt;
&lt;h2 id="le-problème-central--authentification--autorisation"&gt;Le Problème Central : Authentification ≠ Autorisation&lt;/h2&gt;
&lt;p&gt;La plupart des exemples d&amp;rsquo;agents gèrent bien l&amp;rsquo;authentification des utilisateurs. Ils gèrent mal l&amp;rsquo;autorisation. Savoir &lt;em&gt;qui&lt;/em&gt; est l&amp;rsquo;utilisateur ne vous dit pas &lt;em&gt;quelles données&lt;/em&gt; il devrait voir.&lt;/p&gt;
&lt;p&gt;Une application cliente traditionnelle fait des appels d&amp;rsquo;API prévisibles. Un agent IA est non déterministe — il interprète le langage naturel et décide quoi appeler. Il peut être créatif. Il peut aussi se tromper. Et s&amp;rsquo;il est manipulé par injection de prompt, vous avez besoin de règles qui ne dépendent pas du bon comportement de l&amp;rsquo;IA.&lt;/p&gt;
&lt;p&gt;La solution démontrée par ce modèle : &lt;strong&gt;des tokens de courte durée qui transportent exactement les bonnes informations pour chaque saut&lt;/strong&gt;.&lt;/p&gt;
&lt;h2 id="comment-fonctionne-la-chaîne-de-tokens"&gt;Comment Fonctionne la Chaîne de Tokens&lt;/h2&gt;
&lt;p&gt;Le modèle utilise des tokens d&amp;rsquo;accès OAuth 2.0 avec échange de tokens pour réduire les permissions à chaque étape. Un token utilisateur est échangé deux fois avant d&amp;rsquo;atteindre le serveur MCP :&lt;/p&gt;
&lt;ol&gt;
&lt;li&gt;&lt;strong&gt;Premier échange&lt;/strong&gt; — réduit la portée et convertit le token opaque en JWT&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;Deuxième échange&lt;/strong&gt; — ajoute l&amp;rsquo;identité de l&amp;rsquo;agent et une nouvelle audience pour le saut du serveur MCP&lt;/li&gt;
&lt;/ol&gt;
&lt;p&gt;À quoi ressemble le token du serveur MCP :&lt;/p&gt;
&lt;div class="highlight"&gt;&lt;pre tabindex="0" class="chroma"&gt;&lt;code class="language-json" data-lang="json"&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="p"&gt;{&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; &lt;span class="nt"&gt;&amp;#34;scope&amp;#34;&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="s2"&gt;&amp;#34;stocks/read&amp;#34;&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; &lt;span class="nt"&gt;&amp;#34;sub&amp;#34;&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="s2"&gt;&amp;#34;62c839b8...&amp;#34;&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; &lt;span class="nt"&gt;&amp;#34;aud&amp;#34;&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="s2"&gt;&amp;#34;https://mcp.demo.example&amp;#34;&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; &lt;span class="nt"&gt;&amp;#34;customer_id&amp;#34;&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="s2"&gt;&amp;#34;178&amp;#34;&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; &lt;span class="nt"&gt;&amp;#34;region&amp;#34;&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="s2"&gt;&amp;#34;USA&amp;#34;&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="p"&gt;}&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;&lt;p&gt;Le &lt;code&gt;customer_id&lt;/code&gt; est intégré dans le token par le serveur d&amp;rsquo;autorisation, pas passé comme paramètre que l&amp;rsquo;agent contrôle. L&amp;rsquo;API vérifie le token, pas les instructions de l&amp;rsquo;agent.&lt;/p&gt;
&lt;p&gt;Cela signifie : même si quelqu&amp;rsquo;un trompe l&amp;rsquo;agent pour qu&amp;rsquo;il essaie d&amp;rsquo;obtenir les données d&amp;rsquo;un autre client, le token ne l&amp;rsquo;autorisera pas.&lt;/p&gt;
&lt;h2 id="ce-que-le-modèle-déploie"&gt;Ce que le Modèle Déploie&lt;/h2&gt;
&lt;p&gt;Avec quelques commandes &lt;code&gt;azd&lt;/code&gt; vous obtenez :&lt;/p&gt;
&lt;ul&gt;
&lt;li&gt;Un agent backend sur Microsoft Foundry (C#, SDK Microsoft A2A et MCP)&lt;/li&gt;
&lt;li&gt;Un serveur MCP exposant un exemple d&amp;rsquo;API de portefeuille&lt;/li&gt;
&lt;li&gt;Curity Identity Server comme serveur d&amp;rsquo;autorisation, aux côtés d&amp;rsquo;Entra ID pour l&amp;rsquo;authentification&lt;/li&gt;
&lt;li&gt;Des passerelles API externes et internes gérant l&amp;rsquo;échange de tokens et la journalisation d&amp;rsquo;audit&lt;/li&gt;
&lt;li&gt;Bicep pour toute l&amp;rsquo;infrastructure Azure : Container Apps, VNet, ACR, Azure AI Foundry, Key Vault, Azure SQL Database, stockage&lt;/li&gt;
&lt;/ul&gt;
&lt;p&gt;Tout le modèle est inspecTable et personnalisable.&lt;/p&gt;
&lt;h2 id="le-principe-de-conception-qui-vaut-la-peine-dêtre-emprunté"&gt;Le Principe de Conception qui Vaut la Peine d&amp;rsquo;être Emprunté&lt;/h2&gt;
&lt;p&gt;Même si vous n&amp;rsquo;utilisez pas Curity, le modèle est transférable : &lt;strong&gt;les agents ne devraient jamais avoir un accès permanent à l&amp;rsquo;API&lt;/strong&gt;. Chaque action devrait utiliser un token de courte durée avec le scope minimum nécessaire pour cet appel spécifique, émis pour l&amp;rsquo;identité spécifique de l&amp;rsquo;agent, portant les claims dont l&amp;rsquo;API a besoin pour prendre des décisions d&amp;rsquo;autorisation.&lt;/p&gt;
&lt;p&gt;Cela résiste aux agents créatifs, aux erreurs et à l&amp;rsquo;injection de prompt d&amp;rsquo;une façon que &amp;ldquo;assurez-vous simplement que l&amp;rsquo;agent ne fait pas de mauvaises choses&amp;rdquo; ne fera jamais.&lt;/p&gt;
&lt;h2 id="conclusion"&gt;Conclusion&lt;/h2&gt;
&lt;p&gt;Les modèles de sécurité pour les agents IA sont encore en cours d&amp;rsquo;élaboration dans l&amp;rsquo;industrie. Ce modèle est l&amp;rsquo;une des implémentations de référence les plus complètes que j&amp;rsquo;ai vues — il couvre le flux d&amp;rsquo;autorisation réel, pas seulement l&amp;rsquo;authentification.&lt;/p&gt;
&lt;p&gt;Post original : &lt;a href="https://devblogs.microsoft.com/azure-sdk/azd-curity-least-privilege-ai-agents/"&gt;Least privilege AI agents: A new azd template from Curity and Microsoft&lt;/a&gt;&lt;/p&gt;</content:encoded></item></channel></rss>