Apigee Edge का दस्तावेज़ देखा जा रहा है.
Apigee X के दस्तावेज़ पर जाएं. जानकारी
वर्शन: 2.0.1
Cloud Firestore डेटाबेस में डेटा बनाना, पढ़ना या मिटाना.
इस कॉन्टेंट में, इस एक्सटेंशन को कॉन्फ़िगर करने और इस्तेमाल करने के बारे में जानकारी दी गई है. एपीआई प्रॉक्सी से इस एक्सटेंशन का इस्तेमाल करने से पहले, आपको ये काम करने होंगे:
Firebase कंसोल में, वह Firebase प्रोजेक्ट बनाएं जहां आपका डेटा सेव है.
कॉन्फ़िगरेशन रेफ़रंस का इस्तेमाल करके एक्सटेंशन को जोड़ने और कॉन्फ़िगर करने के दौरान, जनरेट हुई कुंजी वाली JSON फ़ाइल के कॉन्टेंट का इस्तेमाल करें.
Cloud Firestore के बारे में जानकारी
Cloud Firestore, डेटा को दस्तावेज़ों में सेव करता है. ये दस्तावेज़, कलेक्शन में सेव किए जाते हैं. दस्तावेज़ में पहली बार डेटा जोड़ने पर, Cloud Firestore अपने-आप कलेक्शन और दस्तावेज़ बना देता है. आपको खास तौर पर कलेक्शन या दस्तावेज़ बनाने की ज़रूरत नहीं है.
Cloud Firestore के बारे में ज़्यादा जानने के लिए, Cloud Firestore के दस्तावेज़ में Firestore का इस्तेमाल शुरू करना लेख पढ़ें.
सैंपल
यहां दिए गए उदाहरणों में, ExtensionCallout नीति का इस्तेमाल करके, Cloud Firestore एक्सटेंशन ऐक्शन के लिए सहायता कॉन्फ़िगर करने का तरीका बताया गया है.
डेटा जोड़ें
यहां दी गई ExtensionCallout नीति, users कलेक्शन में freewill@example.com नाम का दस्तावेज़ जोड़ती है. data प्रॉपर्टी, नए दस्तावेज़ के फ़ील्ड और वैल्यू की जानकारी देती है.
<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<ConnectorCallout async="false" continueOnError="true" enabled="true" name="Add-User-Data">
<DisplayName>Add User Data</DisplayName>
<Connector>my-cloud-firestore-extension</Connector>
<Action>setDocument</Action>
<Input><![CDATA[{
"colName" : "users",
"docName" : "freewill@example.com",
"data" : {
"firstName": "Will",
"lastName": "Witman",
"address": "270-8243 Tempor St.",
"city": "Fort Worth",
"region": "TX",
"postalCode": "86519",
"email": "freewill@example.com",
"username": "freewill444"
}
}]]></Input>
</ConnectorCallout>
डेटा पाना
इस उदाहरण में, ExtensionCallout नीति, users कलेक्शन से freewill@example.com दस्तावेज़ की वैल्यू को वापस लाती है. यहां <Output> एलिमेंट का parsed एट्रिब्यूट false पर सेट है, ताकि रिटर्न किया गया नतीजा, ऑब्जेक्ट में पार्स किए गए JSON के बजाय, JSON स्ट्रिंग के तौर पर दिखे. ज़्यादा जानकारी के लिए, <Output> एलिमेंट का रेफ़रंस देखें.
<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<ConnectorCallout async="false" continueOnError="true" enabled="true" name="Get-User-Data">
<DisplayName>Get User Data</DisplayName>
<Connector>straut-cloud-firestore-extension</Connector>
<Action>getDocument</Action>
<Input><![CDATA[{
"colName" : "users",
"docName" : "freewill@example.com"
}]]></Input>
<Output parsed="false">firestore.userdata.retrieved</Output>
</ConnectorCallout>
मैसेज असाइन करें नीति में, रिस्पॉन्स पेलोड असाइन करने के लिए, एक्सटेंशन के रिस्पॉन्स को सेव करने वाले वैरिएबल की वैल्यू का इस्तेमाल किया जाता है.
<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<AssignMessage name="CopyUserDataToResponse">
<DisplayName>Copy User Data To Response</DisplayName>
<AssignTo type="response" createNew="false"/>
<Set>
<Payload contentType="application/json">{firestore.userdata.retrieved}</Payload>
</Set>
</AssignMessage>
डेटा मिटाएं
इस उदाहरण में, ExtensionCallout नीति, users कलेक्शन से lizzie@example.com दस्तावेज़ को मिटा देती है.
<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<ConnectorCallout async="false" continueOnError="true" enabled="true" name="Delete-User-Data">
<DisplayName>Delete User Data</DisplayName>
<Connector>my-cloud-firestore-extension</Connector>
<Action>deleteDocument</Action>
<Input><![CDATA[{
"colName" : "users",
"docName" : "lizzie@example.com"
}]]></Input>
</ConnectorCallout>
क्वेरी डेटा
इस उदाहरण में, ExtensionCallout नीति, cities कलेक्शन के बारे में क्वेरी करती है. क्वेरी के नतीजों को state और population फ़ील्ड के हिसाब से फ़िल्टर किया जाता है. यहां <Output> एलिमेंट का parsed एट्रिब्यूट false पर सेट है, ताकि रिटर्न किया गया नतीजा, ऑब्जेक्ट में पार्स किए गए JSON के बजाय, JSON स्ट्रिंग के तौर पर दिखे. ज़्यादा जानकारी के लिए, <Output> एलिमेंट का रेफ़रंस देखें.
<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<ConnectorCallout async="false" continueOnError="true" enabled="true" name="Query-City-Data">
<DisplayName>Query City Data</DisplayName>
<Connector>cloud-firestore-extension</Connector>
<Action>query</Action>
<Input><![CDATA[{
"colName":"cities",
"queryArray":[
["state", "==", "CA"],
["population","<",1000000]
]
}]]></Input>
<Output parsed="false">compound-query-output</Output>
</ConnectorCallout>
मैसेज असाइन करें नीति में, रिस्पॉन्स पेलोड असाइन करने के लिए, एक्सटेंशन के रिस्पॉन्स को सेव करने वाले वैरिएबल की वैल्यू का इस्तेमाल किया जाता है.
<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<AssignMessage name="CopyQueryResultsToResponse">
<DisplayName>Copy Query Results To Response</DisplayName>
<AssignTo type="response" createNew="false"/>
<Set>
<Payload contentType="application/json">{firestore.querydata.retrieved}</Payload>
</Set>
</AssignMessage>
कार्रवाइयां
deleteDocument
किसी कलेक्शन से एक दस्तावेज़ मिटाता है.
अनुरोध पैरामीटर
<Input><![CDATA[{
"colName" : "firestore-collection-name",
"docName" : "firestore-document-name"
}]]></Input>
| पैरामीटर | ब्यौरा | टाइप | डिफ़ॉल्ट | ज़रूरी है |
|---|---|---|---|---|
| colName | उस कलेक्शन का नाम जिसमें मौजूद दस्तावेज़ को मिटाना है. | स्ट्रिंग | कोई नहीं. | हां. |
| docName | जिस दस्तावेज़ को मिटाना है उसका नाम. | स्ट्रिंग | कोई नहीं. | हां. |
जवाब
कोई नहीं.
getDocument
किसी एक दस्तावेज़ का कॉन्टेंट वापस लाता है.
अनुरोध पैरामीटर
<Input><![CDATA[{
"colName" : "firestore-collection-name",
"docName" : "firestore-document-name"
}]]></Input>
| पैरामीटर | ब्यौरा | टाइप | डिफ़ॉल्ट | ज़रूरी है |
|---|---|---|---|---|
| colName | उस कलेक्शन का नाम जिसमें से दस्तावेज़ को वापस लाना है. | स्ट्रिंग | कोई नहीं. | हां. |
| docName | जिस दस्तावेज़ को वापस लाना है उसका नाम. | स्ट्रिंग | कोई नहीं. | हां. |
जवाब
JSON फ़ॉर्मैट में दस्तावेज़ का कॉन्टेंट शामिल करने वाला ऑब्जेक्ट.
क्वेरी
फ़िल्टर बनाने वाली शर्तों के हिसाब से किसी कलेक्शन को क्वेरी करता है.
इस ऐक्शन का queryArray पैरामीटर, अरे का अरे (या फ़िल्टर करने की कोई शर्त न होने पर खाली अरे) तय करता है. हर इनर ऐरे, फ़िल्टर की एक शर्त बताता है. एक से ज़्यादा इनर ऐरे, एक से ज़्यादा शर्तों को दिखाते हैं. इन शर्तों को AND ऑपरेटर से जोड़ा जाता है.
इनर कंडीशन कलेक्शन में मौजूद हर एलिमेंट, कंडीशन का एक हिस्सा दिखाता है. शर्त वाले कलेक्शन में हमेशा ये तीन एलिमेंट होते हैं:
- कलेक्शन फ़ील्ड की जानकारी देने वाला बायाँ एलिमेंट.
- ऑपरेटर की जानकारी देने वाला मिडल एलिमेंट.
- कलेक्शन फ़ील्ड की वैल्यू बताने वाला राइट एलिमेंट.
इस उदाहरण में, कलेक्शन के state और population फ़ील्ड के आधार पर फ़िल्टर करने के लिए, दो शर्त वाले ऐरे बताए गए हैं:
<Input><![CDATA[{
"colName":"cities",
"queryArray":[
["state", "==", "CA"],
["population","<",1000000]
]
}]]></Input>
रनटाइम के दौरान, इस कार्रवाई को क्वेरी के तौर पर समझा जाता है. जैसे:
वे सभी शहर चुनें जहां राज्य = 'CA' और जनसंख्या < 1000000
एक से ज़्यादा शर्तों वाली क्वेरी के लिए, Cloud Firestore में कंपोजिट इंडेक्स का इस्तेमाल करना ज़रूरी है. ज़्यादा जानकारी के लिए, Cloud Firestore में इंडेक्स टाइप लेख पढ़ें.
अनुरोध पैरामीटर
सिंटैक्स
<Input><![CDATA[{
"colName" : "firestore-collection-name",
"queryArray" : "queryArray": query-condition-array
}]]></Input>
उदाहरण
इस उदाहरण में, queryArray पैरामीटर दो शर्तों के बारे में बताता है. इन शर्तों के आधार पर, colName पैरामीटर से तय किए गए cities कलेक्शन को फ़िल्टर किया जाता है.
एक से ज़्यादा शर्तों वाली क्वेरी के लिए, Cloud Firestore में कंपोजिट इंडेक्स का इस्तेमाल करना ज़रूरी है. ज़्यादा जानकारी के लिए, Cloud Firestore में इंडेक्स टाइप लेख पढ़ें.
<Input><![CDATA[{
"colName":"cities",
"queryArray":[["state", "==", "CA"],["population","<",1000000]]
}]]></Input>
रनटाइम के दौरान, इस कार्रवाई को क्वेरी के तौर पर समझा जाता है. जैसे:
वे सभी शहर चुनें जहां राज्य = 'CA' और जनसंख्या < 1000000
| पैरामीटर | ब्यौरा | टाइप | डिफ़ॉल्ट | ज़रूरी है |
|---|---|---|---|---|
| colName | उस कलेक्शन का नाम जिसकी क्वेरी करनी है. | स्ट्रिंग | कोई नहीं. | हां. |
| queryArray | शर्तों के ऐरे का एक कलेक्शन, जो एक साथ फ़िल्टर के हिस्सों की जानकारी देता है. शर्तों को हटाने के लिए, खाली कलेक्शन दें. नतीजों को फ़िल्टर न करें. | Array | कोई नहीं. | हां. |
जवाब
JSON फ़ॉर्मैट में दस्तावेज़ का कॉन्टेंट शामिल करने वाला ऑब्जेक्ट.
setDocument
किसी दस्तावेज़ को Cloud Firestore कलेक्शन में कॉपी करता है. अगर दस्तावेज़ कलेक्शन में पहले से मौजूद है, तो यह उसे ओवरराइट कर देता है.
अनुरोध पैरामीटर
<Input><![CDATA[{
"colName" : "firestore-collection-name",
"docName" : "firestore-document-name",
"data" : "data-to-copy"
}]]></Input>
| पैरामीटर | ब्यौरा | टाइप | डिफ़ॉल्ट | ज़रूरी है |
|---|---|---|---|---|
| colName | उस कलेक्शन का नाम जिसमें दस्तावेज़ बनाना है. | स्ट्रिंग | कोई नहीं. | हां. |
| docName | उस दस्तावेज़ का नाम जिसमें data को कॉपी करना है. |
स्ट्रिंग | कोई नहीं. | हां. |
| डेटा | docName में कॉपी किया जाने वाला डेटा. यह एक मान्य JSON ऑब्जेक्ट होना चाहिए. ऐरे का इस्तेमाल नहीं किया जा सकता. |
ऑब्जेक्ट | कोई नहीं. | नहीं. |
जवाब
कोई नहीं.
कॉन्फ़िगरेशन का रेफ़रंस
एपीआई प्रॉक्सी में इस्तेमाल करने के लिए, इस एक्सटेंशन को कॉन्फ़िगर और डिप्लॉय करते समय इनका इस्तेमाल करें. Apigee console का इस्तेमाल करके एक्सटेंशन कॉन्फ़िगर करने का तरीका जानने के लिए, एक्सटेंशन जोड़ना और कॉन्फ़िगर करना लेख पढ़ें.
सामान्य एक्सटेंशन प्रॉपर्टी
हर प्रॉपर्टी के लिए नीचे दी गई प्रॉपर्टी मौजूद हैं.
| प्रॉपर्टी | जानकारी | डिफ़ॉल्ट | ज़रूरी है |
|---|---|---|---|
name |
वह नाम, जिसे आप एक्सटेंशन का यह कॉन्फ़िगरेशन दे रहे हैं. | कभी नहीं | हां |
packageName |
एक्सटेंशन पैकेज का नाम, जो Apigee Edge से दिया गया है. | कभी नहीं | हां |
version |
उस एक्सटेंशन पैकेज का वर्शन नंबर जिससे आपको एक्सटेंशन कॉन्फ़िगर करना है. | कभी नहीं | हां |
configuration |
आप जिस एक्सटेंशन को जोड़ रहे हैं उसके लिए खास तौर पर कॉन्फ़िगरेशन वैल्यू. इस एक्सटेंशन पैकेज के लिए प्रॉपर्टी देखें | कभी नहीं | हां |
इस एक्सटेंशन पैकेज के लिए प्रॉपर्टी
| प्रॉपर्टी | ब्यौरा | डिफ़ॉल्ट | ज़रूरी है |
|---|---|---|---|
| firestoreDB | Cloud Firestore डेटाबेस का यूआरएल, जिसका इस्तेमाल इस एक्सटेंशन को अनुरोध करते समय करना चाहिए. आम तौर पर, यह यूआरएल फ़ॉर्म https://DATABASE_NAME.firebaseio.com के लिए होता है. |
कोई नहीं. | हां. |
| क्रेडेंशियल | Apigee Edge कंसोल में डालने पर, यह उस कुंजी फ़ाइल का कॉन्टेंट होता है जिसे आपने Firebase के निर्देशों के साथ जनरेट किया था. मैनेजमेंट एपीआई के ज़रिए भेजे जाने पर, यह कुंजी फ़ाइल से जनरेट की गई, base64 कोड में बदली गई वैल्यू होती है. | कोई नहीं. | हां. |