mirror of
https://github.com/mayswind/ezbookkeeping.git
synced 2026-05-15 23:47:33 +08:00
code refactor
This commit is contained in:
@@ -5,6 +5,7 @@ import (
|
||||
|
||||
"github.com/go-co-op/gocron/v2"
|
||||
|
||||
"github.com/mayswind/ezbookkeeping/pkg/core"
|
||||
"github.com/mayswind/ezbookkeeping/pkg/errs"
|
||||
"github.com/mayswind/ezbookkeeping/pkg/log"
|
||||
"github.com/mayswind/ezbookkeeping/pkg/settings"
|
||||
@@ -27,7 +28,7 @@ var (
|
||||
)
|
||||
|
||||
// InitializeCronJobSchedulerContainer initializes the cron job scheduler according to the config
|
||||
func InitializeCronJobSchedulerContainer(config *settings.Config, startScheduler bool) error {
|
||||
func InitializeCronJobSchedulerContainer(ctx core.Context, config *settings.Config, startScheduler bool) error {
|
||||
var err error
|
||||
|
||||
Container.scheduler, err = gocron.NewScheduler(
|
||||
@@ -39,7 +40,7 @@ func InitializeCronJobSchedulerContainer(config *settings.Config, startScheduler
|
||||
return err
|
||||
}
|
||||
|
||||
Container.registerAllJobs(config)
|
||||
Container.registerAllJobs(ctx, config)
|
||||
|
||||
if startScheduler {
|
||||
Container.scheduler.Start()
|
||||
@@ -75,13 +76,13 @@ func (c *CronJobSchedulerContainer) SyncRunJobNow(jobName string) error {
|
||||
return nil
|
||||
}
|
||||
|
||||
func (c *CronJobSchedulerContainer) registerAllJobs(config *settings.Config) {
|
||||
func (c *CronJobSchedulerContainer) registerAllJobs(ctx core.Context, config *settings.Config) {
|
||||
if config.EnableRemoveExpiredTokens {
|
||||
Container.registerIntervalJob(RemoveExpiredTokensJob)
|
||||
Container.registerIntervalJob(ctx, RemoveExpiredTokensJob)
|
||||
}
|
||||
}
|
||||
|
||||
func (c *CronJobSchedulerContainer) registerIntervalJob(job *CronJob) {
|
||||
func (c *CronJobSchedulerContainer) registerIntervalJob(ctx core.Context, job *CronJob) {
|
||||
gocronJob, err := c.scheduler.NewJob(
|
||||
job.Period.ToJobDefinition(),
|
||||
gocron.NewTask(job.doRun),
|
||||
@@ -93,9 +94,9 @@ func (c *CronJobSchedulerContainer) registerIntervalJob(job *CronJob) {
|
||||
c.allJobs = append(c.allJobs, job)
|
||||
c.allJobsMap[job.Name] = job
|
||||
c.allGocronJobsMap[job.Name] = gocronJob
|
||||
log.Infof("[cron_container.registerJob] job \"%s\" has been registered", job.Name)
|
||||
log.Debugf("[cron_container.registerJob] job \"%s\" gocron id is %s", job.Name, gocronJob.ID())
|
||||
log.Infof(ctx, "[cron_container.registerJob] job \"%s\" has been registered", job.Name)
|
||||
log.Debugf(ctx, "[cron_container.registerJob] job \"%s\" gocron id is %s", job.Name, gocronJob.ID())
|
||||
} else {
|
||||
log.Errorf("[cron_container.registerJob] job \"%s\" cannot be been registered, because %s", job.Name, err.Error())
|
||||
log.Errorf(ctx, "[cron_container.registerJob] job \"%s\" cannot be been registered, because %s", job.Name, err.Error())
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user