diff --git a/cmd/commandfuncs.go b/cmd/commandfuncs.go index e76d7f10b..80d00a371 100644 --- a/cmd/commandfuncs.go +++ b/cmd/commandfuncs.go @@ -189,6 +189,10 @@ func cmdRun(fl Flags) (int, error) { cleanModVersion := strings.TrimPrefix(goModule.Version, "v") certmagic.UserAgent = "Caddy/" + cleanModVersion + // by using Caddy, user indicates agreement to CA terms + // (very important, or ACME account creation will fail!) + certmagic.DefaultACME.Agreed = true + // run the initial config err = caddy.Load(config, true) if err != nil { diff --git a/modules/caddytls/acmeissuer.go b/modules/caddytls/acmeissuer.go index 53638fe55..0e43046f5 100644 --- a/modules/caddytls/acmeissuer.go +++ b/modules/caddytls/acmeissuer.go @@ -116,7 +116,6 @@ func (m *ACMEIssuer) makeIssuerTemplate() certmagic.ACMEManager { template := certmagic.ACMEManager{ CA: m.CA, Email: m.Email, - Agreed: true, CertObtainTimeout: time.Duration(m.ACMETimeout), TrustedRoots: m.rootPool, } diff --git a/modules/caddytls/automation.go b/modules/caddytls/automation.go index 9476445c3..73c12f935 100644 --- a/modules/caddytls/automation.go +++ b/modules/caddytls/automation.go @@ -154,7 +154,7 @@ func (ap *AutomationPolicy) Provision(tlsApp *TLS) error { } // if this automation policy has no Issuer defined, and - // none the subjects do not qualify for a public certificate, + // none of the subjects qualify for a public certificate, // set the issuer to internal so that these names can all // get certificates; critically, we can only do this if an // issuer is not explictly configured (IssuerRaw, vs. just @@ -198,7 +198,7 @@ func (ap *AutomationPolicy) Provision(tlsApp *TLS) error { KeySource: keySource, OnDemand: ond, Storage: storage, - Issuer: ap.Issuer, // if nil, certmagic.New() will set default in returned Config + Issuer: ap.Issuer, // if nil, certmagic.New() will create one } if rev, ok := ap.Issuer.(certmagic.Revoker); ok { template.Revoker = rev @@ -210,8 +210,8 @@ func (ap *AutomationPolicy) Provision(tlsApp *TLS) error { // access to the correct storage and cache so it can solve // ACME challenges -- it's an annoying, inelegant circular // dependency that I don't know how to resolve nicely!) - if configger, ok := ap.Issuer.(ConfigSetter); ok { - configger.SetConfig(ap.magic) + if annoying, ok := ap.Issuer.(ConfigSetter); ok { + annoying.SetConfig(ap.magic) } return nil