✨ feat(活动): 微信公众号口令
This commit is contained in:
@@ -6,8 +6,10 @@ 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, getBindPhoneDataShow } from '../../../services/activity/bindPhoneService';
|
||||
import { getBindPhoneData, getAllSnsLinkDataShow, getPublicAccountData } from '../../../services/activity/bindPhoneService';
|
||||
import { ActivityBindPhoneRewardModel } from '../../../db/ActivityBindPhoneReward';
|
||||
import { ActivityPublicAccountCodeModel } from '../../../db/ActivityPublicAccountCode';
|
||||
import { UserModel } from '../../../db/User';
|
||||
|
||||
|
||||
export default function (app: Application) {
|
||||
@@ -25,7 +27,7 @@ export class BindPhoneHandler {
|
||||
const serverId = session.get('serverId');
|
||||
const uid = session.get('userid');
|
||||
|
||||
let playerData = await getBindPhoneDataShow(activityId, roleId, serverId, uid);
|
||||
let playerData = await getAllSnsLinkDataShow(activityId, roleId, serverId, uid);
|
||||
return resResult(STATUS.SUCCESS, {
|
||||
playerData
|
||||
})
|
||||
@@ -98,9 +100,30 @@ export class BindPhoneHandler {
|
||||
* @memberof BindPhoneHandler
|
||||
*/
|
||||
async receiveGiftCode(msg: { activityId: number }, session: BackendSession) {
|
||||
return resResult(STATUS.SUCCESS);
|
||||
}
|
||||
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 user = await UserModel.findUserByUid(uid);
|
||||
let playerData = await getPublicAccountData(activityId, roleId, serverId, user);
|
||||
let data = playerData?.wxPublicAccount;
|
||||
if(!data) return resResult(STATUS.ACTIVITY_ID_ERROR);
|
||||
if(data.status == BIND_PHONE_STATUS.WAIT_BIND) return resResult(STATUS.ACTIVITY_PUBLIC_ACCOUNT_WAIT);
|
||||
if(data.status == BIND_PHONE_STATUS.RECEIVED) return resResult(STATUS.ACTIVITY_PUBLIC_ACCOUNT_RECEIVED);
|
||||
|
||||
await ActivityPublicAccountCodeModel.receive(activityId, user.channelId);
|
||||
let rewardArray = stringToRewardParam(data.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
|
||||
});
|
||||
}
|
||||
|
||||
/**
|
||||
* 前往论坛,用于前往论坛任务
|
||||
|
||||
Reference in New Issue
Block a user