<?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/hi/tags/oauth/</link><description>Articles, tutorials and insights from the .NET community.</description><generator>Hugo</generator><language>hi</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/hi/tags/oauth/index.xml" rel="self" type="application/rss+xml"/><item><title>आपके AI एजेंट में एक पहचान समस्या है (और यहाँ है वह टेम्पलेट जो इसे हल करता है)</title><link>https://thedotnetblog.com/hi/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/hi/news/emiliano-montesdeoca/azd-least-privilege-ai-agents-oauth-token-pattern/</guid><description>Curity और Microsoft का एक नया azd टेम्पलेट दिखाता है कि AI एजेंट कैसे बनाएं जो बारीक स्कोप के साथ अल्पकालिक OAuth टोकन का उपयोग करते हैं — ताकि एजेंट कभी भी ऐसा डेटा न देख सकें जो उन्हें नहीं देखना चाहिए।</description><content:encoded>&lt;p&gt;हर AI एजेंट प्रोजेक्ट में एक ऐसा क्षण आता है जो कुछ इस तरह जाता है: डेमो पूरी तरह काम करता है, एजेंट प्राकृतिक भाषा की व्याख्या करता है, सही API कॉल करता है, सही डेटा लौटाता है। फिर आप वास्तविक उपयोगकर्ताओं के बारे में सोचना शुरू करते हैं।&lt;/p&gt;
&lt;p&gt;एक उपयोगकर्ता के एजेंट सत्र को दूसरे उपयोगकर्ता का डेटा देखने से क्या रोकता है? क्या होगा अगर एजेंट को प्रॉम्प्ट इंजेक्शन के माध्यम से धोखा दिया जाए? क्या होगा अगर यह किसी अप्रत्याशित तरीके से एक टूल को कॉल करे?&lt;/p&gt;
&lt;p&gt;ये एज केस नहीं हैं। ये वे डिज़ाइन निर्णय हैं जो आपको रिलीज़ से पहले लेने होंगे।&lt;/p&gt;
&lt;p&gt;Curity और Microsoft का एक नया &lt;code&gt;azd&lt;/code&gt; टेम्पलेट आपको ठीक इसी समस्या के लिए एक कार्यशील संदर्भ देता है।&lt;/p&gt;
&lt;h2 id="मखय-समसय-परमणकरण--परधकरण"&gt;मुख्य समस्या: प्रमाणीकरण ≠ प्राधिकरण&lt;/h2&gt;
&lt;p&gt;अधिकांश एजेंट सैंपल उपयोगकर्ता प्रमाणीकरण को अच्छी तरह संभालते हैं। वे प्राधिकरण को खराब तरीके से संभालते हैं। यह जानना कि उपयोगकर्ता &lt;em&gt;कौन&lt;/em&gt; है, आपको नहीं बताता कि उन्हें &lt;em&gt;कौन सा डेटा&lt;/em&gt; देखना चाहिए।&lt;/p&gt;
&lt;p&gt;एक पारंपरिक क्लाइंट ऐप अनुमानित API कॉल करता है। AI एजेंट गैर-नियतात्मक है — यह प्राकृतिक भाषा की व्याख्या करता है और तय करता है कि क्या कॉल करना है। यह रचनात्मक हो सकता है। यह गलत भी हो सकता है। और अगर इसे प्रॉम्प्ट इंजेक्शन के माध्यम से हेरफेर किया जाए, तो आपको ऐसे नियमों की ज़रूरत है जो AI के अच्छे व्यवहार पर निर्भर न हों।&lt;/p&gt;
&lt;p&gt;इस टेम्पलेट द्वारा प्रदर्शित समाधान: &lt;strong&gt;अल्पकालिक टोकन जो प्रत्येक हॉप के लिए बिल्कुल सही जानकारी ले जाते हैं&lt;/strong&gt;।&lt;/p&gt;
&lt;h2 id="टकन-चन-कस-कम-करत-ह"&gt;टोकन चेन कैसे काम करती है&lt;/h2&gt;
&lt;p&gt;टेम्पलेट प्रत्येक चरण में अनुमतियों को संकुचित करने के लिए टोकन एक्सचेंज के साथ OAuth 2.0 एक्सेस टोकन का उपयोग करता है। MCP सर्वर तक पहुंचने से पहले उपयोगकर्ता टोकन दो बार एक्सचेंज होता है:&lt;/p&gt;
&lt;ol&gt;
&lt;li&gt;&lt;strong&gt;पहला एक्सचेंज&lt;/strong&gt; — स्कोप को संकुचित करता है और अपारदर्शी टोकन को JWT में परिवर्तित करता है&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;दूसरा एक्सचेंज&lt;/strong&gt; — MCP सर्वर हॉप के लिए एजेंट पहचान और एक नई ऑडियंस जोड़ता है&lt;/li&gt;
&lt;/ol&gt;
&lt;p&gt;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; प्राधिकरण सर्वर द्वारा टोकन में एम्बेड किया गया है, न कि एक पैरामीटर के रूप में जो एजेंट नियंत्रित करता है। API टोकन की जाँच करता है, एजेंट के निर्देशों की नहीं।&lt;/p&gt;
&lt;p&gt;इसका मतलब है: भले ही कोई एजेंट को किसी अन्य ग्राहक का डेटा प्राप्त करने की कोशिश करने के लिए धोखा दे, टोकन इसे अधिकृत नहीं करेगा।&lt;/p&gt;
&lt;h2 id="टमपलट-कय-तनत-करत-ह"&gt;टेम्पलेट क्या तैनात करता है&lt;/h2&gt;
&lt;p&gt;कुछ &lt;code&gt;azd&lt;/code&gt; कमांड के साथ आपको मिलता है:&lt;/p&gt;
&lt;ul&gt;
&lt;li&gt;Microsoft Foundry पर एक बैकएंड एजेंट (C#, Microsoft A2A और MCP SDK)&lt;/li&gt;
&lt;li&gt;एक MCP सर्वर जो एक नमूना पोर्टफोलियो API को उजागर करता है&lt;/li&gt;
&lt;li&gt;प्राधिकरण सर्वर के रूप में Curity Identity Server, प्रमाणीकरण के लिए Entra ID के साथ&lt;/li&gt;
&lt;li&gt;बाहरी और आंतरिक API गेटवे जो टोकन एक्सचेंज और ऑडिट लॉगिंग संभालते हैं&lt;/li&gt;
&lt;li&gt;सभी Azure इन्फ्रास्ट्रक्चर के लिए Bicep: Container Apps, VNet, ACR, Azure AI Foundry, Key Vault, Azure SQL Database, स्टोरेज&lt;/li&gt;
&lt;/ul&gt;
&lt;p&gt;पूरा पैटर्न निरीक्षणीय और अनुकूलनीय है।&lt;/p&gt;
&lt;h2 id="उधर-लन-लयक-डजइन-सदधत"&gt;उधार लेने लायक डिज़ाइन सिद्धांत&lt;/h2&gt;
&lt;p&gt;भले ही आप Curity का उपयोग न करें, पैटर्न स्थानांतरणीय है: &lt;strong&gt;एजेंटों के पास कभी भी स्थायी API एक्सेस नहीं होनी चाहिए&lt;/strong&gt;। प्रत्येक कार्रवाई को उस विशिष्ट कॉल के लिए आवश्यक न्यूनतम स्कोप के साथ एक अल्पकालिक टोकन का उपयोग करना चाहिए, विशिष्ट एजेंट पहचान के लिए जारी किया गया, उन दावों को वहन करते हुए जो API को प्राधिकरण निर्णय लेने के लिए चाहिए।&lt;/p&gt;
&lt;p&gt;यह रचनात्मक एजेंटों, गलतियों और प्रॉम्प्ट इंजेक्शन का सामना उन तरीकों से करता है जो &amp;ldquo;बस सुनिश्चित करें कि एजेंट बुरी चीजें न करे&amp;rdquo; कभी नहीं कर सकता।&lt;/p&gt;
&lt;h2 id="नषकरष"&gt;निष्कर्ष&lt;/h2&gt;
&lt;p&gt;AI एजेंटों के लिए सुरक्षा पैटर्न अभी भी उद्योग भर में काम किए जा रहे हैं। यह टेम्पलेट मैंने देखे सबसे पूर्ण संदर्भ कार्यान्वयनों में से एक है — यह केवल प्रमाणीकरण नहीं बल्कि वास्तविक प्राधिकरण प्रवाह को कवर करता है।&lt;/p&gt;
&lt;p&gt;मूल पोस्ट: &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>