From 7ceba1452ba6395abd5841f62e96e384df21aa05 Mon Sep 17 00:00:00 2001 From: hxp <ale99527@vip.qq.com> Date: 星期六, 29 十二月 2018 02:38:08 +0800 Subject: [PATCH] 5424 【后端】【1.4】跨服竞技场开发(GM工具增加跨服服务器维护操作) --- ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/GameWorld.py | 92 +++++++++++++++++++++++++++++++++------------- 1 files changed, 66 insertions(+), 26 deletions(-) diff --git a/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/GameWorld.py b/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/GameWorld.py index d6faac5..b3b541d 100644 --- a/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/GameWorld.py +++ b/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/GameWorld.py @@ -590,6 +590,19 @@ return curTimeStr #--------------------------------------------------------------------- + +def GetOperationActionDateStr(dateInfo, openServerDay): + '''获取运营活动对应日期,存数字代表开服天配置,需要转化为对应的日期 + @param dateInfo: 运营活动表配置的日期信息, 如果是纯数字代表开服天 + @param openServerDay: 当前开服天 + ''' + if not dateInfo.isdigit(): + return dateInfo + actionServerDay = int(dateInfo) + curDateTime = datetime.datetime.today() + actionDateTime = curDateTime + datetime.timedelta(days=(actionServerDay-openServerDay)) + return "%d-%d-%d" % (actionDateTime.year, actionDateTime.month, actionDateTime.day) + ##获得服务器系统时间 # @param 无 # @return 返回值. 时间Data格式 @@ -1003,18 +1016,8 @@ return GetGameWorld().GetServerVersion() def GetServerGroupID(): - # 服务器组ID: 代表一台服务器中包含的合服、混服的各平台区服组成的一个独立游戏区服服务器环境, 用某个ID来代表此服务器 - # 在跨服环境中,此ID就是代表来自同一台服务器子服的玩家 - # 服务器组ID生成规则: DB平台标识对应编号 * 1000000 + DB配置的ServerID - # ServerID支持范围: 1~999999 - # 平台编号支持范围:1~2000 - platform = GetPlatform() - serverNum = GetPlatformServerNum(platform) - if not serverNum: - return 0 - serverNum = max(1, min(2000, serverNum)) - serverID = max(1, min(999999, GetServerID())) - return serverNum * 1000000 + serverID + ## 服务器组ID,必须唯一,代表这台物理服务器 + return ToIntDef(ReadChConfig.GetPyMongoConfig("platform", "GroupID"), 0) def GetPlatformServerNum(platform): # 获取服务器的平台编号 @@ -1073,10 +1076,26 @@ return mainServerID return GetServerID() + +#=============================================================================== +# 平台ID = appid +# 运营ID = spid +# 服务器账号更改 +# 原先账号组合为 +# 运营提供的玩家账号ID + 平台ID + 区服组成 +# +# 因为IOS和安卓在支持混服的情况下,还要能支持同一个角色号,故引入一个新的运营ID(客户端打包配置),以保证玩家账号为同一个 +# 账号组合变更 +# 运营提供的玩家账号ID + 运营ID + 区服组成 +# +# 原游戏中获取平台ID接口变更 +# 1. db 从数据库中的账号表获取AppID +# 2. GameServer和MapServer 接口改为GetOperator 参考 GetPlayerPlatform +#=============================================================================== + ##获取玩家所属平台 -def GetPlayerPlatform(gameAccID): - infoList = gameAccID.split(Def_AccID_Split_Sign) - return "" if len(infoList) < 3 else infoList[-2] +def GetPlayerPlatform(curPlayer): + return curPlayer.GetAccountData().GetOperator() ##获取平台账号 def GetPlatformAccID(gameAccID): @@ -1553,14 +1572,9 @@ return inputText -## 是否跨服服务器 -# @param None None -# @return -def IsMergeServer(): - config = MapConfig.GetConfig() - - return config.get('IsMergeWarServe', 0) - +def IsCrossServer(): + ## 是否跨服服务器 + return ToIntDef(ReadChConfig.GetPyMongoConfig("Merge", "IsMergeServer"), 0) ## 时间格式转换成数值时间,可参考datetime.datetime.fromtimestamp(102645645) # @param timeNum @@ -1589,9 +1603,9 @@ ''' checkDate = ChangeTimeNumToDatetime(checkTime) curDate = GetCurrentTime() - if checkDate > curDate: - #DebugLog("检查时间比当前时间大") - return False + #if checkDate > curDate: + # #DebugLog("检查时间比当前时间大") + # return False Def_OnEventHour = ShareDefine.Def_OnEventHour chkYear, chkMonth, chkDay, chkHour = checkDate.year, checkDate.month, checkDate.day, checkDate.hour @@ -1608,6 +1622,7 @@ checkDateEx = datetime.datetime(chkYear, chkMonth, chkDay, 0, 0, 0) curDateEx = datetime.datetime(curYear, curMonth, curDay, 0, 0, 0) diffDays = (curDateEx - checkDateEx).days + ## 当前时间比检查的时间大1天 if diffDays == 1: if chkHour < Def_OnEventHour: #DebugLog("日期相差天数1, 不同天! chkHour(%s) < %s" % (chkHour, Def_OnEventHour)) @@ -1618,6 +1633,19 @@ return False #DebugLog("日期相差天数1, 同天! curHour(%s) < %s <= chkHour(%s)" % (curHour, Def_OnEventHour, chkHour)) + return True + + ## 当前时间比检查的时间小1天 + elif diffDays == -1: + if curHour < Def_OnEventHour: + #DebugLog("日期相差天数-1, 不同天! curHour(%s) < %s" % (curHour, Def_OnEventHour)) + return False + + if chkHour >= Def_OnEventHour: + #DebugLog("日期相差天数-1, 不同天! chkHour(%s) >= %s" % (chkHour, Def_OnEventHour)) + return False + + #DebugLog("日期相差天数-1, 同天! chkHour(%s) < %s <= curHour(%s)" % (chkHour, Def_OnEventHour, curHour)) return True #DebugLog("日期相差天数大于1,不同一天!") @@ -1814,6 +1842,18 @@ 'SendMergerChildMsg', msgList, len(msgList)) return +def SendMsgToCrossServer(msgType, dataMsg, srcPlayerID=0, queryType=0, queryID=0): + ## 发送信息到跨服服务器 + msgList = str([msgType, dataMsg]) + GetPlayerManager().GameServer_QueryPlayerResult(srcPlayerID, queryType, queryID, "SendMsgToCrossServer", msgList, len(msgList)) + return + +def SendMsgToClientServer(msgType, dataMsg, serverGroupIDList, srcPlayerID=0, queryType=0, queryID=0): + ## 发送信息到子服 + msgList = str([msgType, dataMsg, serverGroupIDList]) + GetPlayerManager().GameServer_QueryPlayerResult(srcPlayerID, queryType, queryID, "SendMsgToClientServer", msgList, len(msgList)) + return + ## 根据排行获取名次对应值 # @param orderDict {名次:obj, ...} 名次支持段跳跃 # @param order 名次,从1开始 -- Gitblit v1.8.0