2023-01-12 01:27:06 -05:00
|
|
|
package lego
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"github.com/go-acme/lego/v4/certcrypto"
|
|
|
|
"github.com/go-acme/lego/v4/certificate"
|
|
|
|
"github.com/go-acme/lego/v4/challenge/http01"
|
|
|
|
"github.com/go-acme/lego/v4/providers/dns"
|
|
|
|
"os"
|
|
|
|
"strings"
|
|
|
|
"time"
|
|
|
|
)
|
|
|
|
|
|
|
|
func (l *Lego) SetProvider() error {
|
|
|
|
switch l.config.CertMode {
|
|
|
|
case "http":
|
2023-01-20 08:34:40 -05:00
|
|
|
err := l.client.Challenge.SetHTTP01Provider(http01.NewProviderServer("", "80"))
|
2023-01-12 01:27:06 -05:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
case "dns":
|
|
|
|
for k, v := range l.config.DNSEnv {
|
|
|
|
os.Setenv(k, v)
|
|
|
|
}
|
|
|
|
p, err := dns.NewDNSChallengeProviderByName(l.config.Provider)
|
|
|
|
if err != nil {
|
|
|
|
return fmt.Errorf("create dns challenge provider error: %s", err)
|
|
|
|
}
|
|
|
|
err = l.client.Challenge.SetDNS01Provider(p)
|
|
|
|
if err != nil {
|
|
|
|
return fmt.Errorf("set dns provider error: %s", err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (l *Lego) CreateCert() (err error) {
|
|
|
|
request := certificate.ObtainRequest{
|
|
|
|
Domains: []string{l.config.CertDomain},
|
|
|
|
}
|
|
|
|
certificates, err := l.client.Certificate.Obtain(request)
|
|
|
|
if err != nil {
|
|
|
|
return fmt.Errorf("obtain certificate error: %s", err)
|
|
|
|
}
|
|
|
|
err = l.writeCert(certificates)
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (l *Lego) RenewCert() error {
|
|
|
|
file, err := os.ReadFile(l.config.CertFile)
|
|
|
|
if err != nil {
|
|
|
|
return fmt.Errorf("read cert file error: %s", err)
|
|
|
|
}
|
|
|
|
if e, err := l.CheckCert(file); !e {
|
|
|
|
return nil
|
|
|
|
} else if err != nil {
|
|
|
|
return fmt.Errorf("check cert error: %s", err)
|
|
|
|
}
|
|
|
|
res, err := l.client.Certificate.Renew(certificate.Resource{
|
|
|
|
Domain: l.config.CertDomain,
|
|
|
|
Certificate: file,
|
|
|
|
}, false, false, "")
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
err = l.writeCert(res)
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (l *Lego) CheckCert(file []byte) (bool, error) {
|
|
|
|
cert, err := certcrypto.ParsePEMCertificate(file)
|
|
|
|
if err != nil {
|
|
|
|
return false, err
|
|
|
|
}
|
|
|
|
notAfter := int(time.Until(cert.NotAfter).Hours() / 24.0)
|
|
|
|
if notAfter > 30 {
|
|
|
|
return false, nil
|
|
|
|
}
|
|
|
|
return true, nil
|
|
|
|
}
|
|
|
|
func (l *Lego) parseParmas(path string) string {
|
|
|
|
r := strings.NewReplacer("{domain}", l.config.CertDomain,
|
|
|
|
"{email}", l.config.Email)
|
|
|
|
return r.Replace(path)
|
|
|
|
}
|
|
|
|
func (l *Lego) writeCert(certificates *certificate.Resource) error {
|
2023-01-12 01:30:37 -05:00
|
|
|
err := checkPath(l.config.CertFile)
|
|
|
|
if err != nil {
|
|
|
|
return fmt.Errorf("check path error: %s", err)
|
2023-01-12 01:27:06 -05:00
|
|
|
}
|
2023-01-12 01:30:37 -05:00
|
|
|
err = os.WriteFile(l.parseParmas(l.config.CertFile), certificates.Certificate, 0644)
|
2023-01-12 01:27:06 -05:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
2023-01-12 01:30:37 -05:00
|
|
|
err = checkPath(l.config.KeyFile)
|
|
|
|
if err != nil {
|
|
|
|
return fmt.Errorf("check path error: %s", err)
|
2023-01-12 01:27:06 -05:00
|
|
|
}
|
|
|
|
err = os.WriteFile(l.parseParmas(l.config.KeyFile), certificates.PrivateKey, 0644)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|