Projetos do Google Cloud

Todos os projetos do Apps Script usam o Google Cloud para gerenciar autorização, 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, projetos padrão são bons para scripts simples ou comuns, mas use um projeto padrão para qualquer aplicativo complexo, de qualidade comercial ou que queira publicar.

É possível mudar de um projeto padrão para um projeto 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 posterior 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, ele cria um projeto padrão do Cloud que opera em segundo plano.

  • Para a maioria dos scripts, você nunca precisa ver ou 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, o Apps Script vai ativar o serviço avançado no projeto padrão do Cloud quando você salvar o projeto do script.
  • Para alguns scripts, você precisa interagir com o console do Google Cloud. Nesses casos, o script precisa usar um projeto padrão do Cloud. Por exemplo, para ver os registros do Google Cloud no console, seu script precisa usar um projeto padrão.

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

Mostrar 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 seu projeto de script antes de 8 de abril de 2019, use um projeto padrão que pode ser acessado no console do Google Cloud. Para acessá-lo, 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 projetos padrão do Cloud. Veja mais informações em Excluir projetos do Cloud com o 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 alterá-lo para um projeto padrão, o Apps Script excluirá o projeto padrão anexado ao script com todas as configurações ou informações contidas nele.
  • Se um script ficar inativo 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 seu 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 realizar as tarefas abaixo com projetos padrão.

Quando o Apps Script exige projetos padrão do Cloud

Use um projeto padrão nestas situações:

Propriedades do projeto 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 troca 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 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 pede que um usuário autorize um script que usa um projeto padrão, o nome do projeto do Cloud é usado para identificar o script (não o nome do projeto do script). Por esse motivo, defina um nome apropriado para o projeto 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 isso, ative a API no projeto correspondente do Cloud. 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, digite a API que você quer ativar e pressione Enter.
  5. Clique na API nos resultados da pesquisa e em Ativar para que a API seja ativada para este 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 também seja necessário configurar a API selecionando-a no painel de 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. Às vezes, esses identificadores são necessários 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 código do projeto é alfanumérico. É possível editar o Nome do projeto, que aparece para os usuários durante os prompts de autorização.

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

Se você estiver usando o Google Cloud Logging ou o Error Reporting no projeto de script, poderá visualizar esses registros e relatórios no Console do Google Cloud da seguinte maneira:

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

Ao usar serviços que exigem OAuth, o Google solicita que os usuários os autorizem. Com as configurações da tela de consentimento do OAuth, você pode 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. Nos projetos padrão do Cloud, é possível 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 que seu script usa. Para alguns aplicativos, você precisa criar outras credenciais do OAuth (IDs e chaves secretas dos clientes). 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.

Para adicionar outros proprietários ou outros papéis a um projeto padrão, faça o seguinte. Você precisa ter permissões de edição no projeto para fazer qualquer uma dessas alterações:

  1. Determine quem são seus colaboradores. Recomendamos que você crie ou use um Grupo do Google existente. Também é possível 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. Você pode adicionar e-mails, Grupos do Google ou domínios individualmente como novos membros.
  6. Clique em Salvar.

Agrupar vários scripts em 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, em seguida, troque em cada projeto de script para usá-lo. Não é possível fazer isso com projetos padrão.

Usar um projeto do Cloud padrão diferente

É possível alternar um projeto de script para que ele use um projeto padrão do Cloud diferente. Se o script exigir a configuração manual do projeto do Cloud, mude de um projeto padrão para um projeto padrão. Para saber mais sobre quando você precisa usar um projeto padrão, consulte 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 no script, precisará ativar as APIs correspondentes no novo projeto do Cloud. Você perderá todos os dados vinculados aos serviços avançados no projeto anterior do Cloud. Para saber como ativar as APIs no projeto do Cloud, consulte Ativar as APIs do Google Workspace.
  • Se o script usar o serviço integrado do Google Drive, ative a API Drive em 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 precisam fazer uma nova autorização. Na maioria dos casos, todos os usuários que autorizaram apps associados ao novo projeto também precisam fazer uma nova autorização.
  • 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 seus usuários precisam reinstalar o app. Para mais informações sobre como criar uma nova página "Detalhes do app", consulte Publicar um app.
  • Não é possível retornar um script 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 alternar um projeto do Cloud de um script para outro, 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 de projeto fácil de lembrar para localizá-lo na página Gerenciar recursos do console do Google Cloud. O Apps Script usa esse nome ao pedir que os usuários autorizem o script.
  2. Para usar um projeto atual, 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 do 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 novo número do projeto e clique em Definir projeto.

Projetos na nuvem 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 valiosos ao desenvolver scripts, complementos e apps da Web com uma equipe, mas eles impõem algumas restrições sobre o que é possível fazer com projetos do Cloud padrão mais antigos.

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á restrições adicionais 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 exijam 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 mudança. 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 no Apps Script

Se você tiver a permissão resourcemanager.projects.list para a pasta de projetos do Apps Script da sua organização, poderá visualizar todos os projetos padrão e padrão do Cloud com o 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 no Apps Script, selecione o projeto que você quer excluir e clique em Excluir.

Para excluir um projeto do Apps Script com gcloud, use os seguintes comandos.

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.