<?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/pt/tags/oauth/</link><description>Articles, tutorials and insights from the .NET community.</description><generator>Hugo</generator><language>pt</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/pt/tags/oauth/index.xml" rel="self" type="application/rss+xml"/><item><title>O Seu Agente de IA Tem um Problema de Identidade (E Aqui Está o Template que o Resolve)</title><link>https://thedotnetblog.com/pt/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/pt/news/emiliano-montesdeoca/azd-least-privilege-ai-agents-oauth-token-pattern/</guid><description>Um novo template azd da Curity e Microsoft mostra como construir agentes de IA que usam tokens OAuth de curta duração com escopos de granularidade fina — para que os agentes nunca possam ver dados que não deveriam ver.</description><content:encoded>&lt;p&gt;Há um momento em cada projeto de agente de IA que vai mais ou menos assim: a demo funciona perfeitamente, o agente interpreta a linguagem natural, chama as APIs certas, retorna os dados certos. Então você começa a pensar nos usuários reais.&lt;/p&gt;
&lt;p&gt;O que impede a sessão do agente de um usuário de ver os dados de outro usuário? E se o agente for enganado por injeção de prompt? E se ele chamar uma ferramenta de uma forma inesperada?&lt;/p&gt;
&lt;p&gt;Estes não são casos extremos. São decisões de design que você precisa tomar antes de lançar.&lt;/p&gt;
&lt;p&gt;Um novo template &lt;code&gt;azd&lt;/code&gt; da Curity e Microsoft fornece uma referência funcional para exatamente este problema.&lt;/p&gt;
&lt;h2 id="o-problema-central-autenticação--autorização"&gt;O Problema Central: Autenticação ≠ Autorização&lt;/h2&gt;
&lt;p&gt;A maioria dos exemplos de agentes trata bem a autenticação de usuários. Trata mal a autorização. Saber &lt;em&gt;quem&lt;/em&gt; é o usuário não te diz &lt;em&gt;quais dados&lt;/em&gt; ele deveria ver.&lt;/p&gt;
&lt;p&gt;Uma aplicação cliente tradicional faz chamadas de API previsíveis. Um agente de IA é não-determinístico — interpreta a linguagem natural e decide o que chamar. Pode ser criativo. Também pode estar errado. E se for manipulado por injeção de prompt, você precisa de regras que não dependam do bom comportamento da IA.&lt;/p&gt;
&lt;p&gt;A solução que este template demonstra: &lt;strong&gt;tokens de curta duração que carregam exatamente as informações certas para cada salto&lt;/strong&gt;.&lt;/p&gt;
&lt;h2 id="como-funciona-a-cadeia-de-tokens"&gt;Como Funciona a Cadeia de Tokens&lt;/h2&gt;
&lt;p&gt;O template usa tokens de acesso OAuth 2.0 com troca de tokens para restringir permissões a cada passo. Um token de usuário é trocado duas vezes antes de chegar ao servidor MCP:&lt;/p&gt;
&lt;ol&gt;
&lt;li&gt;&lt;strong&gt;Primeira troca&lt;/strong&gt; — restringe o escopo e converte o token opaco em JWT&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;Segunda troca&lt;/strong&gt; — adiciona a identidade do agente e um novo audience para o salto do servidor MCP&lt;/li&gt;
&lt;/ol&gt;
&lt;p&gt;Como é o token do 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;O &lt;code&gt;customer_id&lt;/code&gt; está incorporado no token pelo servidor de autorização, não passado como um parâmetro que o agente controla. A API verifica o token, não as instruções do agente.&lt;/p&gt;
&lt;p&gt;Isso significa: mesmo que alguém engane o agente para tentar buscar os dados de outro cliente, o token não autorizará.&lt;/p&gt;
&lt;h2 id="o-que-o-template-implanta"&gt;O que o Template Implanta&lt;/h2&gt;
&lt;p&gt;Com alguns comandos &lt;code&gt;azd&lt;/code&gt; você obtém:&lt;/p&gt;
&lt;ul&gt;
&lt;li&gt;Um agente backend no Microsoft Foundry (C#, SDKs Microsoft A2A e MCP)&lt;/li&gt;
&lt;li&gt;Um servidor MCP que expõe uma API de portfólio de exemplo&lt;/li&gt;
&lt;li&gt;Curity Identity Server como servidor de autorização, junto com Entra ID para autenticação&lt;/li&gt;
&lt;li&gt;Gateways de API externos e internos que gerenciam a troca de tokens e o registro de auditoria&lt;/li&gt;
&lt;li&gt;Bicep para toda a infraestrutura Azure: Container Apps, VNet, ACR, Azure AI Foundry, Key Vault, Azure SQL Database, armazenamento&lt;/li&gt;
&lt;/ul&gt;
&lt;p&gt;Todo o padrão é inspecionável e personalizável.&lt;/p&gt;
&lt;h2 id="o-princípio-de-design-que-vale-a-pena-adotar"&gt;O Princípio de Design que Vale a Pena Adotar&lt;/h2&gt;
&lt;p&gt;Mesmo se você não usar Curity, o padrão é transferível: &lt;strong&gt;agentes nunca deveriam ter acesso permanente à API&lt;/strong&gt;. Cada ação deveria usar um token de curta duração com o escopo mínimo necessário para aquela chamada específica, emitido para a identidade específica do agente, carregando as claims de que a API precisa para tomar decisões de autorização.&lt;/p&gt;
&lt;p&gt;Isso resiste a agentes criativos, erros e injeção de prompt de maneiras que &amp;ldquo;apenas certifique-se de que o agente não faça coisas ruins&amp;rdquo; nunca resistirá.&lt;/p&gt;
&lt;h2 id="conclusão"&gt;Conclusão&lt;/h2&gt;
&lt;p&gt;Os padrões de segurança para agentes de IA ainda estão sendo desenvolvidos em toda a indústria. Este template é uma das implementações de referência mais completas que vi — cobre o fluxo de autorização real, não apenas a autenticação.&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>