Files
novatask/internal/logic/admin/send_email_reward_logic.go
2025-01-20 21:55:43 +08:00

63 lines
1.7 KiB
Go

package admin
import (
"context"
"github.com/zeromicro/go-zero/core/logx"
"github.com/zeromicro/go-zero/core/threading"
"nova_task/internal/consts"
"nova_task/internal/pkg/errs"
"nova_task/internal/svc"
)
type SendEmailRewardLogic struct {
logx.Logger
ctx context.Context
svcCtx *svc.ServiceContext
}
// 执行发放奖励操作
func NewSendEmailRewardLogic(ctx context.Context, svcCtx *svc.ServiceContext) *SendEmailRewardLogic {
return &SendEmailRewardLogic{
Logger: logx.WithContext(ctx),
ctx: ctx,
svcCtx: svcCtx,
}
}
func (l *SendEmailRewardLogic) SendEmailReward() error {
rewards, err := l.svcCtx.EmailRewardModel.AllRequireSend(l.ctx)
if err != nil {
l.Errorw("get email reward failed", logx.Field("err", err))
return errs.New(errs.ErrDatabaseOperate, err)
}
if len(rewards) <= 0 {
l.Infow("no email reward to send")
return errs.Success()
}
threading.GoSafe(func() {
ctx := context.Background()
for _, rw := range rewards {
u, err := l.svcCtx.UserModel.FindOneByEmail(ctx, rw.Email)
if err != nil {
l.Errorw("find user failed", logx.Field("err", err), logx.Field("email", rw.Email))
continue
}
err = l.svcCtx.EmailRewardModel.SetSent(ctx, rw.Id, u.Id)
if err != nil {
l.Errorw("set sent failed", logx.Field("err", err), logx.Field("id", rw.Id), logx.Field("uid", u.Id))
continue
}
err = l.svcCtx.AddUserAsset(ctx, u.Id, 0, consts.AssetType(rw.RewardType), "", rw.Value, rw.Remark, 0, 0, false)
if err != nil {
l.Errorw("insert task asset record failed", logx.Field("err", err), logx.Field("uid", u.Id), logx.Field("rewardType", rw.RewardType), logx.Field("value", rw.Value))
}
}
})
return errs.Success()
}