<?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/pl/tags/oauth/</link><description>Articles, tutorials and insights from the .NET community.</description><generator>Hugo</generator><language>pl</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/pl/tags/oauth/index.xml" rel="self" type="application/rss+xml"/><item><title>Twój agent AI ma problem z tożsamością (i oto szablon, który go rozwiązuje)</title><link>https://thedotnetblog.com/pl/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/pl/news/emiliano-montesdeoca/azd-least-privilege-ai-agents-oauth-token-pattern/</guid><description>Nowy szablon azd od Curity i Microsoft pokazuje, jak budować agentów AI używających krótkotrwałych tokenów OAuth z precyzyjnymi zakresami — aby agenci nigdy nie mogli zobaczyć danych, których nie powinni widzieć.</description><content:encoded>&lt;p&gt;W każdym projekcie agenta AI jest taki moment: demo działa idealnie, agent interpretuje język naturalny, wywołuje właściwe API, zwraca właściwe dane. Potem zaczynasz myśleć o prawdziwych użytkownikach.&lt;/p&gt;
&lt;p&gt;Co powstrzymuje sesję agenta jednego użytkownika przed zobaczeniem danych innego użytkownika? Co się stanie, jeśli agent zostanie oszukany przez wstrzyknięcie promptu? Co jeśli wywołuje narzędzie w nieoczekiwany sposób?&lt;/p&gt;
&lt;p&gt;To nie są przypadki graniczne. To są decyzje projektowe, które musisz podjąć przed wydaniem.&lt;/p&gt;
&lt;p&gt;Nowy szablon &lt;code&gt;azd&lt;/code&gt; od Curity i Microsoft daje ci działające odniesienie dokładnie do tego problemu.&lt;/p&gt;
&lt;h2 id="podstawowy-problem-uwierzytelnianie--autoryzacja"&gt;Podstawowy problem: Uwierzytelnianie ≠ Autoryzacja&lt;/h2&gt;
&lt;p&gt;Większość przykładów agentów dobrze obsługuje uwierzytelnianie użytkowników. Słabo obsługuje autoryzację. Wiedza &lt;em&gt;kim&lt;/em&gt; jest użytkownik nie mówi ci &lt;em&gt;jakie dane&lt;/em&gt; powinien zobaczyć.&lt;/p&gt;
&lt;p&gt;Tradycyjna aplikacja kliencka wykonuje przewidywalne wywołania API. Agent AI jest niedeterministyczny — interpretuje język naturalny i decyduje, co wywołać. Może być kreatywny. Może też się mylić. A jeśli zostanie zmanipulowany przez wstrzyknięcie promptu, potrzebujesz reguł, które nie opierają się na dobrym zachowaniu AI.&lt;/p&gt;
&lt;p&gt;Rozwiązanie zademonstrowane przez ten szablon: &lt;strong&gt;krótkotrwałe tokeny niosące dokładnie właściwe informacje dla każdego skoku&lt;/strong&gt;.&lt;/p&gt;
&lt;h2 id="jak-działa-łańcuch-tokenów"&gt;Jak działa łańcuch tokenów&lt;/h2&gt;
&lt;p&gt;Szablon używa tokenów dostępu OAuth 2.0 z wymianą tokenów, aby zawęzić uprawnienia na każdym etapie. Token użytkownika jest wymieniany dwukrotnie przed dotarciem do serwera MCP:&lt;/p&gt;
&lt;ol&gt;
&lt;li&gt;&lt;strong&gt;Pierwsza wymiana&lt;/strong&gt; — zawęża zakres i konwertuje nieprzejrzysty token na JWT&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;Druga wymiana&lt;/strong&gt; — dodaje tożsamość agenta i nowych odbiorców dla skoku serwera MCP&lt;/li&gt;
&lt;/ol&gt;
&lt;p&gt;Jak wygląda token serwera 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;&lt;code&gt;customer_id&lt;/code&gt; jest osadzony w tokenie przez serwer autoryzacji, nie przekazywany jako parametr kontrolowany przez agenta. API sprawdza token, a nie instrukcje agenta.&lt;/p&gt;
&lt;p&gt;To oznacza: nawet jeśli ktoś oszuka agenta, aby próbował pobrać dane innego klienta, token tego nie autoryzuje.&lt;/p&gt;
&lt;h2 id="co-wdraża-szablon"&gt;Co wdraża szablon&lt;/h2&gt;
&lt;p&gt;Kilkoma poleceniami &lt;code&gt;azd&lt;/code&gt; otrzymujesz:&lt;/p&gt;
&lt;ul&gt;
&lt;li&gt;Backend agenta na Microsoft Foundry (C#, SDK Microsoft A2A i MCP)&lt;/li&gt;
&lt;li&gt;Serwer MCP eksponujący przykładowe API portfolio&lt;/li&gt;
&lt;li&gt;Curity Identity Server jako serwer autoryzacji, wraz z Entra ID do uwierzytelniania&lt;/li&gt;
&lt;li&gt;Zewnętrzne i wewnętrzne bramy API obsługujące wymianę tokenów i rejestrowanie audytu&lt;/li&gt;
&lt;li&gt;Bicep dla całej infrastruktury Azure: Container Apps, VNet, ACR, Azure AI Foundry, Key Vault, Azure SQL Database, przechowywanie&lt;/li&gt;
&lt;/ul&gt;
&lt;p&gt;Cały wzorzec jest możliwy do inspekcji i dostosowania.&lt;/p&gt;
&lt;h2 id="zasada-projektowa-warta-zapożyczenia"&gt;Zasada projektowa warta zapożyczenia&lt;/h2&gt;
&lt;p&gt;Nawet jeśli nie używasz Curity, wzorzec jest przenośny: &lt;strong&gt;agenci nigdy nie powinni mieć stałego dostępu do API&lt;/strong&gt;. Każda akcja powinna używać krótkotrwałego tokenu z minimalnym zakresem niezbędnym dla tego konkretnego wywołania, wydanego dla konkretnej tożsamości agenta, niosącego roszczenia, których API potrzebuje do podejmowania decyzji autoryzacyjnych.&lt;/p&gt;
&lt;p&gt;To wytrzymuje kreatywnych agentów, błędy i wstrzyknięcia promptów w sposób, w jaki &amp;ldquo;tylko upewnij się, że agent nie robi złych rzeczy&amp;rdquo; nigdy nie wytrzyma.&lt;/p&gt;
&lt;h2 id="podsumowanie"&gt;Podsumowanie&lt;/h2&gt;
&lt;p&gt;Wzorce bezpieczeństwa dla agentów AI są nadal opracowywane w całej branży. Ten szablon jest jedną z najbardziej kompletnych implementacji referencyjnych, jakie widziałem — obejmuje rzeczywisty przepływ autoryzacji, nie tylko uwierzytelnianie.&lt;/p&gt;
&lt;p&gt;Oryginalny post: &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>