diff --git a/game-server/app.ts b/game-server/app.ts index a83205545..fd253e0ae 100644 --- a/game-server/app.ts +++ b/game-server/app.ts @@ -135,7 +135,7 @@ app.configure('production|development|local', function () { app.set(RESERVED.ERROR_HANDLER, errorHandler); app.set(RESERVED.GLOBAL_ERROR_HANDLER, globalErrorHandler); app.globalAfter((err: Error, routeRecord: RouteRecord, msg: any, session: FrontendOrBackendSession, resp: any, cb: HandlerCallback) => { - console.log('global after ', err, routeRecord, msg) + console.log('global after ', err, msg&&msg.route, msg&&JSON.stringify(msg.body), session&&session.get('roleId')) }) app.globalBefore((routeRecord: RouteRecord, msg: any, session: FrontendOrBackendSession, cb: HandlerCallback) => { diff --git a/game-server/app/servers/battle/handler/dailyBattleHandler.ts b/game-server/app/servers/battle/handler/dailyBattleHandler.ts index eb2066fc6..9697a62fd 100644 --- a/game-server/app/servers/battle/handler/dailyBattleHandler.ts +++ b/game-server/app/servers/battle/handler/dailyBattleHandler.ts @@ -92,7 +92,6 @@ export class DailyBattleHandler { await RoleModel.costGold(roleId, buyCost); let newDailyRecord = await DailyRecordModel.increseBuyCount(roleId, type, count); - console.log(buyCost); let checkDailyResult = await getDailyNum(newDailyRecord, timesPerDay, timesCanBuy); return resResult(STATUS.SUCCESS, { type, ...checkDailyResult, buyCost}); } diff --git a/game-server/app/servers/battle/handler/expeditionBattleHandler.ts b/game-server/app/servers/battle/handler/expeditionBattleHandler.ts index 0d26e40dc..180f5cdbd 100644 --- a/game-server/app/servers/battle/handler/expeditionBattleHandler.ts +++ b/game-server/app/servers/battle/handler/expeditionBattleHandler.ts @@ -5,7 +5,7 @@ import { ExpeditionRecordModel } from '../../../db/ExpeditionRecord'; import { ExpeditionWarRecordModel } from '../../../db/ExpeditionWarRecord'; import { ExpeditionPointModel } from '../../../db/ExpeditionPoint'; import { RoleModel } from '../../../db/Role'; -import { calculateSumCE, genCode } from '../../../pubUtils/util'; +import { calculateSumCE, genCode, setLocalHours } from '../../../pubUtils/util'; import { matchPlayers, matchRobots, getPointRewardStatus, getCEScaleAndRange } from '../../../services/expeditionService'; import { EXPEDITION_INCREASE_POINT } from '../../../consts/consts'; import { WarReward } from '../../../services/warRewardService'; @@ -33,7 +33,7 @@ export class ExpeditionBattleHandler { // 每日刷新,刷新关卡进度,宝箱进度,武将状态 let now = new Date(); - let today = now.setHours(0, 0, 0, 0); + let today = setLocalHours(0, now); let expeditionRecord = await ExpeditionRecordModel.getTodayRecord(roleId, today); if(!expeditionRecord) { // 每天新建一条记录 let code = genCode(8); diff --git a/game-server/app/servers/battle/handler/normalBattleHandler.ts b/game-server/app/servers/battle/handler/normalBattleHandler.ts index 3a9a8f7be..a63fa0b1a 100644 --- a/game-server/app/servers/battle/handler/normalBattleHandler.ts +++ b/game-server/app/servers/battle/handler/normalBattleHandler.ts @@ -252,7 +252,6 @@ export class NormalBattleHandler { if(!warInfo) { return resResult(STATUS.BATTLE_MISS_INFO); } - console.log(warInfo) // 校验是否三星通关过 let condition1 = await BattleRecordModel.getBattleRecordByIdAndStar(roleId, battleId, 3); if(!condition1) { diff --git a/game-server/app/servers/battle/handler/towerBattleHandler.ts b/game-server/app/servers/battle/handler/towerBattleHandler.ts index cece1d7d9..9c7c1d561 100644 --- a/game-server/app/servers/battle/handler/towerBattleHandler.ts +++ b/game-server/app/servers/battle/handler/towerBattleHandler.ts @@ -8,7 +8,7 @@ import { TowerRecordModel } from './../../../db/TowerRecord'; import { Application, BackendSession } from 'pinus'; import { getTaskById, getTowerDataByLv } from '../../../pubUtils/gamedata'; import { decodeArrayStr, resResult, shouldRefresh, calculateNum } from '../../../pubUtils/util'; -import { calcuHangUpReward, checkTaskConditions, checkHangUpSpdUpCnt, createCurTasks, treatTask, getRemainTime } from '../../../services/battleService'; +import { calcuHangUpReward, checkTaskConditions, checkHangUpSpdUpCnt, createCurTasks, treatTask, getRemainTime, getTasksReward } from '../../../services/battleService'; import { handleFixedReward, handleReward } from '../../../services/rewardService'; export default function(app: Application) { @@ -109,12 +109,10 @@ export class TowerBattleHandler { let {data: {hangUpSpdUpCnt, gold}} = result; const costGold = this.getHangUpCost(hangUpSpdUpCnt, msg.speedUpCnt); - console.log(costGold, gold) if(costGold > gold) { return resResult(STATUS.TOWER_GOLD_NOT_ENOUGH); } await RoleModel.costGold(roleId, costGold); - console.log(costGold); const spdUpResult = await RoleModel.hangUpSpdUp(roleId, msg.speedUpCnt, curTime); if (!spdUpResult) { @@ -170,7 +168,12 @@ export class TowerBattleHandler { } await RoleModel.increaseTowerRefCnt(roleId, needRefresh, curTime); + // tmp: 将刷掉的旧任务的奖励发送到邮件中 + let oldReward = await getTasksReward(roleId, curTime); + console.log(JSON.stringify(oldReward)); await TowerTaskRecModel.refreshTask(roleId); // 刷掉旧的任务 + + let curTasks = await createCurTasks(towerLv, roleId, roleName); // 刷出新的任务 let nextCostGold = calculateNum(GOLD_COST_RATIO.TPWER_TASK_REF, {num: towerTaskReCnt + 1}, 200); @@ -255,4 +258,11 @@ export class TowerBattleHandler { const rec = await TowerTaskRecModel.finishTask(msg.batchCode, compTasks); return resResult(STATUS.SUCCESS, { compTasks: treatTask(rec, curTime), goods }); } + + + async getTowerRank(msg: {}, session: BackendSession) { + let ranks = await RoleModel.getRank('tower', ['roleId', 'roleName', 'towerLv', 'lv', 'vLv']); + + return resResult(STATUS.SUCCESS, { ranks }); + } } diff --git a/game-server/app/servers/connector/handler/entryHandler.ts b/game-server/app/servers/connector/handler/entryHandler.ts index 54bc88d3e..cf88d2dbe 100644 --- a/game-server/app/servers/connector/handler/entryHandler.ts +++ b/game-server/app/servers/connector/handler/entryHandler.ts @@ -26,7 +26,6 @@ export class EntryHandler { * @param {Object} session current session object */ async enter(msg: { token: string, serverId: number }, session: FrontendSession) { - console.log('******enter') let self = this; let serverId = msg.serverId; diff --git a/game-server/app/services/battleService.ts b/game-server/app/services/battleService.ts index 9af340a10..fc81b361c 100644 --- a/game-server/app/services/battleService.ts +++ b/game-server/app/services/battleService.ts @@ -197,7 +197,7 @@ async function checkCond(roleId: string, heroes, type: number, param: number, cn switch (type) { case 1: - let field = param == 1?'star': 'rank'; + let field = param == 1?'star': 'fire'; // fire:觉醒的火,在满星了之后会继续进行觉醒,显示类似6星1火 for(let hid of heroes) { const rec = await HeroModel.findByHidAndRole(hid, roleId); if (rec[field] >= param) { @@ -285,4 +285,20 @@ export function treatTask(recs: Array, curTime: Date) { } return { heroes, batchCode, taskId, taskCode, status, completeTime, remainTime } }); +} + +export async function getTasksReward(roleId: string, curTime: Date) { + let oldTasks = await TowerTaskRecModel.getCurTasks(roleId); + let goods = []; + for(let task of oldTasks) { + let {completeTime, reward, termsForAdd, additionalReward} = getTaskById(task.taskId); + if (task.sendTime && task.sendTime.getTime() + completeTime * 1000 < curTime.getTime()) { + goods = goods.concat(decodeStr('fixReward', reward)); + if(termsForAdd) { + const result = checkTaskConditions(roleId, task.heroes, termsForAdd); + goods = goods.concat(decodeStr('fixReward', result?additionalReward:'')); + } + } + } + return goods } \ No newline at end of file diff --git a/game-server/app/services/eventSercive.ts b/game-server/app/services/eventSercive.ts index f7e2ab40e..b9caa1edb 100644 --- a/game-server/app/services/eventSercive.ts +++ b/game-server/app/services/eventSercive.ts @@ -2,7 +2,7 @@ import { Application, FrontendOrBackendSession } from 'pinus'; import { getGamedata } from '../pubUtils/gamedata'; import EventRecord, { EventRecordModel } from '../db/EventRecord'; import { RoleModel } from '../db/Role'; -import { genCode, decodeStrSingle, decodeStr, getRandomWithWeight, resResult } from '../pubUtils/util'; +import { genCode, decodeStrSingle, decodeStr, getRandomWithWeight, resResult, setLocalHours } from '../pubUtils/util'; import { EVENT_STATUS, EVENT_RECORD_STATUS, EVENT_TYPE, EVENT_RANDOM_TYPE_ONE_OPEN, EVENT_QUIZ_NUM, EVENT_ANSWER_STATUS } from '../consts/consts'; import { EVENT_REFRESH_NUM } from '../consts/consts'; import { STATUS } from '../consts/statusCode'; @@ -62,8 +62,8 @@ export async function setBattleStatus(app: Application, session: FrontendOrBacke */ export function getEventTime(now: Date) { let curTime = Number(now); - let todayA = now.setHours(12, 0, 0, 0) - 8*60*60*1000; // 每天12点,修复时差 - let todayB = now.setHours(18, 0, 0, 0) - 8*60*60*1000; // 每天18点,修复时差 + let todayA = setLocalHours(12, now); // 每天12点 + let todayB = setLocalHours(18, now); // 每天18点 let yesterdayB = todayB - 86400000; // 前一天12点 let t = 0; if(curTime < todayA) { @@ -196,7 +196,7 @@ export async function refreshEvent(num: number, roleId: string, roleName: string let role = await RoleModel.findByRoleId(roleId); dicEvent = dicEvent.filter(cur => { // 筛选适合等级 let { suitLevel } = cur; - suitLevel = decodeStrSingle('eventSuitLevel', suitLevel); + suitLevel = decodeStrSingle('suitLevel', suitLevel); return suitLevel.min <= role.lv && suitLevel.max >= role.lv }); if(EVENT_RANDOM_TYPE_ONE_OPEN) { @@ -292,7 +292,6 @@ function randomPosition(positionStr: string, prePoint: Array, curPoint: * @param msg */ function pushEventMsg(app: Application, roleId: string, channelName: string, msg: any ) { - console.log('***pushEventMsg', channelName) let channelService = app.get('channelService'); let param = { msg }; diff --git a/game-server/app/services/expeditionService.ts b/game-server/app/services/expeditionService.ts index 39a9106d9..3740da7b1 100644 --- a/game-server/app/services/expeditionService.ts +++ b/game-server/app/services/expeditionService.ts @@ -4,7 +4,7 @@ import { RoleModel } from '../db/Role'; import { PvpDefenseModel } from '../db/PvpDefense'; import { getWarJsons, getGamedata } from '../pubUtils/gamedata'; -import { decodeStr, resResult } from '../pubUtils/util'; +import { decodeStr, resResult, setLocalHours } from '../pubUtils/util'; import { WAR_JSON_ATTRIBUTE_TYPE } from '../consts/consts'; @@ -71,7 +71,7 @@ export async function getCEScaleAndRange(roleId: string, curDicExpedition: any) // 匹配,判断是不是新手期 const role = await RoleModel.findByRoleId(roleId); let now = new Date(); - let today = now.setHours(0,0,0,0); + let today = setLocalHours(0, now); let isNew = today - role.createdAt.getTime() <= 3*24*60*60*1000; let scale = isNew?curDicExpedition.CEScaleNew:curDicExpedition.CEScale; let range = isNew?curDicExpedition.CERangeNew:curDicExpedition.CERange; diff --git a/game-server/app/services/normalBattleService.ts b/game-server/app/services/normalBattleService.ts index 79923fd5a..2c3930b5b 100644 --- a/game-server/app/services/normalBattleService.ts +++ b/game-server/app/services/normalBattleService.ts @@ -13,7 +13,7 @@ export async function roleLevelup(roleId: string, kingExp: number) { for(let i = lv; i <= newLv; i++) { let {sum, cur} = getExpByLv(i); let lastSum = sum - cur; - console.log(sum, cur, lastSum, exp, newExp); + // console.log(sum, cur, lastSum, exp, newExp); let startExp = exp > lastSum? exp - lastSum: 0; let getExp = newExp > sum? cur - startExp: newExp - lastSum - startExp; diff --git a/game-server/app/services/rewardService.ts b/game-server/app/services/rewardService.ts index dc83b18f8..cf8a1dcdf 100644 --- a/game-server/app/services/rewardService.ts +++ b/game-server/app/services/rewardService.ts @@ -82,7 +82,6 @@ async function rewardItems (roleId: string, dicGood: any, field: string, data: { let {id, cnt} = data; let result = await RoleModel.addItems(roleId, field, id, cnt); - console.log(result) goods.push({ id: id, diff --git a/shared/consts/consts.ts b/shared/consts/consts.ts index 1ca477967..80c12eb36 100644 --- a/shared/consts/consts.ts +++ b/shared/consts/consts.ts @@ -150,6 +150,10 @@ export const TOWER_TASK_CONST = { MAX_HEROES_NUM: 3 } +export const DAILY_CONST = { + REFRESH_TIME: 5 +} + export const WAR_JSON_ATTRIBUTE_TYPE = { "1": "hp", // 生命 "2": "atk", // 物攻 diff --git a/shared/db/BattleRecord.ts b/shared/db/BattleRecord.ts index ff94db890..9b4d45e40 100644 --- a/shared/db/BattleRecord.ts +++ b/shared/db/BattleRecord.ts @@ -54,7 +54,6 @@ export default class BattleRecord extends BaseModel { public static async getBattleList( roleId: string, warType: number, lean = true) { const searchObj = { roleId, warType, status: 1 }; const count = await BattleRecordModel.countDocuments(searchObj); - console.log(roleId, warType, count); const limit = 1000; const page = Math.ceil(count/limit); let result = new Array(); diff --git a/shared/db/DailyRecord.ts b/shared/db/DailyRecord.ts index d43e90989..e12206fb3 100644 --- a/shared/db/DailyRecord.ts +++ b/shared/db/DailyRecord.ts @@ -1,5 +1,8 @@ import BaseModel from './BaseModel'; import { index, getModelForClass, prop } from '@typegoose/typegoose'; +import { DAILY_CONST } from './../consts/consts'; +import { setLocalHours } from './../pubUtils/util'; + /** * 战斗记录接口 @@ -27,11 +30,11 @@ export default class DailyRecord extends BaseModel { const dailyRecord = await DailyRecordModel.findOne({ roleId, type }).lean(lean); let {count = 0, refTime = 0, buyCount = 0} = dailyRecord||{}; let now = new Date(); - let today = now.setHours(0, 0, 0, 0); + let today = setLocalHours(DAILY_CONST.REFRESH_TIME, now); + + console.log('******dailyTime*******', today, now, new Date(), refTime); if(today > refTime) { - refTime = today; - count = 0; - buyCount = 0; + refTime = today; count = 0; buyCount = 0; } let result = await DailyRecordModel.findOneAndUpdate({roleId, type}, {$set: {refTime, count, buyCount}}, {new: true, upsert: true}); return result; diff --git a/shared/db/ExpeditionRecord.ts b/shared/db/ExpeditionRecord.ts index 723c756a0..dbdd50991 100644 --- a/shared/db/ExpeditionRecord.ts +++ b/shared/db/ExpeditionRecord.ts @@ -56,7 +56,6 @@ export default class ExpeditionRecord extends BaseModel { pushArr.push({hid: actorId, hp, ap}) } } - console.log(JSON.stringify(oldHeroes), JSON.stringify(heroes), JSON.stringify(pushArr), JSON.stringify(updateArr)) for(let {hid, hp, ap} of updateArr) { await ExpeditionRecordModel.findOneAndUpdate( {expeditionCode, 'heroes.hid': hid }, diff --git a/shared/db/ExpeditionWarRecord.ts b/shared/db/ExpeditionWarRecord.ts index 482a1c9bf..6a784f955 100644 --- a/shared/db/ExpeditionWarRecord.ts +++ b/shared/db/ExpeditionWarRecord.ts @@ -93,7 +93,6 @@ export default class ExpeditionWarRecord extends BaseModel { public static async updateEnemiesStatus(expeditionCode: string, expeditionId: number, battleStatus: number, enemies: Array<{dataId: number, hp: number, ap: number}>, lean = true) { for(let {dataId, hp, ap} of enemies) { - console.log('updateEnemiesStatus',ap) await ExpeditionWarRecordModel.findOneAndUpdate( {expeditionCode, expeditionId, 'enemies.dataId': dataId }, {$set: {'enemies.$.attribute.hp': hp, 'enemies.$.attribute.ap': ap}} diff --git a/shared/db/GMUser.ts b/shared/db/GMUser.ts index 2e12d4cb8..066c4401d 100644 --- a/shared/db/GMUser.ts +++ b/shared/db/GMUser.ts @@ -44,7 +44,7 @@ export default class GMUser extends BaseModel { } public static async getGmAccountByToken(token: string, lean = true) { - console.log(token) + // console.log(token) const user = await GMUserModel.findOne({token}).select('uid username name token').lean(lean); return user; } diff --git a/shared/db/Hero.ts b/shared/db/Hero.ts index 2fffb0d91..90b4974e4 100644 --- a/shared/db/Hero.ts +++ b/shared/db/Hero.ts @@ -29,6 +29,8 @@ export default class Hero extends BaseModel { @prop({ required: true }) star: number; // 星级 + @prop({ required: true }) + fire: number; // 觉醒的火,在满星了之后会继续进行觉醒,显示类似6星1火 @prop({ required: true, default: 1 }) rank: number; // 阶数 @prop({ required: true, default: 0 }) diff --git a/shared/db/PvpDefense.ts b/shared/db/PvpDefense.ts index 28b8b3ff0..c7551a516 100644 --- a/shared/db/PvpDefense.ts +++ b/shared/db/PvpDefense.ts @@ -41,7 +41,6 @@ export default class PvpDefense extends BaseModel { } public static async findByScale(roleId: string, min: number, max: number, lean = true) { - console.log(min, max); const result = await PvpDefenseModel.find({ roleId: {$ne: roleId}, ce: { $lte: max, $gte: min } }).sort({updatedAt: -1}).limit(100).lean(lean); return result; } diff --git a/shared/db/Role.ts b/shared/db/Role.ts index 824242404..93e22f01c 100644 --- a/shared/db/Role.ts +++ b/shared/db/Role.ts @@ -8,6 +8,7 @@ import { shouldRefresh } from '../pubUtils/util'; * 角色字段接口 */ @index({ roleId: 1 }) +@index({ towerLv: -1, towerUpTime: 1 }) // @index({ userInfo.uid: 1, serverId: 1 }) export default class Role extends BaseModel { @@ -100,6 +101,8 @@ export default class Role extends BaseModel { // 天梯相关 @prop({ required: true, default: 1 }) towerLv: number; // 天梯当前层数 + @prop({ required: true, default: new Date() }) + towerUpTime: Date; // 天梯爬到这一层的时间 @prop({ required: true, default: HANG_UP_CONSTS.MAX_SPD_UP_CNT}) hangUpSpdUpCnt: number; // 挂机加速次数 @@ -155,7 +158,7 @@ export default class Role extends BaseModel { } public static async towerLvUp(roleId: string, lean = true) { - let role = await RoleModel.findOneAndUpdate({roleId}, {$inc: {towerLv: 1}}, {new: true}).lean(lean); + let role = await RoleModel.findOneAndUpdate({roleId}, {$inc: {towerLv: 1}, towerUpTime: new Date()}, {new: true}).lean(lean); return role; } @@ -179,7 +182,6 @@ export default class Role extends BaseModel { } public static async levelup(roleId: string, lv: number, exp: number, lean = true) { - console.log(lv, exp) let role = await RoleModel.findOneAndUpdate({roleId}, {$set: { exp, lv }}, {new: true}).lean(lean); return role; } @@ -254,6 +256,17 @@ export default class Role extends BaseModel { } return role; } + + // 获取排行榜 + public static async getRank(type: string, fields: Array, page = 1, limit = 100, lean = true) { + let sortBy = {}; + if(type == 'tower') { + sortBy['towerLv'] = -1; + sortBy['towerUpTime'] = 1; + } + const ranks = await RoleModel.find().select(fields.join(' ')).sort(sortBy).limit(limit).skip((page - 1) * limit).lean(lean); + return ranks; + } } export const RoleModel = getModelForClass(Role); diff --git a/shared/db/TowerRecord.ts b/shared/db/TowerRecord.ts index 91e12b4c2..b6c3dba67 100644 --- a/shared/db/TowerRecord.ts +++ b/shared/db/TowerRecord.ts @@ -37,7 +37,7 @@ export default class TowerRecord extends BaseModel { const recDoc = new TowerRecordModel(); const update = Object.assign(recDoc.toJSON(), towerInfo ); const { roleId, lv } = towerInfo; - console.log(JSON.stringify(towerInfo)) + // console.log(JSON.stringify(towerInfo)) let rec = await TowerRecordModel.findOneAndUpdate({roleId, lv}, {$set: update}, {upsert: true, new: true}).lean(lean); return rec; } diff --git a/shared/db/TowerTaskRec.ts b/shared/db/TowerTaskRec.ts index d8acab5f6..623a1bf09 100644 --- a/shared/db/TowerTaskRec.ts +++ b/shared/db/TowerTaskRec.ts @@ -101,7 +101,7 @@ export default class TowerTaskRec extends BaseModel { public static async refreshTask(roleId: string, lean = true) { let curTime = new Date(); const refTime = getRefTime(curTime, TOWER_TASK_CONST.REFRESH_TIME); - console.log(refTime) + // console.log(refTime) const recs = await TowerTaskRecModel.updateMany({roleId, createdAt: {$gte: refTime}, refreshStatus: 1}, {refreshStatus: 0}, {new: true}).lean(lean); return recs; } diff --git a/shared/pubUtils/gamedata.ts b/shared/pubUtils/gamedata.ts index 27778f0dd..7b585befd 100644 --- a/shared/pubUtils/gamedata.ts +++ b/shared/pubUtils/gamedata.ts @@ -1,5 +1,6 @@ import fs = require('fs'); import path = require('path'); +import { decodeStr, decodeStrSingle } from './util'; let gamedata = {}; const wars = ['dic_zyz_gk_main', 'dic_zyz_gk_mainElite', 'dic_zyz_gk_daily', 'dic_zyz_gk_event', 'dic_zyz_gk_tower', 'dic_zyz_gk_expedition']; // 关卡相关的表 @@ -35,7 +36,7 @@ function parseTowerData() { } function parseTowerTaskData() { - const towerTaskFile = 'dic_zyz_tower_tasks'; + const towerTaskFile = 'dic_zyz_search'; const towerTaskData = gamedata['jsons'][towerTaskFile] || []; towerTaskData.forEach(elem => { if (elem && elem.taskId) { @@ -172,7 +173,6 @@ export function getLvByExp(exp: number) { let curLv = 0; let entries = levelInfos.entries(); for (let [lv, {sum}] of entries) { - console.log(lv, sum) if(exp < sum) { curLv = lv; break; } @@ -182,6 +182,5 @@ export function getLvByExp(exp: number) { } export function getExpByLv(lv: number) { - console.log(lv) return levelInfos.get(lv); } \ No newline at end of file diff --git a/shared/pubUtils/util.ts b/shared/pubUtils/util.ts index a047987b1..7548cb892 100644 --- a/shared/pubUtils/util.ts +++ b/shared/pubUtils/util.ts @@ -19,6 +19,7 @@ const moment = require('moment'); if(str == '&'|| !str) { return [] } else { + console.log(str) return str.split(splitForm).map(cur => { return decodeStrSingle(type,cur); }); @@ -50,7 +51,7 @@ const moment = require('moment'); result = { gid: parseInt(gid), count: parseInt(count), frequency: parseInt(frequency) }; break; } - case 'eventSuitLevel': { + case 'suitLevel': { let [min, max] = arr; if(isNaN(min) || isNaN(max)) throw new Error('data table format wrong'); result = { min: parseInt(min), max: parseInt(max) }; @@ -180,7 +181,7 @@ export function deltaDays(preTime: Date, proTime: Date): number { */ export function shouldRefresh(preTime: Date, now: Date, hour: number, deltaDay = 1): boolean { let curTime = new Date(now.getTime()); - let refeshTime = curTime.setHours(hour, 0, 0, 0); + let refeshTime = setLocalHours(hour, curTime); if (refeshTime - preTime.getTime() > deltaDay * 24 * 60 * 60 * 1000 && curTime.getTime() >= refeshTime) { return true; } @@ -197,9 +198,8 @@ export function getRefTime(now = new Date(), hour: number, day = 0) { if (curTime.getHours() < hour) { curTime.setDate(curTime.getDate() - 1); } - curTime.setHours(hour, 0, 0, 0); - curTime = new Date(curTime.getTime() + day * 24 * 60 * 60 * 1000); - return curTime; + let today = setLocalHours(hour, curTime); + return new Date(today + day * 24 * 60 * 60 * 1000); } export function getRandEelm(source: Array = [], cnt = 1): Array { @@ -301,4 +301,14 @@ export function calculateNum(ratio: {A: number, B: number}, params: {num: number console.error(e); return defaultVal; } +} + + +export function setLocalHours(hour: number, curTime = new Date()) { + // curTime: 格林威治时间 + let offset = curTime.getTimezoneOffset(); // 格林威治时间和本地时间之间的时差(分) + console.log('offset:', offset); + let localTime = new Date(curTime.getTime() - offset * 60 * 1000 + 8 * 60 * 60 * 1000); // 中国时间 + localTime.setUTCHours(hour, 0, 0, 0); // 中国的几点 + return localTime.getTime() + offset * 60 * 1000 - 8 * 60 * 60 * 1000; // 回到格林威治时间 } \ No newline at end of file diff --git a/shared/resource/jsons/dic_zyz_daily.json b/shared/resource/jsons/dic_zyz_daily.json index cddf11820..0fe669a1e 100644 --- a/shared/resource/jsons/dic_zyz_daily.json +++ b/shared/resource/jsons/dic_zyz_daily.json @@ -2,32 +2,32 @@ { "dailyType": 1, "name": "护送商人", - "timesPerDay": 5, - "timesCanBuy": 10, - "difficultLvl": "3001&3002&3003&3004&3005", + "timesPerDay": 200, + "timesCanBuy": 200, + "difficultLvl": "3001&3002&3003&3004&3005&3006&3007&3008&3009", "description": "内有不同难度,可获得大量铜钱" }, { "dailyType": 2, "name": "城池守卫", - "timesPerDay": 5, - "timesCanBuy": 10, + "timesPerDay": 200, + "timesCanBuy": 200, "difficultLvl": "3010&3011&3012&3013&3014", "description": "内有不同难度,可获得大量武将经验书" }, { "dailyType": 3, "name": "保护矿产", - "timesPerDay": 5, - "timesCanBuy": 10, + "timesPerDay": 200, + "timesCanBuy": 200, "difficultLvl": "3020&3021&3022&3023&3024", "description": "内有不同难度,可获得大量装备材料" }, { "dailyType": 4, "name": "测试测试", - "timesPerDay": 5, - "timesCanBuy": 10, + "timesPerDay": 200, + "timesCanBuy": 200, "difficultLvl": "3020&3021&3022&3023&3024", "description": "内有不同难度,测试用" } diff --git a/shared/resource/jsons/dic_zyz_gk_daily.json b/shared/resource/jsons/dic_zyz_gk_daily.json index b3fe0af07..e8a573141 100644 --- a/shared/resource/jsons/dic_zyz_gk_daily.json +++ b/shared/resource/jsons/dic_zyz_gk_daily.json @@ -96,7 +96,7 @@ "dispatchJsonId": 3005, "bg_img_id": 501, "script_id": 0, - "fixReward": "31003&1|31004&30|31002&20|31002&20", + "fixReward": "31001&1|31002&30|31002&20|31002&20", "warType": 4, "gk_name": "每日&护送商人", "kingExp": 100, @@ -227,14 +227,14 @@ "iconName": "新手", "recommendedPower": 10008, "previousGk": 0, - "dailyType": 1 + "dailyType": 2 }, { "war_id": 3011, "dispatchJsonId": 3011, "bg_img_id": 501, "script_id": 0, - "fixReward": "10206&1|1&10|2&2|3&3", + "fixReward": "10201&1|1&10|2&2|3&3", "warType": 4, "gk_name": "每日&城池守卫", "kingExp": 100, @@ -303,7 +303,7 @@ "dispatchJsonId": 3014, "bg_img_id": 501, "script_id": 0, - "fixReward": "31003&1|31004&30|31002&20|31002&20", + "fixReward": "31001&1|31002&30|31002&20|31002&20", "warType": 4, "gk_name": "每日&城池守卫", "kingExp": 100, @@ -342,7 +342,7 @@ "iconName": "新手", "recommendedPower": 10008, "previousGk": 0, - "dailyType": 1 + "dailyType": 3 }, { "war_id": 3021, @@ -418,7 +418,7 @@ "dispatchJsonId": 3024, "bg_img_id": 501, "script_id": 0, - "fixReward": "31003&1|31004&30|31002&20|31002&20", + "fixReward": "31001&1|31002&30|31002&20|31002&20", "warType": 4, "gk_name": "每日&保护矿产", "kingExp": 100, diff --git a/shared/resource/jsons/dic_zyz_search.json b/shared/resource/jsons/dic_zyz_search.json new file mode 100644 index 000000000..2ca105184 --- /dev/null +++ b/shared/resource/jsons/dic_zyz_search.json @@ -0,0 +1,182 @@ +[ + { + "taskId": 1, + "taskName": "调查怪事", + "quality": 1, + "reward": "31001&50|31002&100", + "additionalReward": "10201&5|10202&10", + "termsForAdd": "1&2&2|2&2&1|3&1&1", + "actorNeeded": 2, + "completeTime": 60, + "suitFloor": 1, + "weight": 1 + }, + { + "taskId": 2, + "taskName": "调查嘻嘻", + "quality": 1, + "reward": "17001&50|17002&100", + "additionalReward": "10305&5|10401&10", + "termsForAdd": "2&1&1|3&2&1", + "actorNeeded": 2, + "completeTime": 60, + "suitFloor": 1, + "weight": 1 + }, + { + "taskId": 3, + "taskName": "调查呵呵", + "quality": 1, + "reward": "17003&50|17004&100", + "additionalReward": "10402&5|10403&10", + "termsForAdd": "2&3&1|3&3&1", + "actorNeeded": 2, + "completeTime": 60, + "suitFloor": 1, + "weight": 1 + }, + { + "taskId": 4, + "taskName": "调查多龙巴鲁托", + "quality": 2, + "reward": "17005&50|17006&100", + "additionalReward": "10404&5|10405&10", + "termsForAdd": "2&4&1|3&4&1", + "actorNeeded": 2, + "completeTime": 60, + "suitFloor": 1, + "weight": 1 + }, + { + "taskId": 5, + "taskName": "调查美纳斯", + "quality": 2, + "reward": "17007&50|17008&100", + "additionalReward": "10501&5|10502&10", + "termsForAdd": "1&1&1|2&4&1|3&5&1", + "actorNeeded": 2, + "completeTime": 60, + "suitFloor": 1, + "weight": 1 + }, + { + "taskId": 6, + "taskName": "调查凯南", + "quality": 2, + "reward": "10001&50|10002&100", + "additionalReward": "10503&5|10504&10", + "termsForAdd": "3&6&1", + "actorNeeded": 2, + "completeTime": 60, + "suitFloor": 1, + "weight": 1 + }, + { + "taskId": 7, + "taskName": "调查男枪", + "quality": 3, + "reward": "10003&50|10004&100", + "additionalReward": "10505&5|10601&10", + "termsForAdd": "3&7&1", + "actorNeeded": 2, + "completeTime": 60, + "suitFloor": 1, + "weight": 1 + }, + { + "taskId": 8, + "taskName": "调查潘森", + "quality": 3, + "reward": "10005&50|10101&100", + "additionalReward": "10602&5|10603&10", + "termsForAdd": "3&8&2", + "actorNeeded": 3, + "completeTime": 60, + "suitFloor": 1, + "weight": 1 + }, + { + "taskId": 9, + "taskName": "调查卡牌", + "quality": 3, + "reward": "10102&50|10103&100", + "additionalReward": "10604&5|10605&10", + "termsForAdd": "1&1&1|2&1&1|3&1&1", + "actorNeeded": 3, + "completeTime": 60, + "suitFloor": 1, + "weight": 1 + }, + { + "taskId": 10, + "taskName": "调查瑟提", + "quality": 4, + "reward": "10103&50|10104&100", + "additionalReward": "10701&5|10702&10", + "termsForAdd": "1&2&1|2&2&1|3&2&1", + "actorNeeded": 3, + "completeTime": 120, + "suitFloor": 1, + "weight": 1 + }, + { + "taskId": 11, + "taskName": "调查班图", + "quality": 4, + "reward": "10105&50|10201&100", + "additionalReward": "10703&5|10704&10", + "termsForAdd": "1&1&1|2&3&1|3&3&1", + "actorNeeded": 3, + "completeTime": 120, + "suitFloor": 1, + "weight": 1 + }, + { + "taskId": 12, + "taskName": "调查政府", + "quality": 4, + "reward": "10202&50|10203&100", + "additionalReward": "10705&5|12001&10", + "termsForAdd": "1&2&1|2&4&1|3&4&1", + "actorNeeded": 3, + "completeTime": 120, + "suitFloor": 1, + "weight": 1 + }, + { + "taskId": 13, + "taskName": "调查CIA", + "quality": 5, + "reward": "10204&50|10205&100", + "additionalReward": "12002&5|12003&10", + "termsForAdd": "1&1&1|2&1&1|3&5&1", + "actorNeeded": 3, + "completeTime": 120, + "suitFloor": 1, + "weight": 1 + }, + { + "taskId": 14, + "taskName": "调查中情局", + "quality": 5, + "reward": "10301&50|10302&100", + "additionalReward": "12004&5|12005&10", + "termsForAdd": "1&2&1|2&2&1|3&6&1", + "actorNeeded": 3, + "completeTime": 120, + "suitFloor": 1, + "weight": 1 + }, + { + "taskId": 15, + "taskName": "调查王宇一", + "quality": 5, + "reward": "10303&50|10304&100", + "additionalReward": "12006&5|12007&10", + "termsForAdd": "1&1&1|2&3&1|3&7&1", + "actorNeeded": 3, + "completeTime": 120, + "suitFloor": 1, + "weight": 1 + } +] \ No newline at end of file diff --git a/shared/resource/jsons/dic_zyz_tower_tasks.json b/shared/resource/jsons/dic_zyz_tower_tasks.json deleted file mode 100644 index c1bfef49a..000000000 --- a/shared/resource/jsons/dic_zyz_tower_tasks.json +++ /dev/null @@ -1,86 +0,0 @@ -[ - { - "taskId": 1, - "taskName": "任务1", - "quality": 1, - "reward": "1&2|2&1", - "bonus": "3&2|4&1", - "bonusCondition": "2&2&1", - "actorCnt": 1, - "completeTime": 30, - "suitFloor": 1, - "weight": 1 - }, - { - "taskId": 2, - "taskName": "任务2", - "quality": 2, - "reward": "1&2|2&1", - "bonus": "3&2|4&1", - "bonusCondition": "1&5&2", - "actorCnt": 2, - "completeTime": 120, - "suitFloor": 1, - "weight": 1 - }, - { - "taskId": 3, - "taskName": "任务3", - "quality": 3, - "reward": "1&2|2&1", - "bonus": "3&2|4&1", - "bonusCondition": "3&1&1", - "actorCnt": 1, - "completeTime": 500000, - "suitFloor": 1, - "weight": 1 - }, - { - "taskId": 4, - "taskName": "任务4", - "quality": 4, - "reward": "1&2|2&1", - "bonus": "3&2|4&1", - "bonusCondition": "1&5&2|2&2&1|3&1&1", - "actorCnt": 1, - "completeTime": 50, - "suitFloor": 1, - "weight": 1 - }, - { - "taskId": 5, - "taskName": "任务5", - "quality": 4, - "reward": "1&2|2&1", - "bonus": "3&2|4&1", - "bonusCondition": "1&5&2|2&2&1|3&1&1", - "actorCnt": 1, - "completeTime": 30, - "suitFloor": 1, - "weight": 1 - }, - { - "taskId": 6, - "taskName": "任务6", - "quality": 5, - "reward": "1&2|2&1", - "bonus": "3&2|4&1", - "bonusCondition": "1&5&2|2&2&1|3&1&1", - "actorCnt": 1, - "completeTime": 30, - "suitFloor": 1, - "weight": 1 - }, - { - "taskId": 7, - "taskName": "任务7", - "quality": 5, - "reward": "1&2|2&1", - "bonus": "3&2|4&1", - "bonusCondition": "1&5&2|2&2&1|3&1&1", - "actorCnt": 1, - "completeTime": 30, - "suitFloor": 1, - "weight": 1 - } -] \ No newline at end of file diff --git a/web-server/app/controller/home.ts b/web-server/app/controller/home.ts index e305b99aa..e55186747 100644 --- a/web-server/app/controller/home.ts +++ b/web-server/app/controller/home.ts @@ -8,13 +8,6 @@ export default class HomeController extends Controller { public async dev() { const { ctx } = this; - let time1 = new Date(); - let time2 = Number(time1); - let offset = time1.getTimezoneOffset(); - - let today = time1.setHours(0, 0, 0, 0); - - console.log(time1, time2, offset, today); await ctx.render('index',{ title: 'xxx' });