From a410c052ad4992ca846e3e30f0ccf9ab0b85a1d7 Mon Sep 17 00:00:00 2001 From: hxp <ale99527@vip.qq.com> Date: 星期三, 17 九月 2025 17:14:32 +0800 Subject: [PATCH] 129 【战斗】战斗系统-服务端(甄姬、曹操技能;增加本次技能万分比效果ID6004;) --- ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/PyMongoDB/LogicProcess/UserCtrlDB.py | 99 +++++++++++++++++++++++++++++++------------------ 1 files changed, 63 insertions(+), 36 deletions(-) diff --git a/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/PyMongoDB/LogicProcess/UserCtrlDB.py b/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/PyMongoDB/LogicProcess/UserCtrlDB.py index 38349a0..9c88912 100644 --- a/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/PyMongoDB/LogicProcess/UserCtrlDB.py +++ b/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/PyMongoDB/LogicProcess/UserCtrlDB.py @@ -27,7 +27,7 @@ import inspect from Collections.CollectionDefine import * import binascii -# from GMToolLogicProcess import ProjSpecialProcess +from GMToolLogicProcess import ProjSpecialProcess from Common import (CommFunc, mylog, CommFuncEx) import PegasusCollectorProxy import shutil @@ -415,12 +415,45 @@ return def findDBPlayer(self, playerID): + '''根据玩家ID查找dbPlayer + @return: None or tagDBPlayer + ''' col = self.db[UCN_DBPlayer] dbPlayer = DataServerPlayerData.tagDBPlayer() dbPlayer.IsDeleted = 0 if not dbPlayer.adoLoadCEx(col, {"PlayerID":playerID}): return return dbPlayer + + def findDBPlayerByName(self, playerName, backDBPlayer=False): + '''根据玩家名查找dbPlayer + @param backDBPlayer: 可指定返回 tagDBPlayer 实例,默认false,直接返回db数据字典 + @return: None or db数据字典{k:v, ...} or tagDBPlayer + ''' + collection = self.db[UCN_DBPlayer] + rec = collection.find_one({'PlayerName':fix_incomingText(playerName), 'IsDeleted':0}) + if not rec: + return + if backDBPlayer: + dbPlayer = DataServerPlayerData.tagDBPlayer() + dbPlayer.readRecord(rec) + return dbPlayer + return rec + + def findDBPlayerByAccID(self, accID, backDBPlayer=False): + '''根据玩家账号查找dbPlayer + @param backDBPlayer: 可指定返回 tagDBPlayer 实例,默认false,直接返回db数据字典 + @return: None or db数据字典{k:v, ...} or tagDBPlayer + ''' + collection = self.db[UCN_DBPlayer] + rec = collection.find_one({'AccID':fix_incomingText(accID), 'IsDeleted':0}) + if not rec: + return + if backDBPlayer: + dbPlayer = DataServerPlayerData.tagDBPlayer() + dbPlayer.readRecord(rec) + return dbPlayer + return rec def requestLogicProcess(self, pack): db = self.db @@ -433,6 +466,14 @@ mylog.debug("begin process request type = %d"%requestType) + if requestType == CommonDefine.gstGMToolCommand: + oFuncGrade = self.GetFuncGrade('gstGMToolCommand') + oFuncGrade.Start() + self.OnGMToolCommand(db, pack) + oFuncGrade.End() + return True + + if requestType == CommonDefine.gstGeneralDBOper: oFuncGrade = self.GetFuncGrade('gstGeneralDBOper') oFuncGrade.Start() @@ -815,12 +856,7 @@ oFuncGrade.End() return True - if requestType == CommonDefine.gstGMToolCmdUserDBRequest: - oFuncGrade = self.GetFuncGrade("gstGMToolCmdUserDBRequest") - oFuncGrade.Start() - self.OnGMToolCmdUserDBRequest(db, pack) - oFuncGrade.End() - return True + if requestType == CommonDefine.gstMergerChildToCenter: oFuncGrade = self.GetFuncGrade("gstMergerChildToCenter") oFuncGrade.Start() @@ -896,6 +932,24 @@ self.packSend(sessionID, 0, 0, CommonDefine.atMergeLogic, MMORPGPack.stGame, MMORPGPack.stData, sendPack.GetBuffer()) + def OnPlayerLogin(self, curPlayer): + ProjSpecialProcess.GMCmdPlayerLogin(curPlayer) + return + + def OnGMToolCommand(self, db, pack): + + if CommonDefine.IsDebug(): + import binascii + mylog.debug('buf = %s'%binascii.b2a_hex(pack.getBuffer())) + + try: + ProjSpecialProcess.OnGMToolCommand(pack) + except: + msg = error.formatMsg('error', error.ERROR_NO_172, "LogicProcessThread::OnGMToolCommand Catch a unexpetcted exception, error = %s"%traceback.format_exc()) + mylog.error(msg) + + + def OnGeneralDBOper(self, db, pack): buf = pack.getBuffer() recvPack = RecvPackProtocol.tagGDGameServerGeneralDBOper() @@ -3509,21 +3563,6 @@ DBPlayerRecData = DataServerPlayerData.tagDBPlayerRecData() data += DBPlayerRecData.adoQueryAll(collection) mylog.debug("tagDBPlayerRecData ok") - - collection = db[UCN_DBPyMineAreaAward] - DBPyMineAreaAward = DataServerPlayerData.tagDBPyMineAreaAward() - data += DBPyMineAreaAward.adoQueryAll(collection) - mylog.debug("tagDBPyMineAreaAward ok") - - collection = db[UCN_DBPyMineAreaRecord] - DBPyMineAreaRecord = DataServerPlayerData.tagDBPyMineAreaRecord() - data += DBPyMineAreaRecord.adoQueryAll(collection) - mylog.debug("tagDBPyMineAreaRecord ok") - - collection = db[UCN_DBPyMineAreaItem] - DBPyMineAreaItem = DataServerPlayerData.tagDBPyMineAreaItem() - data += DBPyMineAreaItem.adoQueryAll(collection) - mylog.debug("tagDBPyMineAreaItem ok") collection = db[UCN_DBPyCouple] DBPyCouple = DataServerPlayerData.tagDBPyCouple() @@ -3926,9 +3965,6 @@ gameDataReadPos = self.savegameServerWorldData(decompressGameData, gameDataReadPos, UCN_DBPyFuncTeam, DataServerPlayerData.tagDBPyFuncTeam, db) gameDataReadPos = self.savegameServerWorldData(decompressGameData, gameDataReadPos, UCN_DBPyFuncTeamMem, DataServerPlayerData.tagDBPyFuncTeamMem, db) gameDataReadPos = self.savegameServerWorldData(decompressGameData, gameDataReadPos, UCN_DBPlayerRecData, DataServerPlayerData.tagDBPlayerRecData, db) - gameDataReadPos = self.savegameServerWorldData(decompressGameData, gameDataReadPos, UCN_DBPyMineAreaAward, DataServerPlayerData.tagDBPyMineAreaAward, db) - gameDataReadPos = self.savegameServerWorldData(decompressGameData, gameDataReadPos, UCN_DBPyMineAreaRecord, DataServerPlayerData.tagDBPyMineAreaRecord, db) - gameDataReadPos = self.savegameServerWorldData(decompressGameData, gameDataReadPos, UCN_DBPyMineAreaItem, DataServerPlayerData.tagDBPyMineAreaItem, db) gameDataReadPos = self.savegameServerWorldData(decompressGameData, gameDataReadPos, UCN_DBPyCouple, DataServerPlayerData.tagDBPyCouple, db) gameDataReadPos = self.savegameServerWorldData(decompressGameData, gameDataReadPos, UCN_DBPyUnNotifyLoveGiftRec, DataServerPlayerData.tagDBPyUnNotifyLoveGiftRec, db) gameDataReadPos = self.savegameServerWorldData(decompressGameData, gameDataReadPos, UCN_DBPyCharmValueRec, DataServerPlayerData.tagDBPyCharmValueRec, db) @@ -4062,9 +4098,6 @@ gameDataReadPos = self.savegameServerWorldData(decompressGameData, gameDataReadPos, UCN_DBPyFuncTeam, DataServerPlayerData.tagDBPyFuncTeam, db) gameDataReadPos = self.savegameServerWorldData(decompressGameData, gameDataReadPos, UCN_DBPyFuncTeamMem, DataServerPlayerData.tagDBPyFuncTeamMem, db) gameDataReadPos = self.savegameServerWorldData(decompressGameData, gameDataReadPos, UCN_DBPlayerRecData, DataServerPlayerData.tagDBPlayerRecData, db) - gameDataReadPos = self.savegameServerWorldData(decompressGameData, gameDataReadPos, UCN_DBPyMineAreaAward, DataServerPlayerData.tagDBPyMineAreaAward, db) - gameDataReadPos = self.savegameServerWorldData(decompressGameData, gameDataReadPos, UCN_DBPyMineAreaRecord, DataServerPlayerData.tagDBPyMineAreaRecord, db) - gameDataReadPos = self.savegameServerWorldData(decompressGameData, gameDataReadPos, UCN_DBPyMineAreaItem, DataServerPlayerData.tagDBPyMineAreaItem, db) gameDataReadPos = self.savegameServerWorldData(decompressGameData, gameDataReadPos, UCN_DBPyCouple, DataServerPlayerData.tagDBPyCouple, db) gameDataReadPos = self.savegameServerWorldData(decompressGameData, gameDataReadPos, UCN_DBPyUnNotifyLoveGiftRec, DataServerPlayerData.tagDBPyUnNotifyLoveGiftRec, db) gameDataReadPos = self.savegameServerWorldData(decompressGameData, gameDataReadPos, UCN_DBPyCharmValueRec, DataServerPlayerData.tagDBPyCharmValueRec, db) @@ -5680,14 +5713,8 @@ mylog.error(msg) return False return True - def OnGMToolCmdUserDBRequest(self,db, pack): - # try: - # ProjSpecialProcess.OnGMToolCmdUserDBRequest(db,pack) - # except: - # msg = error.formatMsg('error', error.ERROR_NO_172, "OnGMToolCmdUserDBRequest Catch a unexpetcted exception, error = %s"%traceback.format_exc()) - # mylog.error(msg) - # return False - return True + + def OnMergerChildToCenter(self,db, pack): mylog.debug('OnMergerChildToCenter in') # #伪装来源,便于回包 -- Gitblit v1.8.0