From 86227d696b4f15c4940a15d4b28a0dc3335ea98f Mon Sep 17 00:00:00 2001 From: hxp <ale99527@vip.qq.com> Date: 星期二, 02 七月 2019 16:55:45 +0800 Subject: [PATCH] 7690 【2.0.200】【后端】取消拍卖行获得拍品的广播和邮件 --- ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/GameWorld.py | 70 +++++++++++++++++++++++++++-------- 1 files changed, 54 insertions(+), 16 deletions(-) diff --git a/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/GameWorld.py b/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/GameWorld.py index e7edcd4..ade467b 100644 --- a/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/GameWorld.py +++ b/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/GameWorld.py @@ -45,16 +45,15 @@ import datetime import ChConfig import os -import MapConfig import CommFunc import ShareDefine -import PyMapTable #import psyco from decimal import Decimal import time import copy import ConfigParser - +import PyGameData +import urllib import md5 #--------------------------------------------------------------------- #设置允许的最大迭代数目, 默认1000 @@ -596,11 +595,16 @@ @param dateInfo: 运营活动表配置的日期信息, 如果是纯数字代表开服天 @param openServerDay: 当前开服天 ''' - if not dateInfo.isdigit(): + if dateInfo.startswith("Mix"): + diffDay = GetGameWorld().GetGameWorldDictByKey(ShareDefine.Def_Notify_WorldKey_MixServerDay) + 1 + actionServerDay = int(dateInfo[3:]) + elif not dateInfo.isdigit(): return dateInfo - actionServerDay = int(dateInfo) + else: + diffDay = openServerDay + actionServerDay = int(dateInfo) curDateTime = datetime.datetime.today() - actionDateTime = curDateTime + datetime.timedelta(days=(actionServerDay-openServerDay)) + actionDateTime = curDateTime + datetime.timedelta(days=(actionServerDay-diffDay)) return "%d-%d-%d" % (actionDateTime.year, actionDateTime.month, actionDateTime.day) ##获得服务器系统时间 @@ -746,6 +750,17 @@ return curNPC return +def FindNPCByNPCIDEx(copyMapID, npcID): + #查询某条分线的npc + gameNPCManager = GetNPCManager() + for index in xrange(gameNPCManager.GetNPCCountByGWIndex(copyMapID)): + curNPC = gameNPCManager.GetNPCByIndexByGWIndex(copyMapID, index) + curID = curNPC.GetID() + if curID == 0: + continue + if npcID == curNPC.GetNPCID(): + return curNPC + return #--------------------------------------------------------------------- ##根据NPC的类型选择返回对象 # @param npcIndex NPC索引 @@ -1035,15 +1050,19 @@ def GetPlatform(): return ReadChConfig.GetPyMongoConfig("platform", "PlatformName") -##获得当前服务器ID -# @param 无 -# @return -def GetServerID(): - return ToIntDef(GetServerSID()[1:], 0) +#=============================================================================== +# ##获得当前服务器ID +# # @param 无 +# # @return +# def GetServerID(): +# return ToIntDef(GetServerSID()[1:], 0) +#=============================================================================== -def GetServerSID(): - ##获得当前服务器ID, 带s的 - return ReadChConfig.GetPyMongoConfig("platform", "ServerID") +#=============================================================================== +# def GetServerSID(): +# ##获得当前服务器ID, 带s的 +# return ReadChConfig.GetPyMongoConfig("platform", "ServerID") +#=============================================================================== def GetCreateRoleDays(curPlayer): # 获取创角第几天 @@ -1074,7 +1093,7 @@ mainServerID = ToIntDef(ReadChConfig.GetPyMongoConfig("platform", "%sMainServerID" % accIDPlatform), None) if mainServerID != None: return mainServerID - return GetServerID() + return 0 #=============================================================================== @@ -1576,6 +1595,12 @@ ## 是否跨服服务器 return ToIntDef(ReadChConfig.GetPyMongoConfig("Merge", "IsMergeServer"), 0) +def GetCrossZoneName(): + ## 跨服服务器分区名,标记一起跨服分区的名字,配置在跨服服务器,子服不用配置,由跨服服务器同步 + if IsCrossServer(): + return ReadChConfig.GetPyMongoConfig("Merge", "CrossZoneName") + return PyGameData.g_crossZoneName + ## 时间格式转换成数值时间,可参考datetime.datetime.fromtimestamp(102645645) # @param timeNum # @return 时间数值 1970年起 @@ -1805,7 +1830,8 @@ if updDictValue == 0: curPlayer.NomalDictDelProperty(keyName, 0) else: - curPlayer.NomalDictAddProperty(keyName, updDictValue) + import PlayerControl + PlayerControl.NomalDictSetProperty(curPlayer, keyName, updDictValue) #DebugLog("SetDictValueByBit keyFormat=%s,isBin=%s,bit=%s,keyNum=%s,keyName=%s,dictValue=%s,bitIndex=%s,updDictValue=%s" # % (keyFormat, isBin, bit, keyNum, keyName, dictValue, bitIndex, updDictValue)) return dictValue, updDictValue @@ -1959,3 +1985,15 @@ return +# 向运维发送邮件,用于需要紧急处理的信息 +# 此处不包含服务器报错的汇报 +def SendGameStateMail(msgInfo): + # 使用方式 向OpenStateUrl 发送Type为GameWarning,那么就会收到一封游戏内容警告邮件,信息为MsgInfo + getUrl = ReadChConfig.GetPyMongoConfig("EventReport", "OpenStateUrl") + groupID = ReadChConfig.GetPyMongoConfig("platform", "GroupID") + userDBName = ReadChConfig.GetPyMongoConfig("connect", "USER_DB_NAME") + getUrl = getUrl + "?Type=GameWarning&groupID=%s&userDBName=%s&MsgInfo=%s"%(groupID, userDBName, urllib.quote_plus(msgInfo)) + + GetGameWorld().EventReport_EventReport("", "", "", "", 0, getUrl) + + -- Gitblit v1.8.0