v0.3.0
This release features the DNS-01 challenge with numerous solvers as well as EC support for certificates and account keys.
Added:
- CLI: The
--dnsswitch. To include the DNS challenge for consideration. When using this switch, all other solvers are disabled. Supported are the following solvers: cloudflare, digitalocean, dnsimple, dyn, gandi, googlecloud, namecheap, route53, rfc2136 and manual. - CLI: The
--accept-tosswitch. Indicates your acceptance of the Let's Encrypt terms of service without prompting you. - CLI: The
--webrootswitch. The HTTP-01 challenge may now be completed by dropping a file into a webroot. When using this switch, all other solvers are disabled. - CLI: The
--key-typeswitch. This replaces the--rsa-key-sizeswitch and supports the following key types: EC256, EC384, RSA2048, RSA4096 and RSA8192. - CLI: The
--dnshelpswitch. This displays a more in-depth help topic for DNS solvers. - CLI: The
--no-bundlesub switch for therunandrenewcommands. When this switch is set, the CLI will not bundle the issuer certificate with your certificate. - lib: A new type for challenge identifiers
Challenge - lib: A new interface for custom challenge providers
acme.ChallengeProvider - lib: A new interface for DNS-01 providers to allow for custom timeouts for the validation function
acme.ChallengeProviderTimeout - lib: SetChallengeProvider function. Pass a challenge identifier and a Provider to replace the default behaviour of a challenge.
- lib: The DNS-01 challenge has been implemented with modular solvers using the
ChallengeProviderinterface. Included solvers are: cloudflare, digitalocean, dnsimple, gandi, namecheap, route53, rfc2136 and manual. - lib: The
acme.KeyTypetype was added and is used for the configuration of crypto parameters for RSA and EC keys. Valid KeyTypes are: EC256, EC384, RSA2048, RSA4096 and RSA8192.
Changed
- lib: ExcludeChallenges now expects to be passed an array of
Challengetypes. - lib: HTTP-01 now supports custom solvers using the
ChallengeProviderinterface. - lib: TLS-SNI-01 now supports custom solvers using the
ChallengeProviderinterface. - lib: The
GetPrivateKeyfunction in theacme.Userinterface is now expected to return acrypto.PrivateKeyinstead of anrsa.PrivateKeyfor EC compat. - lib: The
acme.NewClientfunction now expects anacme.KeyTypeinstead of the keyBits parameter.
Removed
- CLI: The
rsa-key-sizeswitch was removed in favor ofkey-typeto support EC keys.
Fixed
- lib: Fixed a race condition in HTTP-01
- lib: Fixed an issue where status codes on ACME challenge responses could lead to no action being taken.
- lib: Fixed a regression when calling the Renew function with a SAN certificate.