<?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/ca/tags/oauth/</link><description>Articles, tutorials and insights from the .NET community.</description><generator>Hugo</generator><language>ca</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/ca/tags/oauth/index.xml" rel="self" type="application/rss+xml"/><item><title>El Teu Agent d'IA Té un Problema d'Identitat (I Aquí Tens la Plantilla que el Resol)</title><link>https://thedotnetblog.com/ca/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/ca/news/emiliano-montesdeoca/azd-least-privilege-ai-agents-oauth-token-pattern/</guid><description>Una nova plantilla azd de Curity i Microsoft mostra com construir agents d'IA que utilitzen tokens OAuth de curta durada amb àmbits de gra fi — perquè els agents mai puguin veure dades que no haurien de veure.</description><content:encoded>&lt;p&gt;Hi ha un moment en cada projecte d&amp;rsquo;agent d&amp;rsquo;IA que funciona més o menys així: la demo funciona perfectament, l&amp;rsquo;agent interpreta el llenguatge natural, crida les API correctes, retorna les dades correctes. Llavors comences a pensar en els usuaris reals.&lt;/p&gt;
&lt;p&gt;Què impedeix que la sessió de l&amp;rsquo;agent d&amp;rsquo;un usuari vegi les dades d&amp;rsquo;un altre usuari? Què passa si l&amp;rsquo;agent és enganyat mitjançant injecció de prompts? Què passa si crida una eina d&amp;rsquo;una manera inesperada?&lt;/p&gt;
&lt;p&gt;Aquestes no són casos extrems. Són decisions de disseny que has de prendre abans d&amp;rsquo;envisar.&lt;/p&gt;
&lt;p&gt;Una nova plantilla &lt;code&gt;azd&lt;/code&gt; de Curity i Microsoft et dóna una referència funcional per a exactament aquest problema.&lt;/p&gt;
&lt;h2 id="el-problema-principal-autenticació--autorització"&gt;El Problema Principal: Autenticació ≠ Autorització&lt;/h2&gt;
&lt;p&gt;La majoria de mostres d&amp;rsquo;agents gestionen bé l&amp;rsquo;autenticació d&amp;rsquo;usuaris. Gestionen malament l&amp;rsquo;autorització. Saber &lt;em&gt;qui&lt;/em&gt; és l&amp;rsquo;usuari no et diu &lt;em&gt;quines dades&lt;/em&gt; hauria de veure.&lt;/p&gt;
&lt;p&gt;Una aplicació client tradicional fa crides d&amp;rsquo;API predictibles. Un agent d&amp;rsquo;IA és no determinista — interpreta el llenguatge natural i decideix a qui cridar. Pot ser creatiu. També pot estar equivocat. I si és manipulat a través d&amp;rsquo;injecció de prompts, necessites regles que no depenguin que la IA es comporti bé.&lt;/p&gt;
&lt;p&gt;La solució que demostra aquesta plantilla: &lt;strong&gt;tokens de curta durada que transporten exactament la informació correcta per a cada salt&lt;/strong&gt;.&lt;/p&gt;
&lt;h2 id="com-funciona-la-cadena-de-tokens"&gt;Com Funciona la Cadena de Tokens&lt;/h2&gt;
&lt;p&gt;La plantilla utilitza tokens d&amp;rsquo;accés OAuth 2.0 amb intercanvi de tokens per estrenyir els permisos a cada pas. Un token d&amp;rsquo;usuari s&amp;rsquo;intercanvia dues vegades abans d&amp;rsquo;arribar al servidor MCP:&lt;/p&gt;
&lt;ol&gt;
&lt;li&gt;&lt;strong&gt;Primer intercanvi&lt;/strong&gt; — estreny l&amp;rsquo;àmbit i converteix el token opac en un JWT&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;Segon intercanvi&lt;/strong&gt; — afegeix la identitat de l&amp;rsquo;agent i una nova audiència per al salt del servidor MCP&lt;/li&gt;
&lt;/ol&gt;
&lt;p&gt;Com és el token del servidor 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;El &lt;code&gt;customer_id&lt;/code&gt; queda incorporat al token pel servidor d&amp;rsquo;autorització, no es passa com un paràmetre que controla l&amp;rsquo;agent. L&amp;rsquo;API comprova el token, no les instruccions de l&amp;rsquo;agent.&lt;/p&gt;
&lt;p&gt;Això significa: fins i tot si algú enganya l&amp;rsquo;agent perquè intenti obtenir les dades d&amp;rsquo;un altre client, el token no ho autoritzarà.&lt;/p&gt;
&lt;h2 id="què-desplega-la-plantilla"&gt;Què Desplega la Plantilla&lt;/h2&gt;
&lt;p&gt;Amb uns quants comandaments &lt;code&gt;azd&lt;/code&gt; obtens:&lt;/p&gt;
&lt;ul&gt;
&lt;li&gt;Un agent backend a Microsoft Foundry (C#, SDK de Microsoft A2A i MCP)&lt;/li&gt;
&lt;li&gt;Un servidor MCP que exposa una API de cartera de mostra&lt;/li&gt;
&lt;li&gt;Curity Identity Server com a servidor d&amp;rsquo;autorització, al costat d&amp;rsquo;Entra ID per a l&amp;rsquo;autenticació&lt;/li&gt;
&lt;li&gt;Passarel·les d&amp;rsquo;API externes i internes que gestionen l&amp;rsquo;intercanvi de tokens i el registre d&amp;rsquo;auditoria&lt;/li&gt;
&lt;li&gt;Bicep per a tota la infraestructura Azure: Container Apps, VNet, ACR, Azure AI Foundry, Key Vault, Azure SQL Database, emmagatzematge&lt;/li&gt;
&lt;/ul&gt;
&lt;p&gt;Tot el patró és inspeccionable i personalitzable.&lt;/p&gt;
&lt;h2 id="el-principi-de-disseny-que-val-la-pena-adoptar"&gt;El Principi de Disseny que Val la Pena Adoptar&lt;/h2&gt;
&lt;p&gt;Fins i tot si no uses Curity, el patró és transferible: &lt;strong&gt;els agents mai haurien de tenir accés permanent a l&amp;rsquo;API&lt;/strong&gt;. Cada acció hauria d&amp;rsquo;usar un token de curta durada amb el mínim àmbit necessari per a aquella crida específica, emès a la identitat específica de l&amp;rsquo;agent, portant les reclamacions que l&amp;rsquo;API necessita per prendre decisions d&amp;rsquo;autorització.&lt;/p&gt;
&lt;p&gt;Això resisteix agents creatius, errors i injecció de prompts de maneres que &amp;ldquo;assegura&amp;rsquo;t que l&amp;rsquo;agent no faci coses dolentes&amp;rdquo; mai ho farà.&lt;/p&gt;
&lt;h2 id="conclusió"&gt;Conclusió&lt;/h2&gt;
&lt;p&gt;Els patrons de seguretat per a agents d&amp;rsquo;IA encara s&amp;rsquo;estan definint a tota la indústria. Aquesta plantilla és una de les implementacions de referència més completes que he vist — cobreix el flux d&amp;rsquo;autorització real, no només l&amp;rsquo;autenticació.&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>