feat(活动): 绑定手机

This commit is contained in:
luying
2022-12-07 15:02:11 +08:00
parent f44c5d592a
commit bdbac4b085
11 changed files with 250 additions and 4 deletions

View File

@@ -29,6 +29,7 @@ export class ActivityHandler {
const roleId = session.get('roleId');
const serverId = session.get('serverId');
const guildCode = session.get('guildCode');
const uid: number = session.get('userid');
const sid: string = session.get('sid');
@@ -41,7 +42,7 @@ export class ActivityHandler {
for (let activityId of groupData.activities) {
let activityData = await getActivityById(activityId);
if (activityData) {
let playerActivityData = await getActivity(serverId, roleId, guildCode, activityId, activityData.type);
let playerActivityData = await getActivity(serverId, roleId, uid, guildCode, activityId, activityData.type);
if(playerActivityData) {
playerGroupActivityArray.push(playerActivityData);
}
@@ -64,6 +65,7 @@ export class ActivityHandler {
const roleId = session.get('roleId');
const serverId = session.get('serverId');
const guildCode = session.get('guildCode');
const uid = session.get('userid');
let orderInfo = await UserOrderModel.findOrder(localOrderID);
if (!orderInfo || orderInfo.roleId != roleId) {
@@ -74,7 +76,7 @@ export class ActivityHandler {
for(let activityData of activities) {
if (!activityData) continue;
let playerActivityData = await getActivity(serverId, roleId, guildCode, activityData.activityId, activityData.type);
let playerActivityData = await getActivity(serverId, roleId, uid, guildCode, activityData.activityId, activityData.type);
if(playerActivityData) {
result.push(playerActivityData);
}

View File

@@ -0,0 +1,80 @@
import { Application, BackendSession, HandlerService } from 'pinus';
import { resResult } from '../../../pubUtils/util';
import { BIND_PHONE_STATUS, ITEM_CHANGE_REASON, STATUS } from '../../../consts';
import { getPlayerDailyChallengesData } from '../../../services/activity/dailyChallengesService';
import { DailyItem } from '../../../domain/activityField/dailyChallengesField';
import { addReward, stringToRewardParam } from '../../../services/activity/giftPackageService';
import { RewardParam } from '../../../domain/activityField/rewardField';
import { ActivityDailyChallengesModel } from '../../../db/ActivityDailyChallenges';
import { getBindPhoneData } from '../../../services/activity/bindPhoneService';
import { ActivityBindPhoneRewardModel } from '../../../db/ActivityBindPhoneReward';
export default function (app: Application) {
new HandlerService(app, {});
return new BindPhoneHandler(app);
}
export class BindPhoneHandler {
constructor(private app: Application) {
}
/************************绑定手机****************************/
/**
* @description 绑定手机数据
* @param {{ activityId: number}} msg
* @param {BackendSession} session
* @memberof BindPhoneHandler
*/
async bind(msg: { activityId: number }, session: BackendSession) {
const { activityId } = msg;
const roleId = session.get('roleId');
const serverId = session.get('serverId');
const sid = session.get('sid');
const roleName = session.get('roleName');
const uid = session.get('userid');
let playerData = await getBindPhoneData(activityId, roleId, serverId, uid);
if(!playerData) return resResult(STATUS.ACTIVITY_ID_ERROR);
if(playerData.status != BIND_PHONE_STATUS.WAIT_BIND) return resResult(STATUS.ACTIVITY_HAS_BIND);
await ActivityBindPhoneRewardModel.addRecord(activityId, uid, BIND_PHONE_STATUS.HAS_BIND, { roleId, roleName, serverId });
return resResult(STATUS.SUCCESS, {
activityId,
status: BIND_PHONE_STATUS.HAS_BIND
});
}
/**
* @description 领取奖励
* @param {{ activityId: number}} msg
* @param {BackendSession} session
* @memberof BindPhoneHandler
*/
async receiveReward(msg: { activityId: number }, session: BackendSession) {
const { activityId } = msg;
const roleId = session.get('roleId');
const serverId = session.get('serverId');
const sid = session.get('sid');
const roleName = session.get('roleName');
const uid = session.get('userid');
let playerData = await getBindPhoneData(activityId, roleId, serverId, uid);
if(!playerData) return resResult(STATUS.ACTIVITY_ID_ERROR);
if(playerData.status == BIND_PHONE_STATUS.WAIT_BIND) return resResult(STATUS.ACTIVITY_BIND_ERR);
if(playerData.status == BIND_PHONE_STATUS.RECEIVED) return resResult(STATUS.ACTIVITY_BIND_RECEIVED);
await ActivityBindPhoneRewardModel.addRecord(activityId, uid, BIND_PHONE_STATUS.RECEIVED, { roleId, roleName, serverId });
let rewardArray = stringToRewardParam(playerData.rewards)
let { goods, addHeros } = await addReward(roleId, roleName, sid, serverId, rewardArray, ITEM_CHANGE_REASON.ACT_BIND_PHONE);
return resResult(STATUS.SUCCESS, {
activityId,
status: BIND_PHONE_STATUS.RECEIVED,
goods, addHeros
});
}
}

View File

@@ -40,6 +40,7 @@ import { getGuideGachaData } from './gachaService';
import { getPopNoticeData } from './popNoticeService';
import { _getActivities, _getActivitiesByServerId, _getActivitiesByType, _getActivityById } from './activityRemoteService';
import { getGroupShopDataShow } from './groupShopService';
import { getBindPhoneDataShow } from './bindPhoneService';
/**
* 获取活动数据
@@ -49,7 +50,7 @@ import { getGroupShopDataShow } from './groupShopService';
* @param {string} roleId 角色Id
*
*/
export async function getActivity(serverId: number, roleId: string, guildCode: string, activityId: number, activityType: number) {
export async function getActivity(serverId: number, roleId: string, uid: number, guildCode: string, activityId: number, activityType: number) {
try {
let activityData = null;
switch (activityType) {
@@ -226,6 +227,11 @@ export async function getActivity(serverId: number, roleId: string, guildCode: s
activityData = await getGroupShopDataShow(activityId, roleId);
break
}
case ACTIVITY_TYPE.BIND_PHONE:
{
activityData = await getBindPhoneDataShow(activityId, roleId, serverId, uid);
break
}
default: {
console.log('未知活动类型.........', activityType)
break;

View File

@@ -0,0 +1,55 @@
import { ACTIVITY_TYPE } from '../../consts';
import { ActivityModel, ActivityModelType } from '../../db/Activity';
import { ActivityBindPhoneRewardModel } from '../../db/ActivityBindPhoneReward';
import { ActivityDailyChallengesModel, ActivityDailyChallengesModelType } from '../../db/ActivityDailyChallenges';
import { RoleModel } from '../../db/Role';
import { ServerlistModel } from '../../db/Serverlist';
import { UserModel } from '../../db/User';
import { BindPhoneData } from '../../domain/activityField/bindPhoneField';
import { DailyChallengesData } from '../../domain/activityField/dailyChallengesField';
import { getRoleCreateTime, getServerCreateTime } from '../redisService';
import { getActivitiesByType, getActivityById } from './activityService';
/**
* 获取活动数据
*
* @param {number} serverId 区Id
* @param {number} activityId 活动Id
* @param {string} roleId 角色Id
*
*/
export async function getBindPhoneData(activityId: number, roleId: string, serverId: number, uid: number) {
let activityData: ActivityModelType = await getActivityById(activityId);
if(activityData.type != ACTIVITY_TYPE.BIND_PHONE) return null;
let createTime = await getRoleCreateTime(roleId);
let serverTime = await getServerCreateTime(serverId);
let playerData = new BindPhoneData(activityData, createTime, serverTime);
let user = await UserModel.findUserByUid(uid);
let receiveRec = await ActivityBindPhoneRewardModel.findByUid(activityId, uid);
playerData.setRecord(user, receiveRec);
return playerData;
}
/**
* 玩家玩家活动数据
*
* @param {number} serverId 区Id
* @param {number} activityId 活动Id
* @param {string} roleId 角色Id
*
*/
export async function getBindPhoneDataShow(activityId: number, roleId: string, serverId: number, uid: number) {
let playerData = await getBindPhoneData(activityId, roleId, serverId, uid);
if(playerData && playerData.canShow && playerData.canShow()) {
return playerData.getShowResult();
}
return null
}

View File

@@ -60,6 +60,7 @@ export enum ACTIVITY_TYPE {
GUIDE_GACHA = 45, // 500抽
POP_NOTICE = 46, // 打脸公告
GROUP_SHOP = 49, // 团购
BIND_PHONE = 50, // 绑定手机号
}
/**
@@ -249,4 +250,10 @@ export enum GROUP_SHOP_PRICE_STATUS {
NOT_ENOUGH = 0, // 客户端的价格不足当前价格
NORMAL = 1, // 正好
OVER = 2, // 客户端的价格高于当前价格
}
export enum BIND_PHONE_STATUS {
WAIT_BIND = 0, // 待绑定
HAS_BIND = 1, // 已绑定待领取
RECEIVED = 2, // 已领取
}

View File

@@ -1047,6 +1047,7 @@ export enum ITEM_CHANGE_REASON {
LADDER_BATTLE_REWARD = 152, // 名将擂台关卡奖励
ACT_GROUP_SHOP_BUY = 153, // 团购
ACT_TURNTABLE_RECEIVE_BOX = 154, // 活动 幸运转盘领取宝箱
ACT_BIND_PHONE = 155, // 活动 绑定手机奖励
}
export enum TA_EVENT {

View File

@@ -517,6 +517,9 @@ export const STATUS = {
ACTIVITY_GROUP_SHOP_BUY_CNT_MAX: { code: 50039, simStr: '购买次数超过最大值' },
ACTIVITY_GROUP_SHOP_ITEM_NOT_FOUND: { code: 50040, simStr: '未找到该商品' },
ACTIVITY_GROUP_SHOP_PRICE_ERR: { code: 50041, simStr: '提供的折扣未达到该价格' },
ACTIVITY_BIND_ERR: { code: 50042, simStr: '清先绑定手机' },
ACTIVITY_BIND_RECEIVED: { code: 50043, simStr: '奖励已领取过' },
ACTIVITY_HAS_BIND: { code: 50044, simStr: '已绑定' },
// GM后台相关状态 60000 - 69999
GM_ERR_PASSWORD: { code: 60001, simStr: '账号或密码错误' },

View File

@@ -0,0 +1,44 @@
import BaseModel from './BaseModel';
import { index, getModelForClass, prop, DocumentType } from '@typegoose/typegoose';
/**
* 活动系统 - 团购总记录
*/
@index({ activityId: 1, uid: 1 })
export default class Activity_Bind_Phone_Reward extends BaseModel {
@prop({ required: true })
activityId: number; // 活动Id
@prop({ required: true })
uid: number; // 玩家账号id
@prop({ required: true })
status: number; // 状态 0-未绑定 1-已绑定 2-已领取
@prop({ required: true })
serverId: number; // 领取时的服务器id
@prop({ required: true })
roleId: string; // 领取时的账号
@prop({ required: true })
roleName: string; // 领取时的账号名
public static async findByUid(activityId: number, uid: number) {
let result: ActivityBindPhoneRewardType = await ActivityBindPhoneRewardModel.findOne({ activityId, uid }).lean();
return result;
}
public static async addRecord(activityId: number, uid: number, status: number, param: ActivityBindPhoneRewardUpdate) {
let result: ActivityBindPhoneRewardType = await ActivityBindPhoneRewardModel.findOneAndUpdate({ activityId, uid }, { $set: { status, ...param} }, { new: true, upsert: true }).lean();
return result;
}
}
export const ActivityBindPhoneRewardModel = getModelForClass(Activity_Bind_Phone_Reward);
export interface ActivityBindPhoneRewardType extends Pick<DocumentType<Activity_Bind_Phone_Reward>, keyof Activity_Bind_Phone_Reward> { }
export type ActivityBindPhoneRewardUpdate = Partial<ActivityBindPhoneRewardType>; // 将所有字段变成可选项

View File

@@ -295,7 +295,6 @@ export default class User extends BaseModel {
return user;
}
private static getSearchObj(form: SearchUserParam) {
let searchObj = {};
if(form['uid']) searchObj['uid'] = form.uid;

View File

@@ -0,0 +1,43 @@
import { BIND_PHONE_STATUS } from '../../consts';
import { ActivityModelType } from '../../db/Activity';
import { ActivityBindPhoneRewardType } from '../../db/ActivityBindPhoneReward';
import { UserType } from '../../db/User';
import { ActivityBase } from './activityField';
// 数据库
interface BindPhoneDataInDb {
rewards: string;
}
// 数据
export class BindPhoneData extends ActivityBase {
rewards: string;
status: number = BIND_PHONE_STATUS.WAIT_BIND; // 状态 0-未绑定 1-已绑定可领取 2-已领取
constructor(activityData: ActivityModelType, createTime: number, serverTime: number) {
super(activityData, createTime, serverTime);
this.initData(activityData.data)
}
public initData(data: string) {
let dataObj: BindPhoneDataInDb = JSON.parse(data);
this.rewards = dataObj.rewards;
}
public setRecord(user: UserType, data: ActivityBindPhoneRewardType) {
if(user && user.channelInfo && user.channelInfo.is_phone_bind == 1) this.status = BIND_PHONE_STATUS.HAS_BIND;
if(data) this.status = data.status;
}
public getShowResult() {
if(this.status == BIND_PHONE_STATUS.RECEIVED) return null
return {
...this.getBaseKeys(),
rewards: this.rewards,
status: this.status,
}
}
}

View File

@@ -256,5 +256,11 @@
"activityType": 49,
"name": "GROUP_SHOP",
"string": "团购"
},
{
"id": 50,
"activityType": 50,
"name": "BIND_PHONE",
"string": "绑定手机"
}
]