Die Classroom App unterstützt drei Arten von Stream-Elementen: CourseWork
, CourseWorkMaterials
und Announcements
. In dieser Anleitung wird beschrieben, wie Sie CourseWork
verwalten. Die APIs für alle Stream-Elemente sind jedoch ähnlich. Weitere Informationen zu den Stream-Elementtypen und ihren Unterschieden finden Sie unter API-Ressourcen.
Die CourseWork
-Ressource stellt eine Aufgabe dar, die Schülern oder Studenten in einem bestimmten Kurs zugewiesen wurde. Sie enthält alle zusätzlichen Materialien und Details wie Fälligkeitsdatum oder maximale Punktzahl. Es gibt vier Untertypen von CourseWork
: Aufgaben, Aufgaben mit Quiz, Kurzantwortfragen und Multiple-Choice-Fragen. Die Classroom API unterstützt drei dieser Untertypen: Aufgaben, Kurzantwortfragen und Multiple-Choice-Fragen. Diese Typen werden durch das Feld CourseWork.workType
dargestellt.
Zusätzlich zur CourseWork
-Ressource können Sie erledigte Aufgaben mit der StudentSubmission
-Ressource verwalten.
Kursaufgaben erstellen
CourseWork
können nur im Namen der Lehrkraft des Kurses erstellt werden.
Der Versuch, CourseWork
im Namen eines Schülers/Studenten oder eines Domainadministrators zu erstellen, der nicht als Lehrkraft für den Kurs registriert ist, führt zu einem PERMISSION_DENIED
-Fehler. Weitere Informationen zu den verschiedenen Rollen in Classroom
Wenn Sie CourseWork
mit der Methode courses.courseWork.create
erstellen, können Sie Links als materials
anhängen, wie im folgenden Beispielcode gezeigt:
Java
Python
Die Felder title
und workType
sind Pflichtfelder. Alle anderen sind optional.
Wenn state
nicht angegeben ist, wird CourseWork
im Status „Entwurf“ erstellt.
Verwenden Sie eine Link-Ressource mit einem angegebenen Ziel-url
, um verknüpfte Materialien in die CourseWork
einzufügen. Classroom ruft automatisch die title
und die Thumbnail-Bild-URL (thumbnailUrl
) ab. Die Classroom API unterstützt auch nativ Google Drive- und YouTube-Materialien, die auf ähnliche Weise mit einer DriveFile-Ressource oder einer YouTubeVideo-Ressource eingebunden werden können.
Wenn Sie ein Fälligkeitsdatum angeben möchten, legen Sie die Felder dueDate
und dueTime
auf die entsprechende UTC-Zeit fest. Das Fälligkeitsdatum muss in der Zukunft liegen.
Die CourseWork
-Antwort enthält eine vom Server zugewiesene Kennung, mit der in anderen API-Anfragen auf die Zuweisung verwiesen werden kann.
CourseWork abrufen
Sie können CourseWork
im Namen von Schülern/Studenten und Lehrkräften des entsprechenden Kurses abrufen. Sie können CourseWork
auch im Namen von Domainadministratoren abrufen, auch wenn diese keine Lehrkraft im Kurs sind. Verwenden Sie courses.courseWork.get
, um eine bestimmte CourseWork
abzurufen. Verwenden Sie courses.courseWork.list
, um alle CourseWork
abzurufen (optional mit bestimmten Kriterien).
Der erforderliche Bereich hängt von der Rolle ab, die der anfragende Nutzer im Kurs hat. Wenn der Nutzer ein Schüler oder Student ist, verwenden Sie einen der folgenden Bereiche:
https://www.googleapis.com/auth/classroom.coursework.me.readonly
https://www.googleapis.com/auth/classroom.coursework.me
Wenn der Nutzer eine Lehrkraft oder ein Domainadministrator ist, verwenden Sie einen der folgenden Bereiche:
https://www.googleapis.com/auth/classroom.coursework.students.readonly
https://www.googleapis.com/auth/classroom.coursework.students
Die Berechtigung zum Abrufen eines CourseWork
bedeutet nicht, dass Sie auch die Berechtigung zum Zugriff auf Materialien oder Materialmetadaten haben. In der Praxis bedeutet das, dass ein Administrator den Titel einer angehängten Drive-Datei möglicherweise nicht sieht, wenn er kein Mitglied des Kurses ist.
Antworten von Schülern und Studenten verwalten
Eine StudentSubmission
-Ressource stellt die Arbeit dar, die ein Schüler oder Student für eine CourseWork
erledigt hat. Die Ressource enthält Metadaten zur Aufgabe, z. B. den Status und die Note. Für jeden Schüler wird implizit ein StudentSubmission
erstellt, wenn ein neues CourseWork
erstellt wird.
In den folgenden Abschnitten werden häufige Aktionen zum Verwalten von Schülerantworten beschrieben.
Antworten der Schüler/Studenten abrufen
Schüler und Studenten können ihre eigenen Einsendungen abrufen, Lehrkräfte die Einsendungen aller Schüler und Studenten in ihren Kursen und Domainadministratoren alle Einsendungen aller Schüler und Studenten in ihrer Domain. Jeder StudentSubmission
wird eine Kennung zugewiesen. Wenn Sie die Kennung kennen, verwenden Sie courses.courseWork.studentSubmissions.get
, um die Einreichung abzurufen.
Mit der Methode courses.courseWork.studentSubmissions.list
können Sie alle StudentSubmission
-Ressourcen abrufen, die bestimmten Kriterien entsprechen, wie im folgenden Beispiel gezeigt:
Java
Python
Rufen Sie StudentSubmission
-Ressourcen ab, die zu einem bestimmten Schüler gehören, indem Sie den Parameter userId
angeben, wie im folgenden Beispiel gezeigt:
Java
Python
Schüler werden durch die eindeutige ID oder E-Mail-Adresse identifiziert, wie in der Ressource Student
dargestellt. Der aktuelle Nutzer kann auch mit der Kurzform "me"
auf seine eigene ID verweisen.
Es ist auch möglich, die von Schülern/Studenten eingereichten Aufgaben für alle Aufgaben in einem Kurs abzurufen. Verwenden Sie dazu das Literal "-"
als courseWorkId
, wie im folgenden Beispiel gezeigt:
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()
Der erforderliche Bereich hängt von der Rolle ab, die der anfragende Nutzer im Kurs hat. Wenn der Nutzer eine Lehrkraft oder ein Domainadministrator ist, verwenden Sie den folgenden Bereich:
https://www.googleapis.com/auth/classroom.coursework.students.readonly
https://www.googleapis.com/auth/classroom.coursework.students
Wenn der Nutzer ein Schüler oder Student ist, verwenden Sie den folgenden Bereich:
https://www.googleapis.com/auth/classroom.coursework.me.readonly
https://www.googleapis.com/auth/classroom.coursework.me
Die Berechtigung zum Abrufen eines StudentSubmission
bedeutet nicht, dass Sie auch auf Anhänge oder Metadaten von Anhängen zugreifen dürfen. In der Praxis bedeutet das, dass ein Administrator den Titel einer angehängten Drive-Datei möglicherweise nicht sieht, wenn er kein Mitglied des Kurses ist.
Einer Antwort eines Schülers/Studenten Anhänge hinzufügen
Sie können einer Schülerarbeit Links hinzufügen, indem Sie eine Link
-, DriveFile
- oder YouTubeVideo
-Ressource anhängen. Dies geschieht mit courses.courseWork.studentSubmissions.modifyAttachments
, wie im folgenden Beispiel gezeigt:
Java
Python
Eine Link
-Anlage wird durch das Ziel url
definiert. Classroom ruft automatisch die title
und das Vorschaubild (thumbnailUrl
) ab. Weitere Informationen zu Materialien, die an StudentSubmissions
angehängt werden können, finden Sie unter Material
.
Die StudentSubmission
kann nur von einem Kursleiter oder dem Schüler oder Studenten, dem sie gehört, geändert werden. Sie können Materials
nur anhängen, wenn die CourseWorkType
des StudentSubmission
ASSIGNMENT
ist.
Der erforderliche Bereich hängt von der Rolle ab, die der anfragende Nutzer im Kurs hat. Wenn der Nutzer eine Lehrkraft ist, verwenden Sie den folgenden Bereich:
https://www.googleapis.com/auth/classroom.coursework.students
Wenn der Nutzer ein Schüler oder Student ist, verwenden Sie den folgenden Bereich:
https://www.googleapis.com/auth/classroom.coursework.me