nft质押任务逻辑
This commit is contained in:
90
internal/job/earn/cron.go
Normal file
90
internal/job/earn/cron.go
Normal file
@@ -0,0 +1,90 @@
|
||||
package earn
|
||||
|
||||
import (
|
||||
"context"
|
||||
ea "github.com/earn-alliance/earnalliance-go"
|
||||
"github.com/robfig/cron/v3"
|
||||
"github.com/spf13/cast"
|
||||
"github.com/zeromicro/go-zero/core/logx"
|
||||
"nova_task/internal/consts"
|
||||
"nova_task/internal/svc"
|
||||
)
|
||||
|
||||
// Cron 用户数据上报earn平台定时任务
|
||||
type Cron struct {
|
||||
ctx context.Context
|
||||
svcCtx *svc.ServiceContext
|
||||
}
|
||||
|
||||
func NewCron(ctx context.Context, svcCtx *svc.ServiceContext) cron.Job {
|
||||
e := &Cron{ctx: ctx, svcCtx: svcCtx}
|
||||
if e.svcCtx.Config.EarnCorn.RunOnStart {
|
||||
e.Run()
|
||||
}
|
||||
return e
|
||||
}
|
||||
|
||||
func (c *Cron) Spec() string {
|
||||
return c.svcCtx.Config.EarnCorn.Spec
|
||||
}
|
||||
|
||||
func (c *Cron) Run() {
|
||||
logx.Debugw("run earn cron task")
|
||||
conf, err := c.svcCtx.ConfigModel.FindOneByName(c.ctx, consts.EarnAllianceInviterId)
|
||||
if err != nil {
|
||||
logx.Errorw("find earn alliance inviter id failed", logx.Field("err", err))
|
||||
return
|
||||
}
|
||||
c.pushUserInfo(cast.ToUint(conf.Value))
|
||||
c.pushUserBind(cast.ToUint(conf.Value))
|
||||
}
|
||||
|
||||
func (c *Cron) pushUserInfo(shareId uint) {
|
||||
us, err := c.svcCtx.PromoteBindModel.FindRequirePushUser(c.ctx, shareId)
|
||||
if err != nil {
|
||||
logx.Errorw("find require push user failed", logx.Field("err", err), logx.Field("share_id", shareId))
|
||||
return
|
||||
}
|
||||
logx.Debugw("find require push user", logx.Field("count", len(us)))
|
||||
for _, u := range us {
|
||||
ui, err := c.svcCtx.UserModel.FindOne(c.ctx, u.InvitedUid)
|
||||
if err != nil {
|
||||
logx.Errorw("find user failed", logx.Field("err", err), logx.Field("uid", u.InvitedUid))
|
||||
continue
|
||||
}
|
||||
var twitterId string
|
||||
ut, err := c.svcCtx.TwitterModel.FindOne(c.ctx, u.InvitedUid)
|
||||
if err == nil {
|
||||
twitterId = ut.TwitterId
|
||||
}
|
||||
|
||||
err = c.svcCtx.PromoteBindModel.UpdatePushUser(c.ctx, u.Id)
|
||||
if err != nil {
|
||||
logx.Errorw("update push user failed", logx.Field("err", err), logx.Field("uid", u.InvitedUid), logx.Field("twitter_id", twitterId), logx.Field("email", ui.Email))
|
||||
} else {
|
||||
c.svcCtx.Earn.SetIdentifiers(cast.ToString(ui.Id), &ea.Identifiers{
|
||||
Email: ea.IdentifierFrom(ui.Email),
|
||||
TwitterId: ea.IdentifierFrom(twitterId),
|
||||
})
|
||||
logx.Infow("push user info success", logx.Field("uid", u.InvitedUid), logx.Field("twitter_id", twitterId), logx.Field("email", ui.Email))
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
func (c *Cron) pushUserBind(shareId uint) {
|
||||
us, err := c.svcCtx.TouristBindModel.FindRequirePushUser(c.ctx, shareId)
|
||||
if err != nil {
|
||||
logx.Errorw("find require push bind role user failed", logx.Field("err", err), logx.Field("share_id", shareId))
|
||||
return
|
||||
}
|
||||
logx.Debugw("find require push bind role user", logx.Field("count", len(us)))
|
||||
for _, u := range us {
|
||||
err = c.svcCtx.PromoteBindModel.UpdatePushRole(c.ctx, u.Id)
|
||||
if err != nil {
|
||||
logx.Errorw("update push user failed", logx.Field("err", err), logx.Field("uid", u.Uid))
|
||||
} else {
|
||||
c.svcCtx.Earn.Track(cast.ToString(u.Uid), "BIND_ROLE", nil, nil)
|
||||
logx.Infow("push user info success", logx.Field("uid", u.Uid))
|
||||
}
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user