Configuração

Antes de adicionar o recurso "Fazer login com o Google", "One Tap" ou o login automático ao seu site, configure o OAuth e, opcionalmente, a política de segurança de conteúdo do site.

Encontrar seu ID do cliente da API do Google

Para ativar o recurso no seu site, primeiro configure o ID do cliente da API do Google. Para isso, siga estas etapas:

  1. Abra a página Credenciais do console de APIs do Google.
  2. Crie ou selecione um projeto das APIs do Google. Se você já tiver um projeto para o botão "Fazer login com o Google" ou o Google One Tap, use o projeto atual e o ID do cliente da Web. Ao criar aplicativos de produção, pode ser necessário usar vários projetos. Repita as etapas restantes desta seção para cada projeto que você gerencia.
  3. Clique em Criar credenciais > ID do cliente OAuth e, em Tipo de app, selecione Aplicativo da Web para criar um novo ID do cliente. Para usar um ID do cliente atual, selecione um do tipo Aplicativo da Web.
  4. Adicione o URI do site a Origens JavaScript autorizadas. O URI inclui apenas o esquema e o nome de host totalmente qualificado. Por exemplo, https://www.example.com.

  5. Como opção, as credenciais podem ser retornadas usando um redirecionamento para um endpoint que você hospeda, em vez de um callback do JavaScript. Nesse caso, adicione os URIs de redirecionamento aos URIs de redirecionamento autorizados. Os URIs de redirecionamento incluem o esquema, o nome de host totalmente qualificado e o caminho e precisam obedecer às regras de validação de URI de redirecionamento. Por exemplo, https://www.example.com/auth-receiver.

Tanto o recurso "Fazer login com o Google" quanto a autenticação com um toque incluem uma tela de consentimento que informa aos usuários o aplicativo que está solicitando acesso aos dados, o tipo de dados solicitados e os termos aplicáveis.

  1. Abra a página Tela de consentimento do OAuth na seção "APIs e serviços" do Google Developer Console.
  2. Se solicitado, selecione o projeto que você acabou de criar.
  3. Na página "Tela de consentimento do OAuth", preencha o formulário e clique no botão "Salvar".

    1. Nome do aplicativo:o nome do aplicativo que solicita o consentimento. O nome precisa refletir com precisão seu aplicativo e ser consistente com o nome que os usuários veem em outros lugares.

    2. Logotipo do aplicativo:essa imagem aparece na tela de consentimento para ajudar os usuários a reconhecerem seu app. O logotipo aparece na tela de consentimento do "Fazer login com o Google" e nas configurações da conta, mas não aparece na caixa de diálogo "Um toque".

    3. E-mail de suporte:mostrado na tela de consentimento para o suporte ao usuário e para os administradores do G Suite que avaliam o acesso ao seu aplicativo para os usuários. Esse endereço de e-mail é mostrado aos usuários na tela de consentimento do Fazer login com o Google quando o usuário clica no nome do aplicativo.

    4. Escopos para APIs do Google:os escopos permitem que seu aplicativo acesse os dados particulares do usuário. Para a autenticação, o escopo padrão (e-mail, perfil, openid) é suficiente. Não é necessário adicionar escopos sensíveis. Geralmente, é recomendável solicitar escopos de forma incremental, no momento em que o acesso é necessário, em vez de fazer isso com antecedência. Saiba mais

    5. Domínios autorizados: para proteger você e seus usuários, o Google só permite que os aplicativos que autenticam usando OAuth usem domínios autorizados. Os links dos seus aplicativos precisam estar hospedados em domínios autorizados. Saiba mais.

    6. Link da página inicial do aplicativo:exibido na tela de consentimento do recurso "Fazer login com o Google" e nas informações de exoneração de responsabilidade em conformidade com o GDPR em um toque, abaixo do botão "Continuar como". Precisa ser hospedado em um domínio autorizado.

    7. Link da Política de Privacidade do aplicativo:exibido na tela de consentimento do recurso "Fazer login com o Google" e nas informações de exoneração de responsabilidade em conformidade com o GDPR em um toque no botão "Continuar como". Precisa ser hospedado em um domínio autorizado.

    8. Link dos Termos de Serviço do aplicativo (opcional): mostrado na tela de consentimento "Fazer login com o Google" e informações de um toque sobre a exoneração de responsabilidade em conformidade com o GDPR no botão "Continuar como". Precisa estar hospedado em um domínio autorizado.

  4. Verifique o "Status de verificação". Se o aplicativo precisar de verificação, clique no botão "Enviar para verificação". Consulte os requisitos de verificação do OAuth para ver mais detalhes.

Exibição das configurações do OAuth durante o login

Um toque usando o FedCM

Configurações de consentimento OAuth exibidas pelo Chrome com um toque usando o FedCM

O Domínio autorizado de nível superior é exibido durante o consentimento do usuário no Chrome.

Um toque sem FedCM

Configurações de consentimento do OAuth mostradas pelo One Tap

O nome do aplicativo é exibido durante o consentimento do usuário.

Figura 1. Configurações de consentimento do OAuth exibidas pelo recurso Um toque no Chrome.

Política de Segurança de Conteúdo

Embora opcional, recomendamos uma Política de Segurança de Conteúdo para proteger seu app e evitar ataques de scripting em vários sites (XSS). Para saber mais, consulte uma Introdução à CSP e CSP e XSS.

Sua Política de Segurança de Conteúdo pode incluir uma ou mais diretivas, como connect-src, frame-src, script-src, style-src ou default-src.

Se o CSP incluir:

  • connect-src, adicione https://accounts.google.com/gsi/ para permitir que uma página carregue o URL pai de endpoints do lado do servidor dos Serviços de Identificação do Google.
  • Diretiva frame-src: adicione https://accounts.google.com/gsi/ para permitir o URL pai dos iframes do botão OneTap e do botão Fazer login com o Google.
  • Diretiva script-src, adicione https://accounts.google.com/gsi/client para permitir o URL da biblioteca JavaScript dos Serviços de Identificação do Google.
  • Diretiva style-src, adicione https://accounts.google.com/gsi/style para permitir o URL das folhas de estilo dos serviços de identidade do Google.
  • A diretiva default-src, se usada, é uma alternativa se alguma das diretivas anteriores (connect-src, frame-src, script-src ou style-src) não for especificada. Adicione https://accounts.google.com/gsi/ para permitir que uma página carregue o URL pai para endpoints do lado do servidor dos Serviços de identidade do Google.

Evite listar URLs GIS individuais ao usar connect-src. Isso ajuda a minimizar falhas quando o SIG é atualizado. Por exemplo, em vez de adicionar https://accounts.google.com/gsi/status, use o URL pai do SIG https://accounts.google.com/gsi/.

Este exemplo de cabeçalho de resposta permite que os Serviços de identidade do Google sejam carregados e executados com sucesso:

Content-Security-Policy-Report-Only: script-src
https://accounts.google.com/gsi/client; frame-src
https://accounts.google.com/gsi/; connect-src https://accounts.google.com/gsi/;

Política de abertura entre origens

O botão "Fazer login com o Google" e o Google One Tap podem exigir mudanças na Cross-Origin-Opener-Policy (COOP) para criar pop-ups.

Quando o FedCM está ativado, o navegador renderiza pop-ups diretamente, e nenhuma mudança é necessária.

No entanto, quando o FedCM estiver desativado, defina o cabeçalho COOP:

  • para same-origin e
  • inclui same-origin-allow-popups.

A falha na definição do cabeçalho adequado interrompe a comunicação entre as janelas, levando a uma janela pop-up em branco ou bugs semelhantes.