mirror of
				https://github.com/TeaOSLab/EdgeAPI.git
				synced 2025-11-04 16:00:24 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			74 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			74 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
package tasks
 | 
						|
 | 
						|
import (
 | 
						|
	"github.com/TeaOSLab/EdgeAPI/internal/db/models"
 | 
						|
	"github.com/iwind/TeaGo/dbs"
 | 
						|
	"github.com/iwind/TeaGo/logs"
 | 
						|
	"time"
 | 
						|
)
 | 
						|
 | 
						|
func init() {
 | 
						|
	dbs.OnReady(func() {
 | 
						|
		looper := NewEventLooper()
 | 
						|
		go looper.Start()
 | 
						|
	})
 | 
						|
}
 | 
						|
 | 
						|
// 事件相关处理程序
 | 
						|
type EventLooper struct {
 | 
						|
}
 | 
						|
 | 
						|
func NewEventLooper() *EventLooper {
 | 
						|
	return &EventLooper{}
 | 
						|
}
 | 
						|
 | 
						|
func (this *EventLooper) Start() {
 | 
						|
	ticker := time.NewTicker(2 * time.Second)
 | 
						|
	for range ticker.C {
 | 
						|
		err := this.loop()
 | 
						|
		if err != nil {
 | 
						|
			logs.Println("[EVENT_LOOPER]" + err.Error())
 | 
						|
		}
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
func (this *EventLooper) loop() error {
 | 
						|
	lockerKey := "eventLooper"
 | 
						|
	isOk, err := models.SharedSysLockerDAO.Lock(nil, lockerKey, 3600)
 | 
						|
	if err != nil {
 | 
						|
		return err
 | 
						|
	}
 | 
						|
	defer func() {
 | 
						|
		err = models.SharedSysLockerDAO.Unlock(nil, lockerKey)
 | 
						|
		if err != nil {
 | 
						|
			logs.Println("[EVENT_LOOPER]" + err.Error())
 | 
						|
		}
 | 
						|
	}()
 | 
						|
	if !isOk {
 | 
						|
		return nil
 | 
						|
	}
 | 
						|
 | 
						|
	events, err := models.SharedSysEventDAO.FindEvents(nil, 100)
 | 
						|
	if err != nil {
 | 
						|
		return err
 | 
						|
	}
 | 
						|
	for _, eventOne := range events {
 | 
						|
		event, err := eventOne.DecodeEvent()
 | 
						|
		if err != nil {
 | 
						|
			logs.Println("[EVENT_LOOPER]" + err.Error())
 | 
						|
			continue
 | 
						|
		}
 | 
						|
		err = event.Run()
 | 
						|
		if err != nil {
 | 
						|
			logs.Println("[EVENT_LOOPER]" + err.Error())
 | 
						|
			continue
 | 
						|
		}
 | 
						|
		err = models.SharedSysEventDAO.DeleteEvent(nil, int64(eventOne.Id))
 | 
						|
		if err != nil {
 | 
						|
			return err
 | 
						|
		}
 | 
						|
	}
 | 
						|
 | 
						|
	return nil
 | 
						|
}
 |