O app Sala de Aula é compatível com três tipos de itens do mural:
CourseWork
, CourseWorkMaterials
e Announcements
. Este guia descreve como gerenciar CourseWork
, mas as APIs para todos os itens de stream são semelhantes. Consulte Recursos da API para saber mais sobre os tipos de itens de stream e as diferenças entre eles.
O recurso CourseWork
representa um item de trabalho atribuído a estudantes em um curso específico, incluindo materiais e detalhes adicionais, como data de entrega ou pontuação máxima. Há quatro subtipos de CourseWork
:
atividades, atividades com teste, perguntas de resposta curta e
perguntas de múltipla escolha. A API Classroom é compatível com três desses subtipos: atividades, perguntas de resposta curta e perguntas de múltipla escolha. Esses tipos são representados pelo campo
CourseWork.workType
.
Além do recurso CourseWork
, é possível gerenciar o trabalho concluído
com o recurso StudentSubmission
.
Criar atividades
Os CourseWork
só podem ser criados em nome do professor do curso.
A tentativa de criar CourseWork
em nome de um estudante ou de um administrador de domínio que não seja professor do curso resulta em um erro PERMISSION_DENIED
. Consulte Tipos de usuários para saber mais sobre as diferentes funções no Google Sala de Aula.
Ao criar CourseWork
usando o método courses.courseWork.create
, você
pode anexar links como materials
, conforme mostrado no exemplo de código abaixo:
Java
Python
Os campos title
e workType
são obrigatórios. Todos os outros campos são opcionais.
Se state
não for especificado, o CourseWork
será criado em um estado de rascunho.
Use um recurso de link com um destino especificado
url
para incluir materiais vinculados no CourseWork
. A Sala de Aula
busca automaticamente o title
e o URL da imagem em miniatura (thumbnailUrl
). A
API Classroom também oferece suporte nativo a materiais do Google Drive e do YouTube, que podem ser incluídos com um recurso
DriveFile ou YouTubeVideo de maneira semelhante.
Para especificar uma data de vencimento, defina os campos dueDate
e dueTime
com o horário UTC correspondente. A data de vencimento precisa estar no futuro.
A resposta CourseWork
inclui um identificador atribuído pelo servidor que pode ser usado
para referenciar a atribuição em outras solicitações de API.
Recuperar CourseWork
Você pode recuperar CourseWork
em nome dos estudantes e professores do curso correspondente. Você também pode recuperar CourseWork
em nome dos administradores do domínio, mesmo que eles não sejam professores do curso. Para recuperar um CourseWork
específico, use courses.courseWork.get
. Para recuperar todos os
CourseWork
(opcionalmente correspondendo a alguns critérios), use
courses.courseWork.list
.
O escopo necessário depende da função que o usuário solicitante tem no curso. Se o usuário for um estudante, use um dos seguintes escopos:
https://www.googleapis.com/auth/classroom.coursework.me.readonly
https://www.googleapis.com/auth/classroom.coursework.me
Se o usuário for um professor ou administrador do domínio, use um dos seguintes escopos:
https://www.googleapis.com/auth/classroom.coursework.students.readonly
https://www.googleapis.com/auth/classroom.coursework.students
Ter permissão para recuperar um CourseWork
não implica permissões para acessar materiais ou metadados de materiais. Na prática, isso significa que um administrador talvez não veja o título de um arquivo anexado do Drive se não for participante do curso.
Gerenciar respostas dos estudantes
Um recurso StudentSubmission
representa o trabalho feito por um estudante para uma
CourseWork
. O recurso inclui metadados relacionados ao trabalho, como status e nota. Um StudentSubmission
é criado implicitamente
para cada estudante quando um novo CourseWork
é criado.
As seções a seguir explicam ações comuns que gerenciam as respostas dos estudantes.
Recuperar respostas dos estudantes
Os estudantes podem recuperar os próprios envios, os professores podem recuperar os envios de todos os estudantes dos cursos, e os administradores de domínio podem recuperar todos os envios de todos os estudantes do domínio. Cada StudentSubmission
recebe um identificador. Se você souber o identificador, use
courses.courseWork.studentSubmissions.get
para recuperar o envio.
Use o método courses.courseWork.studentSubmissions.list
para receber todos os recursos StudentSubmission
que correspondem a alguns critérios, conforme mostrado no exemplo a seguir:
Java
Python
Recupere recursos StudentSubmission
que pertencem a um estudante específico
especificando o parâmetro userId
, conforme mostrado neste exemplo:
Java
Python
Os estudantes são identificados pelo ID exclusivo ou endereço de e-mail, conforme representado no recurso
Student
. O usuário atual também pode se referir à própria ID usando o atalho
"me"
.
Também é possível recuperar os envios dos estudantes para todas as atividades de um curso. Para fazer isso, use o literal "-"
como o courseWorkId
, conforme mostrado no
exemplo a seguir:
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()
O escopo necessário depende da função que o usuário solicitante tem no curso. Se o usuário for um professor ou administrador do domínio, use o seguinte escopo:
https://www.googleapis.com/auth/classroom.coursework.students.readonly
https://www.googleapis.com/auth/classroom.coursework.students
Se o usuário for um estudante, use o seguinte escopo:
https://www.googleapis.com/auth/classroom.coursework.me.readonly
https://www.googleapis.com/auth/classroom.coursework.me
Ter permissão para recuperar um StudentSubmission
não implica permissões
para acessar anexos ou metadados de anexos. Na prática, isso significa que um administrador pode não ver o título de um arquivo anexado do Drive se não for participante do curso.
Adicionar anexos a uma resposta de estudante
É possível anexar links a uma atividade enviada por um estudante anexando um recurso Link
,
DriveFile
ou YouTubeVideo
. Isso é feito com
courses.courseWork.studentSubmissions.modifyAttachments
, conforme mostrado na
amostra a seguir:
Java
Python
Um anexo Link
é definido pelo destino url
. O Google Sala de Aula
busca automaticamente o title
e a imagem em miniatura (thumbnailUrl
). Consulte
Material
para saber mais sobre os materiais que podem ser anexados a
StudentSubmissions
.
O StudentSubmission
só pode ser modificado por um professor do curso ou pelo estudante que é o proprietário dele. Só é possível anexar Materials
se o
CourseWorkType
do StudentSubmission
for ASSIGNMENT
.
O escopo necessário depende da função que o usuário solicitante tem no curso. Se o usuário for um professor, use o seguinte escopo:
https://www.googleapis.com/auth/classroom.coursework.students
Se o usuário for um estudante, use o seguinte escopo:
https://www.googleapis.com/auth/classroom.coursework.me