From 3d1d9f4441de92a98a322823b48e983e7d7ce845 Mon Sep 17 00:00:00 2001 From: hujiabin <519660157@qq.com> Date: Thu, 25 Jan 2024 16:49:49 +0800 Subject: [PATCH] 1 --- doc/Chip.py | 28 --- doc/Fragment.py | 17 -- doc/Hero.py | 33 +--- webapp/controller/ChipController.class.php | 179 ------------------ .../ComputingPowerController.class.php | 6 + webapp/services/TameBattleDataService.php | 11 +- 6 files changed, 14 insertions(+), 260 deletions(-) diff --git a/doc/Chip.py b/doc/Chip.py index 16101b73..88b6fce7 100644 --- a/doc/Chip.py +++ b/doc/Chip.py @@ -31,34 +31,6 @@ class Chip(object): _common.RspHead(), ['!data', [_common.Chip()], '芯片信息'] ] - },{ - 'name': 'upgradeLevelPreview', - 'desc': '芯片升级前置操作', - 'group': 'Chip', - 'url': 'webapp/index.php?c=Chip&a=upgradeLevelPreview', - 'params': [ - _common.ReqHead(), - ['unique_id', '', 'unique_id'], - ], - 'response': [ - _common.RspHead(), - ['!data', [_common.ChipPro()], '芯片信息'] - ] - },{ - 'name': 'upgradeLevel', - 'desc': '芯片升级', - 'group': 'Chip', - 'url': 'webapp/index.php?c=Chip&a=upgradeLevel', - 'params': [ - _common.ReqHead(), - ['unique_id_main', '', '源芯片token id'], - ['unique_id_param', '', '材料芯片token id 例:参数1 参数2 参数3'], - ], - 'response': [ - _common.RspHead(), - ['!data', [_common.Chip()], '芯片信息'], - ['property_chg', _common.PropertyChg(), '属性变更'], - ] },{ 'name': 'upgradeQuality', 'desc': '芯片升阶', diff --git a/doc/Fragment.py b/doc/Fragment.py index ae7c2901..b6038187 100644 --- a/doc/Fragment.py +++ b/doc/Fragment.py @@ -20,23 +20,6 @@ class Fragment(object): ['property_chg', _common.PropertyChg(), '属性变更'], ['item_id', 0, '道具id'] ] - },{ - 'name': 'syntheticFragmentOld', - 'desc': '碎片合成', - 'group': 'Fragment', - 'url': 'webapp/index.php?c=Fragment&a=syntheticFragment', - 'params': [ - _common.ReqHead(), - ['type', '', '类型:1 英雄;2 枪械'], - ['params', '', '普通碎片 item id,用“|”分开;例:item id1|item id2|item id3...'], - ['param', '', '特殊碎片 item id'], - ['item_id', '', '英雄或枪械 item id'], - ], - 'response': [ - _common.RspHead(), - ['property_chg', _common.PropertyChg(), '属性变更'], - ['item_id', 0, '道具id'] - ] },{ 'name': 'showBaseByItemId', 'desc': '查看item的基本信息', diff --git a/doc/Hero.py b/doc/Hero.py index 9c9ab5b0..6fc17694 100644 --- a/doc/Hero.py +++ b/doc/Hero.py @@ -47,22 +47,6 @@ class Hero(object): _common.RspHead(), ] }, - { - 'name': 'upgradeLevelPreview', - 'desc': '升等级', - 'group': 'Hero', - 'url': 'webapp/index.php?c=Hero&a=upgradeLevelPreview', - 'params': [ - _common.ReqHead(), - ['hero_uniid', 0, '英雄唯一id'], - ], - 'response': [ - _common.RspHead(), - ['old_hero', _common.Hero(), '英雄-老'], - ['new_hero', _common.Hero(), '英雄-新'], - ['cost', _common.Cost(), '所需费用'], - ] - }, { 'name': 'heroDetails', 'desc': '英雄详情', @@ -77,22 +61,7 @@ class Hero(object): ['!data', [_common.Hero()], '英雄信息'] ] }, - { - 'name': 'upgradeLv', - 'desc': '升级', - 'group': 'Hero', - 'url': 'webapp/index.php?c=Hero&a=upgradeLv', - 'params': [ - _common.ReqHead(), - ['hero_uniid', 0, '英雄唯一id'], - ], - 'response': [ - _common.RspHead(), - ['property_chg', _common.PropertyChg(), '属性变更'], - ['old_hero', _common.Hero(), '英雄-老'], - ['new_hero', _common.Hero(), '英雄-新'], - ] - },{ + { 'name': 'setHeroSkill', 'desc': '设置通用技能', 'group': 'Hero', diff --git a/webapp/controller/ChipController.class.php b/webapp/controller/ChipController.class.php index 2f6a704c..284a82f4 100644 --- a/webapp/controller/ChipController.class.php +++ b/webapp/controller/ChipController.class.php @@ -58,185 +58,6 @@ class ChipController extends BaseAuthedController )); } - public function upgradeLevelPreview(){ - $unique_id = trim(getReqVal('unique_id', 0)); - if (! $unique_id) { - $this->_rspErr(1, 'Please enter parameter unique_id'); - return; - } - $chipDb = Chip::find($unique_id); - if (!$chipDb){ - $this->_rspErr(1,'unique_id parameter error'); - return; - } - if ($chipDb['chip_grade'] == Chip::CHIP_LV_MAX){ - $this->_rspErr(1,' Level upper limit'); - return; - } - $paramMeta = mt\Parameter::getByName('chip_upgrade_cost'); - if (!$paramMeta){ - $this->_rspErr(1, ' parameter null'); - return; - } - $chip = Chip::toDto($chipDb); - $rand_attr = emptyReplace(json_decode($chipDb['rand_attr'], true), array()); - $chipMeta = mt\ChipAttr::getAttrByItemId($chipDb['item_id']); - if ($chipMeta){ - array_unshift($rand_attr,array( - 'attr_id'=>$chipMeta['attr_id'], - 'val' => $chipMeta['lv'.($chipDb['chip_grade']+1)] - )); - } - $chip['rand_attr_after'] = $rand_attr; - - $paramValue = explode('|',$paramMeta['param_value']); - $gold = 0; - $stone = 0; - switch ($chipDb['chip_grade']){ - case 1: { - $lv2 = explode(':',$paramValue[0]); - $gold = $lv2[0]; - $stone = $lv2[1]; - };break; - case 2: { - $lv3 = explode(':',$paramValue[1]); - $gold = $lv3[0]; - $stone = $lv3[1]; - };break; - } - - $chip['cost'] = array( - array( - 'item_id' => V_ITEM_GOLD, - 'item_num' => $gold - ), - array( - 'item_id' => V_ITEM_CHIP_META, - 'item_num' => $stone - ) - ); - $this->_rspData(array( - 'data' => $chip - )); - } - - public function selectChip(){ - $unique_id = trim(getReqVal('unique_id', 0)); - $idxArr = explode(' ',$unique_id); - if (count($idxArr)<0){ - $this->_rspErr(1, 'Please enter instructions'); - return; - } - $chipDbMain = Chip::find($idxArr[0]); - $chipDbParam = Chip::find($idxArr[1]); - if (!$chipDbMain || !$chipDbParam){ - $this->_rspErr(1,'unique_id parameter error'); - return; - } - if ($chipDbParam['token_id']) { - $this->_rspErr(1, "Unable to use nft chip"); - return; - } - if (!$chipDbParam['state']) { - $this->_rspErr(1, "Unable to use free chip"); - return; - } - if ($chipDbParam['chip_grade']>$chipDbMain['chip_grade']){ - $this->_rspErr(1, "The selected material is too high grade"); - return; - } - $cost = \services\FormulaService::getChipCumulativeCost($chipDbParam['chip_grade']); - $this->_rspData(['cost'=>$cost]); - } - - public function upgradeLevel(){ - $chipUniId = trim(getReqVal('chip_uniid', 0)); - if (!$chipUniId) { - $this->_rspErr(1, 'Please enter parameter'); - return; - } - $chipDb = Chip::find($chipUniId); - if (!$chipDb){ - $this->_rspErr(1,'unique_id_main parameter error'); - return; - } - if ($chipDb['chip_grade'] == Chip::CHIP_LV_MAX){ - $this->_rspErr(1,' Level upper limit'); - return; - } - - $paramMeta = mt\Parameter::getByName('chip_upgrade_cost'); - if (!$paramMeta){ - $this->_rspErr(1, ' parameter null'); - return; - } - $paramValue = explode('|',$paramMeta['param_value']); - $gold = 0; - $stone = 0; - switch ($chipDb['chip_grade']){ - case 1: { - $lv2 = explode(':',$paramValue[0]); - $gold = $lv2[0]; - $stone = $lv2[1]; - };break; - case 2: { - $lv3 = explode(':',$paramValue[1]); - $gold = $lv3[0]; - $stone = $lv3[1]; - };break; - } - - $costItems = array( - array( - 'item_id' => V_ITEM_GOLD, - 'item_num' => $gold - ), - array( - 'item_id' => V_ITEM_CHIP_META, - 'item_num' => $stone - ), - ); - $lackItem = null; - if (!$this->_hasEnoughItems($costItems, $lackItem)) { - $this->_rspErr(3, $this->_getLackItemErrMsg($lackItem)); - return; - } - $this->_decItems($costItems); -// Bag::decItem(V_ITEM_CHIP_META,$stone); - - { - //埋点 - $event = [ - 'name' => LogService::CHIP_LEVEL_UP, - 'val' => $gold - ]; - LogService::consumeGold($event); - } - - $propertyChgService = new services\PropertyChgService(); - $propertyChgService->addChip(); - $propertyChgService->addBagChg(); - $propertyChgService->addUserChg(); - $rand_attr = emptyReplace(json_decode($chipDb['rand_attr'], true), array()); - $attrProMeta = \mt\ChipAttr::getAttrPool($chipDb); - array_push($rand_attr,array( - 'attr_id'=>$attrProMeta['attr_id'], - 'val'=>$attrProMeta['val'], - )); - Chip::update2($chipUniId, - array( - 'chip_grade' => $chipDb['chip_grade']+1, - //'state' => Chip::GETED_STATE, - 'rand_attr' => json_encode($rand_attr), - ) - ); - $chipDbNew = Chip::toDto(Chip::find($chipUniId)); - $this->_rspData([ - 'data'=>$chipDbNew, - 'property_chg' => $propertyChgService->toDto(), - ]); - } - public function upgradeQuality(){ $chipUniId = trim(getReqVal('chip_uniid', 0)); if (!$chipUniId) { diff --git a/webapp/controller/ComputingPowerController.class.php b/webapp/controller/ComputingPowerController.class.php index 2082031b..55dd5467 100644 --- a/webapp/controller/ComputingPowerController.class.php +++ b/webapp/controller/ComputingPowerController.class.php @@ -27,6 +27,12 @@ use mt\Parameter; use phpcommon\SqlHelper; class ComputingPowerController extends BaseAuthedController { + public function _handlePre() + { + parent::_handlePre(); + die; + } + public function info(){ $period_state = -1 ; //-1:算力周期未开始 0:正常周期 1:等待周期 2:维护周期 $curr_period = array( diff --git a/webapp/services/TameBattleDataService.php b/webapp/services/TameBattleDataService.php index e968b283..21fb7a59 100644 --- a/webapp/services/TameBattleDataService.php +++ b/webapp/services/TameBattleDataService.php @@ -1268,12 +1268,13 @@ class TameBattleDataService extends BaseService { switch (getXVal($this->allInfo,'room_mode', 0)){ case self::MATCH_MODE_PVP :{ - if (myself()->_getNowTime() > strtotime($currentHashRate['obtain_start_time']) && + if ($currentHashRate && + myself()->_getNowTime() > strtotime($currentHashRate['obtain_start_time']) && strtotime($currentHashRate['obtain_end_time']) > myself()->_getNowTime()){ $this->applyEx($hisBattleData['hash_rate_data']['pvpData']); $hisBattleData['hash_rate_data']['modifytime'] = myself()->_getNowTime(); } - if (! $server_task_state && + if (! $server_task_state && $currentServerTask && myself()->_getNowTime() > strtotime($currentServerTask['obtain_start_time']) && myself()->_getNowTime() < strtotime($currentServerTask['obtain_end_time'])) { $this->applyEx($serverTaskData['data']['pvpData']); @@ -1283,11 +1284,13 @@ class TameBattleDataService extends BaseService { } break; case self::ROOM_MODE_MOBA :{ - if (myself()->_getNowTime() > strtotime($currentHashRate['obtain_start_time']) && strtotime($currentHashRate['obtain_end_time']) > myself()->_getNowTime()){ + if ($currentHashRate && + myself()->_getNowTime() > strtotime($currentHashRate['obtain_start_time']) && + strtotime($currentHashRate['obtain_end_time']) > myself()->_getNowTime()){ $this->applyEx($hisBattleData['hash_rate_data']['mobaData']); $hisBattleData['hash_rate_data']['modifytime'] = myself()->_getNowTime(); } - if (! $server_task_state && + if (! $server_task_state && $currentServerTask && myself()->_getNowTime() > strtotime($currentServerTask['obtain_start_time']) && myself()->_getNowTime() < strtotime($currentServerTask['obtain_end_time'])) { $this->applyEx($serverTaskData['data']['mobaData']);