<?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/tr/tags/oauth/</link><description>Articles, tutorials and insights from the .NET community.</description><generator>Hugo</generator><language>tr</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/tr/tags/oauth/index.xml" rel="self" type="application/rss+xml"/><item><title>AI Ajanınızın Bir Kimlik Sorunu Var (Ve İşte Bunu Çözen Şablon)</title><link>https://thedotnetblog.com/tr/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/tr/news/emiliano-montesdeoca/azd-least-privilege-ai-agents-oauth-token-pattern/</guid><description>Curity ve Microsoft'tan yeni bir azd şablonu, ince taneli kapsamlara sahip kısa ömürlü OAuth belirteçleri kullanan AI ajanlarının nasıl oluşturulacağını gösteriyor — böylece ajanlar asla görmemesi gereken verileri göremez.</description><content:encoded>&lt;p&gt;Her AI ajan projesinde şöyle bir an gelir: Demo mükemmel çalışır, ajan doğal dili yorumlar, doğru API&amp;rsquo;leri çağırır, doğru verileri döndürür. Sonra gerçek kullanıcıları düşünmeye başlarsınız.&lt;/p&gt;
&lt;p&gt;Bir kullanıcının ajan oturumunun başka bir kullanıcının verilerini görmesini ne engeller? Ya ajan, istem enjeksiyonu yoluyla kandırılırsa? Ya bir aracı beklenmedik bir şekilde çağırırsa?&lt;/p&gt;
&lt;p&gt;Bunlar kenar durumlar değil. Bunlar yayın öncesinde vermeniz gereken tasarım kararları.&lt;/p&gt;
&lt;p&gt;Curity ve Microsoft&amp;rsquo;tan yeni bir &lt;code&gt;azd&lt;/code&gt; şablonu, tam olarak bu sorun için çalışan bir referans sağlar.&lt;/p&gt;
&lt;h2 id="temel-sorun-kimlik-doğrulama--yetkilendirme"&gt;Temel Sorun: Kimlik Doğrulama ≠ Yetkilendirme&lt;/h2&gt;
&lt;p&gt;Çoğu ajan örneği, kullanıcı kimlik doğrulamasını iyi şekilde ele alır. Yetkilendirmeyi ise kötü şekilde ele alır. Kullanıcının &lt;em&gt;kim&lt;/em&gt; olduğunu bilmek, hangi &lt;em&gt;verileri&lt;/em&gt; görmeleri gerektiğini söylemez.&lt;/p&gt;
&lt;p&gt;Geleneksel bir istemci uygulaması öngörülebilir API çağrıları yapar. Bir AI ajanı deterministik değildir — doğal dili yorumlar ve neyi çağıracağına karar verir. Yaratıcı olabilir. Aynı zamanda yanılabilir. Ve istem enjeksiyonu yoluyla manipüle edilirse, AI&amp;rsquo;nin iyi davranmasına bağlı olmayan kurallara ihtiyacınız vardır.&lt;/p&gt;
&lt;p&gt;Bu şablonun gösterdiği çözüm: &lt;strong&gt;Her atlama için tam olarak doğru bilgiyi taşıyan kısa ömürlü belirteçler&lt;/strong&gt;.&lt;/p&gt;
&lt;h2 id="belirteç-zinciri-nasıl-çalışır"&gt;Belirteç Zinciri Nasıl Çalışır&lt;/h2&gt;
&lt;p&gt;Şablon, her adımda izinleri daraltmak için belirteç değişimi ile OAuth 2.0 erişim belirteçlerini kullanır. Kullanıcı belirteci, MCP sunucusuna ulaşmadan önce iki kez değiştirilir:&lt;/p&gt;
&lt;ol&gt;
&lt;li&gt;&lt;strong&gt;Birinci değişim&lt;/strong&gt; — Kapsamı daraltır ve opak belirteci JWT&amp;rsquo;ye dönüştürür&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;İkinci değişim&lt;/strong&gt; — MCP sunucu atlaması için ajan kimliği ve yeni bir hedef kitle ekler&lt;/li&gt;
&lt;/ol&gt;
&lt;p&gt;MCP sunucu belirtecinin görünümü:&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;, ajanın kontrol ettiği bir parametre olarak geçirilmez, yetkilendirme sunucusu tarafından belirtece gömülür. API, ajanın talimatlarını değil, belirteci kontrol eder.&lt;/p&gt;
&lt;p&gt;Bu şu anlama gelir: Birisi ajanı başka bir müşterinin verilerini almaya zorlamaya çalışsa bile, belirteç buna izin vermez.&lt;/p&gt;
&lt;h2 id="şablonun-dağıttıkları"&gt;Şablonun Dağıttıkları&lt;/h2&gt;
&lt;p&gt;Birkaç &lt;code&gt;azd&lt;/code&gt; komutuyla şunları elde edersiniz:&lt;/p&gt;
&lt;ul&gt;
&lt;li&gt;Microsoft Foundry üzerinde bir arka uç ajan (C#, Microsoft A2A ve MCP SDK&amp;rsquo;ları)&lt;/li&gt;
&lt;li&gt;Örnek bir portföy API&amp;rsquo;si sunan bir MCP sunucusu&lt;/li&gt;
&lt;li&gt;Kimlik doğrulama için Entra ID ile birlikte yetkilendirme sunucusu olarak Curity Identity Server&lt;/li&gt;
&lt;li&gt;Belirteç değişimini ve denetim kaydını işleyen harici ve dahili API ağ geçitleri&lt;/li&gt;
&lt;li&gt;Tüm Azure altyapısı için Bicep: Container Apps, VNet, ACR, Azure AI Foundry, Key Vault, Azure SQL Database, depolama&lt;/li&gt;
&lt;/ul&gt;
&lt;p&gt;Desenin tamamı incelenebilir ve özelleştirilebilir.&lt;/p&gt;
&lt;h2 id="ödünç-almaya-değer-tasarım-ilkesi"&gt;Ödünç Almaya Değer Tasarım İlkesi&lt;/h2&gt;
&lt;p&gt;Curity kullanmasanız bile, desen aktarılabilir: &lt;strong&gt;Ajanlar asla kalıcı API erişimine sahip olmamalıdır&lt;/strong&gt;. Her eylem, söz konusu spesifik çağrı için gereken minimum kapsama sahip kısa ömürlü bir belirteç kullanmalı, spesifik ajan kimliği için düzenlenmeli, API&amp;rsquo;nin yetkilendirme kararları almak için ihtiyaç duyduğu talepleri taşımalıdır.&lt;/p&gt;
&lt;p&gt;Bu, yaratıcı ajanlara, hatalara ve istem enjeksiyonuna karşı &amp;ldquo;sadece ajanın kötü şeyler yapmamasını sağlayın&amp;quot;ın asla sağlayamayacağı şekillerde dayanıklıdır.&lt;/p&gt;
&lt;h2 id="sonuç"&gt;Sonuç&lt;/h2&gt;
&lt;p&gt;AI ajanlar için güvenlik desenleri hâlâ sektör genelinde şekilleniyor. Bu şablon, gördüğüm en kapsamlı referans uygulamalarından biri — yalnızca kimlik doğrulamayı değil, gerçek yetkilendirme akışını da ele alıyor.&lt;/p&gt;
&lt;p&gt;Orijinal gönderi: &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>