活动:vip签到判断购买条件
This commit is contained in:
@@ -1,11 +1,12 @@
|
||||
import { Application, BackendSession } from 'pinus';
|
||||
import { resResult } from '../../../pubUtils/util';
|
||||
import { STATUS, ACTIVITY_RESOURCES_TYPE, ACTIVITY_TYPE } from '../../../consts';
|
||||
import { getPlayerSignInData, signInActivity } from '../../../services/signInService';
|
||||
import { STATUS, SIGNIN_VIP_OPEN_LIMIT, ACTIVITY_TYPE, SERVER_OPEN_TIME } from '../../../consts';
|
||||
import { canBuyVip, getPlayerSignInData, signInActivity } from '../../../services/signInService';
|
||||
import { addItems, createHeroes, handleCost } from '../../../services/rewardService';
|
||||
import { SignInItem } from '../../../domain/activityField/signInField';
|
||||
import { ActivitySignInModel } from '../../../db/ActivitySignIn';
|
||||
import moment = require('moment');
|
||||
import { RoleModel } from '../../../db/Role';
|
||||
|
||||
|
||||
export default function (app: Application) {
|
||||
@@ -21,10 +22,11 @@ export class SignInHandler {
|
||||
/**
|
||||
* @description 获取普通签到活动数据
|
||||
* @param {BackendSession} session
|
||||
* @param {{ activityId: number}} msg
|
||||
* @memberof SignInHandler
|
||||
*/
|
||||
async getSignInActivity(msg: {}, session: BackendSession) {
|
||||
const { } = msg;
|
||||
async getSignInActivity(msg: { activityId: number }, session: BackendSession) {
|
||||
const { activityId } = msg;
|
||||
const roleId = session.get('roleId');
|
||||
const serverId = session.get('serverId');
|
||||
|
||||
@@ -33,12 +35,12 @@ export class SignInHandler {
|
||||
return resResult(STATUS.ACTIVITY_CLOSED);
|
||||
}
|
||||
|
||||
let activityData = await signInActivity(ACTIVITY_TYPE.SIGN_IN, serverId, roleId);
|
||||
if (!activityData) {//未配置活动数据
|
||||
return resResult(STATUS.ACTIVITY_MISSING);
|
||||
}
|
||||
// let activityData = await signInActivity(ACTIVITY_TYPE.SIGN_IN, serverId, roleId);
|
||||
// if (!activityData) {//未配置活动数据
|
||||
// return resResult(STATUS.ACTIVITY_MISSING);
|
||||
// }
|
||||
|
||||
let activityId = activityData.activityId;//活动ID
|
||||
// let activityId = activityData.activityId;//活动ID
|
||||
let playerData = await getPlayerSignInData(activityId, serverId, roleId)
|
||||
|
||||
if (!playerData) return resResult(STATUS.ACTIVITY_MISSING);
|
||||
@@ -48,7 +50,7 @@ export class SignInHandler {
|
||||
|
||||
/**
|
||||
* @description 签到获得奖励
|
||||
* @param {{ activityId: number, dayIndex: number}} msg
|
||||
* @param {{ activityId: number, dayIndex: number}} msg
|
||||
* @param {BackendSession} session
|
||||
* @memberof SignInHandler
|
||||
*/
|
||||
@@ -64,9 +66,14 @@ export class SignInHandler {
|
||||
if (todayIndex < 5 || todayIndex > 24) {//未开启
|
||||
return resResult(STATUS.ACTIVITY_CLOSED);
|
||||
}
|
||||
if (todayIndex < dayIndex) {
|
||||
if (dayIndex > todayIndex) {
|
||||
return resResult(STATUS.ACTIVITY_DAY_INDEX_OVER);
|
||||
}
|
||||
let openTime = SERVER_OPEN_TIME;
|
||||
//开服第一个月可以签到之前未领取的奖励,下个月只能签到当天奖励
|
||||
if (moment(openTime).diff(moment(), 'months') != 1 && (dayIndex != todayIndex)) {
|
||||
return resResult(STATUS.ACTIVITY_SIGNIN_EXPIRE);
|
||||
}
|
||||
|
||||
let activityData = await signInActivity(ACTIVITY_TYPE.SIGN_IN, serverId, roleId);
|
||||
if (!activityData) {//未配置活动数据
|
||||
@@ -76,9 +83,25 @@ export class SignInHandler {
|
||||
return resResult(STATUS.ACTIVITY_EXPIRE);
|
||||
}
|
||||
|
||||
|
||||
|
||||
let playerData = await getPlayerSignInData(activityId, serverId, roleId)
|
||||
if (!playerData) return resResult(STATUS.ACTIVITY_MISSING);
|
||||
|
||||
let roundIndex = playerData.roundIndex;
|
||||
|
||||
//高级签到开启条件
|
||||
let { lv } = await RoleModel.findByRoleId(roleId);
|
||||
if (playerData.type == ACTIVITY_TYPE.SIGN_IN_VIP) {
|
||||
if (!canBuyVip(lv))
|
||||
return resResult(STATUS.ACTIVITY_SIGNIN_VIP_CONDITION);
|
||||
|
||||
if (!await ActivitySignInModel.isBuyVip(activityId, roleId, roundIndex)) {
|
||||
return resResult(STATUS.ACTIVITY_SIGNIN_VIP_CONDITION);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
let signinItemData: SignInItem = playerData.findDayItem(dayIndex);
|
||||
if (!signinItemData) {
|
||||
return resResult(STATUS.ACTIVITY_DATA_ERROR);
|
||||
@@ -87,7 +110,7 @@ export class SignInHandler {
|
||||
return resResult(STATUS.ACTIVITY_REWARDED);
|
||||
}
|
||||
|
||||
await ActivitySignInModel.addSignInRecord(activityId, roleId, dayIndex);
|
||||
await ActivitySignInModel.addSignInRecord(activityId, roleId, roundIndex, dayIndex);
|
||||
let reward = signinItemData.goodReward();
|
||||
let goods = await addItems(roleId, roleName, sid, reward);
|
||||
let heroReward = signinItemData.heroReward();
|
||||
|
||||
Reference in New Issue
Block a user