(37需求): 查询角色接口

This commit is contained in:
luying
2023-05-06 21:08:59 +08:00
parent d30abf287f
commit 4fe472b537
5 changed files with 84 additions and 3 deletions

View File

@@ -561,4 +561,26 @@ export class GetServerParam {
checkParams() {
return this.server_id != undefined && this.time != undefined && this.sign != undefined
}
}
export class GetServerAndUidParam {
time: number;
appid: string;
gid: string;
uid: number;
dsid: number;
sign: string;
constructor(data: any) {
this.time = data.time;
this.appid = data.appid;
this.gid = data.gid;
this.uid = data.uid;
this.dsid = data.dsid;
this.sign = data.sign;
}
checkParams() {
return this.appid != undefined && this.time != undefined && this.gid != undefined && this.uid != undefined && this.dsid != undefined && this.sign != undefined
}
}

View File

@@ -1,5 +1,5 @@
import { Controller } from 'egg';
import { GetGuildInfoByUserParam, GetRoleByServerParam, GetRoleByUidParam, GetServerListParam, GetServerParam, GuildNameCallBackParam, IOSRefundParam, PayCallback37Data, RoleNameCallBackParam, SendGiftCodeParam } from '../domain/sdk';
import { GetGuildInfoByUserParam, GetRoleByServerParam, GetRoleByUidParam, GetServerAndUidParam, GetServerListParam, GetServerParam, GuildNameCallBackParam, IOSRefundParam, PayCallback37Data, RoleNameCallBackParam, SendGiftCodeParam } from '../domain/sdk';
export default class SdkController extends Controller {
@@ -76,6 +76,14 @@ export default class SdkController extends Controller {
return;
}
public async getRoleByUidAndServerForLogin() {
const { ctx } = this;
const params = new GetServerAndUidParam(ctx.query||ctx.request.body);
ctx.body = await ctx.service.sdk.getRoleByUidAndServerForLogin(params);
return;
}
public async getRoleByUid() {
const { ctx } = this;
const params = new GetRoleByUidParam(ctx.query);

View File

@@ -73,6 +73,7 @@ module.exports = () => {
'/cb/getrolebyserver',
'/cb/getserverinfo',
'/cb/getrolebyuid',
'/cb/getrolebyuidandserver',
];
for(let str of urls) {
if(url && url.startsWith(str)) {
@@ -94,6 +95,8 @@ module.exports = () => {
case '/cb/getrolebyserver':
case '/cb/getserverinfo':
return ctx.query.server_id.toString();
case '/cb/getrolebyuidandserver':
return ctx.query? ctx.query.dsid.toString(): ctx.request.body.dsid.toString();
case '/cb/getrolebyuid':
return 'main';
}

View File

@@ -48,6 +48,8 @@ export default (app: Application) => {
router.get('/cb/getrolebyserver', controller.sdk.getRoleByUidAndServer);
router.get('/cb/getrolebyuid', controller.sdk.getRoleByUid);
router.get('/cb/getserverinfo', controller.sdk.getServerInfo);
router.get('/cb/getrolebyuidandserver', controller.sdk.getRoleByUidAndServerForLogin);
router.post('/cb/getrolebyuidandserver', controller.sdk.getRoleByUidAndServerForLogin);
// 问卷星回调
router.post('/cb/wjx', controller.sdk.wjxCallback)

View File

@@ -1,7 +1,7 @@
import { Service } from 'egg';
import { REDIS_KEY, PAY_37_CALLBACK_CODE, SDK_37_CONST, ORDER_STATE, SDK_37_TREAT_CODE, SERVER_STATUS, SDK_37_REFUND_CODE, SDK_37_ACTIVITY_CODE, PUBLIC_ACCOUNT_GIFT, GIFT_GENERATE_TYPE } from '@consts';
import { GetGuildInfoByUserParam, GetRoleByServerParam, GetRoleByUidParam, GetServerListParam, GetServerParam, GuildNameCallBackParam, IOSRefundParam, PayCallback37Data, RoleNameCallBackParam, SendGiftCodeParam } from '../domain/sdk';
import { GetGuildInfoByUserParam, GetRoleByServerParam, GetRoleByUidParam, GetServerAndUidParam, GetServerListParam, GetServerParam, GuildNameCallBackParam, IOSRefundParam, PayCallback37Data, RoleNameCallBackParam, SendGiftCodeParam } from '../domain/sdk';
import { RedisClient } from 'redis';
import { checkParamPrice, get37GetServerMd5Sign, get37Md5SignA, get37Md5SignB, getChannelId, getRedisSubChannel, md5 } from '../pubUtils/sdkUtil';
import { UserOrderModel } from '@db/UserOrder';
@@ -623,8 +623,54 @@ export default class Sdk extends Service {
if(sign != params.sign) return resResult(SDK_37_ACTIVITY_CODE.SIGN_ERR);
if(nowSeconds() - params.time > 15 * 60) {
return SDK_37_ACTIVITY_CODE.TIME_IS_EXPIRED;
return resResult(SDK_37_ACTIVITY_CODE.TIME_IS_EXPIRED);
}
return resResult(SDK_37_ACTIVITY_CODE.SUCCESS);
}
// 根据服务器获取玩家数据
public async getRoleByUidAndServerForLogin(params:GetServerAndUidParam) {
try {
let validateResult = this.getRoleByUidAndServerForLoginValidate(params);
if(validateResult.code != SDK_37_ACTIVITY_CODE.SUCCESS.code) return { state: 0, data: null, msg: validateResult.simStr };
let channelId = getChannelId('37', params.uid);
let user = await UserModel.findUserByChannel(channelId);
if(!user) return resResult(SDK_37_ACTIVITY_CODE.ROLE_NOT_FOUND);
let server = await ServerlistModel.findByServerId(params.dsid);
if(!server) return resResult(SDK_37_ACTIVITY_CODE.SERVER_NOT_FOUND);
let role = await Role.findByUid(user.uid, params.dsid, 'roleId roleName lv createTime serverId ce');
if(!role) return resResult(SDK_37_ACTIVITY_CODE.ROLE_NOT_FOUND);
return {
state: 1, data: [{
dsid: role.serverId.toString(),
dsname: server.name,
drid: role.roleId,
drname: role.roleName,
drlevel: role.lv.toString(),
dpower: role.ce.toString(),
}], msg: '成功'
}
} catch(e) {
console.error(e);
return { state: 0, data: null, msg: SDK_37_ACTIVITY_CODE.INTERNAL_ERR };
}
}
private getRoleByUidAndServerForLoginValidate(params:GetServerAndUidParam) {
if(!params.checkParams()) return SDK_37_ACTIVITY_CODE.WRONG_PARAMS;
let { appid, gid, uid, dsid, time } = params;
let str = `${time}${appid}${gid}${dsid}${uid}${SDK_37_CONST.LOGIN_KEY}`;
let sign = md5(str);
console.log('#### str: ', str, 'sign', sign);
if(sign != params.sign) return SDK_37_ACTIVITY_CODE.SIGN_ERR;
if(nowSeconds() - params.time > 15 * 60) {
return SDK_37_ACTIVITY_CODE.TIME_IS_EXPIRED;
}
return SDK_37_ACTIVITY_CODE.SUCCESS;
}
}