This commit is contained in:
mamengke01
2020-12-25 14:15:03 +08:00
parent 0c5cb1daac
commit 04fa4e79cf
14 changed files with 304 additions and 27 deletions

View File

@@ -6,8 +6,12 @@ import { EquipModel } from '../../../db/Equip';
import { calculateCE, resResult } from '../../../pubUtils/util';
import {Application, BackendSession, createTcpMailBox} from 'pinus';
import { COUNTER } from '../../../consts';
import { handleCost } from '../../../services/rewardService'
import { getTitle } from '../../../pubUtils/data'
import { handleCost } from '../../../services/rewardService';
import { getTitle, getTeraph } from '../../../pubUtils/data';
import { SSL_OP_SSLEAY_080_CLIENT_DH_BUG } from 'constants';
import { getTeraphAttr } from '../../../consts/constModules/abilityConst'
const _ = require('underscore');
export default function(app: Application) {
return new RoleHandler(app);
}
@@ -75,12 +79,10 @@ export class RoleHandler {
let roleId = session.get('roleId');
let role = await RoleModel.findByRoleId(roleId);
let sid: string = session.get('sid');
let title = ++role.title;
let titleInfo = getTitle(role.title);
if (!titleInfo)
return resResult(STATUS.DIC_DATA_NOT_FOUND)
let title = ++role.title;
if (!getTitle(title))
return resResult(STATUS.ROLE_REACH_MAX_TITLE_LEVEL)
if (titleInfo.lvLimited > role.lv)
return resResult(STATUS.COM_BATTLE_LV_NOT_ENOUGH)
let consumes = titleInfo.material;
@@ -91,4 +93,75 @@ export class RoleHandler {
return resResult(STATUS.SUCCESS, { roleId, title });
}
//神像强化
async roleTeraphStrengthen(msg: {id: number, type: number}, session: BackendSession){
let {id, type} = msg;
let roleId = session.get('roleId');
let role = await RoleModel.findByRoleId(roleId);
let sid: string = session.get('sid');
let index = _.findIndex(role.teraphs, {id});
if (index < 0)
return resResult(STATUS.WRONG_PARMS);
let teraph = role.teraphs[index];
let teraphInfo = getTeraph(id, teraph.grade);
if (!teraphInfo)
return resResult(STATUS.DIC_DATA_NOT_FOUND)
let falg = true;
for (let attrName in getTeraphAttr()) {
if (teraph[attrName] != teraphInfo[attrName]) {
falg = false;
break;
}
}
if (!!falg)
return resResult(STATUS.ROLE_TERAPH_NOT_STRENGTHEN);
//TODO强化属性
let consumes;
if (type == 1) {
consumes = teraphInfo.upMaterial;
} else if (type == 2) {
consumes = teraphInfo.upMaterial;
} else {
return resResult(STATUS.WRONG_PARMS);
}
let result = await handleCost(roleId, sid, consumes);
if (!result)
return resResult(STATUS.BATTLE_CONSUMES_NOT_ENOUGH);
await RoleModel.updateRoleInfo(roleId, { teraphs: role.teraphs });
return resResult(STATUS.SUCCESS, { roleId, teraphs: role.teraphs });
}
//神像进阶
async roleTeraphQualityUp(msg: {id: number}, session: BackendSession){
let {id} = msg;
let roleId = session.get('roleId');
let role = await RoleModel.findByRoleId(roleId);
let sid: string = session.get('sid');
let index = _.findIndex(role.teraphs, {id});
if (index < 0)
return resResult(STATUS.WRONG_PARMS);
let teraph = role.teraphs[index];
let teraphInfo = getTeraph(id, teraph.grade);
if (!teraphInfo)
return resResult(STATUS.DIC_DATA_NOT_FOUND)
for (let attrName in getTeraphAttr()) {
if (teraph[attrName] != teraphInfo[attrName])
return resResult(STATUS.ROLE_TERAPH_NOT_QUILITY);
}
teraph.grade++;
teraph.atk = 0;
teraph.agi = 0;
teraph.def = 0;
teraph.hp = 0;
teraph.luk = 0;
teraph.mdef = 0;
if (getTeraph(index, teraph.grade))
return resResult(STATUS.DIC_DATA_NOT_FOUND)
let consumes = teraphInfo.upGradeMaterial;
let result = await handleCost(roleId, sid, consumes);
if (!result)
return resResult(STATUS.BATTLE_CONSUMES_NOT_ENOUGH);
await RoleModel.updateRoleInfo(roleId, { teraphs: role.teraphs });
return resResult(STATUS.SUCCESS, { roleId, teraphs: role.teraphs });
}
}