Solicitar um certificado usando a Public CA e um cliente ACME
Este tutorial orienta você na solicitação de um certificado TLS com a Public Certificate Authority usando a Google Cloud CLI. Para informações sobre as ACs raiz e intermediárias usadas pela Public Certificate Authority, consulte Google Trust Services. Não há custo para solicitar certificados da Public CA.
Antes de começar
Instale a Google Cloud CLI. Após a instalação, inicialize a Google Cloud CLI executando o seguinte comando:
gcloud initCrie ou selecione um Google Cloud projeto.
Papéis necessários para selecionar ou criar um projeto
- Selecionar um projeto: a seleção de um projeto não exige um papel específico do IAM. Você pode selecionar qualquer projeto em que tenha recebido um papel.
-
Criar um projeto: para criar um projeto, você precisa do papel de criador de projetos
(
roles/resourcemanager.projectCreator), que contém aresourcemanager.projects.createpermissão. Saiba como conceder papéis.
-
Crie um Google Cloud projeto do:
gcloud projects create PROJECT_ID
Substitua
PROJECT_IDpor um nome para o Google Cloud projeto do que você está criando. -
Selecione o Google Cloud projeto do que você criou:
gcloud config set project PROJECT_ID
Substitua
PROJECT_IDpelo nome do Google Cloud projeto do.
Verifique se você tem o papel do IAM de criador de chaves de contas externas da Public CA (
roles/publicca.externalAccountKeyCreator).Para conceder esse papel, execute o seguinte comando:
gcloud projects add-iam-policy-binding PROJECT_ID \ --member=user:USER \ --role=roles/publicca.externalAccountKeyCreator
Substitua:
PROJECT_ID: ID do projeto do Google CloudUSER: o identificador exclusivo do usuário a quem você quer atribuir o papel do IAM
Para informações sobre como conceder um papel do IAM, consulte Gerenciar o acesso a projetos, pastas e organizações.
Ative a API do Public CA:
Funções necessárias para ativar APIs
Para ativar as APIs, é necessário ter o papel do IAM de administrador de Service Usage role (
roles/serviceusage.serviceUsageAdmin), que contém aserviceusage.services.enablepermissão. Saiba como conceder papéis.gcloud services enable publicca.googleapis.com
Instalar um cliente
Para começar a usar a Public CA, instale um cliente ACME. As instruções a seguir usam Certbot como cliente ACME. Você pode usar qualquer outro cliente ACME se ele oferecer suporte à vinculação de contas externas (EAB).
Para instalar o Certbot, consulte as instruções do Certbot.
Direcione o cliente para o servidor da Public CA. Na primeira vez que o cliente ACME interage com a Public CA, ele gera um novo par de chaves e envia a chave pública para a Public CA.
Solicitar um ID de chave EAB e HMAC
Depois de instalar um cliente ACME, registre sua conta ACME com a Public CA para solicitar certificados da Public CA. Um segredo EAB pode ajudar você a registrar sua conta ACME com a Public CA. Um segredo EAB consiste em um ID de chave e um código de autenticação de mensagem baseado em hash (HMAC, na sigla em inglês).
Você pode usar a Public CA API ou a Google Cloud CLI para solicitar um segredo EAB.
Para solicitar um ID de chave EAB e HMAC, execute o seguinte comando:
gcloud publicca external-account-keys create
Esse comando retorna um segredo EAB válido no ambiente de produção da Public CA. No corpo da resposta, o campo keyId contém o ID da chave EAB e o campo b64MacKey contém o HMAC EAB.
Você precisa usar um segredo EAB em até sete dias após recebê-lo. O segredo EAB será invalidado se você não o usar em até sete dias. A conta ACME registrada usando um segredo EAB não tem validade.
Registrar uma conta ACME
Esta seção explica como registrar uma conta ACME com a Public CA fornecendo o segredo EAB que você acabou de receber.
Use um cliente ACME normal para registrar uma conta ACME e forneça o ID da chave EAB e o HMAC durante o registro.
Para registrar uma conta ACME com a Public CA e vincular a conta ACME ao Google Cloud projeto do que você usou para solicitar o segredo EAB, execute o seguinte comando:
certbot register \
--email "EMAIL_ADDRESS" \
--no-eff-email \
--server "SERVER" \
--eab-kid "EAB_KID" \
--eab-hmac-key "EAB_HMAC_KEY"
Substitua:
EMAIL_ADDRESS: seu endereço de e-mailSERVER: o URL do diretório ACME para o ambiente de produção ou preparoEAB_KID: o ID da chave EABEAB_HMAC_KEY: a chave HMAC EAB
A tabela a seguir fornece a descrição e o URL do diretório ACME para o ambiente de produção e preparo:
| Ambiente | Descrição | URL do diretório ACME |
|---|---|---|
| Produção | O ambiente de produção permite que você receba certificados confiáveis publicamente. | https://dv.acme-v02.api.pki.goog/directory |
| Preparo | O ambiente de preparo retorna certificados que não são confiáveis publicamente. O ambiente de preparo realiza as mesmas verificações de validação que o ambiente de produção Você pode usar o ambiente de preparo para integração ou qualquer outro tipo de teste. | https://dv.acme-v02.test-api.pki.goog/directory |
Só é possível registrar uma conta ACME com um segredo EAB. Depois de registrar uma conta ACME usando um segredo EAB, o segredo EAB se torna inválido e não pode ser reutilizado. Se você quiser registrar várias contas ACME, solicite um segredo EAB exclusivo para cada uma delas.
Solicitar certificados
Depois que a Public CA validar seu controle do destino do certificado e reconhecer que o cliente ACME funciona conforme o esperado para realizar operações de gerenciamento de certificados, você poderá usar os fluxos de trabalho ACME normais para solicitar, renovar e revogar certificados. Você pode realizar essas operações usando o cliente ACME. Para solicitar e renovar um certificado, é necessário concluir um desafio ACME, como o desafio de DNS manual.
Para usar o desafio de DNS manual para solicitar um certificado, execute o seguinte comando:
certbot certonly \
--manual \
--preferred-challenges "dns-01" \
--server "SERVER" \
--domains "DOMAINS"
Substitua:
SERVER: o URL do diretório ACME para o ambiente de produção ou preparoDOMAINS: uma lista separada por vírgulas de domínios para os quais você está solicitando certificados
Limpar
Google CloudSe você não precisar mais de certificados para seus domínios, exclua o projeto do que você criou.
Preparo
Você pode usar o ambiente de preparo da Public CA para solicitar certificados para fins de teste. Os certificados emitidos pela cadeia de ambiente de preparo até uma AC raiz de teste. Os certificados do ambiente de preparo não serão confiáveis para navegadores ou outros clientes que não foram configurados para confiar no certificado raiz de preparo. Para receber um Secret EAB válido no ambiente de preparo, substitua o endpoint de API para usar o endpoint do ambiente de preparo:
gcloud config set api_endpoint_overrides/publicca https://preprod-publicca.googleapis.com/
gcloud publicca external-account-keys create
gcloud config unset api_endpoint_overrides/publicca
Excluir um Google Cloud projeto do:
gcloud projects delete PROJECT_ID