Go Template उपयोग गाइड
यह दस्तावेज़ MCP Gateway में Go Template का उपयोग करके अनुरोध और प्रतिक्रिया डेटा को संसाधित करने के तरीके का वर्णन करता है। Go Template शक्तिशाली टेम्पलेट क्षमताएं प्रदान करता है जो हमें डेटा परिवर्तन और फॉर्मेटिंग को लचीले ढंग से संसाधित करने में मदद करता है।
बुनियादी वाक्यविन्यास
Go Template {{}} को डिलिमिटर के रूप में उपयोग करता है, जिसके भीतर विभिन्न फ़ंक्शन और वेरिएबल का उपयोग किया जा सकता है। MCP Gateway में, हम मुख्य रूप से निम्नलिखित वेरिएबल का उपयोग करते हैं:
.Config: सेवा-स्तरीय कॉन्फ़िगरेशन.Args: अनुरोध पैरामीटर.Request: मूल अनुरोध जानकारी.Response: अपस्ट्रीम सेवा प्रतिक्रिया जानकारी
सामान्य उपयोग के मामले
1. पर्यावरण चर से कॉन्फ़िगरेशन प्राप्त करना
config:
  Authorization: 'Bearer {{ env "AUTH_TOKEN" }}'  # पर्यावरण चर से कॉन्फ़िगरेशन प्राप्त करें
2. अनुरोध हेडर से मान निकालना
headers:
  Authorization: "{{.Request.Headers.Authorization}}"   # क्लाइंट का Authorization हेडर आगे भेजें
  Cookie: "{{.Config.Cookie}}"                         # सेवा कॉन्फ़िगरेशन से मान का उपयोग करें
3. अनुरोध बॉडी का निर्माण
requestBody: |-
  {
    "username": "{{.Args.username}}",
    "email": "{{.Args.email}}"
  }
4. प्रतिक्रिया डेटा का संसाधन
responseBody: |-
  {
    "id": "{{.Response.Data.id}}",
    "username": "{{.Response.Data.username}}",
    "email": "{{.Response.Data.email}}",
    "createdAt": "{{.Response.Data.createdAt}}"
  }
5. नेस्टेड प्रतिक्रिया डेटा का संसाधन
responseBody: |-
  {
    "id": "{{.Response.Data.id}}",
    "username": "{{.Response.Data.username}}",
    "email": "{{.Response.Data.email}}",
    "createdAt": "{{.Response.Data.createdAt}}",
    "preferences": {
      "isPublic": {{.Response.Data.preferences.isPublic}},
      "showEmail": {{.Response.Data.preferences.showEmail}},
      "theme": "{{.Response.Data.preferences.theme}}",
      "tags": {{.Response.Data.preferences.tags}}
    }
  }
6. सरणी डेटा का संसाधन
प्रतिक्रियाओं में सरणी डेटा को संसाधित करते समय, आप Go Template की range कार्यक्षमता का उपयोग कर सकते हैं:
responseBody: |-
  {
    "total": "{{.Response.Data.total}}",
    "rows": [
      {{- $len := len .Response.Data.rows -}}
      {{- $rows := fromJSON .Response.Data.rows }}
      {{- range $i, $e := $rows }}
      {
        "id": {{ $e.id }},
        "detail": "{{ $e.detail }}",
        "deviceName": "{{ $e.deviceName }}"
      }{{ if lt (add $i 1) $len }},{{ end }}
      {{- end }}
    ]
  }
यह उदाहरण दर्शाता है:
- JSON स्ट्रिंग को पारगम्य वस्तु में बदलने के लिए 
fromJSONफ़ंक्शन का उपयोग - सरणी पर पुनरावृत्ति के लिए 
rangeका उपयोग - सरणी की लंबाई प्राप्त करने के लिए 
lenफ़ंक्शन का उपयोग - गणितीय संचालन के लिए 
addफ़ंक्शन का उपयोग - सरणी तत्वों के बीच अल्पविराम विभाजन को नियंत्रित करने के लिए सशर्त कथनों का उपयोग
 
7. URL में पैरामीटर का उपयोग
endpoint: "http://localhost:5236/users/{{.Args.email}}/preferences"
8. जटिल ऑब्जेक्ट डेटा का संचालन
जब आपको अनुरोध या प्रतिक्रियाओं में ऑब्जेक्ट या एरे जैसी जटिल संरचनाओं को JSON में बदलने की आवश्यकता होती है, तो आप toJSON फ़ंक्शन का उपयोग कर सकते हैं:
requestBody: |-
  {
    "isPublic": {{.Args.isPublic}},
    "showEmail": {{.Args.showEmail}},
    "theme": "{{.Args.theme}}",
    "tags": {{.Args.tags}},
    "settings": {{ toJSON .Args.settings }}
  }
इस मामले में, settings एक जटिल ऑब्जेक्ट है जिसे toJSON फ़ंक्शन का उपयोग करके स्वचालित रूप से JSON स्ट्रिंग में बदल दिया जाएगा।
अंतर्निहित फ़ंक्शन
वर्तमान में समर्थित अंतर्निहित फ़ंक्शन:
- 
env: पर्यावरण चर मान प्राप्त करेंAuthorization: 'Bearer {{ env "AUTH_TOKEN" }}' - 
add: पूर्णांक जोड़ करें{{ if lt (add $i 1) $len }},{{ end }} - 
fromJSON: JSON स्ट्रिंग को पारगम्य वस्तु में बदलें{{- $rows := fromJSON .Response.Data.rows }} - 
toJSON: ऑब्जेक्ट को JSON स्ट्रिंग में बदलें"settings": {{ toJSON .Args.settings }} 
नए टेम्पलेट फ़ंक्शन जोड़ने के लिए:
- विशिष्ट उपयोग के मामले का वर्णन करें और एक issue बनाएं
 - PR योगदान का स्वागत है, लेकिन वर्तमान में केवल सामान्य उद्देश्य वाले फ़ंक्शन स्वीकार किए जाते हैं