2024-02-15 16:08:29 +00:00
package acme
import (
"errors"
"fmt"
2024-11-27 21:55:18 +00:00
"strings"
2024-02-15 16:08:29 +00:00
"codeberg.org/codeberg/pages/config"
"codeberg.org/codeberg/pages/server/cache"
"codeberg.org/codeberg/pages/server/certificates"
)
var ErrAcmeMissConfig = errors . New ( "ACME client has wrong config" )
func CreateAcmeClient ( cfg config . ACMEConfig , enableHTTPServer bool , challengeCache cache . ICache ) ( * certificates . AcmeClient , error ) {
// check config
2024-11-27 21:55:18 +00:00
if ( ! cfg . AcceptTerms || ( cfg . DNSProvider == "" && ! cfg . NoDNS01 ) ) && ( cfg . APIEndpoint != "https://acme.mock.directory" || strings . HasPrefix ( cfg . APIEndpoint , "https://localhost" ) ) {
return nil , fmt . Errorf ( "%w: you must set $ACME_ACCEPT_TERMS and $DNS_PROVIDER or $NO_DNS_01, unless $ACME_API is set to https://acme.mock.directory or starts with https://localhost" , ErrAcmeMissConfig )
2024-02-15 16:08:29 +00:00
}
if cfg . EAB_HMAC != "" && cfg . EAB_KID == "" {
return nil , fmt . Errorf ( "%w: ACME_EAB_HMAC also needs ACME_EAB_KID to be set" , ErrAcmeMissConfig )
} else if cfg . EAB_HMAC == "" && cfg . EAB_KID != "" {
return nil , fmt . Errorf ( "%w: ACME_EAB_KID also needs ACME_EAB_HMAC to be set" , ErrAcmeMissConfig )
}
return certificates . NewAcmeClient ( cfg , enableHTTPServer , challengeCache )
}