يتيح واجهة مستخدم Classroom خمسة أنواع من "واجبات الصف": المهام الدراسية،
ومهام الاختبارات، والأسئلة ذات الإجابات القصيرة، والأسئلة ذات الخيارات المتعدّدة،
والمواد. تتيح واجهة Classroom API حاليًا ثلاثة من هذه الأنواع، والمعروفة باسم CourseWorkType
لواجهة برمجة التطبيقات: المهام الدراسية والأسئلة ذات الإجابات القصيرة وأسئلة الخيارات المتعدّدة.
للوصول إلى هذه الوظيفة، يمكنك استخدام مرجع CourseWork، الذي يمثّل مهمة أو سؤالًا تم تكليف الطلاب بحلّه في دورة تدريبية معيّنة، بما في ذلك أي مواد وتفاصيل إضافية، مثل تاريخ التسليم أو الدرجة القصوى.
بالإضافة إلى مورد CourseWork، يمكنك إدارة المهام المكتملة
باستخدام مورد StudentSubmission
. توضّح الأقسام التالية هذه النقاط بمزيد من التفصيل.
إنشاء المهام
يمكن إنشاء المهام فقط نيابةً عن معلّمي الدورة التدريبية، ومحاولة إنشاء مهام في دورة تدريبية نيابةً عن طالب سيؤدي إلى PERMISSION_DENIED
خطأ 403. وبالمثل، لا يمكن لمشرفي النطاق أيضًا إنشاء assignments (مهام) للدورات التدريبية التي لا يدرّسونها، ومحاولة إجراء ذلك من خلال واجهة برمجة التطبيقات
ستؤدي أيضًا إلى ظهور خطأ 403 PERMISSION_DENIED
.
عند إنشاء المهام باستخدام الطريقة courses.courseWork.create
،
يمكنك إرفاق الروابط على النحو التالي: materials
، كما هو موضّح في نموذج الرمز البرمجي أدناه:
Java
Python
تتضمن النتيجة معرّفًا تم تعيينه بواسطة الخادم ويمكن استخدامه للإشارة إلى التعيين في طلبات واجهة برمجة التطبيقات الأخرى.
لتضمين المواد المرتبطة في مهمة تم إنشاؤها باستخدام Classroom API، استخدِم مرجع الربط، مع تحديد عنوان URL المستهدف. يجلب Classroom تلقائيًا العنوان والصورة المصغّرة. بالإضافة إلى ذلك، تتوافق واجهة Classroom API مع مواد Google Drive وYouTube في الأصل، والتي يمكن تضمينها مع مورد DriveFile أو مورد YouTubeVideo بطريقة مماثلة.
لتحديد تاريخ استحقاق، اضبط الحقلَين dueDate
وdueTime
على
التوقيت العالمي المنسق المقابل. يجب أن يكون تاريخ التسليم في المستقبل.
استرداد المهام والأسئلة
يمكنك استرداد المهام والأسئلة للطلاب والمعلمين في الدورة التدريبية المعنيّة أو من خلال مشرف النطاق. لاسترداد مهمة أو سؤال معيّنَين، استخدِم courses.courseWork.get. لاسترداد كل assignments أو questions (اختياريًا مطابقة بعض المعايير)، استخدِم courseWork.list.
يعتمد النطاق المطلوب على الدور الذي يقوم به المستخدم صاحب الدورة التدريبية في الدورة. إذا كان المستخدم طالبًا، يمكنك استخدام أحد النطاقات التالية:
https://www.googleapis.com/auth/classroom.coursework.me.readonly
https://www.googleapis.com/auth/classroom.coursework.me
إذا كان المستخدم معلّمًا أو مشرف نطاق، استخدِم أحد النطاقات التالية:
https://www.googleapis.com/auth/classroom.coursework.students.readonly
https://www.googleapis.com/auth/classroom.coursework.students
إن الحصول على إذن لاسترداد مهمة ما أو سؤال لا يتضمن الأذونات للوصول إلى المواد أو بيانات التعريف للمواد. يعني ذلك عمليًا أنّه قد لا يظهر للمشرف عنوان ملف Drive المرفق إذا لم يكن عضوًا في الدورة التدريبية. إذا كنت تريد السماح للمشرفين بالوصول إلىملفّات المستخدمين، اطّلِع على دليل تفويض الصلاحيات على مستوى النطاق.
إدارة ردود الطلاب
يمثّل مرجع StudentSubmission
العمل الذي أنجزه الطالب ودرجته في مهمة أو
سؤال. يتم إنشاء مورد StudentSubmission
ضمنيًا لكل طالب عند إنشاء سؤال أو
مهمة جديدة.
توضّح الأقسام التالية الإجراءات الشائعة التي يمكن من خلالها إدارة ردود الطلاب.
استرداد ردود الطلاب
يمكن للطلاب استرداد المحتوى الذي أرسلوه، ويمكن للمعلّمين استرداد المحتوى الذي أرسله
جميع الطلاب في الدورات التدريبية التي يدرّسونها، ويمكن لمشرفي النطاق استرداد كل المحتوى الذي أرسله
جميع الطلاب في نطاقهم. يتم تحديد معرّف لكل نموذج يرسله الطالب. إذا كنت تعرف المعرّف، استخدِم courses.courseWork.studentSubmissions.get
لاسترداده.
استخدِم طريقة courses.courseWork.studentSubmissions.list
للحصول على موارد
StudentSubmission
تتطابق مع بعض المعايير، كما هو موضّح في المثال التالي:
Java
Python
استرجع موارد StudentSubmission
التي تخصّ طالبًا معيّنًا من خلال
تحديد المَعلمة userId
، كما هو موضّح في المثال التالي:
Java
Python
يتم التعرّف على الطلاب من خلال المعرّف الفريد أو عنوان البريد الإلكتروني للمستخدم، على النحو الذي تعرضه حزمة تطوير البرامج لوحدة تحكّم المشرف في Google. يمكن للمستخدم الحالي أيضًا الإشارة إلى
رقم تعريفه باستخدام الاختصار "me"
.
من الممكن أيضًا الحصول على المهام التي أرسلها الطلاب لجميع المهام الدراسية ضمن
دورة تدريبية. لإجراء ذلك، استخدِم القيمة الثابتة "-"
كقيمة courseWorkId
، كما هو موضَّح في المثال التالي:
Java
service.courses().courseWork().studentSubmissions()
.list(courseId, "-")
.set("userId", userId)
.execute();
Python
service.courses().courseWork().studentSubmissions().list(
courseId=<course ID or alias>,
courseWorkId='-',
userId=<user ID>).execute()
يعتمد النطاق المطلوب على الدور الذي يقوم به المستخدم صاحب الدورة التدريبية في الدورة. استخدِم النطاق التالي إذا كان المستخدم معلّمًا أو مشرف نطاق:
https://www.googleapis.com/auth/classroom.coursework.students.readonly
https://www.googleapis.com/auth/classroom.coursework.students
استخدِم النطاق التالي إذا كان المستخدم طالبًا:
https://www.googleapis.com/auth/classroom.coursework.me.readonly
https://www.googleapis.com/auth/classroom.coursework.me
إنّ الحصول على إذن باسترداد ملف أرسله أحد الطلاب لا يعني أنّ لديك أذونات للوصول إلى المرفقات أو البيانات الوصفية للمرفقات. من الناحية العملية، يعني ذلك أنّه قد لا يظهر للمشرف عنوان ملف Drive المرفق إذا لم يكن عضوًا في الدورة التدريبية. إذا كنت تريد السماح للمشرفين بالوصول إلى ملفات المستخدمين، اطّلِع على دليل التفويض على مستوى النطاق.
إضافة مرفقات إلى ردّ أحد الطلاب
يمكنك إرفاق الروابط إلى المَهمّة الدراسية التي أرسلها الطالب من خلال إرفاق مرجع Link
أو DriveFile
أو YouTubeVideo
. يتم ذلك باستخدام الرمز
courses.courseWork.studentSubmissions.modifyAttachments
، كما هو موضّح في المثال التالي:
Java
Python
يتم تحديد مرفق الرابط من خلال عنوان URL المستهدف، وسيجلب Classroom تلقائيًا عنوان الفيديو والصورة المصغّرة. يمكنك الاطّلاع على المواد الأخرى في صفحات المراجع ذات الصلة.
لا يمكن تعديل StudentSubmission
إلا من قِبل معلّم الدورة التدريبية أو
الطالب الذي يملكها. لا يمكنك إرفاق Materials
إلا إذا كانت قيمة السمة
CourseWorkType
لإرسال الطالب هي ASSIGNMENT
.
يعتمد النطاق المطلوب على الدور الذي يملكه المستخدم المُقدّم للطلب في الدورة التدريبية. استخدِم النطاق التالي إذا كان المستخدم معلّمًا:
https://www.googleapis.com/auth/classroom.coursework.students
استخدِم النطاق التالي إذا كان المستخدم طالبًا:
https://www.googleapis.com/auth/classroom.coursework.me