Skip to content

nephosolutions/terraform-acme-certificate

Repository files navigation

ACME Certificate

The Automated Certificate Management Environment (ACME) is an evolving standard for the automation of a domain-validated certificate authority. Clients register themselves on an authority using a private key and contact information, and answer challenges for domains that they own by supplying response data issued by the authority via either HTTP or DNS.

Via this process, they prove that they own the domains in question, and can then request certificates for them via the CA. No part of this process requires user interaction, a traditional blocker in obtaining a domain validated certificate.

As the usage model of Terraform generally sees it as being run on a different server than a certificate would normally be placed on, the acme_certifiate resource only supports DNS challenges. This method authenticates certificate domains by requiring the requester to place a TXT record on the FQDNs in the certificate.

The ACME provider responds to DNS challenges automatically by utilizing one of the supported DNS challenge providers. Most providers take credentials as environment variables, but if you would rather use configuration for this purpose, you can by specifying config blocks within a dns_challenge block, along with the provider parameter.

Usage

Example using dnsimple.com as dns challenge provider:

provider "acme" {
  server_url = "https://acme-v02.api.letsencrypt.org/directory"
}

module "acme_certificate" {
  source  = "nephosolutions/certificate/acme"
  version = "3.0.1"

  dns_names     = [
    "www.example.com",
    "www2.example.com"
  ]

  email_address = "info@example.com"

  dns_challenge = {
    provider = "dnsimple"

    config = {
      DNSIMPLE_OAUTH_TOKEN = var.dnsimple_token
    }
  }
}
  • The DNSIMPLE_OAUTH_TOKEN could alternatively be set as runtime environment variable
  • The ACME provider's server_url can be set to https://acme-staging-v02.api.letsencrypt.org/directory for staging

Requirements

Name Version
terraform >= 0.12.26

Providers

No provider.

Modules

Name Source Version
acme_account ./modules/account
acme_certificate ./modules/certificate

Resources

No resources.

Inputs

Name Description Type Default Required
dns_challenge The [DNS challenge|https://www.terraform.io/docs/providers/acme/r/certificate.html#using-dns-challenges] to use in fulfilling the request.
object({
config = map(string)
provider = string
})
n/a yes
dns_names A list of DNS domain names to register the certificate for. The fist one is the cetificate's common name, the primary domain that the certificate will be recognized for. list(string) n/a yes
email_address The contact email address for the account. any n/a yes
min_days_remaining ration of a certificate before a renewal is attempted. A value of less than 0 means that the certificate will never be renewed. number 30 no
recursive_nameservers The recursive nameservers that will be used to check for propagation of the challenge record. Defaults to your system-configured DNS resolvers. list [] no

Outputs

Name Description
certificate_pem The certificate in PEM format.
fullchain_pem The certificate concatenated with the intermediate certificate of the issuer.
issuer_pem The intermediate certificate of the issuer.
private_key_pem The requested ACME certificate private key