<?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/it/tags/oauth/</link><description>Articles, tutorials and insights from the .NET community.</description><generator>Hugo</generator><language>it</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/it/tags/oauth/index.xml" rel="self" type="application/rss+xml"/><item><title>Il Tuo Agente IA Ha un Problema di Identità (Ed Ecco il Template che lo Risolve)</title><link>https://thedotnetblog.com/it/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/it/news/emiliano-montesdeoca/azd-least-privilege-ai-agents-oauth-token-pattern/</guid><description>Un nuovo template azd di Curity e Microsoft mostra come costruire agenti IA che usano token OAuth di breve durata con scope a grana fine — in modo che gli agenti non possano mai vedere dati che non dovrebbero vedere.</description><content:encoded>&lt;p&gt;C&amp;rsquo;è un momento in ogni progetto di agente IA che va più o meno così: la demo funziona perfettamente, l&amp;rsquo;agente interpreta il linguaggio naturale, chiama le API giuste, restituisce i dati giusti. Poi inizi a pensare agli utenti reali.&lt;/p&gt;
&lt;p&gt;Cosa impedisce alla sessione dell&amp;rsquo;agente di un utente di vedere i dati di un altro utente? E se l&amp;rsquo;agente viene ingannato tramite prompt injection? E se chiama uno strumento in modo inaspettato?&lt;/p&gt;
&lt;p&gt;Questi non sono casi limite. Sono decisioni di design che devi prendere prima di rilasciare.&lt;/p&gt;
&lt;p&gt;Un nuovo template &lt;code&gt;azd&lt;/code&gt; di Curity e Microsoft ti fornisce un riferimento funzionante per esattamente questo problema.&lt;/p&gt;
&lt;h2 id="il-problema-principale-autenticazione--autorizzazione"&gt;Il Problema Principale: Autenticazione ≠ Autorizzazione&lt;/h2&gt;
&lt;p&gt;La maggior parte dei campioni di agenti gestisce bene l&amp;rsquo;autenticazione degli utenti. Gestisce male l&amp;rsquo;autorizzazione. Sapere &lt;em&gt;chi&lt;/em&gt; è l&amp;rsquo;utente non ti dice &lt;em&gt;quali dati&lt;/em&gt; dovrebbe vedere.&lt;/p&gt;
&lt;p&gt;Un&amp;rsquo;applicazione client tradizionale fa chiamate API prevedibili. Un agente IA è non deterministico — interpreta il linguaggio naturale e decide cosa chiamare. Può essere creativo. Può anche sbagliare. E se viene manipolato tramite prompt injection, hai bisogno di regole che non dipendano dal buon comportamento dell&amp;rsquo;IA.&lt;/p&gt;
&lt;p&gt;La soluzione dimostrata da questo template: &lt;strong&gt;token di breve durata che trasportano esattamente le informazioni giuste per ogni salto&lt;/strong&gt;.&lt;/p&gt;
&lt;h2 id="come-funziona-la-catena-di-token"&gt;Come Funziona la Catena di Token&lt;/h2&gt;
&lt;p&gt;Il template usa token di accesso OAuth 2.0 con scambio di token per restringere i permessi a ogni passo. Un token utente viene scambiato due volte prima di raggiungere il server MCP:&lt;/p&gt;
&lt;ol&gt;
&lt;li&gt;&lt;strong&gt;Primo scambio&lt;/strong&gt; — restringe lo scope e converte il token opaco in un JWT&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;Secondo scambio&lt;/strong&gt; — aggiunge l&amp;rsquo;identità dell&amp;rsquo;agente e un nuovo audience per il salto del server MCP&lt;/li&gt;
&lt;/ol&gt;
&lt;p&gt;Come appare il token del server 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;Il &lt;code&gt;customer_id&lt;/code&gt; è incorporato nel token dal server di autorizzazione, non passato come parametro che l&amp;rsquo;agente controlla. L&amp;rsquo;API controlla il token, non le istruzioni dell&amp;rsquo;agente.&lt;/p&gt;
&lt;p&gt;Questo significa: anche se qualcuno inganna l&amp;rsquo;agente facendogli tentare di recuperare i dati di un altro cliente, il token non lo autorizzerà.&lt;/p&gt;
&lt;h2 id="cosa-distribuisce-il-template"&gt;Cosa Distribuisce il Template&lt;/h2&gt;
&lt;p&gt;Con pochi comandi &lt;code&gt;azd&lt;/code&gt; ottieni:&lt;/p&gt;
&lt;ul&gt;
&lt;li&gt;Un agente backend su Microsoft Foundry (C#, SDK Microsoft A2A e MCP)&lt;/li&gt;
&lt;li&gt;Un server MCP che espone un&amp;rsquo;API di portafoglio di esempio&lt;/li&gt;
&lt;li&gt;Curity Identity Server come server di autorizzazione, insieme a Entra ID per l&amp;rsquo;autenticazione&lt;/li&gt;
&lt;li&gt;Gateway API esterni e interni che gestiscono lo scambio di token e il logging degli audit&lt;/li&gt;
&lt;li&gt;Bicep per tutta l&amp;rsquo;infrastruttura Azure: Container Apps, VNet, ACR, Azure AI Foundry, Key Vault, Azure SQL Database, storage&lt;/li&gt;
&lt;/ul&gt;
&lt;p&gt;L&amp;rsquo;intero pattern è ispezionabile e personalizzabile.&lt;/p&gt;
&lt;h2 id="il-principio-di-design-che-vale-la-pena-adottare"&gt;Il Principio di Design che Vale la Pena Adottare&lt;/h2&gt;
&lt;p&gt;Anche se non usi Curity, il pattern è trasferibile: &lt;strong&gt;gli agenti non dovrebbero mai avere accesso permanente all&amp;rsquo;API&lt;/strong&gt;. Ogni azione dovrebbe usare un token di breve durata con il minimo scope necessario per quella specifica chiamata, emesso per la specifica identità dell&amp;rsquo;agente, con i claim di cui l&amp;rsquo;API ha bisogno per prendere decisioni di autorizzazione.&lt;/p&gt;
&lt;p&gt;Questo regge contro agenti creativi, errori e prompt injection in modi che &amp;ldquo;assicurati solo che l&amp;rsquo;agente non faccia cose cattive&amp;rdquo; non farà mai.&lt;/p&gt;
&lt;h2 id="conclusione"&gt;Conclusione&lt;/h2&gt;
&lt;p&gt;I pattern di sicurezza per gli agenti IA sono ancora in fase di definizione in tutto il settore. Questo template è una delle implementazioni di riferimento più complete che ho visto — copre il flusso di autorizzazione reale, non solo l&amp;rsquo;autenticazione.&lt;/p&gt;
&lt;p&gt;Post originale: &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>