代码拉取完成,页面将自动刷新
package main
import (
"context"
"github.com/gogf/gf/v2/frame/g"
"github.com/gogf/gf/v2/os/gcron"
"os"
"wxproxy/mylego"
)
var myLego = &mylego.LegoData{}
func initSslAuto() {
if isSSlAuto {
err := myLego.InitLego(email)
if err != nil {
g.Log().Error(ctx, err)
}
myLego.CertPath = g.Cfg().MustGet(ctx, "app.ssl_cert_path", "data/https/server.crt").String()
myLego.KeyPath = g.Cfg().MustGet(ctx, "app.ssl_key_path", "data/https/server.key").String()
if !FileExists(myLego.CertPath) {
_ = os.MkdirAll("data/https", 0777)
err := NewSSLCert()
if err != nil {
return
}
}
_, _ = gcron.AddSingleton(ctx, ssl_cron, func(ctx context.Context) {
err := ReNewSSLCert()
if err != nil {
return
}
})
}
}
func NewSSLCert() error {
g.Log().Info(ctx, "开始获取SSL证书")
defer g.Log().Info(ctx, "SSL证书获取完成")
cs, err := myLego.GetCertsByAliDns(domain, aliDnsKey, aliDnsSec)
if err != nil {
g.Log().Info(ctx, "获取证书失败:"+err.Error())
g.Log().Error(ctx, err)
return err
}
err = myLego.SaveCerts(cs)
if err != nil {
g.Log().Info(ctx, "获取证书失败:"+err.Error())
g.Log().Error(ctx, err)
return err
}
return nil
}
func ReNewSSLCert() error {
//if 1 == 1 {
// return ReloadSSL()
//}
if !myLego.HasGetCerts {
if err := NewSSLCert(); err != nil {
return err
}
return ReloadSSL()
}
cs, err := myLego.ReNew(domain)
if err != nil {
g.Log().Error(ctx, err)
return err
}
err = myLego.SaveCerts(cs)
if err != nil {
g.Log().Error(ctx, err)
return err
}
return ReloadSSL()
}
func FileExists(file string) bool {
fileStat, err := os.Stat(file)
if os.IsNotExist(err) {
return false
}
return !fileStat.IsDir()
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。