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 pelo Apps Script automaticamente ou um projeto padrão criado por você. Em geral, projetos padrão são bons para scripts cotidianos ou simples, mas use um projeto padrão para qualquer aplicativo complexo, com qualidade comercial ou que você pretenda publicar.

É possível alternar 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. Fazer isso 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, não é necessário conferir 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 de script.
  • Em alguns scripts, você precisa 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 gerenciamento de identidade e acesso (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.

Conferir ou atualizar projetos padrão do Cloud

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

Se você criou o 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. Consulte Excluir projetos do Cloud no 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 usar 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 não for executado por 180 dias ou mais, o Apps Script excluirá o projeto padrão associado. Se o script for executado depois que o projeto padrão for excluído pelo Apps Script, o Apps Script criará um para ele.

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 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 alterna 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 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 isso, 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 Project Settings .
  3. Em Projeto do Google Cloud Platform (GCP), clique no número dele.

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 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 depois 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 você também precise 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 é composto apenas por dígitos, enquanto o ID do projeto é alfanumérico. É possível editar o Nome do projeto, que é exibido aos usuários durante os prompts 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, é 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 Geração de registros > Explorador 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 relatório de erros, isso significa que seu projeto de script ainda não registrou exceções.

Quando você usa 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 no 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, é preciso 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.

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

  1. Determine quem devem ser 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 nesse 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 mudar 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 padrão. Para saber mais sobre quando é preciso 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 para o script, ative 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, ative 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 precisam fazer uma nova autorização. Na maioria dos casos, todos os usuários que já 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 os usuários precisarão reinstalar o app. Para saber mais 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 o 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 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 solicitar que os usuários autorizem o script.
  2. Se você quiser usar um projeto atual, abra a página Gerenciar recursos do console do Google Cloud e encontre um projeto para usar. É necessário ter os papéis de navegador do projeto e de 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 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 valiosos ao desenvolver scripts, complementos e apps da Web com uma equipe, mas colocam algumas restrições sobre o que você pode 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á restrições adicionais quando o projeto de script estiver em um drive compartilhado.
  • Se o projeto de script usar 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. Você ainda poderá acessar o projeto padrão se tinha acesso antes da mudança. Por exemplo, se você criou um script na sua pasta "Meu Drive" e o moveu para um drive compartilhado, ainda poderá acessar o projeto do Cloud referente a ele. 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 dos projetos do Cloud no Apps Script

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

  1. Abra a página Gerenciar recursos do console do Google Cloud.
  2. Ao lado da pasta Apps Script, copie o ID.
  3. Clique em Filtro > ID pai e cole o código 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 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.