
यह Google Agent Development Kit (ADK) पर आधारित एक बुद्धिमान व्यय प्रतिपूर्ति एजेंट है, जो Agent2Agent (A2A) सर्वर के रूप में चलता है। इस एजेंट की मुख्य विशेषता बुद्धिमान फॉर्म जेनरेशन है: जब उपयोगकर्ता के प्रतिपूर्ति अनुरोध में आवश्यक जानकारी की कमी होती है, तो एजेंट स्वचालित रूप से उपयोगकर्ता के भरने के लिए एक फॉर्म जेनरेट करता है, जिससे प्रसंस्करण से पहले पूर्ण प्रतिपूर्ति जानकारी एकत्र करना सुनिश्चित होता है।
स्रोत कोड
🎯 प्रोजेक्ट विशेषताएं
- बुद्धिमान फॉर्म इंटरैक्शन: गुम जानकारी को स्वचालित रूप से पहचानता है और डायनामिक फॉर्म जेनरेट करता है
- A2A प्रोटोकॉल समर्थन: मानकीकृत इंटर-एजेंट संचार प्रोटोकॉल
- स्ट्रीमिंग प्रसंस्करण: रियल-टाइम प्रतिक्रियाओं और स्थिति अपडेट का समर्थन करता है
- Google ADK एकीकरण: Google के नवीनतम एजेंट डेवलपमेंट किट पर आधारित
📋 सिस्टम आवश्यकताएं
- Python 3.12 या उच्चतर
- UV पैकेज प्रबंधन उपकरण
- Google API Key (Gemini मॉडल एक्सेस)
🚀 त्वरित शुरुआत
1. Google API Key प्राप्त करें
- Google AI Studio पर जाएं
- अपने Google खाते से लॉग इन करें
- "Get API key" पर क्लिक करें
- नई API key बनाएं या मौजूदा का उपयोग करें
- बाद में उपयोग के लिए API key कॉपी करें
2. पर्यावरण कॉन्फ़िगरेशन
# प्रोजेक्ट को स्थानीय रूप से क्लोन करें (यदि आवश्यक हो)
git clone https://github.com/sing1ee/a2a-adk-expense-reimbursement.git
cd a2a-adk-expense-reimbursement
# पर्यावरण चर फ़ाइल बनाएं
echo "GOOGLE_API_KEY=your_api_key_here" > .env
# your_api_key_here को अपनी वास्तविक API key से बदलें
3. निर्भरताएं स्थापित करें और चलाएं
# वर्चुअल वातावरण सक्रिय करें
source .venv/bin/activate
# uv का उपयोग करके प्रोजेक्ट चलाएं
uv run .
सर्वर http://localhost:10002 पर शुरू होगा।
4. CLI क्लाइंट के साथ परीक्षण
एक नई टर्मिनल विंडो खोलें:
git clone https://github.com/a2aproject/a2a-samples.git
# CLI क्लाइंट डायरेक्टरी में नेविगेट करें (samples/python/hosts/cli में मान लेते हैं)
cd a2a-samples/samples/python/hosts/cli
# प्रतिपूर्ति एजेंट से कनेक्ट करें
uv run . --agent http://localhost:10002
5. परीक्षण इंटरैक्शन उदाहरण
CLI क्लाइंट में निम्नलिखित परीक्षण कमांड दर्ज करें:
# उदाहरण 1: गुम जानकारी के साथ अनुरोध (फॉर्म ट्रिगर होगा)
मुझे दोपहर के भोजन के लिए $20 की प्रतिपूर्ति की आवश्यकता है
# उदाहरण 2: पूर्ण जानकारी के साथ अनुरोध
मुझे 15 जनवरी, 2024 को क्लाइंट दोपहर के भोजन के लिए $50 की प्रतिपूर्ति की आवश्यकता है
# उदाहरण 3: आंशिक जानकारी के साथ अनुरोध
कृपया कल के परिवहन खर्च $25 की प्रतिपूर्ति में मेरी सहायता करें
🏗️ प्रोजेक्ट आर्किटेक्चर
मुख्य फ़ाइल संरचना
a2a-adk-expense-reimbursement/
├── __main__.py # सर्वर स्टार्टअप एंट्री पॉइंट
├── agent.py # मुख्य एजेंट लॉजिक
├── agent_executor.py # A2A अनुरोध निष्पादक
├── pyproject.toml # प्रोजेक्ट कॉन्फ़िगरेशन और निर्भरताएं
└── README.md # प्रोजेक्ट दस्तावेज़
मुख्य घटक विवरण
1. __main__.py - सर्वर एंट्री
- A2A सर्वर और एजेंट जानकारी कॉन्फ़िगर करें
- एजेंट कौशल और क्षमता विवरण सेट करें
- अनुरोधों को सुनने के लिए HTTP सर्वर शुरू करें
2. agent.py - मुख्य एजेंट लॉजिक
तीन मुख्य टूल फ़ंक्शन शामिल हैं:
create_request_form(): प्रतिपूर्ति फॉर्म टेम्प्लेट बनाएंreturn_form(): फॉर्म को A2A प्रोटोकॉल प्रारूप में लपेटें और वापस करेंreimburse(): वास्तविक प्रतिपूर्ति अनुमोदन ऑपरेशन निष्पादित करें
3. agent_executor.py - अनुरोध निष्पादक
- A2A प्रोटोकॉल अनुरोधों और प्रतिक्रियाओं को संभालें
- कार्य स्थितियों का प्रबंधन करें (काम कर रहा है, इनपुट की आवश्यकता है, पूर्ण, आदि)
- एजेंट और A2A सर्वर के बीच संचार का समन्वय करें
🔄 मुख्य वर्कफ़्लो
निम्नलिखित अनुक्रम आरेख प्रतिपूर्ति एजेंट के पूर्ण इंटरैक्शन प्रवाह को दिखाता है:
sequenceDiagram
participant User as उपयोगकर्ता/CLI क्लाइंट
participant Server as A2A सर्वर
participant Agent as प्रतिपूर्ति एजेंट
participant LLM as Gemini 2.0 Flash
User->>Server: प्रतिपूर्ति अनुरोध भेजें<br/>"मुझे दोपहर के भोजन के लिए $20 की प्रतिपूर्ति की आवश्यकता है"
Server->>Agent: उपयोगकर्ता अनुरोध अग्रेषित करें
Agent->>LLM: अनुरोध सामग्री का विश्लेषण करें
LLM->>Agent: गुम तारीख और अन्य जानकारी की पहचान करें
Agent->>Agent: create_request_form() कॉल करें
Agent->>Agent: return_form() कॉल करें
Agent->>Server: फॉर्म संरचना वापस करें
Server->>User: JSON फॉर्म वापस करें<br/>तारीख, राशि, उद्देश्य फ़ील्ड शामिल
User->>User: उपयोगकर्ता फॉर्म भरता है<br/>तारीख, राशि, उद्देश्य
User->>Server: पूर्ण फॉर्म सबमिट करें
Server->>Agent: फॉर्म डेटा अग्रेषित करें
Agent->>LLM: फॉर्म पूर्णता सत्यापित करें
LLM->>Agent: जानकारी पूर्ण होने की पुष्टि करें
Agent->>Agent: reimburse(request_id) कॉल करें
Agent->>Server: अनुमोदन परिणाम वापस करें
Server->>User: अंतिम परिणाम वापस करें<br/>"प्रतिपूर्ति अनुमोदित"
वर्कफ़्लो विवरण
- अनुरोध स्वीकृति: उपयोगकर्ता CLI क्लाइंट के माध्यम से प्रतिपूर्ति अनुरोध भेजता है
- बुद्धिमान विश्लेषण: Gemini मॉडल अनुरोध का विश्लेषण करता है और गुम आवश्यक जानकारी की पहचान करता है
- फॉर्म जेनरेशन: यदि जानकारी अधूरी है, तो आवश्यक फ़ील्ड के साथ स्वचालित रूप से फॉर्म जेनरेट करें
- उपयोगकर्ता इंटरैक्शन: उपयोगकर्ता गुम जानकारी को पूरा करने के लिए फॉर्म भरता है
- जानकारी सत्यापन: फॉर्म डेटा की पूर्णता और वैधता सत्यापित करें
- प्रतिपूर्ति प्रसंस्करण: प्रतिपूर्ति अनुमोदन निष्पादित करें और परिणाम वापस करें
🛠️ उन्नत कॉन्फ़िगरेशन
पर्यावरण चर
# Google API कॉन्फ़िगरेशन
GOOGLE_API_KEY=your_api_key_here
# Vertex AI का उपयोग करें (वैकल्पिक)
GOOGLE_GENAI_USE_VERTEXAI=TRUE
# सर्वर कॉन्फ़िगरेशन
HOST=localhost
PORT=10002
कस्टम पोर्ट के साथ चलाएं
uv run . --host 0.0.0.0 --port 8080
🧪 विकास और डिबगिंग
विस्तृत लॉगिंग सक्षम करें
एजेंट डिफ़ॉल्ट रूप से INFO स्तर लॉगिंग सक्षम करता है। विस्तृत अनुरोध प्रसंस्करण देखें:
# सर्वर लॉग देखें
uv run . 2>&1 | tee agent.log
फॉर्म संरचना उदाहरण
एजेंट JSON Schema प्रारूप का पालन करने वाले फॉर्म जेनरेट करता है:
{
"type": "form",
"form": {
"type": "object",
"properties": {
"date": {
"type": "string",
"format": "date",
"title": "Date",
"description": "Date of expense"
},
"amount": {
"type": "string",
"format": "number",
"title": "Amount",
"description": "Amount of expense"
},
"purpose": {
"type": "string",
"title": "Purpose",
"description": "Purpose of expense"
}
},
"required": ["date", "amount", "purpose"]
}
}
⚠️ सुरक्षा विचार
महत्वपूर्ण सूचना: यह नमूना कोड केवल Agent2Agent (A2A) प्रोटोकॉल के काम करने के तरीके को दिखाने के लिए प्रदर्शन उद्देश्यों के लिए है। उत्पादन अनुप्रयोगों का निर्माण करते समय, किसी भी बाहरी एजेंट को संभावित रूप से अविश्वसनीय इकाई के रूप में माना जाना चाहिए।
सुरक्षा उपाय
- इनपुट सत्यापन: सभी बाहरी इनपुट को सख्ती से सत्यापित और साफ करें
- डेटा प्रसंस्करण: एजेंट कार्ड, संदेश, कलाकृतियों और अन्य डेटा को सावधानी से संभालें
- क्रेडेंशियल प्रबंधन: उचित क्रेडेंशियल सुरक्षा उपाय लागू करें
- अनुमति नियंत्रण: एजेंट की पहुंच अनुमतियों और ऑपरेशन स्कोप को सीमित करें
Related Articles
Explore more content related to this topic
Content Planner Agent Based on A2A and ADK
An intelligent content planning agent based on Google ADK and A2A protocol that creates detailed content outlines from high-level content descriptions.
Implementing A2A Agents with ADK: Complete Development Guide
This guide provides a detailed introduction on how to use Google ADK (Agent Development Kit) framework to implement A2A (Agent2Agent Protocol) intelligent agent systems. From environment setup, project structure design to server-side and client-side agent development, covering the complete development process to help developers quickly build intelligent agent applications that support distributed communication.
A2UI Introduction - Declarative UI Protocol for Agent-Driven Interfaces
Discover A2UI, the declarative UI protocol that enables AI agents to generate rich, interactive user interfaces. Learn how A2UI works, who it's for, how to use it, and see real-world examples from Google Opal, Gemini Enterprise, and Flutter GenUI SDK.
Agent Gateway Protocol (AGP): Practical Tutorial and Specification
Learn the Agent Gateway Protocol (AGP): what it is, problems it solves, core spec (capability announcements, intent payloads, routing and error codes), routing algorithm, and how to run a working simulation.
Integrating A2A Protocol - Intelligent Agent Communication Solution for BeeAI Framework
Using A2A protocol instead of ACP is a better choice for BeeAI, reducing protocol fragmentation and improving ecosystem integration.