L'app Classroom supporta tre tipi di elementi del flusso:
CourseWork
, CourseWorkMaterials
e Announcements
. Questa guida
descrive come gestire CourseWork
, ma le API per tutti gli elementi del flusso sono
simili. Consulta le risorse API per scoprire di più sui tipi di elementi del flusso e sulle loro
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 scadenza o il punteggio massimo. Esistono quattro sottotipi di CourseWork
:
compiti, 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
.
Crea 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 di dominio che non è un insegnante del corso genera un errore PERMISSION_DENIED
. Consulta la sezione Tipi di utenti per scoprire di più sui diversi
ruoli in Classroom.
Quando crei CourseWork
utilizzando il metodo courses.courseWork.create
, puoi allegare 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 Link con una destinazione specificata
url
per includere i materiali collegati in CourseWork
. Classroom
recupera automaticamente l'title
e l'URL dell'immagine in 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 scadenza, 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.
Retrieve CourseWork
Puoi recuperare CourseWork
per conto di studenti e insegnanti del corso corrispondente. Puoi anche recuperare CourseWork
per conto degli amministratori di dominio, anche se non sono insegnanti del corso. Per recuperare un
CourseWork
specifico, utilizza courses.courseWork.get
. Per recuperare tutti
CourseWork
(corrispondenti facoltativamente ad alcuni criteri), utilizza
courses.courseWork.list
.
L'ambito richiesto dipende dal ruolo dell'utente richiedente 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
le autorizzazioni per accedere ai materiali o ai metadati dei materiali. In pratica, ciò 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 metadati relativi al lavoro, ad esempio
lo stato e il voto del lavoro. Un StudentSubmission
viene creato implicitamente
per ogni studente quando viene creato un nuovo CourseWork
.
Le sezioni seguenti spiegano le azioni comuni che gestiscono le risposte degli studenti.
Recuperare le risposte degli studenti
Gli studenti possono recuperare i propri invii, gli insegnanti possono recuperare gli invii
di tutti gli studenti dei loro corsi e gli amministratori di dominio possono recuperare tutti
gli invii di tutti gli studenti del loro dominio. A ogni StudentSubmission
viene
assegnato un identificatore. Se conosci l'identificatore, utilizza
courses.courseWork.studentSubmissions.get
per recuperare l'invio.
Utilizza il metodo courses.courseWork.studentSubmissions.list
per ottenere tutte le risorse StudentSubmission
che corrispondono a determinati criteri, come mostrato nell'esempio seguente:
Java
Python
Recupera le risorse StudentSubmission
appartenenti a un determinato studente specificando il parametro userId
, come mostrato nel seguente esempio:
Java
Python
Gli studenti vengono identificati dall'ID univoco o dall'indirizzo email, come rappresentato nella risorsa
Student
. L'utente attuale può anche fare riferimento al proprio ID utilizzando l'abbreviazione
"me"
.
È anche possibile recuperare i contenuti inviati dagli studenti per tutti i compiti di un corso. Per farlo, 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 richiedente 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 relativi metadati. In pratica, ciò significa che un
amministratore potrebbe non vedere il titolo di un file di Drive allegato se
non è membro del corso.
Aggiungere allegati alla risposta di uno studente
Puoi allegare link a un compito inviato da uno 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 Link
allegato è definito dalla destinazione url
; 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 da un insegnante del corso o dallo studente che ne è proprietario. Puoi allegare Materials
solo se il
CourseWorkType
di StudentSubmission
è ASSIGNMENT
.
L'ambito richiesto dipende dal ruolo dell'utente richiedente 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