增加软质押手动结算测试接口
This commit is contained in:
@@ -48,7 +48,7 @@ func (l *GetNftListLogic) GetNftList(req *types.GetNftListReq) (*types.UserNftLi
|
||||
var hasStake bool
|
||||
var stakeAt string
|
||||
var roleId uint64
|
||||
nft, err := l.svcCtx.StakeNftModel.FindOneByUidTokenId(l.ctx, uid, token)
|
||||
nft, err := l.svcCtx.StakeNftModel.FindOneByTokenId(l.ctx, token)
|
||||
if err == nil {
|
||||
hasStake = nft.State == 1
|
||||
if hasStake {
|
||||
|
||||
@@ -40,37 +40,52 @@ func (l *StakeNftLogic) StakeNft(req *types.StakeNftList) error {
|
||||
l.Errorw("find nft holder failed", logx.Field("err", err), logx.Field("uid", uid), logx.Field("tokenId", tokenId))
|
||||
return errs.New(errs.ErrDatabaseOperate, err)
|
||||
}
|
||||
l.svcCtx.WalletModel.FindUidByAddress(l.ctx, tkHolder.Address)
|
||||
err = l.svcCtx.StakeNftModel.StakeNft(l.ctx, uid, req.RoleId, tokenId)
|
||||
wUid, err := l.svcCtx.WalletModel.FindUidByAddress(l.ctx, tkHolder.Address)
|
||||
if err != nil {
|
||||
if !errors.Is(err, model.ErrNotFound) {
|
||||
l.Errorw("find wallet by address failed", logx.Field("err", err), logx.Field("uid", uid), logx.Field("address", tkHolder.Address))
|
||||
return errs.New(errs.ErrDatabaseOperate, err)
|
||||
}
|
||||
return errs.New(errs.ErrNftNotBelongToUser, "nft not belong to user")
|
||||
}
|
||||
if wUid != uid {
|
||||
l.Errorw("nft not belong to user", logx.Field("uid", uid), logx.Field("address", tkHolder.Address))
|
||||
return errs.New(errs.ErrNftNotBelongToUser, "nft not belong to user")
|
||||
}
|
||||
var sns []int8
|
||||
var propertyId string
|
||||
var tarotType int8
|
||||
if utils.IsBigTarot(tokenId) {
|
||||
sns = []int8{1, 2}
|
||||
propertyId = "402505"
|
||||
tarotType = 1
|
||||
} else {
|
||||
sns = []int8{1}
|
||||
propertyId = "402605"
|
||||
}
|
||||
err = l.svcCtx.StakeNftModel.StakeNft(l.ctx, uid, req.RoleId, tokenId, tarotType)
|
||||
if err != nil {
|
||||
l.Errorw("stake nft failed", logx.Field("err", err), logx.Field("uid", uid), logx.Field("tokenIds", req.TokenIds))
|
||||
return errs.New(errs.ErrDatabaseOperate, err)
|
||||
}
|
||||
|
||||
var sns []int8
|
||||
var propertyId string
|
||||
if utils.IsBigTarot(tokenId) {
|
||||
sns = []int8{1, 2}
|
||||
propertyId = "402505"
|
||||
} else {
|
||||
sns = []int8{1}
|
||||
propertyId = "402605"
|
||||
}
|
||||
for _, sn := range sns {
|
||||
_, err = l.svcCtx.StakePropertyModel.Insert(l.ctx, &model.NhNftStakeProperty{
|
||||
Uid: uid,
|
||||
RoleId: int64(req.RoleId),
|
||||
TokenId: cast.ToUint(tokenId),
|
||||
PropertyId: propertyId,
|
||||
Sn: sn,
|
||||
})
|
||||
if err != nil {
|
||||
errMySQL := new(mysql.MySQLError)
|
||||
if errors.As(err, &errMySQL) {
|
||||
switch errMySQL.Number {
|
||||
case 1062:
|
||||
default:
|
||||
l.Errorw("insert stake property failed", logx.Field("err", err), logx.Field("uid", uid), logx.Field("tokenId", tokenId), logx.Field("propertyId", propertyId))
|
||||
if req.RoleId > 0 {
|
||||
for _, sn := range sns {
|
||||
_, err = l.svcCtx.StakePropertyModel.Insert(l.ctx, &model.NhNftStakeProperty{
|
||||
Uid: uid,
|
||||
RoleId: int64(req.RoleId),
|
||||
TokenId: cast.ToUint(tokenId),
|
||||
PropertyId: propertyId,
|
||||
Sn: sn,
|
||||
})
|
||||
if err != nil {
|
||||
errMySQL := new(mysql.MySQLError)
|
||||
if errors.As(err, &errMySQL) {
|
||||
switch errMySQL.Number {
|
||||
case 1062:
|
||||
default:
|
||||
l.Errorw("insert stake property failed", logx.Field("err", err), logx.Field("uid", uid), logx.Field("tokenId", tokenId), logx.Field("propertyId", propertyId))
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user