Projetos do Google Cloud

Todos os projetos do Apps Script usam o Google Cloud para gerenciar autorizações, serviços avançados e outros detalhes. Para definir e gerenciar essas configurações, cada projeto do Apps Script tem um projeto do Google Cloud associado. Seu projeto de script pode usar um projeto padrão criado automaticamente pelo Apps Script ou um projeto padrão criado por você. Em geral, os projetos padrão são bons para scripts cotidianos ou simples, mas é recomendável usar um projeto padrão para qualquer aplicativo complexo, de qualidade comercial ou que pretenda publicar.

É possível mudar de um projeto padrão para um padrão a qualquer momento, mas não é possível voltar a usar um projeto padrão. É melhor selecionar o projeto do Cloud que seu script usa no início do desenvolvimento. A mudança mais tarde pode causar complicações, como exigir que os usuários autorizem novamente.

Projetos padrão do Cloud

Quando você cria um projeto do Apps Script, o Apps Script cria um projeto padrão do Cloud que opera em segundo plano.

  • Para a maioria dos scripts, não é necessário ver nem ajustar esse projeto padrão. O Apps Script lida com as interações necessárias com o Google Cloud. Por exemplo, se você ativar um serviço avançado no editor do Apps Script, ele será ativado no projeto padrão do Cloud quando você salvar o projeto do script.
  • Em alguns scripts, é necessário interagir com o console do Google Cloud. Nesses casos, seu script precisa usar um projeto padrão do Cloud. Por exemplo, para visualizar os registros do Google Cloud no console do Google Cloud, seu script precisa usar um projeto padrão.

Por padrão, os projetos do Cloud têm uma política de Identity and Access Management (IAM) com uma entrada, uma conta de serviço do Google que atua como proprietária do projeto padrão. A conta de serviço do Google é appsdev-apps-dev-script-auth@system.gserviceaccount.com.

Ver ou atualizar projetos padrão do Cloud

A maioria dos usuários não consegue localizar, visualizar ou editar projetos padrão diretamente no console do Google Cloud. Se você for um administrador, consulte Ver projetos padrão do Google Cloud.

Se você criou o projeto de script antes de 8 de abril de 2019, pode usar um projeto padrão que pode ser acessado no console do Google Cloud. Para acessar o projeto padrão, vá até as configurações do projeto de script e clique no número do projeto.

Excluir projetos padrão do Cloud

Se você for um administrador, poderá excluir projetos padrão do Cloud como faria com os projetos padrão do Cloud. Consulte Excluir projetos do Cloud do Apps Script.

Se você não for um administrador, não será possível excluir projetos padrão. No entanto, o Apps Script exclui projetos padrão nos seguintes cenários:

  • Se você excluir o projeto de script ou mudar para um projeto padrão, o Apps Script excluirá o projeto padrão anexado ao script com as configurações ou informações contidas nele.
  • Se um script não for executado por 180 dias ou mais, o Apps Script vai excluir o projeto padrão associado. Se o script for executado depois que o projeto padrão for excluído, o Apps Script criará um para o script.

Projetos padrão do Cloud

Os projetos padrão do Cloud são a melhor opção para a maioria dos projetos de script, a menos que você precise configurar o projeto manualmente. Nessas situações, é preciso alternar o projeto de script para usar um projeto padrão.

As seções a seguir descrevem quando o Apps Script exige um projeto padrão, as propriedades desses projetos e as tarefas comuns realizadas com eles. Só é possível executar as tarefas abaixo com projetos padrão.

Quando o Apps Script exige projetos padrão do Cloud

Use um projeto padrão nas seguintes situações:

Propriedades de projetos padrão do Cloud

Os projetos padrão têm as seguintes propriedades:

  • É possível acessar todas as configurações do Google Cloud para o projeto diretamente no console do Google Cloud. Isso permite ativar APIs, ajustar credenciais de autorização e configurar outros detalhes.
  • Quando você exclui um projeto de script ou o muda para usar outro projeto padrão, o projeto padrão original permanece e pode ser reutilizado.
  • Ao ativar um serviço avançado em um projeto de script, você precisa ativar manualmente a API correspondente no projeto padrão.
  • Vários projetos de script e outros apps podem compartilhar o mesmo projeto padrão. Se você pretende publicar um projeto de script no Google Workspace Marketplace como um complemento, ele precisa ter o próprio projeto padrão. Apps publicados não podem compartilhar projetos do Cloud com outros apps.
  • Se você quiser executar funções em um projeto de script a partir de outro app usando o método scripts.run da API Apps Script, o projeto de script e o aplicativo de chamada precisarão compartilhar o mesmo projeto padrão.
  • Quando o Apps Script solicita que um usuário autorize um script que usa um projeto padrão, o nome do projeto do Cloud é usado para identificar o script, e não o nome do projeto do script. Por esse motivo, defina um nome de projeto apropriado do Cloud.

Acessar um projeto padrão do Cloud

Para acessar o projeto padrão associado ao seu projeto de script, faça o seguinte:

  1. Abra o projeto do Apps Script.
  2. À esquerda, clique em Configurações do projeto .
  3. Em Projeto do Google Cloud Platform (GCP), clique no número do projeto.

Também é possível encontrar um projeto padrão diretamente na página Gerenciar recursos do console do Google Cloud.

Ativar uma API em um projeto padrão do Cloud

Muitas vezes, um aplicativo do Apps Script precisa de acesso a outra API do Google. Para fazer isso, ative a API no projeto do Cloud correspondente. Para ativar uma API, faça o seguinte:

  1. Abra o projeto do Cloud.
  2. Clique em Menu > APIs e serviços.
  3. Clique em Ativar APIs e serviços.
  4. Na caixa de pesquisa, insira a API que você quer ativar e pressione Enter.
  5. Clique na API nos resultados da pesquisa e em Ativar para habilitar a API para esse projeto do Cloud.

Talvez seja necessário aceitar os Termos de Serviço das APIs do Google ou do Google Cloud. Leia atentamente os Termos de Serviço antes de aceitá-los.

Dependendo do aplicativo, talvez seja necessário configurar a API selecionando-a no painel APIs e serviços.

Determinar o ID e o número de um projeto padrão do Cloud

Todos os projetos do Cloud têm um nome, ID e número de projeto. Ocasionalmente, você precisa ter esses identificadores para configurar serviços ou concluir outras tarefas.

Para determinar o ID e o número do projeto padrão, faça o seguinte:

  1. Abra o projeto do Cloud.
  2. No canto superior direito, clique em Mais > Configurações do projeto.
  3. Veja o Nome, o ID e o Número do projeto no painel Configurações resultante. O número do projeto consiste apenas em dígitos, enquanto o ID do projeto é alfanumérico. É possível editar o Nome do projeto, que aparece para os usuários durante as solicitações de autorização.

Acessar registros e relatórios de erros do Google Cloud no console do Google Cloud

Se você estiver usando a geração de registros do Google Cloud ou o relatório de erros para seu projeto de script, será possível visualizar esses registros e relatórios no console do Google Cloud fazendo o seguinte:

  1. Abra o projeto do Cloud.
  2. Clique no menu .
  3. Role para baixo até a seção Operações e clique em Registros > Explorador de registros.
  4. Para ver os relatórios de erros, role para baixo até a seção Operações e clique em Error Reporting. Se você for solicitado a configurar o relatório de erros, isso significa que o projeto de script ainda não registrou nenhuma exceção.

Ao usar serviços que exigem OAuth, o Google solicita que os usuários autorizem esses serviços. As configurações da tela de permissão OAuth permitem definir algumas das informações que o Google apresenta aos usuários, como o nome do aplicativo e o URL dos Termos de Serviço.

Os projetos padrão do Cloud criam uma tela de consentimento automaticamente com base nos detalhes do projeto do Apps Script. Não é possível ajustar essas configurações. Os projetos padrão do Cloud permitem personalizar essas informações. Para configurar a tela de consentimento do script, faça o seguinte:

  1. Abra o projeto do Cloud.
  2. Clique em Menu > APIs e serviços > Credenciais.
  3. Clique em Configurar tela de consentimento.
  4. Preencha cada seção do fluxo de trabalho da tela de consentimento.
  5. Para registrar suas alterações em cada etapa do fluxo de trabalho, clique em Salvar e continuar.

Crie credenciais do OAuth.

O Apps Script geralmente configura o OAuth para os serviços usados pelo script. Para alguns aplicativos, é necessário criar credenciais OAuth adicionais (IDs e chaves secretas do cliente). Só é possível fazer isso com projetos padrão.

Para criar um ID e uma chave secreta do cliente para seu projeto de script, faça o seguinte:

  1. Abra o projeto do Cloud.
  2. Clique em Menu > APIs e serviços > Credenciais.
  3. Clique em Criar credenciais > ID do cliente OAuth.
  4. Em Tipo de aplicativo, selecione o tipo e preencha o formulário resultante, se necessário. Quando terminar, clique em Criar.
  5. Na caixa de diálogo exibida, clique em Fazer o download do JSON. É possível usar esse arquivo para configurar o OAuth.

Adicionar outros proprietários a um projeto padrão do Cloud

É possível adicionar outros proprietários ou outros papéis a um projeto padrão. Se você estiver colaborando em um projeto, isso ajuda a garantir que alguém da sua equipe sempre tenha acesso às configurações do Google Cloud do projeto de script.

Adicione outros proprietários ou outros papéis a um projeto padrão fazendo o seguinte. Você precisa ter permissões para edição no projeto se quiser fazer alguma destas alterações:

  1. Determine quem são seus colaboradores. Recomendamos que você crie ou use um Grupo do Google existente. Você também pode especificar domínios na lista de colaboradores para incluir todos os usuários desse domínio.
  2. Abra o projeto do Cloud do script.
  3. Clique em Menu > IAM e administrador > IAM.
  4. Na parte de cima, clique em Adicionar.
  5. Siga as instruções na tela para adicionar um ou mais membros novos e os papéis deles ao projeto do Cloud. É possível adicionar e-mails, Grupos do Google ou domínios como novos membros.
  6. Clique em Salvar.

Agrupar vários scripts com um único projeto do Cloud

É possível ter vários projetos do Apps Script compartilhando o mesmo projeto padrão do Cloud. Para fazer isso, crie um projeto padrão e mude cada projeto de script para usá-lo. Não é possível fazer isso com projetos padrão.

Usar outro projeto padrão do Cloud

É possível alternar um projeto de script para que ele use um projeto padrão diferente do Cloud. Se o script exigir uma configuração manual do projeto do Cloud, mude de um projeto padrão para um padrão. Para saber mais sobre quando você precisa usar um projeto padrão, consulte os projetos padrão do Cloud.

Efeitos da mudança para outro projeto padrão do Cloud

Se você alternar seu script de um projeto padrão ou para um projeto padrão diferente, isso terá os seguintes efeitos:

  • Se você tiver ativado os serviços avançados para o script, habilite as APIs correspondentes no novo projeto do Cloud. Você perde todos os dados vinculados aos serviços avançados no projeto anterior do Cloud. Para saber como ativar APIs no projeto do Cloud, consulte Ativar APIs do Google Workspace.
  • Se o script usa o serviço integrado do Google Drive, você precisa ativar a API Drive nos projetos padrão do Cloud.

    No projeto padrão do Cloud, ative a API Drive:

    Ativar a API Drive

  • Todos os usuários que já autorizaram o script precisarão autorizar novamente. Na maioria dos casos, todos os usuários que autorizaram apps associados ao novo projeto também precisam fazer a autorização novamente.
  • Se o script estiver associado a uma página "Detalhes do app" no Google Workspace Marketplace, a página "Detalhes do app", os usuários e as avaliações não serão transferidos para o novo projeto. Você precisa criar uma página "Detalhes do app" no novo projeto, e os usuários precisam reinstalar o app. Para saber mais sobre como criar uma nova página "Detalhes do app", consulte Publicar um app.
  • Não é possível mudar um script de volta para um projeto padrão. O Apps Script exclui os projetos padrão depois que você configura o script para usar um projeto padrão.

Mudar para outro projeto padrão do Cloud

Para trocar um projeto do Cloud de um script para outro projeto do Cloud, siga estas etapas:

  1. Se você não tiver um projeto do Cloud adequado, crie um seguindo as instruções em Criar um projeto. Defina um nome fácil de lembrar para o projeto na página Gerenciar recursos do console do Google Cloud. O Apps Script usa esse nome para solicitar que os usuários autorizem o script.
  2. Se você quiser usar um projeto que já existe, abra a página Gerenciar recursos do console do Google Cloud e encontre um projeto para usar. Você precisa ter os papéis de navegador do projeto e editor de configuração OAuth ou com as permissões equivalentes no projeto. Não é possível usar um projeto criado automaticamente pelo Apps Script.
  3. Determine o Número do projeto do Cloud.
  4. Abra o script do projeto do Cloud que você quer substituir.
  5. À esquerda, clique em Configurações do projeto .
  6. Em Projeto do Google Cloud Platform (GCP), clique em Mudar projeto.
  7. Digite o número do novo projeto e clique em Definir projeto.

Projetos do Cloud e drives compartilhados

Os drives compartilhados (antigos Drives de equipe) oferecem espaços compartilhados onde grupos de usuários do Drive podem colaborar em projetos do Apps Script e documentos do Drive. Os drives compartilhados são úteis para desenvolver scripts, complementos e apps da Web com uma equipe, mas impõem algumas restrições sobre o que é possível fazer com projetos padrão mais antigos do Cloud.

A lista de restrições a seguir descreve como os projetos do Cloud interagem com os drives compartilhados:

  • Se o projeto de script usar um projeto padrão, não haverá outras restrições quando o projeto de script estiver em um drive compartilhado.
  • Se o projeto de script usar um projeto padrão criado a partir de 8 de abril de 2019, não haverá outras restrições quando o projeto de script estiver em um drive compartilhado.
  • Caso seu projeto de script use um projeto padrão criado antes de 8 de abril de 2019, as restrições a seguir serão aplicadas enquanto o projeto de script estiver em um drive compartilhado:
    1. Não é possível acessar o projeto padrão usando a IU do Apps Script ou o console do Google Cloud. Essa restrição impede que você realize ações que exigem acesso direto ao projeto.
    2. Não é possível ativar os serviços avançados. Para ativar os serviços avançados, mude para um projeto padrão.
    3. Quando você move um projeto do Apps Script para um drive compartilhado, o Google restringe o acesso ao projeto padrão do Cloud. Ainda será possível acessar o projeto padrão se você tinha acesso antes da migração. Por exemplo, se você criou um script na pasta "Meu Drive" e o moveu para um drive compartilhado, ainda poderá acessar o projeto do Cloud desse script. Talvez seus colaboradores no drive compartilhado não consigam fazer isso.
    4. Um script mantém o nome do projeto do Cloud que tinha antes de ser movido para um drive compartilhado. Mesmo que você altere o nome do projeto no drive compartilhado, os usuários que autorizam o script ainda verão o nome antigo nas caixas de diálogo de autorização.

Para evitar as restrições acima em scripts mais antigos, mude para um projeto padrão.

Acessar uma lista de projetos do Cloud com o Apps Script

Se você tiver a permissão resourcemanager.projects.list para a pasta de projetos do Apps Script da sua organização, poderá ver todos os projetos padrão e padrão do Cloud do Apps Script na pasta.

  1. Abra a página Gerenciar recursos no console do Google Cloud.
  2. Ao lado da pasta Apps Script, copie o ID.
  3. Clique em Filtro > ID pai e cole o ID da pasta do Apps Script.

Excluir projetos do Cloud no Apps Script

Para excluir um projeto do Cloud no Apps Script, siga as etapas em Acessar uma lista de projetos do Cloud do Apps Script, selecione o projeto que você quer excluir e clique em Excluir.

Para excluir um projeto do Apps Script usando gcloud, use os comandos a seguir.

gcloud projects list --filter='parent.id=APPS_SCRIPT_FOLDER_ID'
gcloud projects delete PROJECT_ID

Para mais informações sobre como excluir projetos do Cloud, consulte Como encerrar (excluir) projetos.