आपको Apigee Edge दस्तावेज़ दिख रहा है.
अभी तक किसी भी व्यक्ति ने चेक इन नहीं किया है
इस पेज पर जाएं
Apigee X दस्तावेज़. जानकारी
इस सेक्शन में बताया गया है कि डेवलपर पोर्टल में पब्लिकेशन के लिए एपीआई प्रॉडक्ट बनाने के लिए, Edge API का इस्तेमाल कैसे किया जा सकता है.
एपीआई का इस्तेमाल करके एपीआई प्रॉडक्ट बनाना
एपीआई प्रॉडक्ट, डेवलपर को रजिस्टर करने में मदद करते हैं ऐसे ऐप्लिकेशन जो एपीआई पासकोड और OAuth ऐक्सेस टोकन का इस्तेमाल करके, एपीआई का इस्तेमाल करते हैं. एपीआई प्रॉडक्ट को इस तरह से डिज़ाइन किया गया है कि आपको 'बंडल' करने के लिए सक्षम करता है API संसाधनों को इकट्ठा और फिर उन बंडल को डेवलपर. उदाहरण के लिए, आपको अपने पार्टनर के लिए एपीआई संसाधनों का एक सेट पब्लिश करना पड़ सकता है जब तक डेवलपर, बाहरी डेवलपर के लिए कोई दूसरा बंडल पब्लिश करते हैं. API प्रॉडक्ट की सहायता से आप अपने एपीआई में कोई बदलाव किए बिना, तुरंत बंडलिंग करें. अगर आप अतिरिक्त फ़ायदा यह है कि डेवलपर ऐक्सेस को 'अपग्रेड' किया जा सकता है और 'डाउनग्रेड किया गया' इसके लिए, जानकारी देने की ज़रूरत नहीं होती डेवलपर को अपने ऐप्लिकेशन के लिए नई उपभोक्ता कुंजियां पाने के लिए.
एपीआई का इस्तेमाल करके एपीआई प्रॉडक्ट बनाने के लिए, पोस्ट करने का अनुरोध करें
/organizations/{org_name}/apiproducts
.
ज़्यादा जानकारी के लिए, एपीआई प्रॉडक्ट एपीआई बनाएं का रेफ़रंस देखें.
नीचे दिया गया अनुरोध, weather_free
नाम का एक एपीआई प्रॉडक्ट बनाता है. एपीआई प्रॉडक्ट
weatherapi
नाम के एपीआई प्रॉक्सी के ज़रिए दिखाए गए सभी एपीआई का ऐक्सेस देता है
test
एनवायरमेंट में डिप्लॉय किया गया है. मंज़ूरी के टाइप को auto
पर सेट किया गया है. इससे पता चलता है कि
ऐक्सेस का अनुरोध स्वीकार कर लिया जाएगा.
curl -X POST https://api.enterprise.apigee.com/v1/organization/myorg/apiproducts \ -H "Content-Type:application/json" \ -d \ '{ "approvalType": "auto", "displayName": "Free API Product", "name": "weather_free", "proxies": [ "weatherapi" ], "environments": [ "test" ] }' \ -u email:password
रिस्पॉन्स का उदाहरण:
{ "apiResources" : [ ], "approvalType" : "auto", "attributes" : [ ], "createdAt" : 1362759663145, "createdBy" : "[email protected]", "displayName" : "Free API Product", "environments" : [ "test" ], "lastModifiedAt" : 1362759663145, "lastModifiedBy" : "[email protected]", "name" : "weather_free", "proxies" : [ "weatherapi" ], "scopes" : [ ] }
ऊपर बनाया गया एपीआई प्रॉडक्ट सबसे बुनियादी स्थिति को लागू करता है. इससे किसी एनवायरमेंट में एपीआई प्रॉक्सी. यह ऐसे एपीआई प्रॉडक्ट के बारे में जानकारी देता है जो अनुमति वाले ऐप्लिकेशन को इसे ऐक्सेस करने की सुविधा देता है टेस्ट एनवायरमेंट में चल रहे एपीआई प्रॉक्सी के ज़रिए ऐक्सेस किए गए किसी भी एपीआई रिसॉर्स को. एपीआई प्रॉडक्ट इसमें अतिरिक्त कॉन्फ़िगरेशन सेटिंग दिखती हैं. इन सेटिंग की मदद से, अपने एपीआई के ऐक्सेस कंट्रोल को ज़रूरत के मुताबिक बनाया जा सकता है अलग-अलग डेवलपर ग्रुप के लिए. उदाहरण के लिए, दो एपीआई प्रॉडक्ट बनाए जा सकते हैं जो ऐक्सेस देते हैं को अलग-अलग एपीआई प्रॉक्सी के लिए डिज़ाइन किया गया है. दो एपीआई प्रॉडक्ट भी बनाए जा सकते हैं, जो दोनों के लिए एक जैसी एपीआई प्रॉक्सी, लेकिन कोटा से जुड़ी अलग-अलग सेटिंग के साथ.
एपीआई प्रॉडक्ट कॉन्फ़िगरेशन सेटिंग
एपीआई प्रॉडक्ट में ये कॉन्फ़िगरेशन विकल्प दिखते हैं:
नाम | ब्यौरा | डिफ़ॉल्ट | ज़रूरी है? |
---|---|---|---|
apiResources |
यूआरआई की कॉमा-सेपरेटेड लिस्ट या रिसॉर्स पाथ, 'बंडल किए गए' एपीआई में प्रॉडक्ट. डिफ़ॉल्ट रूप से, रिसॉर्स पाथ को कोई पाथ चुनें या सभी सबपाथ को वाइल्डकार्ड से चुनें.
वाइल्डकार्ड (/** और /*) इस्तेमाल किए जा सकते हैं. डबल एस्टरिस्क वाइल्डकार्ड से पता चलता है कि सभी
सब-यूआरआई शामिल हैं. एक तारे का निशान यह बताता है कि एक स्तर नीचे केवल यूआरआई हैं
शामिल हैं. |
लागू नहीं | नहीं |
approvalType |
इससे पता चलता है कि एपीआई प्रॉडक्ट से तय किए गए एपीआई को ऐक्सेस करने के लिए, एपीआई पासकोड को कैसे अनुमति दी जाती है. अगर आपने
manual पर सेट है. ऐप्लिकेशन के लिए जनरेट होने वाली कुंजी की वैल्यू 'मंज़ूरी बाकी है' के तौर पर सेट है राज्य.
ऐसी कुंजियां तब तक काम नहीं करेंगी, जब तक उन्हें साफ़ तौर पर अनुमति नहीं मिल जाती. अगर auto पर सेट है, तो
सभी कुंजियां, 'स्वीकार की गई' कैटगरी में जनरेट की जाती हैं और तुरंत काम करने में मदद करता है. (auto यह है
आम तौर पर, इसका इस्तेमाल मुफ़्त/ट्रायल एपीआई वाले उन प्रॉडक्ट का ऐक्सेस देने के लिए किया जाता है जो सीमित कोटा उपलब्ध कराते हैं
या क्षमताओं के बारे में नहीं बताना चाहिए.) |
लागू नहीं | हां |
attributes |
उन एट्रिब्यूट की कैटगरी जिनका इस्तेमाल डिफ़ॉल्ट एपीआई प्रॉडक्ट प्रोफ़ाइल को बढ़ाने के लिए किया जा सकता है ग्राहक के हिसाब से बना मेटाडेटा.
एपीआई प्रॉडक्ट के ऐक्सेस लेवल को सार्वजनिक, निजी या इंटरनल के तौर पर बताने के लिए, इस प्रॉपर्टी का इस्तेमाल करें. उदाहरण के लिए:
"एट्रिब्यूट": [
{
"name": "ऐक्सेस",
"value": "सार्वजनिक"
},
{
"name": "foo","value": "foo" }, { "name": "bar", "value": "bar" }
]
|
लागू नहीं | नहीं |
scopes |
OAuth दायरों की ऐसी सूची जिसकी पुष्टि रनटाइम के दौरान की जाती है. इस सूची को कॉमा लगाकर अलग किया जाता है. (Apigee एज इस बात की पुष्टि करता है कि दिए गए किसी भी ऐक्सेस टोकन में मौजूद स्कोप, एपीआई में सेट किए गए स्कोप से मेल खाते हैं product.) | लागू नहीं | नहीं |
proxies |
नाम वाली एपीआई प्रॉक्सी, जिनसे यह एपीआई प्रॉडक्ट बाउंड है. प्रॉक्सी तय करके, ये काम किए जा सकते हैं एपीआई प्रॉडक्ट में संसाधनों को खास एपीआई प्रॉक्सी के साथ जोड़ना, ताकि डेवलपर को को अन्य एपीआई प्रॉक्सी के ज़रिए उन संसाधनों को ऐक्सेस करने से रोका जा सकता है. | लागू नहीं | नहीं. अगर इसके बारे में नहीं बताया गया है, तो apiResources के बारे में साफ़ तौर पर बताया जाना चाहिए (जानकारी देखें
ऊपर apiResources के लिए) और flow.resource.name वैरिएबल इसमें सेट है
'असाइन करें' मैसेज से जुड़ी नीति. |
environments |
नाम वाले एनवायरमेंट (उदाहरण के लिए, 'टेस्ट' या 'प्रोडक्शन'), जिनसे यह एपीआई प्रॉडक्ट बाउंड है. एक या उससे ज़्यादा एनवायरमेंट तय करके, एपीआई प्रॉडक्ट में शामिल संसाधनों को बाइंड किया जा सकता है खास एनवायरमेंट के हिसाब से बनाया गया है. साथ ही, यह डेवलपर को एपीआई से उन संसाधनों को ऐक्सेस करने से रोकता है प्रॉक्सी नहीं कर सकते. उदाहरण के लिए, इस सेटिंग का इस्तेमाल संसाधनों को रोकने के लिए किया जाता है 'prod' में API प्रॉक्सी से संबद्ध में डिप्लॉय की गई एपीआई प्रॉक्सी से ऐक्सेस किए जाने से 'test'. | लागू नहीं | नहीं. अगर इसके बारे में नहीं बताया गया है, तो apiResources के बारे में साफ़ तौर पर बताया जाना चाहिए और
PendingMessage नीति में flow.resource.name वैरिएबल सेट किया गया. |
quota |
बताई गई समयावधि में, हर ऐप्लिकेशन के लिए अनुमति वाले अनुरोधों की संख्या. | लागू नहीं | नहीं |
quotaInterval |
कोटा का आकलन करने के लिए, समय की इकाइयों की संख्या | लागू नहीं | नहीं |
quotaTimeUnit |
समय की वह इकाई (मिनट, घंटा, दिन या महीना) जिसमें कोटे की गिनती की जाती है. | लागू नहीं | नहीं |
एपीआई प्रॉडक्ट बनाने का ज़्यादा जानकारी वाला उदाहरण नीचे दिया गया है.
curl -X POST https://api.enterprise.apigee.com/v1/o/{org_name}/apiproducts \ -H "Content-Type:application/json" -d \ '{ "apiResources": [ "/forecastrss" ], "approvalType": "auto", "attributes": [ {"name": "access", "value": "public"} ], "description": "Free API Product", "displayName": "Free API Product", "name": "weather_free", "scopes": [], "proxies": [ "weatherapi" ], "environments": [ "test" ], "quota": "10", "quotaInterval": "2", "quotaTimeUnit": "hour" }' \ -u email:password
रिस्पॉन्स का उदाहरण
{ "apiResources" : [ "/forecastrss" ], "approvalType" : "auto", "attributes" : [ { "name" : "access", "value" : "public" }, "createdAt" : 1344454200828, "createdBy" : "[email protected]", "description" : "Free API Product", "displayName" : "Free API Product", "lastModifiedAt" : 1344454200828, "lastModifiedBy" : "[email protected]", "name" : "weather_free", "scopes" : [ ], "proxies": [ {'weatherapi'} ], "environments": [ {'test'} ], "quota": "10", "quotaInterval": "1", "quotaTimeUnit": "hour"}' }
स्कोप के बारे में जानकारी
स्कोप एक ऐसा सिद्धांत है जिसे OAuth और मोटे तौर पर 'अनुमति' के कॉन्सेप्ट पर बनाया गया है. चालू है Apigee Edge, स्कोप का इस्तेमाल करना ज़रूरी नहीं है. सटीक नतीजे पाने के लिए, स्कोप का इस्तेमाल किया जा सकता है अनुमति ऐप्लिकेशन को जारी की जाने वाली हर उपभोक्ता कुंजी 'मास्टर स्कोप' से जुड़ी होती है. कॉन्टेंट बनाने मास्टर स्कोप उन सभी एपीआई प्रॉडक्ट में सभी दायरों का सेट है जिनके लिए ऐप्लिकेशन को मंज़ूरी दी गई है. इसके लिए ऐसे ऐप्लिकेशन जिन्हें एक से ज़्यादा एपीआई प्रॉडक्ट का इस्तेमाल करने की मंज़ूरी दी गई है, मास्टर स्कोप सभी दायरों को मिलाकर लागू होता है का इस्तेमाल उन एपीआई प्रॉडक्ट में किया जा सकता है जिनके लिए उपभोक्ता कुंजी को मंज़ूरी दी गई है.
एपीआई प्रॉडक्ट देखें
एपीआई का इस्तेमाल करके किसी संगठन के लिए बनाए गए एपीआई प्रॉडक्ट देखने के लिए, ये सेक्शन देखें:
- एपीआई वाले प्रॉडक्ट देखना (कमाई करने की सुविधा)
डिफ़ॉल्ट रूप से, सिर्फ़ कमाई करने वाले एपीआई प्रॉडक्ट ही दिखाए जाते हैं. इसका मतलब है कि ऐसे एपीआई प्रॉडक्ट जिनके लिए, पब्लिश किए गए रेट का कम से कम एक प्लान हो. एपीआई के सभी प्रॉडक्ट दिखाने के लिए,
monetized
क्वेरी पैरामीटर कोfalse
पर सेट करें. यह, उस सूची एपीआई प्रॉडक्ट एपीआई के लिए जीईटी अनुरोध जारी करने के बराबर है जिससे कमाई नहीं होती है.https://api.enterprise.apigee.com/v1/organizations/{org_name}/apiproducts?expand=true
अभी तक किसी भी व्यक्ति ने चेक इन नहीं किया है - एपीआई वाले प्रॉडक्ट देखना (कमाई नहीं की गई)
- डेवलपर के लिए, ज़रूरी शर्तें पूरी करने वाले एपीआई प्रॉडक्ट देखना
- किसी कंपनी के लिए ज़रूरी शर्तें पूरी करने वाले एपीआई प्रॉडक्ट देखना
एपीआई का इस्तेमाल करके, एपीआई प्रॉडक्ट को देखने का तरीका यहां दिया गया है:
curl -X GET "https://ext.apiexchange.org/v1/mint/organizations/{org_name}/products?monetized=true" \ -H "Accept:application/json" \ -u email:password
जवाब कुछ ऐसा दिखना चाहिए (जवाब का सिर्फ़ एक हिस्सा दिखता है):
{ "product" : [ { "customAtt1Name" : "user", "customAtt2Name" : "response size", "customAtt3Name" : "content-length", "description" : "payment api product", "displayName" : "payment", "id" : "payment", "name" : "payment", "organization" : { ... }, "pricePoints" : [ ], "status" : "CREATED", "transactionSuccessCriteria" : "status == 'SUCCESS'" }, { "customAtt1Name" : "user", "customAtt2Name" : "response size", "customAtt3Name" : "content-length", "description" : "messaging api product", "displayName" : "messaging", "id" : "messaging", "name" : "messaging", "organization" : ... }, "pricePoints" : [ ], "status" : "CREATED", "transactionSuccessCriteria" : "status == 'SUCCESS'" } ], "totalRecords" : 2 }
एपीआई का इस्तेमाल करके डेवलपर को रजिस्टर करें
सभी ऐप्लिकेशन डेवलपर या कंपनियों के होते हैं. इसलिए, ऐप्लिकेशन बनाने के लिए आपको सबसे पहले किसी डेवलपर या कंपनी को रजिस्टर करने के लिए.
डेवलपर, प्रोफ़ाइल बनाकर किसी संगठन में रजिस्टर होते हैं. ध्यान दें कि डेवलपर प्रोफ़ाइल में शामिल किए गए ईमेल का इस्तेमाल, पूरे डेवलपर के लिए यूनीक कुंजी के तौर पर किया जाता है Apigee Edge.
कमाई करने में मदद करने के लिए, आपको कमाई करने की स्थिति के बारे में बताना होगा एट्रिब्यूट का इस्तेमाल करें. आपके पास कस्टम ऐनलिटिक्स, कस्टम नीति लागू करने वगैरह में इस्तेमाल किए जाने वाले एट्रिब्यूट; ये आर्बिट्रेरी एट्रिब्यूट को Apigee Edge से इस्तेमाल नहीं किया जा सकता,
उदाहरण के लिए, नीचे दिया गया अनुरोध ऐसे डेवलपर की प्रोफ़ाइल रजिस्टर करता है जिसका ईमेल पता
[email protected]
और कमाई करने के सबसेट के बारे में जानकारी देता है
डेवलपर बनाएं एपीआई का इस्तेमाल करने वाले एट्रिब्यूट:
$ curl -H "Content-type:application/json" -X POST -d \ '{"email" : "[email protected]", "firstName" : "Nikola", "lastName" : "Tesla", "userName" : "theremin", "attributes" : [ { "name" : "project_type", "value" : "public" }, { "name": "MINT_BILLING_TYPE", "value": "POSTPAID" }, { "name": "MINT_DEVELOPER_ADDRESS", "value": "{\"address1\":\"Dev One Address\",\"city\":\"Pleasanton\",\"country\":\"US\",\"isPrimary\":true,\"state\":\"CA\",\"zip\":\"94588\"}" }, { "name": "MINT_DEVELOPER_TYPE", "value": "TRUSTED" }, { "name": "MINT_HAS_SELF_BILLING, "value": "FALSE" }, { "name" : "MINT_SUPPORTED_CURRENCY", "value" : "usd" } ] }' \ https://api.enterprise.apigee.com/v1/o/{org_name}/developers \ -u email:password
रिस्पॉन्स का उदाहरण
{ "email" : "[email protected]", "firstName" : "Nikola", "lastName" : "Tesla", "userName" : "theremin", "organizationName" : "{org_name}", "status" : "active", "attributes" : [ { "name" : "project_type", "value" : "public" }, { "name": "MINT_BILLING_TYPE", "value": "POSTPAID" }, { "name": "MINT_DEVELOPER_ADDRESS", "value": "{\"address1\":\"Dev One Address\",\"city\":\"Pleasanton\",\"country\":\"US\",\"isPrimary\":true,\"state\":\"CA\",\"zip\":\"94588\"}" }, { "name": "MINT_DEVELOPER_TYPE", "value": "TRUSTED" }, { "name": "MINT_HAS_SELF_BILLING, "value": "FALSE" }, { "name" : "MINT_SUPPORTED_CURRENCY", "value" : "usd" } ], "createdAt" : 1343189787717, "createdBy" : "admin@apigee.com", "lastModifiedAt" : 1343189787717, "lastModifiedBy" : "admin@apigee.com" }
एपीआई का इस्तेमाल करके डेवलपर ऐप्लिकेशन रजिस्टर करें
Apigee Edge पर रजिस्टर किया गया हर ऐप्लिकेशन, किसी डेवलपर और एपीआई प्रॉडक्ट से जुड़ा होता है. जब कोई ऐप्लिकेशन डेवलपर की ओर से रजिस्टर किया जाता है, तो Apigee Edge "क्रेडेंशियल" जनरेट करता है (a उपभोक्ता कुंजी और सीक्रेट जोड़े) का इस्तेमाल करते हैं. इसके बाद, ऐप्लिकेशन को ये क्रेडेंशियल पूरे करने होंगे ऐप्लिकेशन से जुड़े किसी एपीआई प्रॉडक्ट के हर अनुरोध के हिस्से के तौर पर.
नीचे दिए गए अनुरोध में, बनाएं आपके द्वारा ऊपर बनाए गए डेवलपर के लिए ऐप्लिकेशन पंजीकृत करने के लिए डेवलपर ऐप्लिकेशन API: [email protected] पर पाएं. ऐप्लिकेशन को रजिस्टर करते समय, आपको उस ऐप्लिकेशन का नाम, callbackUrl, और एक या उससे ज़्यादा एपीआई की सूची देनी होती है प्रॉडक्ट:$ curl -H "Content-type:application/json" -X POST -d \ '{ "apiProducts": [ "weather_free"], "callbackUrl" : "login.weatherapp.com", "keyExpiresIn" : "2630000000", "name" : "weatherapp"}' \ https://api.enterprise.apigee.com/v1/o/{org_name}/developers/[email protected]/apps \ -u email:password
callbackUrl का इस्तेमाल यह करता है
कुछ OAuth अनुदान प्रकार (जैसे कि प्राधिकरण कोड) का इस्तेमाल करके ऐप्लिकेशन से रीडायरेक्ट करने के अनुरोधों की पुष्टि की जा सकती है.
अगर आपने OAuth का इस्तेमाल किया है, तो यह वैल्यू वही होनी चाहिए जो redirect_uri
पर सेट है
OAuth अनुरोध करने के लिए इस्तेमाल किया जाता है.
keyExpiresIn
एट्रिब्यूट मिलीसेकंड में, एट्रिब्यूट की वैल्यू
उपभोक्ता कुंजी जोड़ें जिसे डेवलपर ऐप्लिकेशन के लिए जनरेट किया जाएगा. डिफ़ॉल्ट वैल्यू, -1 से पता चलता है कि
असीमित मान्य रहने की अवधि.
रिस्पॉन्स का उदाहरण
{ "appId": "5760d130-528f-4388-8c6f-65a6b3042bd1", "attributes": [ { "name": "DisplayName", "value": "Test Key Expires" }, { "name": "Notes", "value": "Just testing this attribute" } ], "createdAt": 1421770824390, "createdBy": "[email protected]", "credentials": [ { "apiProducts": [ { "apiproduct": "ProductNoResources", "status": "approved" } ], "attributes": [], "consumerKey": "jcAFDcfwImkJ19A5gTsZRzfBItlqohBt", "consumerSecret": "AX7lGGIRJs6s8J8y", "expiresAt": 1424400824401, "issuedAt": 1421770824401, "scopes": [], "status": "approved" } ], "developerId": "e4Oy8ddTo3p1BFhs", "lastModifiedAt": 1421770824390, "lastModifiedBy": "[email protected]", "name": "TestKeyExpires", "scopes": [], "status": "approved" }
एपीआई का इस्तेमाल करने वाले ऐप्लिकेशन के लिए उपभोक्ता कुंजियां मैनेज करना
उपभोक्ता कुंजी पाएं ऐप्लिकेशन के लिए (एपीआई पासकोड)
एपीआई प्रॉडक्ट, उपभोक्ता कुंजी, और सीक्रेट जैसे किसी ऐप्लिकेशन के क्रेडेंशियल, ऐप प्रोफ़ाइल. संगठन का एडमिन, किसी भी समय उपभोक्ता कुंजी वापस पा सकता है.
ऐप्लिकेशन प्रोफ़ाइल में उपभोक्ता कुंजी और सीक्रेट की वैल्यू, उपभोक्ता की स्थिति दिखती है और साथ ही कुंजी के लिए किसी भी एपीआई प्रॉडक्ट असोसिएशन से भी किया जा सकता है. एडमिन के तौर पर, आपके पास उपभोक्ता कुंजी प्रोफ़ाइल देखने की सुविधा चालू करने के लिए, डेवलपर ऐप्लिकेशन की कुंजी की जानकारी पाएं एपीआई:
$ curl -X GET -H "Accept: application/json" \ https://api.enterprise.apigee.com/v1/o/{org_name}/developers/[email protected]/apps/weatherapp/keys/HQg0nCZ54adKobpqEJaE8FefGkdKFc2J \ -u email:password
रिस्पॉन्स का उदाहरण
{ "apiProducts" : [ { "apiproduct" : "weather_free", "status" : "approved" } ], "attributes" : [ ], "consumerKey" : "HQg0nCZ54adKobpqEJaE8FefGkdKFc2J", "consumerSecret" : "1eluIIdWG3JGDjE0", "status" : "approved" }
देखें ज़्यादा जानकारी के लिए, डेवलपर ऐप्लिकेशन की खास जानकारी पाएं.
किसी एपीआई प्रॉडक्ट को ऐप्लिकेशन और कुंजी
किसी ऐप्लिकेशन को अपडेट करके उसमें नया एपीआई प्रॉडक्ट जोड़ने के लिए, ऐप्लिकेशन की कुंजी में एपीआई प्रॉडक्ट जोड़ें API प्रॉडक्ट को Key API में जोड़ें का इस्तेमाल करके. देखें ज़्यादा जानकारी के लिए, एपीआई प्रॉडक्ट को Key में जोड़ें.
किसी एपीआई प्रॉडक्ट को 'ऐप्लिकेशन कुंजी' में जोड़ने से, वह ऐप्लिकेशन चालू हो जाता है जिसमें एपीआई ऐक्सेस करने के लिए कुंजी मौजूद होती है एपीआई प्रॉडक्ट में बंडल किए गए संसाधन. निम्न विधि कॉल ऐप्लिकेशन:
$ curl -H "Content-type:application/json" -X POST -d \ '{ "apiProducts": [ "newAPIProduct"] }' \ https://api.enterprise.apigee.com/v1/o/{org_name}/developers/[email protected]/apps/weatherapp/keys/HQg0nCZ54adKobpqEJaE8FefGkdKFc2J \ -u email:password
जवाब का उदाहरण:
{ "apiProducts": [ { "apiproduct": "weather_free", "status": "approved" }, { "apiproduct": "newAPIProduct", "status": "approved" } ], "attributes": [], "consumerKey": "HQg0nCZ54adKobpqEJaE8FefGkdKFc2J", "consumerSecret": "1eluIIdWG3JGDjE0", "expiresAt": -1, "issuedAt": 1411491156464, "scopes": [], "status": "approved" }
उपभोक्ता कुंजियों को अनुमति दें
अनुमति के टाइप को मैन्युअल पर सेट करके, यह कंट्रोल किया जा सकता है कि किस
डेवलपर, एपीआई प्रॉडक्ट से सुरक्षित संसाधनों को ऐक्सेस कर सकते हैं. एपीआई प्रॉडक्ट में कुंजी होने पर
अनुमति को manual
पर सेट किया गया है, तो उपभोक्ता कुंजियों के लिए साफ़ तौर पर मंज़ूरी मिलना ज़रूरी है. कुंजियां ये हो सकती हैं
डेवलपर ऐप्लिकेशन की खास कुंजी को मंज़ूरी देना या निरस्त करना का इस्तेमाल करके साफ़ तौर पर मंज़ूरी दी गई हो
एपीआई:
$ curl -X POST -H "Content-type:appilcation/octet-stream" \ https://api.enterprise.apigee.com/v1/o/{org_name}/developers/[email protected]/apps/weatherapp/keys/HQg0nCZ54adKobpqEJaE8FefGkdKFc2J?"action=approve" \ -u email:password
रिस्पॉन्स का उदाहरण
{ "apiProducts" : [ { "apiproduct" : "weather_free", "status" : "approved" } ], "attributes" : [ ], "consumerKey" : "HQg0nCZ54adKobpqEJaE8FefGkdKFc2J", "consumerSecret" : "1eluIIdWG3JGDjE0", "status" : "approved" }
देखें ज़्यादा जानकारी के लिए, डेवलपर ऐप्लिकेशन की खास कुंजी को मंज़ूरी दें या निरस्त करें.
एपीआई प्रॉडक्ट को मंज़ूरी दें 'उपभोक्ता कुंजियों' के लिए
किसी एपीआई प्रॉडक्ट को उपभोक्ता कुंजी के साथ जोड़ने की स्थिति भी होती है. एपीआई ऐक्सेस के लिए सफल होने के बाद, उपभोक्ता कुंजी को स्वीकार किया जाना और उपभोक्ता कुंजी के एपीआई प्रॉडक्ट की एक सूची में शामिल करें. उपभोक्ता कुंजी का किसी API प्रॉडक्ट के साथ संबंध ऐसा हो सकता है किसी डेवलपर के लिए किसी कुंजी के लिए API प्रॉडक्ट को स्वीकार या रद्द करें ऐप्लिकेशन एपीआई:
$ curl -X POST -H "Content-type:application/octet-stream" \ https://api.enterprise.apigee.com/v1/o/{org_name}/developers/[email protected]/apps/weatherapp/keys/HQg0nCZ54adKobpqEJaE8FefGkdKFc2J/apiproducts/weather_free?"action=approve" \ -u email:password
यह cURL निर्देश कोई जवाब नहीं देता है. देखें ज़्यादा जानकारी के लिए, डेवलपर ऐप्लिकेशन की कुंजी के लिए, एपीआई प्रॉडक्ट को मंज़ूरी दें या उसे रद्द करें.
इसके लिए API प्रॉडक्ट निरस्त करें उपभोक्ता कुंजियां
कई वजहों से आपको किसी एपीआई के साथ उपभोक्ता कुंजी के जुड़ाव को रद्द करने की ज़रूरत पड़ सकती है प्रॉडक्ट. आपको उपभोक्ता कुंजी से कोई एपीआई प्रॉडक्ट हटाना पड़ सकता है, क्योंकि डेवलपर, जिसकी ट्रायल अवधि खत्म हो चुकी है या जब किसी ऐप्लिकेशन को एक एपीआई प्रॉडक्ट से प्रमोट किया गया है, तो कोई दूसरा.
किसी API प्रॉडक्ट के साथ उपभोक्ता कुंजी के असोसिएशन को निरस्त करने के लिए, मंज़ूरी दें या डेवलपर ऐप्लिकेशन एपीआई की खास कुंजी को निरस्त करें. ऐसा करने के लिए, डेवलपर ऐप्लिकेशन की उपभोक्ता कुंजी:
$ curl -X POST -H "Content-type:application/octet-stream" \ https://api.enterprise.apigee.com/v1/o/{org_name}/developers/[email protected]/apps/weatherapp/keys/HQg0nCZ54adKobpqEJaE8FefGkdKFc2J/apiproducts/weather_free?"action=revoke" \ -u email:password
यह cURL निर्देश कोई जवाब नहीं देता है. देखें ज़्यादा जानकारी के लिए, डेवलपर ऐप्लिकेशन की खास कुंजी को मंज़ूरी दें या निरस्त करें.
एपीआई प्रॉडक्ट सेटिंग लागू करें
एपीआई प्रॉडक्ट को लागू करने के लिए, एपीआई से इनमें से किसी एक तरह की नीति को अटैच करना ज़रूरी है प्रॉक्सी फ़्लो:
- VerifyAPIKey: एपीआई पासकोड का रेफ़रंस लेता है, और इस बात की पुष्टि करता है कि यह सही ऐप्लिकेशन है या नहीं, और एपीआई प्रॉडक्ट से मेल खाता है. इनके लिए, एपीआई पासकोड से जुड़ी नीति की पुष्टि करें देखें वगैरह को कॉपी करने का विकल्प है.
- OAuthV1, “VerifyAccessToken” कार्रवाई: हस्ताक्षर की पुष्टि करता है, OAuth 1.0a ऐक्सेस टोकन और “उपभोक्ता कुंजी” शामिल है. साथ ही, यह ऐप्लिकेशन का मिलान एपीआई प्रॉडक्ट से करता है. इनके लिए OAuth v1.0a नीति देखें वगैरह को कॉपी करने का विकल्प है.
- OAuthV2, “VerifyAccessToken” कार्रवाई: यह पुष्टि करती है कि OAuth 2.0 ऐक्सेस टोकन मान्य है, ऐप्लिकेशन के टोकन से मैच करता है, और ऐप्लिकेशन के मान्य होने की पुष्टि करता है. इसके बाद, यह पुष्टि करता है कि ऐप्लिकेशन मान्य है किसी एपीआई प्रॉडक्ट से ऐप्लिकेशन को जोड़ना. OAuth देखें ज़्यादा जानकारी के लिए, होम पेज पर जाएं.
नीतियों और एपीआई प्रॉडक्ट को कॉन्फ़िगर करने के बाद, Apigee यह प्रोसेस करता है किनारे:
- Apigee Edge को अनुरोध मिलता है और उसे सही एपीआई प्रॉक्सी पर रूट कर दिया जाता है.
- ऐसी नीति लागू की जाती है जो एपीआई पासकोड या OAuth ऐक्सेस टोकन की पुष्टि करती है. इसे क्लाइंट.
- Edge, API पासकोड या ऐक्सेस टोकन को किसी ऐप्लिकेशन प्रोफ़ाइल से रिज़ॉल्व करता है.
- Edge, ऐप्लिकेशन से जुड़े एपीआई प्रॉडक्ट की सूची (अगर कोई है) को रिज़ॉल्व करता है.
- मैच होने वाले पहले एपीआई प्रॉडक्ट का इस्तेमाल, कोटा वैरिएबल की जानकारी अपने-आप भरने के लिए किया जाता है.
- अगर एपीआई पासकोड या ऐक्सेस टोकन से, एपीआई का कोई भी प्रॉडक्ट मैच नहीं करता है, तो अनुरोध अस्वीकार कर दिया जाता है.
- Edge, एपीआई प्रॉडक्ट सेटिंग और कोटा की सेटिंग.