mirror of
				https://github.com/TeaOSLab/EdgeNode.git
				synced 2025-11-04 16:00:25 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			95 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			95 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
// Copyright 2022 GoEdge goedge.cdn@gmail.com. All rights reserved.
 | 
						|
 | 
						|
package nodes
 | 
						|
 | 
						|
import (
 | 
						|
	"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"
 | 
						|
	"time"
 | 
						|
)
 | 
						|
 | 
						|
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()
 | 
						|
}
 |