इस गाइड में, Google Drive Activity API के वर्शन 1 और 2 के बीच के अंतर के बारे में बताया गया है. साथ ही, v2 एपीआई के साथ काम करने के लिए, v1 ऐप्लिकेशन को बदलने का तरीका भी बताया गया है.
अनुमति देना
v1 एपीआई ने इस स्कोप का इस्तेमाल किया था:
https://www.googleapis.com/auth/activity
v2 API के लिए, इनमें से किसी एक स्कोप की ज़रूरत होती है:
https://www.googleapis.com/auth/drive.activity
https://www.googleapis.com/auth/drive.activity.readonly
संसाधन के नाम
v1 API में, Google Drive आइटम और उपयोगकर्ताओं जैसे ऑब्जेक्ट के आइडेंटिफ़ायर, अस्पष्ट स्ट्रिंग थे. v2 API में, आम तौर पर इन ऑब्जेक्ट का रेफ़रंस, संसाधन के नामों का इस्तेमाल करके दिया जाता है. ज़्यादा जानकारी के लिए, Cloud API के डिज़ाइन से जुड़ी गाइड देखें .
आम तौर पर, इन आइडेंटिफ़ायर को बदला जा सकता है. उदाहरण के लिए, v2 API में Drive के आइटम का रेफ़रंस, रिसॉर्स के नाम items/ITEM_ID_V1
का इस्तेमाल करके दिया जाता है.
अनुरोध
वर्शन 2 के लिए अनुरोध का फ़ॉर्मैट, वर्शन 1 के फ़ॉर्मैट से मिलता-जुलता है. खास तौर पर, अब भी Drive फ़ाइल या Drive के किसी पैरंट के लिए गतिविधि का अनुरोध किया जा सकता है. हालांकि, ध्यान रखें कि आपको उन अनुरोध पैरामीटर को items/
से पहले लगाकर, संसाधन के नाम के तौर पर फ़ॉर्मैट करना होगा.
"ग्रुपिंग" को अब
एक साथ जोड़ना कहा जाता है. साथ ही, source
और
userId
अनुरोध पैरामीटर हटा दिए गए हैं.
इसमें नए फ़िल्टर विकल्प भी हैं. इनकी मदद से, रिस्पॉन्स में दिखाए जाने वाले गतिविधि डेटा के टाइप को सीमित किया जा सकता है.
कार्रवाइयां
v1 API में, गतिविधि का टाइप और उस गतिविधि से जुड़ा डेटा, अलग-अलग फ़ील्ड में होता था. उदाहरण के लिए, अगर primaryEventType
फ़ील्ड में move
वैल्यू मौजूद है, तो ऐप्लिकेशन यह मान लेंगे कि टॉप-लेवल move
फ़ील्ड में, जोड़े गए और हटाए गए माता-पिता की जानकारी अपने-आप भर गई है.
v2 API में, ये फ़ील्ड अब अलग नहीं हैं. ActionDetail
मैसेज में सिर्फ़ एक फ़ील्ड सेट है. यह कार्रवाई के टाइप के बारे में बताता है. साथ ही, इसमें उस कार्रवाई से जुड़ी जानकारी होती है. उदाहरण के लिए, किसी आइटम को एक से दूसरी जगह ले जाने के बारे में बताने वाला ActionDetail
, सिर्फ़ move
फ़ील्ड को सेट करता है. साथ ही, उस फ़ील्ड में जोड़े गए और हटाए गए पैरंट आइटम की सूची दिखती है.
v1 API primaryEventType
फ़ील्ड, v2
primaryActionDetail
से मिलता-जुलता है.
Actors
v1 एपीआई में, अगर उपयोगकर्ता कोई जाना-पहचाना व्यक्ति था, तो दिखाई गई गतिविधि में User
होता था. साथ ही, खास मामलों के लिए fromUserDeletion
जैसे टॉप-लेवल फ़ील्ड भी हो सकता था.
v2 API में, Actor
टाइप का बेहतर सेट उपलब्ध है. साथ ही, जब उपयोगकर्ता कोई जाना-पहचाना उपयोगकर्ता होता है, तो user.knownUser
अपने-आप पॉप्युलेट हो जाता है. अगर आपके ऐप्लिकेशन को उपयोगकर्ताओं के बारे में ज़्यादा जानकारी चाहिए, तो वह People API से क्वेरी कर सकता है. इसके लिए, KnownUser
फ़ील्ड personName
को people.get
तरीके में पास करना होगा.
टारगेट
v1 API में, टारगेट हमेशा Drive आइटम होते थे. v2 API में, Drive में मौजूद अन्य तरह के ऑब्जेक्ट भी टारगेट हो सकते हैं. उदाहरण के लिए, किसी ड्राइव में किए गए बदलावों का टारगेट टाइप Drive
होता है. शेयर की गई ड्राइव का रूट फ़ोल्डर अब भी दिखाया जाता है (root
फ़ील्ड में DriveItem
के तौर पर), लेकिन यह गतिविधि का तात्कालिक टारगेट नहीं है. इसी तरह का कॉन्सेप्ट, FileComment
संसाधन पर भी लागू होता है. इस संसाधन के parent
फ़ील्ड में, टारगेट की गई टिप्पणी वाली थ्रेड वाले Drive आइटम की जानकारी होती है.
सभी खातों की गतिविधि
v1 एपीआई में, इकट्ठा करने ("ग्रुप करने") की रणनीति सेट होने पर, जवाब का स्टाइल बदल गया. खास तौर पर, जब कंसोलिडेशन की सुविधा चालू थी, तो हर गतिविधि में कॉम्पोनेंट singleEvents
और combinedEvent
शामिल होता था. इससे उन कॉम्पोनेंट इवेंट के बीच की सामान्य गतिविधि की खास जानकारी मिलती थी. जब कंसोलिडेशन की सुविधा बंद थी, तब combinedEvent
फ़ील्ड में हर गतिविधि का मूल इवेंट शामिल था. इनमें से कोई भी इवेंट एक से ज़्यादा कार्रवाइयों को दिखा सकता है. जैसे, शेयर करने के साथ-साथ बनाना.
v2 API में, जवाब का स्टाइल, एक साथ कई डेटा सोर्स को एक जगह पर इकट्ठा करने की रणनीति के आधार पर नहीं बदलता. ऐसा इसलिए, क्योंकि दिखाए गए DriveActivity
में हमेशा ऐक्टर, टारगेट, और ऐक्शन का पूरा सेट होता है.