Manages classes, rosters, and invitations in Google Classroom.
- REST Resource: v1.courses
- REST Resource: v1.courses.aliases
- REST Resource: v1.courses.announcements
- REST Resource: v1.courses.announcements.addOnAttachments
- REST Resource: v1.courses.courseWork
- REST Resource: v1.courses.courseWork.addOnAttachments
- REST Resource: v1.courses.courseWork.addOnAttachments.studentSubmissions
- REST Resource: v1.courses.courseWork.rubrics
- REST Resource: v1.courses.courseWork.studentSubmissions
- REST Resource: v1.courses.courseWorkMaterials
- REST Resource: v1.courses.courseWorkMaterials.addOnAttachments
- REST Resource: v1.courses.posts
- REST Resource: v1.courses.posts.addOnAttachments
- REST Resource: v1.courses.posts.addOnAttachments.studentSubmissions
- REST Resource: v1.courses.studentGroups
- REST Resource: v1.courses.studentGroups.studentGroupMembers
- REST Resource: v1.courses.students
- REST Resource: v1.courses.teachers
- REST Resource: v1.courses.topics
- REST Resource: v1.invitations
- REST Resource: v1.registrations
- REST Resource: v1.userProfiles
- REST Resource: v1.userProfiles.guardianInvitations
- REST Resource: v1.userProfiles.guardians
Service: classroom.googleapis.com
To call this service, we recommend that you use the Google-provided client libraries . If your application needs to use your own libraries to call this service, use the following information when you make the API requests.
Discovery document
A Discovery Document is a machine-readable specification for describing and consuming REST APIs. It is used to build client libraries, IDE plugins, and other tools that interact with Google APIs. One service may provide multiple discovery documents. This service provides the following discovery document:
Service endpoint
A service endpoint is a base URL that specifies the network address of an API service. One service might have multiple service endpoints. This service has the following service endpoint and all URIs below are relative to this service endpoint:
-
https://classroom.googleapis.com
REST Resource: v1.courses
Methods | |
---|---|
checkAddOnCreationEligibility
|
GET /v1/courses/{courseId}:checkAddOnCreationEligibility
Returns whether a user is eligible to create add-on attachments in a given course. |
checkGradingPeriodsSetupEligibility
|
GET /v1/courses/{courseId}:checkGradingPeriodsSetupEligibility
Returns whether a user is eligible to update GradingPeriodSettings in a given course. |
create
|
POST /v1/courses
Creates a course. |
delete
|
DELETE /v1/courses/{id}
Deletes a course. |
get
|
GET /v1/courses/{id}
Returns a course. |
getGradingPeriodSettings
|
GET /v1/courses/{courseId}/gradingPeriodSettings
Returns the grading period settings in a course. |
list
|
GET /v1/courses
Returns a list of courses that the requesting user is permitted to view, restricted to those that match the request. |
patch
|
PATCH /v1/courses/{id}
Updates one or more fields in a course. |
update
|
PUT /v1/courses/{id}
Updates a course. |
updateGradingPeriodSettings
|
PATCH /v1/courses/{courseId}/gradingPeriodSettings
Updates grading period settings of a course. |
REST Resource: v1.courses.aliases
Methods | |
---|---|
create
|
POST /v1/courses/{courseId}/aliases
Creates an alias for a course. |
delete
|
DELETE /v1/courses/{courseId}/aliases/{alias}
Deletes an alias of a course. |
list
|
GET /v1/courses/{courseId}/aliases
Returns a list of aliases for a course. |
REST Resource: v1.courses.announcements
Methods | |
---|---|
create
|
POST /v1/courses/{courseId}/announcements
Creates an announcement. |
delete
|
DELETE /v1/courses/{courseId}/announcements/{id}
Deletes an announcement. |
get
|
GET /v1/courses/{courseId}/announcements/{id}
Returns an announcement. |
getAddOnContext
|
GET /v1/courses/{courseId}/announcements/{itemId}/addOnContext
Gets metadata for Classroom add-ons in the context of a specific post. |
list
|
GET /v1/courses/{courseId}/announcements
Returns a list of announcements that the requester is permitted to view. |
modifyAssignees
|
POST /v1/courses/{courseId}/announcements/{id}:modifyAssignees
Modifies assignee mode and options of an announcement. |
patch
|
PATCH /v1/courses/{courseId}/announcements/{id}
Updates one or more fields of an announcement. |
REST Resource: v1.courses.announcements.addOnAttachments
Methods | |
---|---|
create
|
POST /v1/courses/{courseId}/announcements/{itemId}/addOnAttachments
Creates an add-on attachment under a post. |
delete
|
DELETE /v1/courses/{courseId}/announcements/{itemId}/addOnAttachments/{attachmentId}
Deletes an add-on attachment. |
get
|
GET /v1/courses/{courseId}/announcements/{itemId}/addOnAttachments/{attachmentId}
Returns an add-on attachment. |
list
|
GET /v1/courses/{courseId}/announcements/{itemId}/addOnAttachments
Returns all attachments created by an add-on under the post. |
patch
|
PATCH /v1/courses/{courseId}/announcements/{itemId}/addOnAttachments/{attachmentId}
Updates an add-on attachment. |
REST Resource: v1.courses.courseWork
Methods | |
---|---|
create
|
POST /v1/courses/{courseId}/courseWork
Creates course work. |
delete
|
DELETE /v1/courses/{courseId}/courseWork/{id}
Deletes a course work. |
get
|
GET /v1/courses/{courseId}/courseWork/{id}
Returns course work. |
getAddOnContext
|
GET /v1/courses/{courseId}/courseWork/{itemId}/addOnContext
Gets metadata for Classroom add-ons in the context of a specific post. |
list
|
GET /v1/courses/{courseId}/courseWork
Returns a list of course work that the requester is permitted to view. |
modifyAssignees
|
POST /v1/courses/{courseId}/courseWork/{id}:modifyAssignees
Modifies assignee mode and options of a coursework. |
patch
|
PATCH /v1/courses/{courseId}/courseWork/{id}
Updates one or more fields of a course work. |
REST Resource: v1.courses.courseWork.addOnAttachments
Methods | |
---|---|
create
|
POST /v1/courses/{courseId}/courseWork/{itemId}/addOnAttachments
Creates an add-on attachment under a post. |
delete
|
DELETE /v1/courses/{courseId}/courseWork/{itemId}/addOnAttachments/{attachmentId}
Deletes an add-on attachment. |
get
|
GET /v1/courses/{courseId}/courseWork/{itemId}/addOnAttachments/{attachmentId}
Returns an add-on attachment. |
list
|
GET /v1/courses/{courseId}/courseWork/{itemId}/addOnAttachments
Returns all attachments created by an add-on under the post. |
patch
|
PATCH /v1/courses/{courseId}/courseWork/{itemId}/addOnAttachments/{attachmentId}
Updates an add-on attachment. |
REST Resource: v1.courses.courseWork.addOnAttachments.studentSubmissions
Methods | |
---|---|
get
|
GET /v1/courses/{courseId}/courseWork/{itemId}/addOnAttachments/{attachmentId}/studentSubmissions/{submissionId}
Returns a student submission for an add-on attachment. |
patch
|
PATCH /v1/courses/{courseId}/courseWork/{itemId}/addOnAttachments/{attachmentId}/studentSubmissions/{submissionId}
Updates data associated with an add-on attachment submission. |
REST Resource: v1.courses.courseWork.rubrics
Methods | |
---|---|
create
|
POST /v1/courses/{courseId}/courseWork/{courseWorkId}/rubrics
Creates a rubric. |
delete
|
DELETE /v1/courses/{courseId}/courseWork/{courseWorkId}/rubrics/{id}
Deletes a rubric. |
get
|
GET /v1/courses/{courseId}/courseWork/{courseWorkId}/rubrics/{id}
Returns a rubric. |
list
|
GET /v1/courses/{courseId}/courseWork/{courseWorkId}/rubrics
Returns a list of rubrics that the requester is permitted to view. |
patch
|
PATCH /v1/courses/{courseId}/courseWork/{courseWorkId}/rubrics/{id}
Updates a rubric. |
REST Resource: v1.courses.courseWork.studentSubmissions
Methods | |
---|---|
get
|
GET /v1/courses/{courseId}/courseWork/{courseWorkId}/studentSubmissions/{id}
Returns a student submission. |
list
|
GET /v1/courses/{courseId}/courseWork/{courseWorkId}/studentSubmissions
Returns a list of student submissions that the requester is permitted to view, factoring in the OAuth scopes of the request. |
modifyAttachments
|
POST /v1/courses/{courseId}/courseWork/{courseWorkId}/studentSubmissions/{id}:modifyAttachments
Modifies attachments of student submission. |
patch
|
PATCH /v1/courses/{courseId}/courseWork/{courseWorkId}/studentSubmissions/{id}
Updates one or more fields of a student submission. |
reclaim
|
POST /v1/courses/{courseId}/courseWork/{courseWorkId}/studentSubmissions/{id}:reclaim
Reclaims a student submission on behalf of the student that owns it. |
return
|
POST /v1/courses/{courseId}/courseWork/{courseWorkId}/studentSubmissions/{id}:return
Returns a student submission. |
turnIn
|
POST /v1/courses/{courseId}/courseWork/{courseWorkId}/studentSubmissions/{id}:turnIn
Turns in a student submission. |
REST Resource: v1.courses.courseWorkMaterials
Methods | |
---|---|
create
|
POST /v1/courses/{courseId}/courseWorkMaterials
Creates a course work material. |
delete
|
DELETE /v1/courses/{courseId}/courseWorkMaterials/{id}
Deletes a course work material. |
get
|
GET /v1/courses/{courseId}/courseWorkMaterials/{id}
Returns a course work material. |
getAddOnContext
|
GET /v1/courses/{courseId}/courseWorkMaterials/{itemId}/addOnContext
Gets metadata for Classroom add-ons in the context of a specific post. |
list
|
GET /v1/courses/{courseId}/courseWorkMaterials
Returns a list of course work material that the requester is permitted to view. |
patch
|
PATCH /v1/courses/{courseId}/courseWorkMaterials/{id}
Updates one or more fields of a course work material. |
REST Resource: v1.courses.courseWorkMaterials.addOnAttachments
Methods | |
---|---|
create
|
POST /v1/courses/{courseId}/courseWorkMaterials/{itemId}/addOnAttachments
Creates an add-on attachment under a post. |
delete
|
DELETE /v1/courses/{courseId}/courseWorkMaterials/{itemId}/addOnAttachments/{attachmentId}
Deletes an add-on attachment. |
get
|
GET /v1/courses/{courseId}/courseWorkMaterials/{itemId}/addOnAttachments/{attachmentId}
Returns an add-on attachment. |
list
|
GET /v1/courses/{courseId}/courseWorkMaterials/{itemId}/addOnAttachments
Returns all attachments created by an add-on under the post. |
patch
|
PATCH /v1/courses/{courseId}/courseWorkMaterials/{itemId}/addOnAttachments/{attachmentId}
Updates an add-on attachment. |
REST Resource: v1.courses.posts
Methods | |
---|---|
getAddOnContext
|
GET /v1/courses/{courseId}/posts/{postId}/addOnContext
Gets metadata for Classroom add-ons in the context of a specific post. |
REST Resource: v1.courses.posts.addOnAttachments
Methods | |
---|---|
create
|
POST /v1/courses/{courseId}/posts/{postId}/addOnAttachments
Creates an add-on attachment under a post. |
delete
|
DELETE /v1/courses/{courseId}/posts/{postId}/addOnAttachments/{attachmentId}
Deletes an add-on attachment. |
get
|
GET /v1/courses/{courseId}/posts/{postId}/addOnAttachments/{attachmentId}
Returns an add-on attachment. |
list
|
GET /v1/courses/{courseId}/posts/{postId}/addOnAttachments
Returns all attachments created by an add-on under the post. |
patch
|
PATCH /v1/courses/{courseId}/posts/{postId}/addOnAttachments/{attachmentId}
Updates an add-on attachment. |
REST Resource: v1.courses.posts.addOnAttachments.studentSubmissions
Methods | |
---|---|
get
|
GET /v1/courses/{courseId}/posts/{postId}/addOnAttachments/{attachmentId}/studentSubmissions/{submissionId}
Returns a student submission for an add-on attachment. |
patch
|
PATCH /v1/courses/{courseId}/posts/{postId}/addOnAttachments/{attachmentId}/studentSubmissions/{submissionId}
Updates data associated with an add-on attachment submission. |
REST Resource: v1.courses.studentGroups
Methods | |
---|---|
create
|
POST /v1/courses/{courseId}/studentGroups
Creates a student group for a course. |
delete
|
DELETE /v1/courses/{courseId}/studentGroups/{id}
Deletes a student group. |
list
|
GET /v1/courses/{courseId}/studentGroups
Returns a list of groups in a course. |
patch
|
PATCH /v1/courses/{courseId}/studentGroups/{id}
Updates one or more fields in a student group. |
REST Resource: v1.courses.studentGroups.studentGroupMembers
Methods | |
---|---|
create
|
POST /v1/courses/{courseId}/studentGroups/{studentGroupId}/studentGroupMembers
Creates a student group member for a student group. |
delete
|
DELETE /v1/courses/{courseId}/studentGroups/{studentGroupId}/studentGroupMembers/{userId}
Deletes a student group member. |
list
|
GET /v1/courses/{courseId}/studentGroups/{studentGroupId}/studentGroupMembers
Returns a list of students in a group. |
REST Resource: v1.courses.students
Methods | |
---|---|
create
|
POST /v1/courses/{courseId}/students
Adds a user as a student of a course. |
delete
|
DELETE /v1/courses/{courseId}/students/{userId}
Deletes a student of a course. |
get
|
GET /v1/courses/{courseId}/students/{userId}
Returns a student of a course. |
list
|
GET /v1/courses/{courseId}/students
Returns a list of students of this course that the requester is permitted to view. |
REST Resource: v1.courses.teachers
Methods | |
---|---|
create
|
POST /v1/courses/{courseId}/teachers
Creates a teacher of a course. |
delete
|
DELETE /v1/courses/{courseId}/teachers/{userId}
Removes the specified teacher from the specified course. |
get
|
GET /v1/courses/{courseId}/teachers/{userId}
Returns a teacher of a course. |
list
|
GET /v1/courses/{courseId}/teachers
Returns a list of teachers of this course that the requester is permitted to view. |
REST Resource: v1.courses.topics
Methods | |
---|---|
create
|
POST /v1/courses/{courseId}/topics
Creates a topic. |
delete
|
DELETE /v1/courses/{courseId}/topics/{id}
Deletes a topic. |
get
|
GET /v1/courses/{courseId}/topics/{id}
Returns a topic. |
list
|
GET /v1/courses/{courseId}/topics
Returns the list of topics that the requester is permitted to view. |
patch
|
PATCH /v1/courses/{courseId}/topics/{id}
Updates one or more fields of a topic. |
REST Resource: v1.invitations
Methods | |
---|---|
accept
|
POST /v1/invitations/{id}:accept
Accepts an invitation, removing it and adding the invited user to the teachers or students (as appropriate) of the specified course. |
create
|
POST /v1/invitations
Creates an invitation. |
delete
|
DELETE /v1/invitations/{id}
Deletes an invitation. |
get
|
GET /v1/invitations/{id}
Returns an invitation. |
list
|
GET /v1/invitations
Returns a list of invitations that the requesting user is permitted to view, restricted to those that match the list request. |
REST Resource: v1.registrations
Methods | |
---|---|
create
|
POST /v1/registrations
Creates a Registration
, causing Classroom to start sending notifications from the provided feed
to the destination provided in cloudPubSubTopic
. |
delete
|
DELETE /v1/registrations/{registrationId}
Deletes a Registration
, causing Classroom to stop sending notifications for that Registration
. |
REST Resource: v1.userProfiles
Methods | |
---|---|
checkUserCapability
|
GET /v1/userProfiles/{userId}:checkUserCapability
Returns whether a user may use the specified Classroom capability. |
get
|
GET /v1/userProfiles/{userId}
Returns a user profile. |
REST Resource: v1.userProfiles.guardianInvitations
Methods | |
---|---|
create
|
POST /v1/userProfiles/{guardianInvitation.studentId}/guardianInvitations
Creates a guardian invitation, and sends an email to the guardian asking them to confirm that they are the student's guardian. |
get
|
GET /v1/userProfiles/{studentId}/guardianInvitations/{invitationId}
Returns a specific guardian invitation. |
list
|
GET /v1/userProfiles/{studentId}/guardianInvitations
Returns a list of guardian invitations that the requesting user is permitted to view, filtered by the parameters provided. |
patch
|
PATCH /v1/userProfiles/{studentId}/guardianInvitations/{invitationId}
Modifies a guardian invitation. |
REST Resource: v1.userProfiles.guardians
Methods | |
---|---|
delete
|
DELETE /v1/userProfiles/{studentId}/guardians/{guardianId}
Deletes a guardian. |
get
|
GET /v1/userProfiles/{studentId}/guardians/{guardianId}
Returns a specific guardian. |
list
|
GET /v1/userProfiles/{studentId}/guardians
Returns a list of guardians that the requesting user is permitted to view, restricted to those that match the request. |