-
Notifications
You must be signed in to change notification settings - Fork 88
Classroom Courses
- API documentation
- Python Regular Expressions
- Definitions
- Special quoting for course aliases and topics
- Updating course owner
- Create and update courses
- Delete courses
- Manage course aliases
- Manage course topics
- Display courses
- Display course announcements
- Display course topics
- Display course work
- Display course submissions
- https://developers.google.com/classroom/reference/rest/
- https://developers.google.com/classroom/reference/rest/v1/courses.students
- https://developers.google.com/classroom/reference/rest/v1/courses.teachers
- https://developers.google.com/classroom/reference/rest/v1/courses.announcements/list
- https://developers.google.com/classroom/reference/rest/v1/courses.topics/list
- https://developers.google.com/classroom/reference/rest/v1/courses.courseWork/list
- https://developers.google.com/classroom/reference/rest/v1/courses.courseWork.studentSubmissions/list
<DomainName> ::= <String>(.<String>)+
<EmailAddress> ::= <String>@<DomainName>
<UniqueID> ::= uid:<String>
<UserItem> ::= <EmailAddress>|<UniqueID>|<String>
<CourseAlias> ::= <String>
<CourseAliasList> ::= "<CourseAlias>(,<CourseAlias>)*"
<CourseAliasEntity> ::=
<CourseAliasList>|<FileSelector>|<CSVFileSelector>|<CSVkmdSelector>|<CSVDataSelector>
<CourseAnnouncementID> ::= <Number>
<CourseAnnouncementIDList> ::= "<CourseAnnouncementID>(,<CourseAnnouncementID>)*"
<CourseAnnouncementIDEntity> ::=
<CourseAnnouncementIDList>|<FileSelector>|<CSVFileSelector>|<CSVkmdSelector>|<CSVSubkeySelector>|<CSVDataSelector>
<CourseAnnouncementState> ::= draft|published|deleted
<CourseAnnouncementStateList> ::= all|"<CourseAnnouncementState>(,<CourseAnnouncementState>)*"
<CourseID> ::= <Number>|d:<CourseAlias>
<CourseIDList> ::= "<CourseID>(,<CourseID>)*"
<CourseEntity> ::=
<CourseIDList>|<FileSelector>|<CSVFileSelector>|<CSVkmdSelector>
<CourseState> ::= active|archived|provisioned|declined|suspended
<CourseStateList> ::= all|"<CourseState>(,<CourseState>)*"
<CourseSubmissionID> ::= <Number>
<CourseSubmissionIDList> ::= "<CourseSubmissionID>(,<CourseSubmissionID>)*"
<CourseSubmissionIDEntity> ::=
<CourseSubmissionIDList>|<FileSelector>|<CSVFileSelector>|<CSVDataSelector>
<CourseSubmissionState> ::= new|created|turned_in|returned|reclaimed_by_student
<CourseSubmissionStateList> ::= all|"<CourseSubmissionState>(,<CourseSubmissionState>)*"
<CourseTopic> ::= <String>
<CourseTopicList> ::= "<CourseTopic>(,<CourseTopic>)*"
<CourseTopicEntity> ::= <CourseTopicList> | <FileSelector> | <CSVFileSelector> | <CSVkmdSelector> | <CSVDataSelector>
<CourseTopicID> ::= <Number>
<CourseTopicIDList> ::= "<CourseTopicID>(,<CourseTopicID>)*"
<CourseTopicIDEntity> ::=
<CourseTopicIDList>|<FileSelector>|<CSVFileSelector>|<CSVkmdSelector>|<CSVSubkeySelector>|<CSVDataSelector>
<CourseWorkID> ::= <Number>
<CourseWorkIDList> ::= "<CourseWorkID>(,<CourseWorkID>)*"
<CourseWorkIDEntity> ::=
<CourseWorkIDList>|<FileSelector>|<CSVFileSelector>|<CSVkmdSelector>|<CSVSubkeySelector>|<CSVDataSelector>
<CourseWorkState> ::= draft|published|deleted
<CourseWorkStateList> ::= all|"<CourseWorkState>(,<CourseWorkState>)*"
<CourseAttribute> ::=
(description <String>)|
(heading <String>)|
(name <String>)|
(room <String>)|
(section <string>)|
(state|status <CourseState>)|
(owner|ownerid|teacher <UserItem>)
<CourseFieldName> ::=
alternatelink|
coursegroupemail|
coursematerialsets|
coursestate|
creationtime|
description|
descriptionheading|
enrollmentcode|
guardiansenabled|
id|
name|
owneremail|
ownerid|
room|
section|
teacherfolder|
teachergroupemail|
updatetime
<CourseFieldNameList> ::= '<CourseFieldName>(,<CourseFieldName>)*'
<CourseAnnouncementFieldName> ::=
alternatelink|
assigneemode|
courseid|
courseannouncementid|
creationtime|
creator|creatoruserid|
id|
materials|
scheduledtime|
state|
text|
updatetime
<CourseAnnouncementFieldNameList> ::= "<CourseAnnouncementFieldName>(,<CourseAnnouncementFieldName>)*"
<CourseAnnouncementOrderByFieldName> ::=
updatetime|
updatedate
<CourseWorkFieldName> ::=
alternatelink|
assigneemode|
courseid|
courseworkid|
courseworktype|
creationtime|
creator|creatoruserid|
description|
duedate|
duetime|
id|
materials|
maxpoints|
scheduledtime|
state|
submissionmodificationmode|
title|
topicid|
updatetime|
worktype
<CourseWorkFieldNameList> ::= "<CourseWorkFieldName>(,<CourseWorkFieldName>)*"
<CourseWorkOrderByFieldName> ::=
duedate|
updatetime|
updatedate
<CourseSubmissionFieldName> ::=
alternatelink|
assignedgrade|
courseid|
courseworkid|
courseworktype|
creationtime|
draftgrade|
id|
late|
state|
submissionhistory|
updatetime|
userid|
worktype
<CourseSubmissionFieldNameList> ::= "<CourseSubmissionFieldName>(,<CourseSubmissionFieldName>)*"
As course aliases and topics can contain spaces, some care must be used when entering <CourseAliasList>
and <CourseTopicList>
.
Suppose you have a course with the alias Math Class
. To get information about it you enter the command: gam info course "d:Math Class"
The shell strips the "
leaving a single argument d:Math Class
; gam correctly processes the argument as it is expecting a single course.
Suppose you enter the command: gam info courses "d:Math Class"
The shell strips the "
leaving a single argument d:Math Class
; as gam is expecting a list, it splits the argument on space leaving two items and then tries to process d:Math
and Class
, not what you want.
You must enter: gam info courses "'d:Math Class'"
The shell strips the "
leaving a single argument 'd:Math Class'
; as gam is expecting a list, it splits the argument on space while honoring the '
leaving one item d:Math Class
and correctly processes the item.
For multiple aliases you must enter: gam info courses "'d:Math Class','d:Science Class'"
When updating a course owner, the Classroom API generates an error if the new owner is not a co-teacher or is the current owner.
Prior to version 5.31.08, if <UserItem>
was not a co-teacher, you got this error:
$ gam update course 123929046789 teacher [email protected]
Course: 123929046789, Update Failed: @IneligibleOwner Only a co-teacher can be invited as owner of the course
GAM now adds <UserItem>
as a co-teacher of the course and then updates them to be the owner.
$ gam update course 123929046789 teacher [email protected]
Course Name: Test, Course: 123929046789, Updated with new teacher as owner: [email protected]
Prior to version 5.31.08, if <UserItem>
is the current owner, you got this error:
$ gam update course 123929046789 teacher [email protected]
Course: 123929046789, Update Failed: @UserAlreadyOwner Cannot transfer course to the user who is already the owner
GAM now reports that the current owner was retained.
$ gam update course 123929046789 teacher [email protected]
Course Name: Test, Course: 123929046789, Updated with current owner: [email protected]
In the normal case when <UserItem>
is a co-teacher, GAM now reports the change.
$ gam update course 123929046789 teacher [email protected]
Course Name: Test, Course: 123929046789, Updated with co-teacher as owner: [email protected]
The options name <String>
and teacher <UserItem>
are required when creating a class.
gam create|add course [id|alias <CourseAlias>] <CourseAttribute>*
[copyfrom <CourseID>
[announcementstates <CourseAnnouncementStateList>]
[workstates <CourseWorkStateList>]
[markpublishedasdraft [<Boolean>]] [removeduedate [<Boolean>]]
[mapsharemodestudentcopy edit|none|view]
[copymaterialsfiles [<Boolean>]]
[copytopics [<Boolean>]]
[members none|all|students|teachers]]
[logdrivefileids [<Boolean>>]]
gam update course <CourseID> <CourseAttribute>+
[copyfrom <CourseID>
[announcementstates <CourseAnnouncementStateList>]
[workstates <CourseWorkStateList>]
[markpublishedasdraft [<Boolean>]] [removeduedate [<Boolean>]]
[mapsharemodestudentcopy edit|none|view]
[copymaterialsfiles [<Boolean>]]
[copytopics [<Boolean>]]
[members none|all|students|teachers]]
[logdrivefileids [<Boolean>>]]
gam update courses <CourseEntity> <CourseAttribute>+
[copyfrom <CourseID>
[announcementstates <CourseAnnouncementStateList>]
[workstates <CourseWorkStateList>]
[markpublishedasdraft [<Boolean>]] [removeduedate [<Boolean>]]
[mapsharemodestudentcopy edit|none|view]
[copymaterialsfiles [<Boolean>]]
[copytopics [<Boolean>]]
[members none|all|students|teachers]]
[logdrivefileids [<Boolean>>]]
copyfrom <CourseID>
allows copying of course announcements, work, topics and members from one course to another.
- Accouncements - By default, no course announcements are copied
-
announcementstates <CourseAnnouncementStateList>
- Copy class announcements with the specified states
-
- Work - By default, no course work is copied
-
workstates <CourseWorkStateList>
- Copy class work with the specified states-
markpublishedasdraft false
- Do not relabel published work as draft; this is the default -
markpublishedasdraft|markpublishedasdraft true
- Relabel published work as draft -
removeduedate false
- Remove due dates before the current time; this is the default -
removeduedate|removeduedate true
- Remove all due dates
-
-
- Announcements and Work Materials files
-
copymaterialsfiles false
- Copy links to files referenced by materials in thecopyfrom
course; this is the default -
copymaterialsfiles|copymaterialsfiles true
- Copy files referenced by materials in thecopyfrom
course- You must verify that the teacher of the course being created/updated has access to the files in the
copyfrom
course - Files can only be copied to a course that is ACTIVE; GAM will adjust the course state as necessary
- You must verify that the teacher of the course being created/updated has access to the files in the
-
- Topics - By default, no course topics are copied; if topics are not copied, references to them will be deleted from class work that is copied
-
copytopics false
- No course topics are copies -
copytopics|copytopics true
- Copy topics
-
- Members - By default, no course members are copied
-
members none
- No course members are copied -
members all
- Copy course students and teachers -
members students
- Copy students -
members teachers
- Copy teachers
-
When true, logdrivefileids [<Boolean>>]
generates a CSV file with headers `courseId,ownerId,fileId' that
lists all drive files in the course.
The Classroom API does not support course materials of type form
, they will not be copied.
The Classroom API does not support stand-alone course material (+Create Material), it will not be copied.
Drive files with shareMode
Each student will get a copy
don't seem to be able to be copied.
-
mapsharemodestudentcopy edit
- MapEach student will get a copy
toStudents can edit file
-
mapsharemodestudentcopy view
- MapEach student will get a copy
toStudents can view file
-
mapsharemodestudentcopy none
or not specified - NoshareMode
mapping is performed, you may get an error
Classes can only be deleted when they are in the ARCHIVED state; to delete a class, you can update its state to ARCHIVED and then delete it or you can specify that it be archived as part of the delete command.
gam delete course <CourseID> [archived]
gam delete courses <CourseEntity> [archived]
These commands can process a single course.
gam course <CourseID> add alias <CourseAlias>
gam course <CourseID> delete alias <CourseAlias>
These commands can process multiple courses.
gam courses <CourseEntity> add alias <CourseAliasEntity>
gam courses <CourseEntity> delete alias <CourseAliasEntity>
These commands can process a single course.
gam course <CourseID> add topic <CourseTopic>
gam course <CourseID> delete topic <CourseTopicID>
These commands can process multiple courses.
gam courses <CourseEntity> add topic <CourseTopicEntity>
gam courses <CourseEntity> delete topic <CourseTopicIDEntity>
gam info course <CourseID> [owneremail] [alias|aliases] [show all|students|teachers] [countsonly]
[fields <CourseFieldNameList>] [skipfields <CourseFieldNameList>] [formatjson]
gam info courses <CourseEntity> [owneremail] [alias|aliases] [show all|students|teachers] [countsonly]
[fields <CourseFieldNameList>] [skipfields <CourseFieldNameList>] [formatjson]
gam print courses [todrive <ToDriveAttribute>*]
(course|class <CourseEntity>)*|([teacher <UserItem>] [student <UserItem>] [states <CourseStateList>])
[owneremail] [owneremailmatchpattern <RegularExpression>]
[alias|aliases|aliasesincolumns [delimiter <Character>]]
[show all|students|teachers] [countsonly]
[fields <CourseFieldNameList>] [skipfields <CourseFieldNameList>] [formatjson [quotechar <Character>]]
[timefilter creationtime|updatetime] [start|starttime <Date>|<Time>] [end|endtime <Date>|<Time>]
By default, the print courses
command displays information about all courses.
To get information about a specific set of courses, use the following option; it can be repeated to select multiple courses.
-
(course|class <CourseEntity>)*
- Display courses with the IDs specified in<CourseEntity>
.
To get information about courses based on its owner's emailaddress, use the owneremailmatchpattern <RegularExpression>
option.
-
[email protected]
- Display courses with a specific owner emailaddress. -
.*test.*
- Display courses with an owner emailaddress that matches a pattern. -
Unknown user
- Display courses where the owner emailaddress has been deleted.
To get information about courses based on their having a particular participant, use the following options. Both options can be specified.
-
teacher <UserItem>
- Display courses with the specified teacher. -
student <UserItem>
- Display courses with the specified student.
To get information about courses based on their state, use the following option. This option can be combined with the teacher
and student
options.
By default, all course states are selected.
-
states <CourseStateList>
- Display courses with any of the specified states.
To get information about courses created/updated within a particular time frame, use the following options.
-
timefilter creationtime|updatetime
- select which event to filter -
start|starttime <Date>|<Time>
- specify the start of the time frame; if not specified, the time frame will be open ended at the start -
end|endtime <Date>|<Time>
- specify the end of the time frame; if not specified, the time frame will be open ended at the end For the filter to apply,timefilter
and at least one ofstart|starttime
andend|endtime
must be specified.
By default, all basic course fields are displayed; use the following options to modify the output.
-
owneremail
- Display course owner email; requires an additional API call per course. -
alias|aliases
- Display course aliases; all aliases are in the single columnAliases
separated by a delimiter; requires an additional API call per course.-
delimiter <Character>
- Delimiter between aliases withprint
command.
-
-
aliasesincolumn
- Display course aliases; theAliases
column contains the number of aliases andAliases.0
,Aliases.1
, ... contain the individual aliases; requires an additional API call per course. -
show all|students|teachers
- Show class participants profile information; requires an additional API call per course.-
countsonly
- Eliminates the student/teacher profile information and outputs only the student/teacher counts.
-
-
fields <CourseFieldNameList>
- Select specific basic fields to display. -
skipfields <CourseFieldNameList>
- Select specific basic fields to eliminate from display; typically used withcoursematerialsets
.
By default, Gam displays the information as columns of fields; the following option causes the ouput to be in JSON format,
-
formatjson
- Display the fields in JSON format.
By default, when writing CSV files, Gam uses a quote character of double quote "
. The quote character is used to enclose columns that contain
the quote character itself, the column delimiter (comma by default) and new-line characters. Any quote characters within the column are doubled.
When using the formatjson
option, double quotes are used extensively in the data resulting in hard to read/process output.
The quotechar <Character>
option allows you to choose an alternate quote character, single quote for instance, that makes for readable/processable output.
quotechar
defaults to gam.cfg/csv_output_quote_char
.
gam print course-announcements [todrive <ToDriveAttribute>*]
(course|class <CourseEntity>)*|([teacher <UserItem>] [student <UserItem>] states <CourseStateList>])
(courseannouncementids <CourseAnnouncementIDEntity>)|((announcementstates <CourseAnnouncementStateList>)*
(orderby <CourseAnnouncementOrderByFieldName> [ascending|descending])*)
[creatoremail] [fields <CourseAnnouncementFieldNameList>] [formatjson [quotechar <Character>]]
[timefilter creationtime|updatetime|scheduledtime] [start|starttime <Date>|<Time>] [end|endtime <Date>|<Time>]
By default, the print course-announcements
command displays course announcement information for all courses.
To get course announcements for a specific set of courses, use the following option; it can be repeated to select multiple courses.
-
(course|class <CourseEntity>)*
- Display courses with the IDs specified in<CourseEntity>
.
To get course announcements for courses based on their having a particular participant, use the following options. Both options can be specified.
-
teacher <UserItem>
- Display courses with the specified teacher. -
student <UserItem>
- Display courses with the specified student.
To get course announcements for courses based on their state, use the following option. This option can be combined with the teacher
and student
options.
By default, all course states are selected.
-
states <CourseStateList>
- Display courses with any of the specified states.
By default, all published course announcements for a course are displayed; use the following options to select specific course announcements.
-
courseannouncementids <CourseAnnouncementIDEntity>
- Display course announcements with the IDs specified in<CourseAnnouncementIDEntity>
. -
announcementstates <CourseAnnouncementStateList>
- Display course announcements with any of the specified states.
To get information about course announcements created/updated/scheduled within a particular time frame, use the following options.
-
timefilter creationtime|updatetime|scheduledtime
- select which event to filter -
start|starttime <Date>|<Time>
- specify the start of the time frame; if not specified, the time frame will be open ended at the start -
end|endtime <Date>|<Time>
- specify the end of the time frame; if not specified, the time frame will be open ended at the end For the filter to apply,timefilter
and at least one ofstart|starttime
andend|endtime
must be specified.
By default, all course announcement fields are displayed; use the following options to modify the output.
-
creatoremail
- Display course announcement creator email; requires an additional API call per course announcement. -
fields <CourseAnnouncementFieldNameList>
- Select specific fields to display.
By default, Gam displays the information as columns of fields; the following option causes the ouput to be in JSON format,
-
formatjson
- Display the fields in JSON format.
By default, when writing CSV files, Gam uses a quote character of double quote "
. The quote character is used to enclose columns that contain
the quote character itself, the column delimiter (comma by default) and new-line characters. Any quote characters within the column are doubled.
When using the formatjson
option, double quotes are used extensively in the data resulting in hard to read/process output.
The quotechar <Character>
option allows you to choose an alternate quote character, single quote for instance, that makes for readable/processable output.
quotechar
defaults to gam.cfg/csv_output_quote_char
.
gam print course-topics [todrive <ToDriveAttribute>*]
(course|class <CourseEntity>)*|([teacher <UserItem>] [student <UserItem>] states <CourseStateList>])
(coursetopicids <CourseTopicIDEntity>)
[formatjson [quotechar <Character>]]
[timefilter updatetime] [start|starttime <Date>|<Time>] [end|endtime <Date>|<Time>]
By default, the print course-topics
command displays course topic information for all courses.
To get course topics for a specific set of courses, use the following option; it can be repeated to select multiple courses.
-
(course|class <CourseEntity>)*
- Display courses with the IDs specified in<CourseEntity>
.
To get course topics for courses based on their having a particular participant, use the following options. Both options can be specified.
-
teacher <UserItem>
- Display courses with the specified teacher. -
student <UserItem>
- Display courses with the specified student.
To get course topics for courses based on their state, use the following option. This option can be combined with the teacher
and student
options.
By default, all course states are selected.
-
states <CourseStateList>
- Display courses with any of the specified states.
By default, all published course topics for a course are displayed; use the following options to select specific course topics.
-
coursetopicids <CourseTopicIDEntity>
- Display course topics with the IDs specified in<CourseTopicIDEntity>
. -
topicstates <CourseTopicStateList>
- Display course topics with any of the specified states.
To get information about course topics updated within a particular time frame, use the following options.
-
timefilter updatetime
- select which event to filter -
start|starttime <Date>|<Time>
- specify the start of the time frame; if not specified, the time frame will be open ended at the start -
end|endtime <Date>|<Time>
- specify the end of the time frame; if not specified, the time frame will be open ended at the end For the filter to apply,timefilter
and at least one ofstart|starttime
andend|endtime
must be specified.
By default, Gam displays the information as columns of fields; the following option causes the ouput to be in JSON format,
-
formatjson
- Display the fields in JSON format.
By default, when writing CSV files, Gam uses a quote character of double quote "
. The quote character is used to enclose columns that contain
the quote character itself, the column delimiter (comma by default) and new-line characters. Any quote characters within the column are doubled.
When using the formatjson
option, double quotes are used extensively in the data resulting in hard to read/process output.
The quotechar <Character>
option allows you to choose an alternate quote character, single quote for instance, that makes for readable/processable output.
quotechar
defaults to gam.cfg/csv_output_quote_char
.
gam print course-work [todrive <ToDriveAttribute>*]
(course|class <CourseEntity>)*|([teacher <UserItem>] [student <UserItem>] states <CourseStateList>])
(workids <CourseWorkIDEntity>)|((workstates <CourseWorkStateList>)*
(orderby <CourseWorkOrderByFieldName> [ascending|descending])*)
[showcreatoremails] [showtopicnames] [fields <CourseWorkFieldNameList>] [formatjson [quotechar <Character>]]
[timefilter creationtime|updatetime|scheduledtime] [start|starttime <Date>|<Time>] [end|endtime <Date>|<Time>]
By default, the print course-work
command displays course work information for all courses.
The Classroom API does not support stand-alone course material (+Create Material), it will not be displayed.
To get course work information for a specific set of courses, use the following option; it can be repeated to select multiple courses.
-
(course|class <CourseEntity>)*
- Display courses with the IDs specified in<CourseEntity>
.
To get course work information for courses based on their having a particular participant, use the following options. Both options can be specified.
-
teacher <UserItem>
- Display courses with the specified teacher. -
student <UserItem>
- Display courses with the specified student.
To get course work information for courses based on their state, use the following option. This option can be combined with the teacher
and student
options.
By default, all course states are selected.
-
states <CourseStateList>
- Display courses with any of the specified states.
To get information about course work created/updated/scheduled within a particular time frame, use the following options.
-
timefilter creationtime|updatetime|scheduledtime
- select which event to filter -
start|starttime <Date>|<Time>
- specify the start of the time frame; if not specified, the time frame will be open ended at the start -
end|endtime <Date>|<Time>
- specify the end of the time frame; if not specified, the time frame will be open ended at the end For the filter to apply,timefilter
and at least one ofstart|starttime
andend|endtime
must be specified.
By default, all course work for a course is displayed; use the following options to select specific course work.
-
workids <CourseWorkIDEntity>
- Display course work with the IDs specified in<CourseWorkIDEntity>
. -
workstates <CourseWorkStateList>
- Display course work with any of the specified states.
By default, all course work fields are displayed; use the following options to modify the output.
-
showcreatoremails
- Display course work creator email; requires an additional API call per course work. -
showtopicnames
- Display topic names; requires and additional API call per course. -
fields <CourseWorkFieldNameList>
- Select specific fields to display.
By default, Gam displays the information as columns of fields; the following option causes the ouput to be in JSON format,
-
formatjson
- Display the fields in JSON format.
By default, when writing CSV files, Gam uses a quote character of double quote "
. The quote character is used to enclose columns that contain
the quote character itself, the column delimiter (comma by default) and new-line characters. Any quote characters within the column are doubled.
When using the formatjson
option, double quotes are used extensively in the data resulting in hard to read/process output.
The quotechar <Character>
option allows you to choose an alternate quote character, single quote for instance, that makes for readable/processable output.
quotechar
defaults to gam.cfg/csv_output_quote_char
.
gam print course-submissions [todrive <ToDriveAttribute>*]
(course|class <CourseEntity>)*|([teacher <UserItem>] [student <UserItem>] states <CourseStateList>])
(workids <CourseWorkIDEntity>)|((workstates <CourseWorkStateList>)*
(orderby <CourseWorkOrderByFieldName> [ascending|descending])*)
(submissionids <CourseSubmissionIDEntity>)|((submissionstates <CourseSubmissionStateList>)*) [late|notlate]
[fields <CourseSubmissionFieldNameList>] [showuserprofile] [formatjson [quotechar <Character>]]
[timefilter creationtime|updatetime] [start|starttime <Date>|<Time>] [end|endtime <Date>|<Time>]
By default, the print course-submissions
command displays course submission information for all course work for all courses.
To get course submission information for a specific set of courses, use the following option; it can be repeated to select multiple courses.
-
(course|class <CourseEntity>)*
- Display courses with the IDs specified in<CourseEntity>
.
To get course submission information for courses based on their having a particular participant, use the following options. Both options can be specified.
-
teacher <UserItem>
- Display courses with the specified teacher. -
student <UserItem>
- Display courses with the specified student.
To get course submission information for courses based on their state, use the following option. This option can be combined with the teacher
and student
options.
By default, all course states are selected.
-
states <CourseStateList>
- Display courses with any of the specified states.
By default, all course work for a course is displayed; use the following options to select specific course work.
-
workids <CourseWorkIDEntity>
- Display course work with the IDs specified in<CourseWorkIDEntity>
. -
workstates <CourseWorkStateList>
- Display course work with any of the specified states.
By default, all course submissions for a course work is displayed; use the following options to select specific course submissions.
-
submissionids <CourseSubmissionIDEntity>
- Display course submissions with the IDs specified in<CourseSubmissionIDEntity>
. -
submissionstates <CourseSubmissionStateList>
- Display course submissions with any of the specified states. -
late
- Display course submissions marked late. -
notlate
- Display course submissions not marked late.
To get information about course submissionss created/updated within a particular time frame, use the following options.
-
timefilter creationtime|updatetime
- select which event to filter -
start|starttime <Date>|<Time>
- specify the start of the time frame; if not specified, the time frame will be open ended at the start -
end|endtime <Date>|<Time>
- specify the end of the time frame; if not specified, the time frame will be open ended at the end For the filter to apply,timefilter
and at least one ofstart|starttime
andend|endtime
must be specified.
By default, all course submission fields are displayed; use the following options to modify the output.
-
fields <CourseSubmissionFieldNameList>
- Select specific fields to display.
By default, only the numeric userId is displayed; use the showuserprofile
option to get the user email address and name.
You can only get profile information if the scope https://www.googleapis.com/auth/classroom.profile.emails
is enabled
for service account access; verify with gam <UserTypeEntity> update serviceaccount
.
By default, Gam displays the information as columns of fields; the following option causes the ouput to be in JSON format,
-
formatjson
- Display the fields in JSON format.
By default, when writing CSV files, Gam uses a quote character of double quote "
. The quote character is used to enclose columns that contain
the quote character itself, the column delimiter (comma by default) and new-line characters. Any quote characters within the column are doubled.
When using the formatjson
option, double quotes are used extensively in the data resulting in hard to read/process output.
The quotechar <Character>
option allows you to choose an alternate quote character, single quote for instance, that makes for readable/processable output.
quotechar
defaults to gam.cfg/csv_output_quote_char
.
Need more help? Ask on the GAM Discussion Group
Update History
Installation
- How to Install GAM7
- How to Uograde GAMADV-XTD3 to GAM7
- How to Upgrade Legacy GAM to GAM7
- How to Update GAM7
- Install GAM as Python Library
- GAM7 on Chrome OS Devices
- GAM7 on Android Devices
- Google Network Addresses
- HTTPS Proxy
- SSL Root CA Certificates
- How to Uninstall GAM7
Configuration
- Authorization
- GAM Configuration
- Running GAM7 securely on a Google Compute Engine
- Using GAM7 with a delegated admin service account
- Using GAM7 with a YubiKey
Notes and Information
- Upgrade Benefits
- Questions? Visit the GAM Discussion Forum
- GAM Public Chat Room
- Scripts
- Other Resources
- Drive REST API v3
- BNF Syntax
- GAM Return Codes
- Python Regular Expressions
- Rclone
Definitions
Command Processing
- Bulk Processing
- Command Line Parsing
- Command Logging and Progress
- Command data from Google Docs/Sheets/Storage
- CSV Special Characters
- CSV Input Filtering
- CSV Output Filtering
- Meta Commands and File Redirection
- Permission matches
- Tag Replace
- Todrive
Collections
Client Access
- Addresses
- Administrators
- Alert Center
- Aliases
- Calendars
- Calendars - Access
- Calendars - Events
- Chrome Auto Update Expiration Counts
- Chrome Browser Cloud Management
- Chrome Device Needs Attention Counts
- Chrome Installed Apps
- Chrome Policies
- Chrome Printers
- Chrome Profile Management
- Chrome Version Counts
- Chrome Version History
- ChromeOS Devices
- Classroom - Courses
- Classroom - Guardians
- Classroom - Invitations
- Classroom - Membership
- Cloud Channel
- Cloud Identity Devices
- Cloud Identity Groups
- Cloud Identity Groups - Membership
- Cloud Identity Policies
- Cloud Storage
- Context Aware Access Levels
- Customer
- Domains
- Domains - Verification
- Domain People - Contacts & Profiles
- Domain Shared Contacts - Global Address List
- Email Audit Monitor
- Find File Owner
- Google Data Transfers
- Groups
- Groups - Membership
- Inbound SSO
- Licenses
- Mobile Devices
- Organizational Units
- Reports
- Reseller
- Resources
- Send Email
- Schemas
- Shared Drives
- Sites
- Users
- Unmanaged Accounts
- Users - Signout and Turn off 2-Step Verification
- Vault - Takeout
- Version and Help
Special Service Account Access
Service Account Access
- Users - Analytics Admin
- Users - Application Specific Passwords
- Users - Backup Verification Codes
- Users - Calendars
- Users - Calendars - Access
- Users - Calendars - Events
- Users - Chat
- Users - Classification Labels
- Users - Classroom - Profile
- Users - Deprovision
- Users - Contacts
- Users - Contacts - Delegates
- Users - Drive - File Selection
- Users - Drive - Activity/Settings
- Users - Drive - Cleanup
- Users - Drive - Comments
- Users - Drive - Copy/Move
- Users - Drive - Files-Display
- Users - Drive - Files-Manage
- Users - Drive - Orphans
- Users - Drive - Ownership
- Users - Drive - Permissions
- Users - Drive - Query
- Users - Drive - Revisions
- Users - Drive - Shortcuts
- Users - Drive - Transfer
- Users - Forms
- Users - Gmail - Client Side Encryption
- Users - Gmail - Delegates
- Users - Gmail - Filters
- Users - Gmail - Forwarding
- Users - Gmail - Labels
- Users - Gmail - Messages/Threads
- Users - Gmail - Profile
- Users - Gmail - S/MIME
- Users - Gmail - SendAs/Signature/Vacation
- Users - Gmail - Settings
- Users - Group Membership
- Users - Keep
- Users - Looker Studio
- Users - Meet
- Users - Classroom - Profile
- Users - People - Contacts & Profiles
- Users - Photo
- Users - Profile Sharing
- Users - Shared Drives
- Users - Spreadsheets
- Users - Tasks
- Users - Tokens
- Users - YouTube