L'app Classroom supporta tre tipi di elementi dello stream:
CourseWork
, CourseWorkMaterials
e Announcements
. Questa guida descrive come gestire CourseWork
, ma le API per tutti gli elementi dello stream sono simili. Consulta le risorse API per saperne di più sui tipi di elementi stream e sulle relative differenze.
La risorsa CourseWork
rappresenta un elemento di lavoro assegnato agli studenti di un determinato corso, inclusi eventuali materiali e dettagli aggiuntivi, come la data di consegna o il punteggio massimo. Esistono quattro sottotipi di CourseWork
:
compiti, compiti con quiz, domande a risposta breve e
domande a scelta multipla. L'API Classroom supporta tre di questi sottotipi: compiti, domande a risposta breve e domande a scelta multipla. Questi tipi sono rappresentati dal campo
CourseWork.workType
.
Oltre alla risorsa CourseWork
, puoi gestire il lavoro completato con la risorsa StudentSubmission
.
Creare lavori del corso
CourseWork
può essere creato solo per conto dell'insegnante del corso.
Il tentativo di creare CourseWork
per conto di uno studente o di un amministratore del dominio che non è un insegnante del corso genera un errore CourseWork
.PERMISSION_DENIED
Consulta la sezione Tipi di utente per scoprire di più sui diversi ruoli di Classroom.
Quando crei CourseWork
utilizzando il metodo courses.courseWork.create
, puoi allegare i link come materials
, come mostrato nel codice di esempio riportato di seguito:
Java
Python
I campi title
e workType
sono obbligatori. Tutti gli altri campi sono facoltativi.
Se state
non è specificato, CourseWork
viene creato in stato di bozza.
Utilizza una risorsa di collegamento con un target specificato
url
per includere i materiali collegati nel CourseWork
. Classroom recupera automaticamente l'URL di title
e l'URL immagine della miniatura (thumbnailUrl
). L'API Classroom supporta anche in modo nativo i materiali di Google Drive e YouTube, che possono essere inclusi con una risorsa DriveFile o YouTubeVideo in modo simile.
Per specificare una data di consegna, imposta i campi dueDate
e dueTime
sull'ora UTC corrispondente. La data di scadenza deve essere una data futura.
La risposta CourseWork
include un identificatore assegnato dal server che può essere utilizzato per fare riferimento all'assegnazione in altre richieste API.
Recuperare il programma dei corsi
Puoi recuperare CourseWork
per conto degli studenti e degli insegnanti del
corso corrispondente. Puoi anche recuperare CourseWork
per conto degli amministratori del dominio, anche se non sono insegnanti del corso. Per recuperare un CourseWork
specifico, utilizza courses.courseWork.get
. Per recuperare tutti
CourseWork
(eventualmente corrispondenti ad alcuni criteri), utilizza
courses.courseWork.list
.
L'ambito richiesto dipende dal ruolo dell'utente che effettua la richiesta nel corso. Se l'utente è uno studente, utilizza uno dei seguenti ambiti:
https://www.googleapis.com/auth/classroom.coursework.me.readonly
https://www.googleapis.com/auth/classroom.coursework.me
Se l'utente è un insegnante o un amministratore di dominio, utilizza uno dei seguenti ambiti:
https://www.googleapis.com/auth/classroom.coursework.students.readonly
https://www.googleapis.com/auth/classroom.coursework.students
L'autorizzazione a recuperare un CourseWork
non implica necessariamente l'autorizzazione ad accedere ai materiali o ai metadati dei materiali. In pratica, questo significa che un amministratore potrebbe non vedere il titolo di un file di Drive allegato se non è membro del corso.
Gestire le risposte degli studenti
Una risorsa StudentSubmission
rappresenta il lavoro svolto da uno studente per un
CourseWork
. La risorsa include i metadati relativi al lavoro, ad esempio lo stato e il voto. Quando viene creato un nuovo CourseWork
, viene creato implicitamente un StudentSubmission
per ogni studente.
Le sezioni seguenti descrivono le azioni comuni per gestire le risposte degli studenti.
Recuperare le risposte degli studenti
Gli studenti possono recuperare i propri contenuti inviati, gli insegnanti possono recuperare i contenuti inviati per tutti gli studenti dei loro corsi e gli amministratori di dominio possono recuperare tutti i contenuti inviati per tutti gli studenti del loro dominio. A ogni StudentSubmission
viene assegnato un identificatore. Se conosci l'identificatore, utilizza
courses.courseWork.studentSubmissions.get
per recuperare i contenuti inviati.
Utilizza il metodo courses.courseWork.studentSubmissions.list
per recuperare tutte le risorse StudentSubmission
che soddisfano alcuni criteri, come mostrato nell'esempio seguente:
Java
Python
Recupera le risorse StudentSubmission
appartenenti a uno studente specifico specificando il parametro userId
, come mostrato nell'esempio seguente:
Java
Python
Gli studenti sono identificati dall'ID univoco o dall'indirizzo email, come rappresentato nella risorsa
Student
. L'utente corrente può anche fare riferimento al proprio ID utilizzando la sigla"me"
.
È anche possibile recuperare i contenuti inviati dagli studenti per tutti i compiti all'interno di un
corso. A tal fine, utilizza il valore letterale "-"
come courseWorkId
, come mostrato nell'esempio seguente:
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()
L'ambito richiesto dipende dal ruolo dell'utente che effettua la richiesta nel corso. Se l'utente è un insegnante o un amministratore di dominio, utilizza il seguente ambito:
https://www.googleapis.com/auth/classroom.coursework.students.readonly
https://www.googleapis.com/auth/classroom.coursework.students
Se l'utente è uno studente, utilizza il seguente ambito:
https://www.googleapis.com/auth/classroom.coursework.me.readonly
https://www.googleapis.com/auth/classroom.coursework.me
L'autorizzazione a recuperare un StudentSubmission
non implica l'autorizzazione
ad accedere agli allegati o ai metadati degli allegati. In pratica, questo significa che un amministratore potrebbe non vedere il titolo di un file di Drive allegato se non è un membro del corso.
Aggiungere allegati a una risposta dello studente
Puoi allegare link a un lavoro inviato dallo studente allegando una risorsa Link
,
DriveFile
o YouTubeVideo
. Questa operazione viene eseguita con
courses.courseWork.studentSubmissions.modifyAttachments
, come mostrato nell'esempio seguente:
Java
Python
Un allegato Link
è definito dal url
di destinazione; Classroom recupera automaticamente il title
e l'immagine in miniatura (thumbnailUrl
). Consulta
Material
per scoprire i materiali che possono essere allegati a
StudentSubmissions
.
Il StudentSubmission
può essere modificato solo dall'insegnante del corso o dall'autore dello stesso. Puoi allegare Materials
solo se il
CourseWorkType
del StudentSubmission
è ASSIGNMENT
.
L'ambito richiesto dipende dal ruolo dell'utente che effettua la richiesta nel corso. Se l'utente è un insegnante, utilizza il seguente ambito:
https://www.googleapis.com/auth/classroom.coursework.students
Se l'utente è uno studente, utilizza il seguente ambito:
https://www.googleapis.com/auth/classroom.coursework.me