इस पेज पर, Google Classroom API में अनुरोधों के काम करने के तरीके के बारे में खास जानकारी दी गई है. इसका मकसद उन पाठकों की मदद करना है जो पहले से ही संसाधन-ओरिएंटेड डिज़ाइन या Google Workspace के एपीआई के बारे में नहीं जानते.
खास कोड सैंपल के लिए, उससे जुड़ी एपीआई गाइड देखें. उदाहरण के लिए, कोर्स बनाएं और मैनेज करें या कोर्सवर्क बनाएं और मैनेज करें.
संसाधन-ओरिएंटेड डिज़ाइन
एपीआई स्ट्रक्चर में बताए गए मुताबिक, Classroom API, संसाधन-ओरिएंटेड डिज़ाइन पैटर्न का पालन करता है. ज़्यादातर संसाधनों में, स्टैंडर्ड ऑपरेशन के लिए तरीके होते हैं. जैसे, संसाधन के इंस्टेंस बनाना, पढ़ना, अपडेट करना, और मिटाना.
उदाहरण के लिए, एपीआई का इस्तेमाल करके Classroom Course
को create()
, patch()
, get()
, list()
, और delete()
किया जा सकता है.
बनाएं
Course
जैसे कोई नया संसाधन बनाने के लिए, उससे जुड़े संसाधन के लिए create()
तरीका कॉल करें.
Create()
कॉल के लिए, हमेशा उससे जुड़े संसाधन की शुरुआती और अहम जानकारी को इनपुट के तौर पर देना ज़रूरी होता है. उदाहरण के लिए, Course
बनाने के लिए, Course
संसाधन पर create()
तरीके को कॉल करें और अनुरोध में name
और
description
के साथ-साथ room
जैसी वैकल्पिक जानकारी दें.
सब-रिसॉर्स (जिन्हें कभी-कभी चाइल्ड रिसॉर्स भी कहा जाता है) के लिए, पैरंट रिसॉर्स के आइडेंटिफ़ायर भी ज़रूरी हैं. उदाहरण के लिए, किसी Course
में CourseWork
बनाते समय, Course
id
की ज़रूरत होती है, ताकि यह तय किया जा सके कि CourseWork
किस Course
से जुड़ा है.
Create()
तरीके, एपीआई कॉल के जवाब में, नए बनाए गए संसाधन का एक इंस्टेंस दिखाते हैं. आम तौर पर, दिखाए गए रिसॉर्स में, सर्वर से जनरेट किए गए अतिरिक्त फ़ील्ड होते हैं. जैसे, रिसॉर्स id
या creationTime
.
पैच
मौजूदा संसाधनों में बदलाव करने के लिए, उस संसाधन पर patch()
तरीके (जिसे कभी-कभी update()
कहा जाता है) को कॉल करें. patch()
तरीका, create()
के तरीके से काफ़ी हद तक मिलता-जुलता है. हालांकि, इन दोनों तरीकों में दो मुख्य अंतर हैं. patch()
तरीका इस्तेमाल करते समय, आपको यह बताना होगा:
- उस संसाधन का
id
जिसमें बदलाव करना है. - फ़ील्ड की सूची, जिसे
updateMask
कहा जाता है. इससे यह तय किया जाता है कि संसाधन के किन फ़ील्ड को अपडेट करना है. अगर फ़ील्ड का डिफ़ॉल्ट सेट मौजूद है या फ़ील्ड का अनुमान लगाया गया है, तो यह विकल्प ज़रूरी नहीं है.
Patch()
तरीके, एपीआई कॉल के जवाब में अपडेट किए गए संसाधन का पूरा इंस्टेंस दिखाते हैं. इसमें सभी बदलाव पूरे हो चुके होते हैं.
पाना और सूची बनाना
संसाधनों को वापस पाने के दो तरीके हैं: get()
और list()
.
get()
तरीका, किसी आइडेंटिफ़ायर की मदद से किसी खास संसाधन को वापस लाता है. उदाहरण के लिए, id
या alias
के आधार पर Course
फ़ेच करना. get()
कॉल, पूरे रिसॉर्स को सीधे तौर पर दिखाता है.
list()
तरीका, एक ही तरह के कई रिसॉर्स को एक ही अनुरोध में पाता है. इसके लिए, अलग-अलग रिसॉर्स आइडेंटिफ़ायर की ज़रूरत नहीं होती. अक्सर, list()
ऑपरेशन को किसी पैरंट रिसॉर्स के सभी सब-रिसॉर्स मिलते हैं. उदाहरण के लिए, Course
में मौजूद सभी CourseWork
को फिर से पाना. यह कई get()
कॉल करने की तुलना में, अनुरोधों को कम करने के लिए मददगार है. यह तब ज़्यादा अहम होता है, जब आपको अपने पसंदीदा संसाधनों के id
की जानकारी न हो.
आम तौर पर, list()
तरीकों में कुछ ऐसे संसाधन होते हैं जिन्हें एक कॉल में दिखाया जा सकता है. साथ ही, कॉल के साथ pageSize
वैल्यू शामिल करके, कम सीमाएं कॉन्फ़िगर की जा सकती हैं. अगर तय सीमा से ज़्यादा रिसॉर्स हैं, तो list()
तरीका पेजेशन के साथ काम करता है. नतीजों के हर "पेज" में एक pageToken
होता है. इसे रिसॉर्स के अगले बैच को फ़ेच करने के लिए, अगले list()
कॉल में शामिल किया जा सकता है.
मिटाएं
delete()
तरीका, id
जैसे संसाधन आइडेंटिफ़ायर को स्वीकार करता है और उससे जुड़े संसाधन को मिटा देता है. अगर delete()
कामयाब होता है, तो कोई जवाब नहीं दिया जाता.
अन्य कार्रवाइयां
Classroom API की मदद से किए जा सकने वाले सभी काम, ऊपर बताए गए स्टैंडर्ड कामों से नहीं किए जा सकते. उदाहरण के लिए, CourseWork
संसाधन के असाइनी में बदलाव करना. ऐसे मामलों में, modifyAssignees
जैसे कस्टम तरीके उपलब्ध होते हैं. इन तरीकों के काम करने का तरीका अलग-अलग होता है. इसलिए, आपको इनके लिए अलग-अलग दस्तावेज़ देखना चाहिए.