mirror of
https://github.com/acepanel/panel.git
synced 2026-02-04 07:57:21 +08:00
61 lines
1.2 KiB
Go
61 lines
1.2 KiB
Go
package job
|
|
|
|
import (
|
|
"log/slog"
|
|
"time"
|
|
|
|
"gorm.io/gorm"
|
|
|
|
"github.com/tnb-labs/panel/internal/app"
|
|
"github.com/tnb-labs/panel/internal/biz"
|
|
pkgcert "github.com/tnb-labs/panel/pkg/cert"
|
|
)
|
|
|
|
// CertRenew 证书续签
|
|
type CertRenew struct {
|
|
db *gorm.DB
|
|
log *slog.Logger
|
|
certRepo biz.CertRepo
|
|
}
|
|
|
|
func NewCertRenew(db *gorm.DB, log *slog.Logger, cert biz.CertRepo) *CertRenew {
|
|
return &CertRenew{
|
|
db: db,
|
|
log: log,
|
|
certRepo: cert,
|
|
}
|
|
}
|
|
|
|
func (r *CertRenew) Run() {
|
|
if app.Status != app.StatusNormal {
|
|
return
|
|
}
|
|
|
|
var certs []biz.Cert
|
|
if err := r.db.Preload("Website").Preload("Account").Preload("DNS").Find(&certs).Error; err != nil {
|
|
r.log.Warn("[Cert Renew] failed to get certs", slog.Any("err", err))
|
|
return
|
|
}
|
|
|
|
for _, cert := range certs {
|
|
if cert.Type == "upload" || !cert.AutoRenew {
|
|
continue
|
|
}
|
|
|
|
decode, err := pkgcert.ParseCert(cert.Cert)
|
|
if err != nil {
|
|
continue
|
|
}
|
|
|
|
// 结束时间大于 7 天的证书不续签
|
|
if time.Until(decode.NotAfter) > 24*7*time.Hour {
|
|
continue
|
|
}
|
|
|
|
_, err = r.certRepo.Renew(cert.ID)
|
|
if err != nil {
|
|
r.log.Warn("[Cert Renew] failed to renew cert", slog.Any("err", err))
|
|
}
|
|
}
|
|
}
|