इवेंट एसिंक्रोनस होते हैं. इन्हें Google Cloud Pub/Sub मैनेज करता है. हर Projectके लिए एक विषय होता है. इवेंट, सभी डिवाइसों और स्ट्रक्चर के लिए अपडेट देते हैं. साथ ही, इवेंट मिलने की गारंटी होती है. हालांकि, इसके लिए ज़रूरी है कि उपयोगकर्ता ने ऐक्सेस टोकन वापस न लिया हो और इवेंट के मैसेज की समयसीमा खत्म न हुई हो.
इवेंट सक्षम करना
इवेंट, SDM API की एक वैकल्पिक सुविधा है. अपने के लिए इवेंट सक्षम करने का तरीका जानने के लिए, Project इवेंट सक्षम करना लेख पढ़ें.
Google Cloud Pub/Sub
Pub/Sub के काम करने के तरीके के बारे में ज़्यादा जानने के लिए, Google Cloud Pub/Sub का दस्तावेज़ देखें. खास तौर पर:
- Pub/Sub के बारे में बुनियादी जानकारी पाने के लिए, उनकी 'तरीका जानें' गाइड देखें.
- समझें कि ऑथेंटिकेशन कैसे काम करता है.
- दी गई क्लाइंट लाइब्रेरी में से कोई एक चुनें या अपनी लाइब्रेरी लिखें. इसके बाद, REST/HTTP या gRPC API सर्फ़ेस का इस्तेमाल करें.
इवेंट की सदस्यता
जनवरी 2025 से पहले, अगर आपके Projectके लिए इवेंट सक्षम किए गए थे, तो आपको उस Project आईडी के लिए एक विषय दिया गया होगा. यह विषय इस फ़ॉर्मैट में होगा:
projects/gcp-project-name/subscriptions/topic-id
इवेंट पाने के लिए, अपने इस्तेमाल के उदाहरण के हिसाब से, उस विषय के लिए पुल या पुश सदस्यता बनाएं. SDM विषय के लिए एक से ज़्यादा सदस्यताएं ली जा सकती हैं. ज़्यादा जानकारी के लिए, सदस्यताएं मैनेज करना लेख पढ़ें.
इवेंट शुरू करना
Pub/Sub की सदस्यता बन जाने के बाद, पहली बार इवेंट शुरू करने के लिए,
devices.list
API कॉल को एक बार ट्रिगर करें. इस कॉल के बाद, सभी स्ट्रक्चर और डिवाइसों के लिए इवेंट पब्लिश किए जाएंगे.
उदाहरण के लिए, 'आसानी से सीखें' गाइड में, अनुमति देना पेज देखें. गाइड.
इवेंट का क्रम
Pub/Sub, इवेंट को क्रम से डिलीवर करने की गारंटी नहीं देता. साथ ही, इवेंट मिलने का क्रम, इवेंट के असल में होने के क्रम से अलग हो सकता है.
इवेंट के क्रम को ठीक करने के लिए, timestamp
फ़ील्ड का इस्तेमाल करें. इवेंट, अलग-अलग या एक ही इवेंट मैसेज में मिलकर भी आ सकते हैं.
ज़्यादा जानकारी के लिए, मैसेज का क्रम तय करना लेख पढ़ें.
यूज़र आईडी
अगर आपका इंटिग्रेशन, स्ट्रक्चर या डिवाइस के बजाय उपयोगकर्ताओं पर आधारित है, तो संसाधनों और इवेंट को कोरिलेट करने के लिए, इवेंट पेलोड में मौजूद
userID फ़ील्ड का इस्तेमाल करें. यह फ़ील्ड, किसी खास उपयोगकर्ता को दिखाने वाला एक ऑफ़स्केट किया गया आईडी है.
userID, हर एपीआई कॉल के एचटीटीपी रिस्पॉन्स हेडर में भी उपलब्ध होता है.
रिलेशन इवेंट
रिलेशन इवेंट, किसी संसाधन के लिए, उससे जुड़े अपडेट को दिखाते हैं. उदाहरण के लिए, जब किसी स्ट्रक्चर में कोई डिवाइस जोड़ा जाता है या जब किसी स्ट्रक्चर से कोई डिवाइस मिटाया जाता है.
रिलेशन इवेंट तीन तरह के होते हैं:
- CREATED
- DELETED
- UPDATED
रिलेशन इवेंट का पेलोड इस तरह होता है:
पेलोड
{
"eventId" : "afe33940-1627-4d94-923c-58397027474e",
"timestamp" : "2019-01-01T00:00:01Z",
"relationUpdate" : {
"type" : "CREATED",
"subject" : "enterprises/project-id/structures/structure-id",
"object" : "enterprises/project-id/devices/device-id"
},
"userId": "AVPHwEuBfnPOnTqzVFT4IONX2Qqhu9EJ4ubO-bNnQ-yi"
}रिलेशन इवेंट में, object वह संसाधन होता है जिसने इवेंट को ट्रिगर किया है. वहीं,
subject वह संसाधन होता है जिसके साथ अब object का संबंध है. ऊपर दिए गए
उदाहरण में, ने इस खास डिवाइस को ऐक्सेस करने की अनुमति दी है. साथ ही, का अनुमति वाला डिवाइस अब उनके अनुमति वाले
स्ट्रक्चर से जुड़ा है. इससे इवेंट ट्रिगर होता है. user developeruser
subject सिर्फ़ कोई कमरा या स्ट्रक्चर हो सकता है. अगर a developer के पास
के स्ट्रक्चर को देखने की अनुमति नहीं है, तो subject हमेशा
खाली होता है. user
फ़ील्ड
| फ़ील्ड | ब्यौरा | डेटा टाइप |
|---|---|---|
eventId |
इवेंट का यूनीक आइडेंटिफ़ायर. | stringExample: "e2d072c8-3e00-4329-ad1a-de29bb5b21b5" |
timestamp |
इवेंट होने का समय. | stringExample: "2019-01-01T00:00:01Z" |
relationUpdate |
यह एक ऑब्जेक्ट है, जिसमें रिलेशन अपडेट के बारे में जानकारी दी जाती है. | object |
userId |
यह एक यूनीक, ऑफ़स्केट किया गया आइडेंटिफ़ायर है, जो उपयोगकर्ता को दिखाता है. | stringExample: "AVPHwEuBfnPOnTqzVFT4IONX2Qqhu9EJ4ubO-bNnQ-yi" |
अलग-अलग तरह के इवेंट और उनके काम करने के तरीके के बारे में ज़्यादा जानने के लिए, इवेंट लेख पढ़ें.
उदाहरण
हर तरह के रिलेशन इवेंट के लिए, इवेंट पेलोड अलग-अलग होते हैं:
CREATED
स्ट्रक्चर बनाया गया
"relationUpdate" : {
"type" : "CREATED",
"subject" : "",
"object" : "enterprises/project-id/structures/structure-id"
}डिवाइस बनाया गया
"relationUpdate" : {
"type" : "CREATED",
"subject" : "enterprises/project-id/structures/structure-id",
"object" : "enterprises/project-id/devices/device-id"
}डिवाइस बनाया गया
"relationUpdate" : {
"type" : "CREATED",
"subject" : "enterprises/project-id/structures/structure-id/rooms/room-id",
"object" : "enterprises/project-id/devices/device-id"
}UPDATED
डिवाइस को रजिस्टर किया गया
"relationUpdate" : {
"type" : "UPDATED",
"subject" : "enterprises/project-id/structures/structure-id/rooms/room-id",
"object" : "enterprises/project-id/devices/device-id"
}DELETED
स्ट्रक्चर मिटाया गया
"relationUpdate" : {
"type" : "DELETED",
"subject" : "",
"object" : "enterprises/project-id/structures/structure-id"
}डिवाइस मिटाया गया
"relationUpdate" : {
"type" : "DELETED",
"subject" : "enterprises/project-id/structures/structure-id",
"object" : "enterprises/project-id/devices/device-id"
}डिवाइस मिटाया गया
"relationUpdate" : {
"type" : "DELETED",
"subject" : "enterprises/project-id/structures/structure-id/rooms/room-id",
"object" : "enterprises/project-id/devices/device-id"
}रिलेशन इवेंट तब नहीं भेजे जाते, जब:
- कोई कमरा मिटाया जाता है
संसाधन इवेंट
संसाधन इवेंट, किसी संसाधन के लिए खास तौर पर अपडेट को दिखाता है. यह किसी ट्रेट फ़ील्ड की वैल्यू में बदलाव के जवाब में हो सकता है. जैसे, थर्मोस्टैट का मोड बदलना. यह किसी डिवाइस ऐक्शन को भी दिखा सकता है, जिससे ट्रेट फ़ील्ड में कोई बदलाव नहीं होता. जैसे, डिवाइस का बटन दबाना.
ट्रेट फ़ील्ड की वैल्यू में बदलाव के जवाब में जनरेट होने वाले इवेंट में, traits ऑब्जेक्ट होता है. यह डिवाइस के GET कॉल की तरह होता है:
पेलोड
{
"eventId" : "adb76f6f-4bd3-4704-8735-faa6e94471c3",
"timestamp" : "2019-01-01T00:00:01Z",
"resourceUpdate" : {
"name" : "enterprises/project-id/devices/device-id",
"traits" : {
"sdm.devices.traits.ThermostatMode" : {
"mode" : "COOL"
}
}
},
"userId": "AVPHwEuBfnPOnTqzVFT4IONX2Qqhu9EJ4ubO-bNnQ-yi",
"resourceGroup" : [
"enterprises/project-id/devices/device-id"
]
}किसी भी ट्रेट फ़ील्ड में बदलाव वाले संसाधन इवेंट के पेलोड फ़ॉर्मैट को समझने के लिए, हर ट्रेट का दस्तावेज़ देखें.
किसी डिवाइस ऐक्शन के जवाब में जनरेट होने वाले इवेंट में भी
पेलोड होता है. इससे ट्रेट फ़ील्ड में कोई बदलाव नहीं होता. हालांकि, इसमें traits ऑब्जेक्ट के बजाय resourceUpdate ऑब्जेक्ट के साथ events ऑब्जेक्ट
होता है:
पेलोड
{
"eventId" : "73d758a1-7d19-4e45-8a19-6506399af5a7",
"timestamp" : "2019-01-01T00:00:01Z",
"resourceUpdate" : {
"name" : "enterprises/project-id/devices/device-id",
"events" : {
"sdm.devices.events.CameraMotion.Motion" : {
"eventSessionId" : "CjY5Y3VKaTZwR3o4Y19YbTVfMF...",
"eventId" : "MkhXoQ0QFEcU9at0j380_gUlJA...",
}
}
}
"userId" : "AVPHwEuBfnPOnTqzVFT4IONX2Qqhu9EJ4ubO-bNnQ-yi",
"eventThreadId" : "d67cd3f7-86a7-425e-8bb3-462f92ec9f59",
"eventThreadState" : "STARTED",
"resourceGroup" : [
"enterprises/project-id/devices/device-id"
]
}इस तरह के संसाधन इवेंट, खास ट्रेट में तय किए जाते हैं. उदाहरण के लिए, Motion इवेंट को CameraMotion trait में तय किया जाता है. इस तरह के संसाधन इवेंट के पेलोड फ़ॉर्मैट को समझने के लिए, हर ट्रेट का दस्तावेज़ देखें.
फ़ील्ड
| फ़ील्ड | ब्यौरा | डेटा टाइप |
|---|---|---|
eventId |
इवेंट का यूनीक आइडेंटिफ़ायर. | stringExample: "73d758a1-7d19-4e45-8a19-6506399af5a7" |
timestamp |
इवेंट होने का समय. | stringExample: "2019-01-01T00:00:01Z" |
resourceUpdate |
यह एक ऑब्जेक्ट है, जिसमें संसाधन अपडेट के बारे में जानकारी दी जाती है. | object |
userId |
यह एक यूनीक, ऑफ़स्केट किया गया आइडेंटिफ़ायर है, जो उपयोगकर्ता को दिखाता है. | stringExample: "AVPHwEuBfnPOnTqzVFT4IONX2Qqhu9EJ4ubO-bNnQ-yi" |
eventThreadId |
इवेंट थ्रेड का यूनीक आइडेंटिफ़ायर. | stringExample: "d67cd3f7-86a7-425e-8bb3-462f92ec9f59" |
eventThreadState |
इवेंट थ्रेड की स्थिति. | stringValues: "STARTED", "UPDATED", "ENDED" |
resourceGroup |
यह एक ऑब्जेक्ट है, जो उन संसाधनों के बारे में बताता है जिनके लिए इस इवेंट के जैसे ही अपडेट हो सकते हैं. इवेंट का संसाधन (जो resourceUpdate ऑब्जेक्ट से मिलता है) हमेशा इस ऑब्जेक्ट में मौजूद रहेगा. |
object |
अलग-अलग तरह के इवेंट और उनके काम करने के तरीके के बारे में ज़्यादा जानने के लिए, इवेंट लेख पढ़ें.
अपडेट की जा सकने वाली सूचनाएं
संसाधन इवेंट के आधार पर सूचनाएं, किसी ऐप्लिकेशन में लागू की जा सकती हैं. जैसे, Android या iOS के लिए. भेजी जाने वाली सूचनाओं की संख्या कम करने के लिए, अपडेट की जा सकने वाली सूचनाएं नाम की सुविधा लागू की जा सकती है. इसमें, एक ही इवेंट थ्रेड में होने वाले अगले इवेंट के आधार पर, मौजूदा सूचनाओं को नई जानकारी के साथ अपडेट किया जाता है.अपडेट की जा सकने वाली सूचनाओं के लिए, इवेंट की सुविधा का इस्तेमाल किया जा सकता है. इन्हें दस्तावेज़ में,
अपडेट की जा सकने वाली सूचनाओं eventThreadId नाम का एक अतिरिक्त फ़ील्ड होता है. इस फ़ील्ड का इस्तेमाल करके, अलग-अलग इवेंट को एक साथ लिंक करें. इससे, उपयोगकर्ता को दिखाई गई मौजूदा सूचना को अपडेट किया जा सकेगा.
इवेंट थ्रेड, इवेंट सेशन से अलग होता है. इवेंट थ्रेड , एक ही थ्रेड में मौजूद पिछले इवेंट के लिए अपडेट किया गया स्टेटस दिखाता है. इवेंट सेशन , एक-दूसरे से जुड़े अलग-अलग इवेंट की पहचान करता है. किसी दिए गए इवेंट सेशन के लिए, एक से ज़्यादा इवेंट थ्रेड हो सकते हैं.
सूचनाओं के लिए, अलग-अलग तरह के इवेंट को अलग-अलग थ्रेड में ग्रुप किया जाता है.
थ्रेड ग्रुपिंग और टाइमिंग लॉजिक को Google मैनेज करता है. इसमें किसी भी समय बदलाव किया जा सकता है. A developer को SDM API से मिले इवेंट थ्रेड और सेशन के आधार पर, सूचनाएं अपडेट करनी चाहिए.
थ्रेड की स्थिति
अपडेट की जा सकने वाली सूचनाओं के लिए, इवेंट में eventThreadState फ़ील्ड भी होता है. इससे, उस समय इवेंट थ्रेड की स्थिति का पता चलता है. इस फ़ील्ड में ये वैल्यू होती हैं:
- STARTED — किसी इवेंट थ्रेड में पहला इवेंट.
- UPDATED — किसी चालू इवेंट थ्रेड में मौजूद इवेंट. एक थ्रेड में, इस स्थिति वाले शून्य या उससे ज़्यादा इवेंट हो सकते हैं.
- ENDED — किसी इवेंट थ्रेड में आखिरी इवेंट. यह थ्रेड के टाइप के आधार पर, आखिरी UPDATED इवेंट की डुप्लीकेट कॉपी हो सकती है.
इस फ़ील्ड का इस्तेमाल करके, इवेंट थ्रेड की प्रोग्रेस और उसके खत्म होने का समय ट्रैक किया जा सकता है.
इवेंट फ़िल्टर करना
कुछ मामलों में, किसी डिवाइस से पता चले इवेंट को SDM Pub/Sub विषय पर पब्लिश होने से फ़िल्टर किया जा सकता है. इस व्यवहार को इवेंट फ़िल्टर करना कहा जाता है. इवेंट फ़िल्टर करने का मकसद, कम समय में एक जैसे इवेंट मैसेज को ज़्यादा बार पब्लिश होने से रोकना है.
उदाहरण के लिए, शुरुआती Motion इवेंट के लिए, SDM विषय पर कोई मैसेज पब्लिश किया जा सकता है. इसके बाद, Motion के अन्य मैसेज को, तय समय तक पब्लिश होने से फ़िल्टर किया जाएगा. वह समय खत्म होने के बाद, उस इवेंट टाइप के लिए कोई इवेंट मैसेज फिर से पब्लिश किया जा सकता है.
Google Home ऐप्लिकेशन (GHA) में, फ़िल्टर किए गए इवेंट अब भी के user's इवेंट इतिहास में दिखेंगे. हालांकि, ऐसे इवेंट से ऐप्लिकेशन की सूचना जनरेट नहीं होती. भले ही, उस सूचना टाइप को चालू किया गया हो.
हर तरह के इवेंट के लिए, इवेंट फ़िल्टर करने का अपना लॉजिक होता है. इसे Google तय करता है और इसमें किसी भी समय बदलाव किया जा सकता है. इवेंट फ़िल्टर करने का यह लॉजिक, इवेंट थ्रेड और सेशन के लॉजिक से अलग होता है.
सेवा खाते
SDM API की सदस्यताओं और इवेंट मैसेज को मैनेज करने के लिए, सेवा खातों का इस्तेमाल करने का सुझाव दिया जाता है. सेवा खाते का इस्तेमाल, कोई ऐप्लिकेशन या वर्चुअल मशीन करती है. कोई व्यक्ति नहीं. साथ ही, इसकी अपनी यूनीक खाता कुंजी होती है.
Pub/Sub API के लिए, सेवा खाते के ऑथराइज़ेशन में टू-लेग्ड OAuth (2LO) का इस्तेमाल किया जाता है.
2LO ऑथराइज़ेशन फ़्लो में:
- सेवा कुंजी का इस्तेमाल करके, ऐक्सेस टोकन का अनुरोध करता है. developer
- एपीआई को कॉल करने के लिए, developer ऐक्सेस टोकन का इस्तेमाल करता है.
Google 2LO के बारे में ज़्यादा जानने और इसे सेट अप करने का तरीका जानने के लिए, सर्वर से सर्वर ऐप्लिकेशन के लिए OAuth 2.0 का इस्तेमाल करना लेख पढ़ें.
अनुमति देना
Pub/Sub API के साथ इस्तेमाल करने के लिए, सेवा खाते को ऑथराइज़ किया जाना चाहिए:
- Google Cloud में, Cloud Pub/Sub API को चालू करें.
- सेवा खाता बनाना लेख में बताए गए तरीके से, सेवा खाता और सेवा खाते की कुंजी बनाएं. हमारा सुझाव है कि इसे सिर्फ़ Pub/Sub का सदस्य की भूमिका दें. पक्का करें कि आपने सेवा खाते की कुंजी को उस मशीन पर डाउनलोड किया हो जो Pub/Sub API का इस्तेमाल करेगी.
- अगर आपको एपीआई ऐक्सेस को तुरंत टेस्ट करना है, तो पिछले
चरण में दिए गए पेज पर मौजूद निर्देशों का पालन करके, अपने
ऐप्लिकेशन कोड को ऑथेंटिकेशन क्रेडेंशियल (सेवा खाते की कुंजी) दें. इसके अलावा,
oauth2lका इस्तेमाल करके, मैन्युअल तरीके से ऐक्सेस टोकन पाएं. - मैसेज को पुल करने और उनकी पुष्टि करने के लिए,
Pub/Sub
project.subscriptionsAPI के साथ सेवा खाते के क्रेडेंशियल या ऐक्सेस टोकन का इस्तेमाल करें.
oauth2l
Google oauth2l, OAuth के लिए कमांड लाइन टूल है. इसे Go में लिखा गया है. इसे Mac या Linux के लिए, Go का इस्तेमाल करके इंस्टॉल करें.
- अगर आपके सिस्टम पर Go नहीं है, तो पहले इसे डाउनलोड और इंस्टॉल करें.
- Go इंस्टॉल होने के बाद,
oauth2lइंस्टॉल करें और इसकी जगह को अपनेPATHएनवायरमेंट वैरिएबल में जोड़ें:go install github.com/google/oauth2l@latestexport PATH=$PATH:~/go/bin - एपीआई के लिए ऐक्सेस टोकन पाने के लिए,
oauth2lका इस्तेमाल करें. इसके लिए, सही OAuth स्कोप का इस्तेमाल करें: उदाहरण के लिए, अगर आपकी सेवा कुंजीoauth2l fetch --credentials path-to-service-key.json --scope https://www.googleapis.com/auth/pubsub https://www.googleapis.com/auth/cloud-platform~/myServiceKey-eb0a5f900ee3.jsonपर मौजूद है, तो:oauth2l fetch --credentials ~/myServiceKey-eb0a5f900ee3.json --scope https://www.googleapis.com/auth/pubsub https://www.googleapis.com/auth/cloud-platformya29.c.Elo4BmHXK5...
इस्तेमाल के बारे में ज़्यादा जानकारी के लिए, oauth2l README देखें.
Google API की क्लाइंट लाइब्रेरी
Google API के लिए कई क्लाइंट लाइब्रेरी उपलब्ध हैं. इनमें OAuth 2.0 का इस्तेमाल किया जाता है. अपनी पसंद की भाषा के बारे में ज़्यादा जानने के लिए, Google API की क्लाइंट लाइब्रेरी देखें.
के साथ इन लाइब्रेरी का इस्तेमाल करते समय, ये स्कोप स्ट्रिंग इस्तेमाल करें: Pub/Sub API
https://www.googleapis.com/auth/pubsub https://www.googleapis.com/auth/cloud-platform
गड़बड़ियां
इस गाइड के मुताबिक, ये गड़बड़ी कोड दिखाए जा सकते हैं:
| गड़बड़ी का मैसेज | RPC | समस्या का हल |
|---|---|---|
| कैमरे की इमेज अब डाउनलोड के लिए उपलब्ध नहीं है. | DEADLINE_EXCEEDED |
इवेंट पब्लिश होने के 30 सेकंड बाद, इवेंट की इमेज की समयसीमा खत्म हो जाती है. पक्का करें कि आपने समयसीमा खत्म होने से पहले इमेज डाउनलोड कर ली हो. |
| इवेंट आईडी, कैमरे से जुड़ा नहीं है. | FAILED_PRECONDITION |
कैमरे के इवेंट से मिले सही eventID का इस्तेमाल करें. |
एपीआई के गड़बड़ी कोड की पूरी सूची देखने के लिए, एपीआई के गड़बड़ी कोड का रेफ़रंस देखें.