fix:分享返利备注以及eventid
This commit is contained in:
@@ -2,13 +2,10 @@ package admin
|
||||
|
||||
import (
|
||||
"context"
|
||||
"github.com/zeromicro/go-zero/core/threading"
|
||||
"nova_task/internal/model"
|
||||
"nova_task/internal/pkg/errs"
|
||||
"strings"
|
||||
"time"
|
||||
|
||||
"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"
|
||||
)
|
||||
|
||||
@@ -54,29 +51,7 @@ func (l *SendEmailRewardLogic) SendEmailReward() error {
|
||||
continue
|
||||
}
|
||||
|
||||
// points,elite_points,castile,keys
|
||||
switch strings.ToLower(rw.RewardType) {
|
||||
case "points":
|
||||
err = l.svcCtx.TaskAssetModel.AddPoint(ctx, u.Id, rw.Value)
|
||||
case "elite_points":
|
||||
err = l.svcCtx.TaskAssetModel.AddElitePoints(ctx, u.Id, rw.Value)
|
||||
case "castile":
|
||||
err = l.svcCtx.TaskAssetModel.AddCastile(ctx, u.Id, rw.Value)
|
||||
case "keys":
|
||||
err = l.svcCtx.TaskAssetModel.AddKeys(ctx, u.Id, int(rw.Value.IntPart()))
|
||||
}
|
||||
if err != nil {
|
||||
l.Errorw("add asset failed", logx.Field("err", err), logx.Field("uid", u.Id), logx.Field("rewardType", rw.RewardType), logx.Field("value", rw.Value))
|
||||
} else {
|
||||
l.Infow("add asset success", logx.Field("uid", u.Id), logx.Field("rewardType", rw.RewardType), logx.Field("value", rw.Value))
|
||||
}
|
||||
_, err = l.svcCtx.TaskAssetRecordModel.Insert(ctx, &model.NhTaskAssetRecord{
|
||||
Uid: int(u.Id),
|
||||
AssetField: rw.RewardType,
|
||||
Count: rw.Value.InexactFloat64(),
|
||||
Remark: rw.Remark,
|
||||
CreateTime: int(time.Now().Unix()),
|
||||
})
|
||||
err = l.svcCtx.AddUserAsset(ctx, u.Id, 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))
|
||||
}
|
||||
|
||||
@@ -5,7 +5,8 @@ import (
|
||||
"github.com/shopspring/decimal"
|
||||
"github.com/spf13/cast"
|
||||
"github.com/zeromicro/go-zero/core/logx"
|
||||
"nova_task/internal/model"
|
||||
"github.com/zeromicro/go-zero/core/stores/sqlx"
|
||||
"nova_task/internal/consts"
|
||||
"nova_task/internal/pkg/utils"
|
||||
"nova_task/internal/svc"
|
||||
"time"
|
||||
@@ -106,30 +107,20 @@ func (l *StakeSettleLogic) StakeSettle() {
|
||||
gameBonus = taskConf.OccupyPercent
|
||||
reward = reward.Mul(decimal.NewFromFloat(float64(100+gameBonus) / 100))
|
||||
}
|
||||
err = l.svcCtx.StakeRewardModel.SetReward(l.ctx, uid, awardSeq, gameBonus, tokensDecimal, reward)
|
||||
if err != nil {
|
||||
logx.Errorw("set reward failed", logx.Field("err", err), logx.Field("uid", uid), logx.Field("awardSeq", awardSeq), logx.Field("coefficient", coefficient), logx.Field("tokens", tokens), logx.Field("reward", reward))
|
||||
continue
|
||||
}
|
||||
err = l.svcCtx.DBConn.TransactCtx(l.ctx, func(ctx context.Context, session sqlx.Session) error {
|
||||
err = l.svcCtx.StakeRewardModel.SetReward(l.ctx, uid, awardSeq, gameBonus, tokensDecimal, reward)
|
||||
if err != nil {
|
||||
//logx.Errorw("set reward failed", logx.Field("err", err), logx.Field("uid", uid), logx.Field("awardSeq", awardSeq), logx.Field("coefficient", coefficient), logx.Field("tokens", tokens), logx.Field("reward", reward))
|
||||
return err
|
||||
}
|
||||
|
||||
// 加资产
|
||||
err = l.svcCtx.TaskAssetModel.AddCastile(l.ctx, uid, reward)
|
||||
if err != nil {
|
||||
logx.Errorw("add castile failed", logx.Field("err", err), logx.Field("uid", uid), logx.Field("awardSeq", awardSeq), logx.Field("reward", reward))
|
||||
continue
|
||||
}
|
||||
// 加资产记录表
|
||||
_, err = l.svcCtx.TaskAssetRecordModel.Insert(l.ctx, &model.NhTaskAssetRecord{
|
||||
Uid: int(uid),
|
||||
EventId: 0,
|
||||
AssetField: "castile",
|
||||
Count: reward.InexactFloat64(),
|
||||
Remark: "nft软质押奖励",
|
||||
ProvideUid: 0,
|
||||
CreateTime: int(now.Unix()),
|
||||
// 加资产
|
||||
err = l.svcCtx.AddUserAssetWithSession(l.ctx, session, uid, consts.AssetType_Castile, reward, "nft软质押奖励", 0, 0, false)
|
||||
return err
|
||||
})
|
||||
|
||||
if err != nil {
|
||||
logx.Errorw("insert task asset record failed", logx.Field("err", err), logx.Field("uid", uid), logx.Field("awardSeq", awardSeq), logx.Field("reward", reward))
|
||||
logx.Errorw("质押结算发放奖励失败", logx.Field("err", err), logx.Field("uid", uid), logx.Field("awardSeq", awardSeq), logx.Field("coefficient", coefficient), logx.Field("tokens", tokens), logx.Field("reward", reward))
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -6,6 +6,7 @@ import (
|
||||
"github.com/shopspring/decimal"
|
||||
"github.com/spf13/cast"
|
||||
"github.com/zeromicro/go-zero/core/stores/sqlx"
|
||||
"nova_task/internal/consts"
|
||||
"nova_task/internal/model"
|
||||
"nova_task/internal/pkg/errs"
|
||||
"nova_task/internal/pkg/utils"
|
||||
@@ -70,19 +71,21 @@ func (l *GetTaskRewardLogic) GetTaskReward(req *types.TaskIdPath) (*types.GetTas
|
||||
return err
|
||||
}
|
||||
// 给予用户奖励
|
||||
err = l.svcCtx.TaskAssetModel.WithSession(session).AddPoint(l.ctx, uint(uid), decimal.NewFromInt(int64(task.Points)))
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
// 记录用户获奖记录
|
||||
_, err = l.svcCtx.TaskAssetRecordModel.Insert(l.ctx, &model.NhTaskAssetRecord{
|
||||
Uid: uid,
|
||||
EventId: uint64(task.Id),
|
||||
AssetField: "points",
|
||||
Count: float64(task.Points),
|
||||
Remark: "完成任务:" + task.Title,
|
||||
CreateTime: int(time.Now().Unix()),
|
||||
})
|
||||
err = l.svcCtx.AddUserAssetWithSession(l.ctx, session, uint(uid), consts.AssetType_Points, decimal.NewFromInt(int64(task.Points)), "完成任务:"+task.Title, uint64(task.Id), 0, true)
|
||||
//err = l.svcCtx.TaskAssetModel.WithSession(session).AddPoint(l.ctx, uint(uid), decimal.NewFromInt(int64(task.Points)))
|
||||
//if err != nil {
|
||||
// return err
|
||||
//}
|
||||
//// 记录用户获奖记录
|
||||
//_, err = l.svcCtx.TaskAssetRecordModel.Insert(l.ctx, &model.NhTaskAssetRecord{
|
||||
// Uid: uid,
|
||||
// EventId: uint64(task.Id),
|
||||
// AssetField: "points",
|
||||
// Count: float64(task.Points),
|
||||
// Remark: "完成任务:" + task.Title,
|
||||
// CreateTime: int(time.Now().Unix()),
|
||||
//})
|
||||
|
||||
return err
|
||||
})
|
||||
|
||||
|
||||
Reference in New Issue
Block a user