إدارة الدورات الدراسية

يتيح واجهة مستخدم Classroom خمسة أنواع من "واجبات الصف": المهام الدراسية، ومهام الاختبارات، والأسئلة ذات الإجابات القصيرة، والأسئلة ذات الخيارات المتعدّدة، والمواد. تتيح Classroom API حاليًا ثلاثة من هذه الأنواع، والتي تُعرف باسم CourseWorkType لواجهة برمجة التطبيقات: المهام والأسئلة التي تتطلب إجابة قصيرة والأسئلة التي تتطلب خيارات متعدّدة.

للوصول إلى هذه الوظيفة، يمكنك استخدام مرجع CourseWork، الذي يمثّل مهمة أو سؤالًا تم تكليف الطلاب بحلّه في دورة تدريبية معيّنة، بما في ذلك أي مواد وتفاصيل إضافية، مثل تاريخ التسليم أو الدرجة القصوى.

بالإضافة إلى مورد CourseWork، يمكنك إدارة المهام المكتملة باستخدام مورد StudentSubmission. توضّح الأقسام التالية هذه النقاط بمزيد من التفصيل.

إنشاء المهام

يمكن إنشاء المهام فقط نيابةً عن معلّمي الدورة التدريبية، ومحاولة إنشاء مهام في دورة تدريبية نيابةً عن طالب سيؤدي إلى PERMISSION_DENIED خطأ 403. وبالمثل، لا يمكن لمشرفي النطاق أيضًا إنشاء assignments (مهام) للدورات التدريبية التي لا يدرّسونها، ومحاولة إجراء ذلك من خلال واجهة برمجة التطبيقات ستؤدي أيضًا إلى ظهور خطأ 403 PERMISSION_DENIED.

عند إنشاء المهام باستخدام الطريقة courses.courseWork.create، يمكنك إرفاق الروابط على النحو التالي: materials، كما هو موضّح في الرمز البرمجي النموذجي أدناه:

Java

classroom/snippets/src/main/java/CreateCourseWork.java
CourseWork courseWork = null;
try {
  // Create a link to add as a material on course work.
  Link articleLink =
      new Link()
          .setTitle("SR-71 Blackbird")
          .setUrl("https://www.lockheedmartin.com/en-us/news/features/history/blackbird.html");

  // Create a list of Materials to add to course work.
  List<Material> materials = Arrays.asList(new Material().setLink(articleLink));

  /* Create new CourseWork object with the material attached.
  Set workType to `ASSIGNMENT`. Possible values of workType can be found here:
  https://developers.google.com/classroom/reference/rest/v1/CourseWorkType
  Set state to `PUBLISHED`. Possible values of state can be found here:
  https://developers.google.com/classroom/reference/rest/v1/courses.courseWork#courseworkstate */
  CourseWork content =
      new CourseWork()
          .setTitle("Supersonic aviation")
          .setDescription(
              "Read about how the SR-71 Blackbird, the world’s fastest and "
                  + "highest-flying manned aircraft, was built.")
          .setMaterials(materials)
          .setWorkType("ASSIGNMENT")
          .setState("PUBLISHED");

  courseWork = service.courses().courseWork().create(courseId, content).execute();

  /* Prints the created courseWork. */
  System.out.printf("CourseWork created: %s\n", courseWork.getTitle());
} catch (GoogleJsonResponseException e) {
  // TODO (developer) - handle error appropriately
  GoogleJsonError error = e.getDetails();
  if (error.getCode() == 404) {
    System.out.printf("The courseId does not exist: %s.\n", courseId);
  } else {
    throw e;
  }
  throw e;
} catch (Exception e) {
  throw e;
}
return courseWork;

Python

classroom/snippets/classroom_create_coursework.py
import google.auth
from googleapiclient.discovery import build
from googleapiclient.errors import HttpError


def classroom_create_coursework(course_id):
  """
  Creates the coursework the user has access to.
  Load pre-authorized user credentials from the environment.
  TODO(developer) - See https://developers.google.com/identity
  for guides on implementing OAuth2 for the application.
  """

  creds, _ = google.auth.default()
  # pylint: disable=maybe-no-member

  try:
    service = build("classroom", "v1", credentials=creds)
    coursework = {
        "title": "Ant colonies",
        "description": """Read the article about ant colonies
                              and complete the quiz.""",
        "materials": [
            {"link": {"url": "http://example.com/ant-colonies"}},
            {"link": {"url": "http://example.com/ant-quiz"}},
        ],
        "workType": "ASSIGNMENT",
        "state": "PUBLISHED",
    }
    coursework = (
        service.courses()
        .courseWork()
        .create(courseId=course_id, body=coursework)
        .execute()
    )
    print(f"Assignment created with ID {coursework.get('id')}")
    return coursework

  except HttpError as error:
    print(f"An error occurred: {error}")
    return error


if __name__ == "__main__":
  # Put the course_id of course whose coursework needs to be created,
  # the user has access to.
  classroom_create_coursework(453686957652)

تتضمّن النتيجة معرّفًا يحدّده الخادم ويمكن استخدامه للإشارة إلى عملية الربط في طلبات واجهة برمجة التطبيقات الأخرى.

لتضمين مواد مرتبطة في مهمة تم إنشاؤها من خلال 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

classroom/snippets/src/main/java/ListSubmissions.java
List<StudentSubmission> studentSubmissions = new ArrayList<>();
String pageToken = null;

try {
  do {
    ListStudentSubmissionsResponse response =
        service
            .courses()
            .courseWork()
            .studentSubmissions()
            .list(courseId, courseWorkId)
            .setPageToken(pageToken)
            .execute();

    /* Ensure that the response is not null before retrieving data from it to avoid errors. */
    if (response.getStudentSubmissions() != null) {
      studentSubmissions.addAll(response.getStudentSubmissions());
      pageToken = response.getNextPageToken();
    }
  } while (pageToken != null);

  if (studentSubmissions.isEmpty()) {
    System.out.println("No student submission found.");
  } else {
    for (StudentSubmission submission : studentSubmissions) {
      System.out.printf(
          "Student id (%s), student submission id (%s)\n",
          submission.getUserId(), submission.getId());
    }
  }
} catch (GoogleJsonResponseException e) {
  // TODO (developer) - handle error appropriately
  GoogleJsonError error = e.getDetails();
  if (error.getCode() == 404) {
    System.out.printf(
        "The courseId (%s) or courseWorkId (%s) does not exist.\n", courseId, courseWorkId);
  } else {
    throw e;
  }
} catch (Exception e) {
  throw e;
}
return studentSubmissions;

Python

classroom/snippets/classroom_list_submissions.py
import google.auth
from googleapiclient.discovery import build
from googleapiclient.errors import HttpError


def classroom_list_submissions(course_id, coursework_id):
  """
  Creates the courses the user has access to.
  Load pre-authorized user credentials from the environment.
  TODO(developer) - See https://developers.google.com/identity
  for guides on implementing OAuth2 for the application.
  """

  creds, _ = google.auth.default()
  # pylint: disable=maybe-no-member
  submissions = []
  page_token = None

  try:
    service = build("classroom", "v1", credentials=creds)
    while True:
      coursework = service.courses().courseWork()
      response = (
          coursework.studentSubmissions()
          .list(
              pageToken=page_token,
              courseId=course_id,
              courseWorkId=coursework_id,
              pageSize=10,
          )
          .execute()
      )
      submissions.extend(response.get("studentSubmissions", []))
      page_token = response.get("nextPageToken", None)
      if not page_token:
        break

    if not submissions:
      print("No student submissions found.")

    print("Student Submissions:")
    for submission in submissions:
      print(
          "Submitted at:"
          f"{(submission.get('id'), submission.get('creationTime'))}"
      )

  except HttpError as error:
    print(f"An error occurred: {error}")
    submissions = None
  return submissions


if __name__ == "__main__":
  # Put the course_id and coursework_id of course whose list needs to be
  # submitted.
  classroom_list_submissions(453686957652, 466086979658)

استرجع موارد StudentSubmission التي تخصّ طالبًا معيّنًا من خلال تحديد المَعلمة userId، كما هو موضّح في المثال التالي:

Java

classroom/snippets/src/main/java/ListStudentSubmissions.java
List<StudentSubmission> studentSubmissions = new ArrayList<>();
String pageToken = null;

try {
  do {
    // Set the userId as a query parameter on the request.
    ListStudentSubmissionsResponse response =
        service
            .courses()
            .courseWork()
            .studentSubmissions()
            .list(courseId, courseWorkId)
            .setPageToken(pageToken)
            .set("userId", userId)
            .execute();

    /* Ensure that the response is not null before retrieving data from it to avoid errors. */
    if (response.getStudentSubmissions() != null) {
      studentSubmissions.addAll(response.getStudentSubmissions());
      pageToken = response.getNextPageToken();
    }
  } while (pageToken != null);

  if (studentSubmissions.isEmpty()) {
    System.out.println("No student submission found.");
  } else {
    for (StudentSubmission submission : studentSubmissions) {
      System.out.printf("Student submission: %s.\n", submission.getId());
    }
  }

Python

classroom/snippets/classroom_list_student_submissions.py
import google.auth
from googleapiclient.discovery import build
from googleapiclient.errors import HttpError


def classroom_list_student_submissions(course_id, coursework_id, user_id):
  """
  Creates the courses the user has access to.
  Load pre-authorized user credentials from the environment.
  TODO(developer) - See https://developers.google.com/identity
  for guides on implementing OAuth2 for the application.
  """

  creds, _ = google.auth.default()
  # pylint: disable=maybe-no-member
  submissions = []
  page_token = None

  try:
    service = build("classroom", "v1", credentials=creds)
    while True:
      coursework = service.courses().courseWork()
      response = (
          coursework.studentSubmissions()
          .list(
              pageToken=page_token,
              courseId=course_id,
              courseWorkId=coursework_id,
              userId=user_id,
          )
          .execute()
      )
      submissions.extend(response.get("studentSubmissions", []))
      page_token = response.get("nextPageToken", None)
      if not page_token:
        break

    if not submissions:
      print("No student submissions found.")

    print("Student Submissions:")
    for submission in submissions:
      print(
          "Submitted at:"
          f"{(submission.get('id'), submission.get('creationTime'))}"
      )

  except HttpError as error:
    print(f"An error occurred: {error}")
  return submissions


if __name__ == "__main__":
  # Put the course_id, coursework_id and user_id of course whose list needs
  # to be submitted.
  classroom_list_student_submissions(453686957652, 466086979658, "me")

يتم تحديد الطلاب من خلال المعرّف الفريد أو عنوان البريد الإلكتروني للمستخدم، على النحو الذي يعرضه "حزمة تطوير البرامج لوحدة تحكّم المشرف في 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

classroom/snippets/src/main/java/ModifyAttachmentsStudentSubmission.java
StudentSubmission studentSubmission = null;
try {
  // Create ModifyAttachmentRequest object that includes a new attachment with a link.
  Link link = new Link().setUrl("https://en.wikipedia.org/wiki/Irrational_number");
  Attachment attachment = new Attachment().setLink(link);
  ModifyAttachmentsRequest modifyAttachmentsRequest =
      new ModifyAttachmentsRequest().setAddAttachments(Arrays.asList(attachment));

  // The modified studentSubmission object is returned with the new attachment added to it.
  studentSubmission =
      service
          .courses()
          .courseWork()
          .studentSubmissions()
          .modifyAttachments(courseId, courseWorkId, id, modifyAttachmentsRequest)
          .execute();

  /* Prints the modified student submission. */
  System.out.printf(
      "Modified student submission attachments: '%s'.\n",
      studentSubmission.getAssignmentSubmission().getAttachments());
} catch (GoogleJsonResponseException e) {
  // TODO (developer) - handle error appropriately
  GoogleJsonError error = e.getDetails();
  if (error.getCode() == 404) {
    System.out.printf(
        "The courseId (%s), courseWorkId (%s), or studentSubmissionId (%s) does "
            + "not exist.\n",
        courseId, courseWorkId, id);
  } else {
    throw e;
  }
} catch (Exception e) {
  throw e;
}
return studentSubmission;

Python

classroom/snippets/classroom_add_attachment.py
def classroom_add_attachment(course_id, coursework_id, submission_id):
  """
  Adds attachment to existing course with specific course_id.
  Load pre-authorized user credentials from the environment.
  TODO(developer) - See https://developers.google.com/identity
  for guides on implementing OAuth2 for the application.
  """
  creds, _ = google.auth.default()
  # pylint: disable=maybe-no-member
  request = {
      "addAttachments": [
          {"link": {"url": "http://example.com/quiz-results"}},
          {"link": {"url": "http://example.com/quiz-reading"}},
      ]
  }

  try:
    service = build("classroom", "v1", credentials=creds)
    while True:
      coursework = service.courses().courseWork()
      coursework.studentSubmissions().modifyAttachments(
          courseId=course_id,
          courseWorkId=coursework_id,
          id=submission_id,
          body=request,
      ).execute()

  except HttpError as error:
    print(f"An error occurred: {error}")


if __name__ == "__main__":
  # Put the course_id, coursework_id and submission_id of course in which
  # attachment needs to be added.
  classroom_add_attachment("course_id", "coursework_id", "me")

يتم تحديد مرفق الرابط من خلال عنوان URL المستهدف، وسيجلب Classroom تلقائيًا عنوان الفيديو والصورة المصغّرة. يمكنك الاطّلاع على المواد الأخرى في صفحات المراجع ذات الصلة.

لا يمكن تعديل StudentSubmission إلا من قِبل معلّم الدورة التدريبية أو الطالب الذي يملكه. لا يمكنك إرفاق Materials إلا إذا كان CourseWorkType العينة التي أرسلها الطالب هي ASSIGNMENT.

يعتمد النطاق المطلوب على الدور الذي يملكه المستخدم المُقدّم للطلب في الدورة التدريبية. استخدِم النطاق التالي إذا كان المستخدم معلّمًا:

  • https://www.googleapis.com/auth/classroom.coursework.students

استخدِم النطاق التالي إذا كان المستخدم طالبًا:

  • https://www.googleapis.com/auth/classroom.coursework.me