Nesta página, descrevemos algumas mensagens de erro, problemas e ações possíveis comuns da API Google Classroom para os seguintes tipos de erros:
- HTTP 400:
FAILED_PRECONDITION
- HTTP 403:
PERMISSION_DENIED
- HTTP 429:
RESOURCE_EXHAUSTED
- HTTP 500:
INTERNAL
HTTP 400: FAILED_PRECONDITION
Um FAILED_PRECONDITION
é retornado quando o usuário tenta uma ação que
não pode ser permitida, seja porque o usuário atingiu um limite ou um estado
do aplicativo, como CourseNotModifiable
. Para corrigir um FAILED_PRECONDITION
,
instrua o usuário a realizar alguma ação e tente de novo. Em alguns casos, você
pode usar endpoints alternativos para corrigir o estado em nome do usuário.
AttachmentNotVisible
AttachmentNotVisible
indica que um ou mais anexos especificados
não estão visíveis para o usuário, não são do tipo solicitado ou não existem. Por exemplo, itens do Drive que não foram compartilhados com o usuário retornariam esse erro.
Possível ação: descreva a causa da falha e sugira que o usuário verifique novamente os identificadores incluídos, como IDs de arquivos do Drive. Além disso, verifique se o usuário tem as permissões adequadas para acessar o anexo.
CannotRemoveCourseFolderOwner
CannotRemoveCourseFolderOwner
indica que o proprietário da pasta do curso no Drive não pode ser removido.
Ação possível: descreva a causa da falha e sugira que o usuário transfira a propriedade da pasta do curso no Drive para outro usuário e tente de novo.
CannotRemoveCourseOwner
CannotRemoveCourseOwner
indica que o proprietário do curso não pode ser removido.
Possível ação: descreva a causa da falha e sugira que o proprietário do curso não seja removido. Na maioria dos casos, o usuário está tentando se remover, o que não é permitido.
CannotRemoveCourseOwnerTransferIncomplete
CannotRemoveCourseOwnerTransferIncomplete
indica que o proprietário do curso não pode ser removido porque a transferência de propriedade da turma ainda está em andamento.
Ação possível: descreva a causa da falha e sugira que o usuário aguarde alguns momentos para que a ação assíncrona de transferência de propriedade da turma seja concluída e tente de novo.
CannotRemoveTeacherWithNoCourseOwner
CannotRemoveTeacherWithNoCourseOwner
indica que um professor não pode ser removido de um curso sem proprietário.
Ação possível: descreva a causa da falha e sugira que o professor não pode ser removido. Na maioria dos casos, a conta de usuário do proprietário do curso foi excluída, causando um estado inválido do curso.
CourseMemberLimitReached
CourseMemberLimitReached
indica que a ação tentada excederia o número máximo permitido de participantes do curso. Esse código geralmente é retornado pelo
students.create()
Para mais informações, consulte a seção "Limites de tamanho da turma" do artigo da Central de Ajuda
Convidar estudantes para uma turma.
Ação possível: descreva a causa da falha e sugira que o usuário remova os membros desnecessários do curso.
CourseNotModifiable
CourseNotModifiable
indica que o curso relevante está em um estado que
não permite a modificação das propriedades (além do estado do curso
em si).
Ação possível:
Peça ao usuário para mudar o curso para um
estado modificável. Para
mudar o estado, use
courses.patch()
.
O estado do curso pode ser alterado em uma solicitação que muda outras propriedades.
CourseTeacherLimitReached
CourseTeacherLimitReached
indica que a ação solicitada excederia o número máximo permitido de professores do curso. Esse código normalmente é retornado pelo método teachers.create()
.
Para mais informações, consulte a seção "Limitações de tamanho da turma" no artigo da Central de Ajuda Adicionar um professor auxiliar a uma turma.
Possível ação:
descreva a causa da falha e sugira que o usuário remova os professores
desnecessários do curso. Se aplicável ao seu app, use o método
teachers.delete()
para gerenciar as listas de professores em nome do usuário.
CourseTitleCannotContainUrl
CourseTitleCannotContainUrl
indica que a ação solicitada não é permitida porque introduziria um URL no título do curso. Os padrões de URL não são compatíveis com títulos de cursos.
Possível ação:
descreva a causa da falha e sugira que o usuário remova o padrão de URL
do campo title
. URLs são permitidos no campo description
.
CourseTopicLimitReached
CourseTopicLimitReached
indica que a ação solicitada excederia o número máximo permitido de tópicos em um curso. Esse código normalmente é retornado pelo método courses.topics.create()
.
Possível ação:
descreva a causa da falha e sugira que o usuário remova tópicos desnecessários. Se aplicável ao seu app, use o método
courses.topics.delete()
para gerenciar temas em nome do usuário.
InactiveCourseOwner
InactiveCourseOwner
: indica que a ação solicitada não é permitida porque a conta do proprietário do curso foi excluída. O administrador do proprietário do curso precisa restaurar a conta dele antes de realizar a ação solicitada.
Ação possível: descreva a causa da falha e sugira que o administrador restaure a conta do proprietário do curso antes de tentar novamente.
IneligibleOwner
IneligibleOwner
indica que o usuário não pode ser adicionado como proprietário do curso porque não é um professor colaborador.
Ação possível: descreva a causa da falha. Se o usuário solicitante não for um administrador, sugira que ele envie um convite para o usuário ser professor no curso antes de atualizar o proprietário. Se o usuário solicitante for um administrador, sugira que ele adicione o usuário como professor auxiliar do curso.
PendingInvitationExists
PendingInvitationExists
indica que alguém já foi convidado para assumir a propriedade do curso. Esse erro ocorre durante a transferência de propriedade do curso
quando uma transferência foi iniciada anteriormente, mas ainda não foi aceita pelo
novo proprietário.
UserCannotOwnCourse
UserCannotOwnCourse
indica que o usuário não pode ser adicionado como proprietário do curso.
Ação possível: descreva a causa da falha e sugira que o curso não pode ser criado com o usuário como proprietário. Um usuário que não é administrador pode receber esse erro se tentar criar um curso com um usuário diferente dele como proprietário. Um administrador que solicita um usuário pode receber esse erro se a conta de usuário especificada como proprietário não existir ou se o usuário não estiver no domínio dele.
UserGroupsMembershipLimitReached
UserGroupsMembershipLimitReached
indica que o usuário já é membro do número máximo permitido de grupos e não pode participar de nenhum curso. Esse código geralmente é retornado por students.create()
ou teachers.create()
.
Para mais informações, consulte a seção "Limitações de tamanho da turma" do artigo da Central de Ajuda Convidar estudantes para uma turma.
Ação possível:
descreva a causa da falha e sugira que o usuário saia dos cursos em
que não está participando. O usuário pode criar outra conta se precisar participar de mais cursos. Se aplicável ao seu app, use students.create()
ou teachers.delete()
para gerenciar as listas em nome do usuário.
HTTP 403: PERMISSION_DENIED
Todos os métodos da API Classroom podem retornar um erro PERMISSION_DENIED
(HTTP 403)
se um usuário final não atender aos pré-requisitos de acesso. A mensagem
que acompanha o erro contém uma
mensagem de erro para
ajudar você a identificar a causa e orientar os usuários a tomar a ação adequada.
As seções a seguir descrevem mensagens de erro comuns da API Classroom.
CannotDirectAddUser
CannotDirectAddUser
indica que um usuário não pode ser adicionado diretamente ao
curso. Esse código aparece quando um administrador de domínio tenta adicionar um
usuário a um curso e esse usuário não tem um endereço de e-mail ou não
pertence ao domínio.
Possível ação: descreva a causa da falha e sugira que o administrador do domínio verifique se a conta de usuário existe e está no domínio do administrador do curso.
ClassroomApiDisabled
ClassroomApiDisabled
indica que o usuário solicitante não tem acesso
à API Classroom.
Ação possível: direcione o usuário para as instruções sobre como ativar o acesso aos dados do Google Sala de Aula. Consulte também ClassroomDisabled, já que o usuário pode estar usando a conta errada.
ClassroomDisabled
ClassroomDisabled
indica que o usuário solicitante não tem acesso ao Google Sala de Aula.
Ação possível: direcione o usuário para as instruções sobre como ativar o acesso ao Google Sala de Aula. O usuário também pode estar usando a conta errada. Por isso, forneça um link para usar várias contas para que ele possa selecionar a conta correta.
ExpiredAddOnToken
ExpiredAddOnToken
indica que o token do complemento usado para fazer chamadas para
a API expirou.
Ação possível: peça ao usuário para atualizar a página ou fazer login no complemento
de novo para que você possa receber o novo parâmetro de consulta addOnToken
do
URL da solicitação.
InvalidAddOnToken
InvalidAddOnToken
indica que o token de complemento transmitido em uma solicitação não tem autorização para criar um anexo de complemento na atividade.
Possível ação: esse erro pode ocorrer se o usuário fizer login no complemento com uma conta diferente da conta do Google Sala de Aula. Peça ao usuário para sair de todas as outras contas no navegador ou abrir o Google Sala de Aula em uma janela anônima do Chrome.
ProjectPermissionDenied
ProjectPermissionDenied
indica que a solicitação tentou modificar um recurso associado a um projeto diferente do Developer Console.
Possível ação: indique que seu aplicativo não pode fazer a solicitação pretendida. Ela só pode ser feita pelo projeto do console do desenvolvedor do ID do cliente OAuth que criou o recurso.
UserIneligibleToUpdateGradingPeriodSettings
UserIneligibleToUpdateGradingPeriodSettings
indica que a solicitação tentou modificar as configurações do período de avaliação em um curso em que o usuário solicitante ou o proprietário do curso não tem a licença adequada do Google Workspace for Education ou o usuário solicitante não é professor do curso nem administrador do domínio.
Ação possível: indique que seu aplicativo não pode fazer a solicitação pretendida para atualizar as configurações do período de avaliação devido ao status da função de licenciamento ou do curso. As licenças podem ser atribuídas no Google Admin Console.
HTTP 429: RESOURCE_EXHAUSTED
O RESOURCE_EXHAUSTED
é retornado quando a ação solicitada não é permitida
porque algum recurso, como cota ou capacidade do servidor, está esgotado. Esses
tipos de erros de solicitação geralmente ocorrem porque o app gerou uma carga
excessiva.
Para evitar acionar esses limites e aumentar a confiabilidade do seu aplicativo, use mecanismos de nova tentativa. Os mecanismos de nova tentativa válidos incluem:
Use a espera exponencial truncada para repetir a solicitação e maximizar a capacidade de solicitações em ambientes simultâneos.
Para evitar colisões, considere a espera exponencial truncada com instabilidade. A introdução de jitter pode ajudar suas solicitações a serem concluídas mais rapidamente, introduzindo um atraso aleatório que distribui picos de solicitações.
Se o aplicativo retornar erros RESOURCE_EXHAUSTED
devido a limitações de cota, envie um pedido de aumento. Para mais informações, consulte o artigo da Central de Ajuda Monitorar cotas de API.
UserCourseJoinRateLimitReached
UserCourseJoinRateLimitReached
indica que o usuário já se inscreveu no número máximo de cursos permitidos em um dia. Para mais informações, consulte a seção "Convites e tamanho do grupo" do artigo da Central de Ajuda Entender as políticas e os limites do Grupos.
Possível ação: descreva a causa da falha e sugira que o usuário aguarde um dia antes de entrar no curso.
HTTP 500: INTERNAL
INTERNAL
indica que ocorreu um erro inesperado ao processar a solicitação. Os erros de solicitação INTERNAL
também podem ser resolvidos usando a espera exponencial para tentar de novo. Se um erro INTERNAL
persistir, registre um bug no Rastreador de problemas públicos da API Classroom.