活动:刷新任务活动添加兑换点数接口

This commit is contained in:
qiaoxin
2021-06-21 15:18:06 +08:00
parent 3c68d50d46
commit 482760086f
4 changed files with 117 additions and 3 deletions

View File

@@ -6,6 +6,7 @@ import { RefreshTaskItem } from '../../../domain/activityField/refreshTaskField'
import { addReward, stringToRewardParam } from '../../../services/giftPackageService';
import { RewardParam } from '../../../domain/activityField/rewardField';
import { ActivityRefreshTaskModel } from '../../../db/ActivityRefreshTask';
import { ActivityRefreshTaskPointModel } from '../../../db/ActivityRefreshTaskPoint';
export default function (app: Application) {
@@ -78,4 +79,40 @@ export class RefreshTaskHandler {
}));
}
/**
* @description 兑换点数
* @param {{ activityId: number, roundIndex: number}} msg
* @param {BackendSession} session
* @memberof RefreshTaskHandler
*/
async exchangePoint(msg: { activityId: number, roundIndex: number }, session: BackendSession) {
const { activityId, roundIndex } = msg;
const roleId = session.get('roleId');
const serverId = session.get('serverId');
const sid = session.get('sid');
const roleName = session.get('roleName');
const funcs = session.get('funcs');
let playerData = await getPlayerRefreshTaskData(activityId, serverId, roleId)
if (!playerData) return resResult(STATUS.ACTIVITY_MISSING);
if (playerData.roundIndex != roundIndex) {
return resResult(STATUS.ACTIVITY_EXPIRE);
}
if ((playerData.totalPoint - playerData.exchangePoint) < playerData.consumePoint) {//点数不够
return resResult(STATUS.ACTIVITY_NO_POINT);
}
await ActivityRefreshTaskPointModel.addReceiveRecord(serverId, activityId, roleId, playerData.consumePoint);
let rewardParamArr: Array<RewardParam> = stringToRewardParam(playerData.reward);
let result = await addReward(roleId, roleName, sid, serverId, funcs, rewardParamArr)
playerData.exchangePoint += playerData.consumePoint;
return resResult(STATUS.SUCCESS, Object.assign(result, {
param: { activityId, roundIndex },
item: { exchangePoint: playerData.exchangePoint },
}));
}
}