mirror of
https://github.com/wyx2685/V2bX.git
synced 2025-01-23 10:28:13 -05:00
111 lines
2.7 KiB
Go
111 lines
2.7 KiB
Go
package lego
|
|
|
|
import (
|
|
"fmt"
|
|
"github.com/Yuzuki616/V2bX/common/file"
|
|
"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"
|
|
"path"
|
|
"strings"
|
|
"time"
|
|
)
|
|
|
|
func (l *Lego) SetProvider() error {
|
|
switch l.config.CertMode {
|
|
case "http":
|
|
err := l.client.Challenge.SetHTTP01Provider(http01.NewProviderServer("", "5002"))
|
|
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 {
|
|
if !file.IsExist(path.Dir(l.config.CertFile)) {
|
|
err := os.MkdirAll(path.Dir(l.config.CertFile), 0755)
|
|
if err != nil {
|
|
return fmt.Errorf("create dir error: %s", err)
|
|
}
|
|
}
|
|
err := os.WriteFile(l.parseParmas(l.config.CertFile), certificates.Certificate, 0644)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
if !file.IsExist(path.Dir(l.config.KeyFile)) {
|
|
err := os.MkdirAll(path.Dir(l.config.CertFile), 0755)
|
|
if err != nil {
|
|
return fmt.Errorf("create dir error: %s", err)
|
|
}
|
|
}
|
|
err = os.WriteFile(l.parseParmas(l.config.KeyFile), certificates.PrivateKey, 0644)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
return nil
|
|
}
|