Compare commits

...

2 Commits

Author SHA1 Message Date
55f4cbdd6b feat provider-article添加AutoMrigate 2024-08-30 13:29:39 +08:00
a6be6c7cba feat 优化cron 2024-08-30 13:27:28 +08:00
3 changed files with 23 additions and 7 deletions

View File

@ -6,18 +6,19 @@ import (
) )
type Cron struct { type Cron struct {
time time.Time time time.Time
ctx context.Context ctx context.Context
f func() cancel context.CancelFunc
f func()
} }
func NewCron(ctx context.Context) *Cron { func NewCron() *Cron {
now := time.Now() now := time.Now()
l, _ := time.LoadLocation("Asia/Shanghai") l, _ := time.LoadLocation("Asia/Shanghai")
return &Cron{ c := &Cron{
ctx: ctx,
time: time.Date(now.Year(), now.Month(), now.Day(), 01, 0, 0, 0, l), time: time.Date(now.Year(), now.Month(), now.Day(), 01, 0, 0, 0, l),
} }
return c
} }
func (c *Cron) SetFunc(f func()) *Cron { func (c *Cron) SetFunc(f func()) *Cron {
@ -38,7 +39,8 @@ func (c *Cron) SetTimeHHmm(HHmm string) *Cron {
return c return c
} }
func (c *Cron) Run() { func (c *Cron) Run(ctx context.Context) {
c.ctx, c.cancel = context.WithCancel(ctx)
for { for {
if time.Now().After(c.time) { if time.Now().After(c.time) {
c.time = c.time.Add(time.Hour * 24) c.time = c.time.Add(time.Hour * 24)
@ -53,3 +55,7 @@ func (c *Cron) Run() {
} }
} }
} }
func (c *Cron) Stop() {
c.cancel()
}

View File

@ -10,6 +10,7 @@ import (
type ProviderArticleApi interface { type ProviderArticleApi interface {
Get(query GetProviderArticleQuery) (article v2.ProviderArticle, err error) Get(query GetProviderArticleQuery) (article v2.ProviderArticle, err error)
Upsert(article v2.ProviderArticle) error Upsert(article v2.ProviderArticle) error
AutoMigrate() error
} }
type providerArticleApi struct { type providerArticleApi struct {
@ -58,3 +59,7 @@ func (p *providerArticleApi) Upsert(article v2.ProviderArticle) error {
DoUpdates: clause.AssignmentColumns([]string{"cost"}), DoUpdates: clause.AssignmentColumns([]string{"cost"}),
}).Create(&article).Error }).Create(&article).Error
} }
func (p *providerArticleApi) AutoMigrate() error {
return p.db.AutoMigrate(&v2.ProviderArticle{})
}

View File

@ -10,6 +10,7 @@ import (
type SellerArticleApi interface { type SellerArticleApi interface {
Get(query GetProviderArticleQuery) (article v2.ProviderArticle, err error) Get(query GetProviderArticleQuery) (article v2.ProviderArticle, err error)
Upsert(article v2.SellerArticle) error Upsert(article v2.SellerArticle) error
AutoMigrate() error
} }
type sellerArticleApi struct { type sellerArticleApi struct {
@ -54,3 +55,7 @@ func (p *sellerArticleApi) Upsert(article v2.SellerArticle) error {
DoUpdates: clause.AssignmentColumns([]string{"sell"}), DoUpdates: clause.AssignmentColumns([]string{"sell"}),
}).Create(&article).Error }).Create(&article).Error
} }
func (p *sellerArticleApi) AutoMigrate() error {
return p.db.AutoMigrate(&v2.SellerArticle{})
}