mirror of
https://github.com/TeaOSLab/EdgeNode.git
synced 2025-11-03 23:20:25 +08:00
96 lines
1.9 KiB
Go
96 lines
1.9 KiB
Go
// Copyright 2022 GoEdge goedge.cdn@gmail.com. All rights reserved.
|
|
|
|
package nodes
|
|
|
|
import (
|
|
"time"
|
|
|
|
"github.com/TeaOSLab/EdgeCommon/pkg/rpc/pb"
|
|
teaconst "github.com/TeaOSLab/EdgeNode/internal/const"
|
|
"github.com/TeaOSLab/EdgeNode/internal/events"
|
|
"github.com/TeaOSLab/EdgeNode/internal/remotelogs"
|
|
"github.com/TeaOSLab/EdgeNode/internal/rpc"
|
|
"github.com/TeaOSLab/EdgeNode/internal/utils/goman"
|
|
"github.com/iwind/TeaGo/Tea"
|
|
)
|
|
|
|
var sharedOCSPTask = NewOCSPUpdateTask()
|
|
|
|
func init() {
|
|
if !teaconst.IsMain {
|
|
return
|
|
}
|
|
|
|
events.On(events.EventLoaded, func() {
|
|
sharedOCSPTask.version = sharedNodeConfig.OCSPVersion
|
|
|
|
goman.New(func() {
|
|
sharedOCSPTask.Start()
|
|
})
|
|
})
|
|
events.OnClose(func() {
|
|
sharedOCSPTask.Stop()
|
|
})
|
|
}
|
|
|
|
// OCSPUpdateTask 更新OCSP任务
|
|
type OCSPUpdateTask struct {
|
|
version int64
|
|
|
|
ticker *time.Ticker
|
|
}
|
|
|
|
func NewOCSPUpdateTask() *OCSPUpdateTask {
|
|
var ticker = time.NewTicker(1 * time.Minute)
|
|
if Tea.IsTesting() {
|
|
ticker = time.NewTicker(10 * time.Second)
|
|
}
|
|
return &OCSPUpdateTask{
|
|
ticker: ticker,
|
|
}
|
|
}
|
|
|
|
func (this *OCSPUpdateTask) Start() {
|
|
for range this.ticker.C {
|
|
err := this.Loop()
|
|
if err != nil {
|
|
if rpc.IsConnError(err) {
|
|
remotelogs.Debug("OCSPUpdateTask", "update ocsp failed: "+err.Error())
|
|
} else {
|
|
remotelogs.Warn("OCSPUpdateTask", "update ocsp failed: "+err.Error())
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
func (this *OCSPUpdateTask) Loop() error {
|
|
rpcClient, err := rpc.SharedRPC()
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
resp, err := rpcClient.SSLCertRPC.ListUpdatedSSLCertOCSP(rpcClient.Context(), &pb.ListUpdatedSSLCertOCSPRequest{
|
|
Version: this.version,
|
|
Size: 100,
|
|
})
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
for _, ocsp := range resp.SslCertOCSP {
|
|
// 更新OCSP
|
|
if sharedNodeConfig != nil {
|
|
sharedNodeConfig.UpdateCertOCSP(ocsp.SslCertId, ocsp.Data, ocsp.ExpiresAt)
|
|
}
|
|
|
|
// 修改版本
|
|
this.version = ocsp.Version
|
|
}
|
|
|
|
return nil
|
|
}
|
|
|
|
func (this *OCSPUpdateTask) Stop() {
|
|
this.ticker.Stop()
|
|
}
|