0312 同步遗漏更新导致的问题,暂未同步以下内容
5563 【英文】【BT】跨服服务器维护优化(打包数据改为db自行管理存取)
10396 新渠道游戏GM版本(增加gitHYGMGame = 21 # 21-欢游GM版,支持区分pid取不同的登录key;)
1111 优化充值兑换商品,直接通过db定时处理未兑换订单(频率调整为1秒5条; 优化查询,增加查询索引;);
1111 优化充值兑换商品,直接通过db定时处理未兑换订单;
| | |
| | | return
|
| | |
|
| | |
|
| | | process(os.sys.argv[1], int(os.sys.argv[2]))
|
| | | #process(os.sys.argv[1], int(os.sys.argv[2]))
|
| | |
| | | PlayerControl.SetCrossMapID(curPlayer, curPlayer.GetMapID()) # 因为主服上传数据之前该值为0,所以登录跨服后在跨服服务器要设置为对应地图
|
| | |
|
| | | #通知运行成功
|
| | | curPlayer.BalanceServer_PlayerLoginInitOK()
|
| | | curPlayer.BalanceServer_PlayerLoginInitOK() #向route设置玩家在map中的索引
|
| | | return
|
| | |
|
| | | def __DoPlayerLoginServer(curPlayer, tick):
|
| | |
| | |
|
| | | #锁住玩家, 等到读取地图成功, 再解锁
|
| | | curPlayer.SetCanMove(False)
|
| | | |
| | | #登陆发图形验证码
|
| | | PlayerAutoCheckOnline.PlayerLoginCaptcha(curPlayer, tick)
|
| | | except:
|
| | | curPlayer.Kick(IPY_GameWorld.disWaitForPlayerLoinError)
|
| | | import traceback
|
| | | GameWorld.RaiseException("玩家上线逻辑错误\r\n%s" % traceback.format_exc())
|
| | |
|
| | | try:
|
| | | curPlayer.SendToBServerServerInitOK() #通知route登录成功 ,route向客户端发送0109包
|
| | | OnAllServerInitOK(curPlayer, tick)
|
| | | #到此处已经可以保存数据,即使客户端不回包断线
|
| | | #后续登录流程等客户端回复 //01 07 地图读取OK#tagCInitMapOK 调用 LoadMapOK
|
| | | except:
|
| | | curPlayer.Kick(IPY_GameWorld.disWaitForPlayerLoinError)
|
| | |
| | | #
|
| | | #-------------------------------------------------------------------------------
|
| | | #
|
| | | UCN_DBPlayerPackData="tagDBPlayerPackData"
|
| | | UCN_DBGameRec="tagDBGameRec"
|
| | | UCN_DBPyFuncTeam="tagDBPyFuncTeam"
|
| | | UCN_DBPyFuncTeamMem="tagDBPyFuncTeamMem"
|
| | | UCN_DBPlayerRecData="tagDBPlayerRecData"
|
| | | UCN_DBPyMineAreaAward="tagDBPyMineAreaAward"
|
| | | UCN_DBPyMineAreaRecord="tagDBPyMineAreaRecord"
|
| | | UCN_DBPyMineAreaItem="tagDBPyMineAreaItem"
|
| | |
| | | import inspect
|
| | | DBConfig = __import__('Config.DBConfig')
|
| | |
|
| | | #------------------------------------------------------
|
| | | #玩家详细信息#tagDBPlayer
|
| | | class tagDBPlayer(Structure):
|
| | | _pack_ = 1
|
| | |
| | | ('Face', ctypes.c_int),
|
| | | ('FacePic', ctypes.c_int),
|
| | | ('Job', ctypes.c_int),
|
| | | ('RoleType', ctypes.c_ulong),
|
| | | ('ReincarnationLv', ctypes.c_ushort),
|
| | | ('LV', ctypes.c_int),
|
| | | ('TotalExp', ctypes.c_ulong),
|
| | |
| | | self.Face, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.FacePic, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.Job, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.RoleType, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.ReincarnationLv, pos = CommFunc.ReadWORD(buf, pos)
|
| | | self.LV, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.TotalExp, pos = CommFunc.ReadDWORD(buf, pos)
|
| | |
| | | rec[u'Face'] = self.Face
|
| | | rec[u'FacePic'] = self.FacePic
|
| | | rec[u'Job'] = self.Job
|
| | | rec[u'RoleType'] = self.RoleType
|
| | | rec[u'ReincarnationLv'] = self.ReincarnationLv
|
| | | rec[u'LV'] = self.LV
|
| | | rec[u'TotalExp'] = self.TotalExp
|
| | |
| | | self.Face = rec.get(u'Face', 0)
|
| | | self.FacePic = rec.get(u'FacePic', 0)
|
| | | self.Job = rec.get(u'Job', 0)
|
| | | self.RoleType = rec.get(u'RoleType', 0)
|
| | | self.ReincarnationLv = rec.get(u'ReincarnationLv', 0)
|
| | | self.LV = rec.get(u'LV', 0)
|
| | | self.TotalExp = rec.get(u'TotalExp', 0)
|
| | |
| | | Face = %s,
|
| | | FacePic = %s,
|
| | | Job = %s,
|
| | | RoleType = %s,
|
| | | ReincarnationLv = %s,
|
| | | LV = %s,
|
| | | TotalExp = %s,
|
| | |
| | | self.Face,
|
| | | self.FacePic,
|
| | | self.Job,
|
| | | self.RoleType,
|
| | | self.ReincarnationLv,
|
| | | self.LV,
|
| | | self.TotalExp,
|
| | |
| | | return output
|
| | |
|
| | | def dumpString(self):
|
| | | output = '''%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s'''%(
|
| | | output = '''%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s'''%(
|
| | | self.PlayerID,
|
| | | self.AccID,
|
| | | self.PlayerName,
|
| | |
| | | self.Face,
|
| | | self.FacePic,
|
| | | self.Job,
|
| | | self.RoleType,
|
| | | self.ReincarnationLv,
|
| | | self.LV,
|
| | | self.TotalExp,
|
| | |
| | | else:
|
| | | self.Operate = Str[:15]
|
| | |
|
| | |
|
| | | #----------------------------------------------------------------------
|
| | | #玩家账户信息#tagDSAccount
|
| | | class tagDSAccount(Structure):
|
| | |
| | | ('ID', ctypes.c_ulong),
|
| | | ('ID2', ctypes.c_ulong),
|
| | | ('Name1', ctypes.c_char * 33),
|
| | | ('Name2', ctypes.c_char * 33),
|
| | | ('Name2', ctypes.c_char * 65),
|
| | | ('Type2', ctypes.c_ubyte),
|
| | | ('Value1', ctypes.c_ulong),
|
| | | ('Value2', ctypes.c_ulong),
|
| | | ('Value3', ctypes.c_ulong),
|
| | | ('Value4', ctypes.c_ulong),
|
| | | ('Value5', ctypes.c_ulong),
|
| | | ('Value6', ctypes.c_ulong),
|
| | | ('Value7', ctypes.c_ulong),
|
| | | ('Value8', ctypes.c_ulong),
|
| | | ('CmpValue', ctypes.c_ulong),
|
| | | ('CmpValue2', ctypes.c_ulong),
|
| | | ('CmpValue3', ctypes.c_ulong),
|
| | | ('DataLen', ctypes.c_ushort),
|
| | | ('UserData', ctypes.c_char_p),
|
| | | ('ADOResult', ctypes.c_ulong),
|
| | | ]
|
| | |
|
| | |
| | | Structure.__init__(self)
|
| | | self.clear()
|
| | |
|
| | |
|
| | | def clear(self):
|
| | | memset(addressof(self), 0, self.getLength())
|
| | |
|
| | | self.Type = 0
|
| | | self.ID = 0
|
| | | self.ID2 = 0
|
| | | self.Name1 = ''
|
| | | self.Name2 = ''
|
| | | self.Type2 = 0
|
| | | self.Value1 = 0
|
| | | self.Value2 = 0
|
| | | self.Value3 = 0
|
| | | self.Value4 = 0
|
| | | self.Value5 = 0
|
| | | self.Value6 = 0
|
| | | self.Value7 = 0
|
| | | self.Value8 = 0
|
| | | self.CmpValue = 0
|
| | | self.CmpValue2 = 0
|
| | | self.CmpValue3 = 0
|
| | | self.DataLen = 0
|
| | | self.UserData = ''
|
| | |
|
| | | def readData(self, buf, pos = 0, length = 0):
|
| | | if not pos <= length:
|
| | | msg = error.formatMsg('error', error.ERROR_NO_150, '(pos = %s)> (length = %s)'%(pos, length))
|
| | | msg = error.formatMsg('error', error.ERROR_NO_148, '(pos = %s) > (length = %s)'%(pos, length))
|
| | | mylog.error(msg)
|
| | | return -1
|
| | | if len(buf) < pos + self.getLength():
|
| | | msg = error.formatMsg('error', error.ERROR_NO_151, 'len = %s while %s expected!'%(len(buf) - pos, self.getLength()))
|
| | | msg = error.formatMsg('error', error.ERROR_NO_149, 'len = %s while %s expected!'%(len(buf) - pos, self.getLength()))
|
| | | mylog.error(msg)
|
| | | return -1
|
| | | self.clear()
|
| | | memmove(addressof(self), buf[pos:], self.getLength())
|
| | | self.Type, pos = CommFunc.ReadBYTE(buf, pos)
|
| | | self.ID, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.ID2, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.Name1, pos = CommFunc.ReadString(buf, pos, 33)
|
| | | self.Name2, pos = CommFunc.ReadString(buf, pos, 65)
|
| | | self.Type2, pos = CommFunc.ReadBYTE(buf, pos)
|
| | | self.Value1, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.Value2, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.Value3, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.Value4, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.Value5, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.Value6, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.Value7, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.Value8, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.CmpValue, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.CmpValue2, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.CmpValue3, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.DataLen, pos = CommFunc.ReadWORD(buf, pos)
|
| | | tmp, pos = CommFunc.ReadString(buf, pos, self.DataLen)
|
| | | self.UserData = ctypes.c_char_p(tmp)
|
| | | return self.getLength()
|
| | |
|
| | |
|
| | | def getBuffer(self):
|
| | | buf = create_string_buffer(self.getLength())
|
| | | memmove(addressof(buf), addressof(self), self.getLength())
|
| | | return string_at(addressof(buf), self.getLength())
|
| | | buf = ''
|
| | | buf = CommFunc.WriteBYTE(buf, self.Type)
|
| | | buf = CommFunc.WriteDWORD(buf, self.ID)
|
| | | buf = CommFunc.WriteDWORD(buf, self.ID2)
|
| | | buf = CommFunc.WriteString(buf, sizeof(ctypes.c_char) * 33, self.Name1)
|
| | | buf = CommFunc.WriteString(buf, sizeof(ctypes.c_char) * 65, self.Name2)
|
| | | buf = CommFunc.WriteBYTE(buf, self.Type2)
|
| | | buf = CommFunc.WriteDWORD(buf, self.Value1)
|
| | | buf = CommFunc.WriteDWORD(buf, self.Value2)
|
| | | buf = CommFunc.WriteDWORD(buf, self.Value3)
|
| | | buf = CommFunc.WriteDWORD(buf, self.Value4)
|
| | | buf = CommFunc.WriteDWORD(buf, self.Value5)
|
| | | buf = CommFunc.WriteDWORD(buf, self.Value6)
|
| | | buf = CommFunc.WriteDWORD(buf, self.Value7)
|
| | | buf = CommFunc.WriteDWORD(buf, self.Value8)
|
| | | buf = CommFunc.WriteDWORD(buf, self.CmpValue)
|
| | | buf = CommFunc.WriteDWORD(buf, self.CmpValue2)
|
| | | buf = CommFunc.WriteDWORD(buf, self.CmpValue3)
|
| | | buf = CommFunc.WriteWORD(buf, self.DataLen)
|
| | | buf = CommFunc.WriteString(buf, self.DataLen, self.UserData)
|
| | | return buf
|
| | |
|
| | | def getLength(self):
|
| | | return sizeof(tagDBBillboard)
|
| | | length = 0
|
| | | length += sizeof(ctypes.c_ubyte)
|
| | | length += sizeof(ctypes.c_ulong)
|
| | | length += sizeof(ctypes.c_ulong)
|
| | | length += sizeof(ctypes.c_char) * 33
|
| | | length += sizeof(ctypes.c_char) * 65
|
| | | length += sizeof(ctypes.c_ubyte)
|
| | | length += sizeof(ctypes.c_ulong)
|
| | | length += sizeof(ctypes.c_ulong)
|
| | | length += sizeof(ctypes.c_ulong)
|
| | | length += sizeof(ctypes.c_ulong)
|
| | | length += sizeof(ctypes.c_ulong)
|
| | | length += sizeof(ctypes.c_ulong)
|
| | | length += sizeof(ctypes.c_ulong)
|
| | | length += sizeof(ctypes.c_ulong)
|
| | | length += sizeof(ctypes.c_ulong)
|
| | | length += sizeof(ctypes.c_ulong)
|
| | | length += sizeof(ctypes.c_ulong)
|
| | | length += sizeof(ctypes.c_ushort)
|
| | | length += self.DataLen
|
| | | return length
|
| | |
|
| | | def getRecord(self):
|
| | | '''组织存储记录'''
|
| | |
| | | rec[u'Type2'] = self.Type2
|
| | | rec[u'Value1'] = self.Value1
|
| | | rec[u'Value2'] = self.Value2
|
| | | rec[u'Value3'] = self.Value3
|
| | | rec[u'Value4'] = self.Value4
|
| | | rec[u'Value5'] = self.Value5
|
| | | rec[u'Value6'] = self.Value6
|
| | | rec[u'Value7'] = self.Value7
|
| | | rec[u'Value8'] = self.Value8
|
| | | rec[u'CmpValue'] = self.CmpValue
|
| | | rec[u'CmpValue2'] = self.CmpValue2
|
| | | rec[u'CmpValue3'] = self.CmpValue3
|
| | | rec[u'DataLen'] = self.DataLen
|
| | | rec[u'UserData'] = fix_incomingText(self.UserData)
|
| | | return rec
|
| | |
|
| | | def readRecord(self, rec):
|
| | |
| | | self.Type2 = rec.get(u'Type2', 0)
|
| | | self.Value1 = rec.get(u'Value1', 0)
|
| | | self.Value2 = rec.get(u'Value2', 0)
|
| | | self.Value3 = rec.get(u'Value3', 0)
|
| | | self.Value4 = rec.get(u'Value4', 0)
|
| | | self.Value5 = rec.get(u'Value5', 0)
|
| | | self.Value6 = rec.get(u'Value6', 0)
|
| | | self.Value7 = rec.get(u'Value7', 0)
|
| | | self.Value8 = rec.get(u'Value8', 0)
|
| | | self.CmpValue = rec.get(u'CmpValue', 0)
|
| | | self.CmpValue2 = rec.get(u'CmpValue2', 0)
|
| | | self.CmpValue3 = rec.get(u'CmpValue3', 0)
|
| | | self.DataLen = rec.get(u'DataLen', 0)
|
| | | self.UserData = fix_outgoingText(rec.get(u'UserData', u''))
|
| | |
|
| | | def adoLoad(self, collection):
|
| | | '''使用KEY查找并读取'''
|
| | |
| | | Type2 = %s,
|
| | | Value1 = %s,
|
| | | Value2 = %s,
|
| | | Value3 = %s,
|
| | | Value4 = %s,
|
| | | Value5 = %s,
|
| | | Value6 = %s,
|
| | | Value7 = %s,
|
| | | Value8 = %s,
|
| | | CmpValue = %s,
|
| | | CmpValue2 = %s,
|
| | | CmpValue3 = %s,
|
| | | DataLen = %s,
|
| | | UserData = %s,
|
| | | ADOResult = %s,
|
| | | '''%(
|
| | | self.Type,
|
| | |
| | | self.Type2,
|
| | | self.Value1,
|
| | | self.Value2,
|
| | | self.Value3,
|
| | | self.Value4,
|
| | | self.Value5,
|
| | | self.Value6,
|
| | | self.Value7,
|
| | | self.Value8,
|
| | | self.CmpValue,
|
| | | self.CmpValue2,
|
| | | self.CmpValue3,
|
| | | self.DataLen,
|
| | | self.UserData,
|
| | | self.ADOResult,
|
| | | )
|
| | | return output
|
| | |
|
| | | def dumpString(self):
|
| | | output = '''%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s'''%(
|
| | | output = '''%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s'''%(
|
| | | self.Type,
|
| | | self.ID,
|
| | | self.ID2,
|
| | |
| | | self.Type2,
|
| | | self.Value1,
|
| | | self.Value2,
|
| | | self.Value3,
|
| | | self.Value4,
|
| | | self.Value5,
|
| | | self.Value6,
|
| | | self.Value7,
|
| | | self.Value8,
|
| | | self.CmpValue,
|
| | | self.CmpValue2,
|
| | | self.CmpValue3,
|
| | | self.DataLen,
|
| | | self.UserData,
|
| | | )
|
| | | return output
|
| | |
|
| | |
| | | self.Name1 = Str[:33]
|
| | |
|
| | | def SetName2(self,Str):
|
| | | if len(Str)<=33:
|
| | | if len(Str)<=65:
|
| | | self.Name2 = Str
|
| | | else:
|
| | | self.Name2 = Str[:33]
|
| | | self.Name2 = Str[:65]
|
| | |
|
| | |
|
| | |
|
| | |
|
| | | #------------------------------------------------------
|
| | | #国家家族战排位赛表#tagDBCountryFamilyWarRace
|
| | |
| | | ('Extra3', ctypes.c_ulong),
|
| | | ('Extra4', ctypes.c_ulong),
|
| | | ('Extra5', ctypes.c_ulong),
|
| | | ('Extra6', ctypes.c_ulong),
|
| | | ('Extra7', ctypes.c_ulong),
|
| | | ('Extra8', ctypes.c_ulong),
|
| | | ('Extra9', ctypes.c_ulong),
|
| | | ('Extra10', ctypes.c_ulong),
|
| | | ('ServerID', ctypes.c_ulong),
|
| | | ('ADOResult', ctypes.c_ulong),
|
| | | ]
|
| | |
|
| | |
| | | def clear(self):
|
| | | memset(addressof(self), 0, self.getLength())
|
| | |
|
| | |
|
| | | def readData(self, buf, pos = 0, length = 0):
|
| | | if not pos <= length:
|
| | | msg = error.formatMsg('error', error.ERROR_NO_150, '(pos = %s)> (length = %s)'%(pos, length))
|
| | | msg = error.formatMsg('error', error.ERROR_NO_148, '(pos = %s) > (length = %s)'%(pos, length))
|
| | | mylog.error(msg)
|
| | | return -1
|
| | | if len(buf) < pos + self.getLength():
|
| | | msg = error.formatMsg('error', error.ERROR_NO_151, 'len = %s while %s expected!'%(len(buf) - pos, self.getLength()))
|
| | | msg = error.formatMsg('error', error.ERROR_NO_149, 'len = %s while %s expected!'%(len(buf) - pos, self.getLength()))
|
| | | mylog.error(msg)
|
| | | return -1
|
| | | self.clear()
|
| | | memmove(addressof(self), buf[pos:], self.getLength())
|
| | | self.ID, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.Name, pos = CommFunc.ReadString(buf, pos, 33)
|
| | | self.LeaderID, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.LeaderName, pos = CommFunc.ReadString(buf, pos, 33)
|
| | | self.LeaderOfficialRank, pos = CommFunc.ReadBYTE(buf, pos)
|
| | | self.Broadcast, pos = CommFunc.ReadString(buf, pos, 200)
|
| | | self.LV, pos = CommFunc.ReadBYTE(buf, pos)
|
| | | self.Money, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.Hornor, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.BillboardPlace, pos = CommFunc.ReadWORD(buf, pos)
|
| | | self.AcceptJoin, pos = CommFunc.ReadBYTE(buf, pos)
|
| | | self.CreateTime, pos = CommFunc.ReadString(buf, pos, 30)
|
| | | self.Point, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.FamilyActiveValue, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.LastWeekFamilyActiveValue, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.BeChallengedTime, pos = CommFunc.ReadString(buf, pos, 20)
|
| | | self.Extra1, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.Extra2, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.Extra3, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.Extra4, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.Extra5, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.Extra6, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.Extra7, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.Extra8, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.Extra9, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.Extra10, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.ServerID, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | return self.getLength()
|
| | |
|
| | |
|
| | |
| | | rec[u'Extra3'] = self.Extra3
|
| | | rec[u'Extra4'] = self.Extra4
|
| | | rec[u'Extra5'] = self.Extra5
|
| | | rec[u'Extra6'] = self.Extra6
|
| | | rec[u'Extra7'] = self.Extra7
|
| | | rec[u'Extra8'] = self.Extra8
|
| | | rec[u'Extra9'] = self.Extra9
|
| | | rec[u'Extra10'] = self.Extra10
|
| | | rec[u'ServerID'] = self.ServerID
|
| | | return rec
|
| | |
|
| | | def readRecord(self, rec):
|
| | |
| | | self.Extra3 = rec.get(u'Extra3', 0)
|
| | | self.Extra4 = rec.get(u'Extra4', 0)
|
| | | self.Extra5 = rec.get(u'Extra5', 0)
|
| | | self.Extra6 = rec.get(u'Extra6', 0)
|
| | | self.Extra7 = rec.get(u'Extra7', 0)
|
| | | self.Extra8 = rec.get(u'Extra8', 0)
|
| | | self.Extra9 = rec.get(u'Extra9', 0)
|
| | | self.Extra10 = rec.get(u'Extra10', 0)
|
| | | self.ServerID = rec.get(u'ServerID', 0)
|
| | |
|
| | | def adoLoad(self, collection):
|
| | | '''使用KEY查找并读取'''
|
| | |
| | | Extra3 = %s,
|
| | | Extra4 = %s,
|
| | | Extra5 = %s,
|
| | | Extra6 = %s,
|
| | | Extra7 = %s,
|
| | | Extra8 = %s,
|
| | | Extra9 = %s,
|
| | | Extra10 = %s,
|
| | | ServerID = %s,
|
| | | ADOResult = %s,
|
| | | '''%(
|
| | | self.ID,
|
| | |
| | | self.Extra3,
|
| | | self.Extra4,
|
| | | self.Extra5,
|
| | | self.Extra6,
|
| | | self.Extra7,
|
| | | self.Extra8,
|
| | | self.Extra9,
|
| | | self.Extra10,
|
| | | self.ServerID,
|
| | | self.ADOResult,
|
| | | )
|
| | | return output
|
| | |
|
| | | def dumpString(self):
|
| | | output = '''%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s'''%(
|
| | | output = '''%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s'''%(
|
| | | self.ID,
|
| | | self.Name,
|
| | | self.LeaderID,
|
| | |
| | | self.Extra3,
|
| | | self.Extra4,
|
| | | self.Extra5,
|
| | | self.Extra6,
|
| | | self.Extra7,
|
| | | self.Extra8,
|
| | | self.Extra9,
|
| | | self.Extra10,
|
| | | self.ServerID,
|
| | | )
|
| | | return output
|
| | |
|
| | |
| | | else:
|
| | | self.BeChallengedTime = Str[:20]
|
| | |
|
| | |
|
| | |
|
| | |
|
| | | #------------------------------------------------------
|
| | |
| | | ('Sex', ctypes.c_ubyte),
|
| | | ('LV', ctypes.c_ushort),
|
| | | ('Job', ctypes.c_ubyte),
|
| | | ('Face', ctypes.c_ulong),
|
| | | ('FacePic', ctypes.c_ulong),
|
| | | ('FamilyLV', ctypes.c_ubyte),
|
| | | ('FamilyName', ctypes.c_char * 33),
|
| | | ('FamilyActiveValue', ctypes.c_ulong),
|
| | |
| | | ('Exattr3', ctypes.c_ulong),
|
| | | ('Exattr4', ctypes.c_ulong),
|
| | | ('Exattr5', ctypes.c_ulong),
|
| | | ('Exattr6', ctypes.c_ulong),
|
| | | ('Exattr7', ctypes.c_ulong),
|
| | | ('Exattr8', ctypes.c_ulong),
|
| | | ('ReincarnationLv', ctypes.c_ushort),
|
| | | ('OperateInfo', ctypes.c_ulong),
|
| | | ('ADOResult', ctypes.c_ulong),
|
| | |
| | | self.Sex, pos = CommFunc.ReadBYTE(buf, pos)
|
| | | self.LV, pos = CommFunc.ReadWORD(buf, pos)
|
| | | self.Job, pos = CommFunc.ReadBYTE(buf, pos)
|
| | | self.Face, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.FacePic, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.FamilyLV, pos = CommFunc.ReadBYTE(buf, pos)
|
| | | self.FamilyName, pos = CommFunc.ReadString(buf, pos, 33)
|
| | | self.FamilyActiveValue, pos = CommFunc.ReadDWORD(buf, pos)
|
| | |
| | | self.Exattr3, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.Exattr4, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.Exattr5, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.Exattr6, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.Exattr7, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.Exattr8, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.ReincarnationLv, pos = CommFunc.ReadWORD(buf, pos)
|
| | | self.OperateInfo, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | return self.getLength()
|
| | |
| | | rec[u'Sex'] = self.Sex
|
| | | rec[u'LV'] = self.LV
|
| | | rec[u'Job'] = self.Job
|
| | | rec[u'Face'] = self.Face
|
| | | rec[u'FacePic'] = self.FacePic
|
| | | rec[u'FamilyLV'] = self.FamilyLV
|
| | | rec[u'FamilyName'] = fix_incomingText(self.FamilyName)
|
| | | rec[u'FamilyActiveValue'] = self.FamilyActiveValue
|
| | |
| | | rec[u'Exattr3'] = self.Exattr3
|
| | | rec[u'Exattr4'] = self.Exattr4
|
| | | rec[u'Exattr5'] = self.Exattr5
|
| | | rec[u'Exattr6'] = self.Exattr6
|
| | | rec[u'Exattr7'] = self.Exattr7
|
| | | rec[u'Exattr8'] = self.Exattr8
|
| | | rec[u'ReincarnationLv'] = self.ReincarnationLv
|
| | | rec[u'OperateInfo'] = self.OperateInfo
|
| | | return rec
|
| | |
| | | self.Sex = rec.get(u'Sex', 0)
|
| | | self.LV = rec.get(u'LV', 0)
|
| | | self.Job = rec.get(u'Job', 0)
|
| | | self.Face = rec.get(u'Face', 0)
|
| | | self.FacePic = rec.get(u'FacePic', 0)
|
| | | self.FamilyLV = rec.get(u'FamilyLV', 0)
|
| | | self.FamilyName = fix_outgoingText(rec.get(u'FamilyName', u''))
|
| | | self.FamilyActiveValue = rec.get(u'FamilyActiveValue', 0)
|
| | |
| | | self.Exattr3 = rec.get(u'Exattr3', 0)
|
| | | self.Exattr4 = rec.get(u'Exattr4', 0)
|
| | | self.Exattr5 = rec.get(u'Exattr5', 0)
|
| | | self.Exattr6 = rec.get(u'Exattr6', 0)
|
| | | self.Exattr7 = rec.get(u'Exattr7', 0)
|
| | | self.Exattr8 = rec.get(u'Exattr8', 0)
|
| | | self.ReincarnationLv = rec.get(u'ReincarnationLv', 0)
|
| | | self.OperateInfo = rec.get(u'OperateInfo', 0)
|
| | |
|
| | |
| | | Sex = %s,
|
| | | LV = %s,
|
| | | Job = %s,
|
| | | Face = %s,
|
| | | FacePic = %s,
|
| | | FamilyLV = %s,
|
| | | FamilyName = %s,
|
| | | FamilyActiveValue = %s,
|
| | |
| | | Exattr3 = %s,
|
| | | Exattr4 = %s,
|
| | | Exattr5 = %s,
|
| | | Exattr6 = %s,
|
| | | Exattr7 = %s,
|
| | | Exattr8 = %s,
|
| | | ReincarnationLv = %s,
|
| | | OperateInfo = %s,
|
| | | ADOResult = %s,
|
| | |
| | | self.Sex,
|
| | | self.LV,
|
| | | self.Job,
|
| | | self.Face,
|
| | | self.FacePic,
|
| | | self.FamilyLV,
|
| | | self.FamilyName,
|
| | | self.FamilyActiveValue,
|
| | |
| | | self.Exattr3,
|
| | | self.Exattr4,
|
| | | self.Exattr5,
|
| | | self.Exattr6,
|
| | | self.Exattr7,
|
| | | self.Exattr8,
|
| | | self.ReincarnationLv,
|
| | | self.OperateInfo,
|
| | | self.ADOResult,
|
| | |
| | | return output
|
| | |
|
| | | def dumpString(self):
|
| | | output = '''%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s'''%(
|
| | | output = '''%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s'''%(
|
| | | self.PlayerID,
|
| | | self.FamilyID,
|
| | | self.Name,
|
| | | self.Sex,
|
| | | self.LV,
|
| | | self.Job,
|
| | | self.Face,
|
| | | self.FacePic,
|
| | | self.FamilyLV,
|
| | | self.FamilyName,
|
| | | self.FamilyActiveValue,
|
| | |
| | | self.Exattr3,
|
| | | self.Exattr4,
|
| | | self.Exattr5,
|
| | | self.Exattr6,
|
| | | self.Exattr7,
|
| | | self.Exattr8,
|
| | | self.ReincarnationLv,
|
| | | self.OperateInfo,
|
| | | )
|
| | |
| | | else:
|
| | | self.FamilyName = Str[:33]
|
| | |
|
| | | |
| | |
|
| | |
|
| | | #------------------------------------------------------
|
| | | #玩家骠车马匹表#tagPlayerHorseTable
|
| | | class tagPlayerHorseTable(Structure):
|
| | |
| | | ('JobLevel', ctypes.c_ubyte),
|
| | | ('LV', ctypes.c_ushort),
|
| | | ('RealmLV', ctypes.c_ushort),
|
| | | ('Face', ctypes.c_ulong),
|
| | | ('FacePic', ctypes.c_ulong),
|
| | | ('ADOResult', ctypes.c_ulong),
|
| | | ]
|
| | |
|
| | |
| | | def clear(self):
|
| | | memset(addressof(self), 0, self.getLength())
|
| | |
|
| | |
|
| | | def readData(self, buf, pos = 0, length = 0):
|
| | | if not pos <= length:
|
| | | msg = error.formatMsg('error', error.ERROR_NO_150, '(pos = %s)> (length = %s)'%(pos, length))
|
| | | msg = error.formatMsg('error', error.ERROR_NO_148, '(pos = %s) > (length = %s)'%(pos, length))
|
| | | mylog.error(msg)
|
| | | return -1
|
| | | if len(buf) < pos + self.getLength():
|
| | | msg = error.formatMsg('error', error.ERROR_NO_151, 'len = %s while %s expected!'%(len(buf) - pos, self.getLength()))
|
| | | msg = error.formatMsg('error', error.ERROR_NO_149, 'len = %s while %s expected!'%(len(buf) - pos, self.getLength()))
|
| | | mylog.error(msg)
|
| | | return -1
|
| | | self.clear()
|
| | | memmove(addressof(self), buf[pos:], self.getLength())
|
| | | self.TeamID, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.PlayerID, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.TeamIndex, pos = CommFunc.ReadBYTE(buf, pos)
|
| | | self.TeamLV, pos = CommFunc.ReadBYTE(buf, pos)
|
| | | self.PlayerName, pos = CommFunc.ReadString(buf, pos, 33)
|
| | | self.Job, pos = CommFunc.ReadBYTE(buf, pos)
|
| | | self.JobLevel, pos = CommFunc.ReadBYTE(buf, pos)
|
| | | self.LV, pos = CommFunc.ReadWORD(buf, pos)
|
| | | self.RealmLV, pos = CommFunc.ReadWORD(buf, pos)
|
| | | self.Face, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.FacePic, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | return self.getLength()
|
| | |
|
| | |
|
| | |
| | | rec[u'JobLevel'] = self.JobLevel
|
| | | rec[u'LV'] = self.LV
|
| | | rec[u'RealmLV'] = self.RealmLV
|
| | | rec[u'Face'] = self.Face
|
| | | rec[u'FacePic'] = self.FacePic
|
| | | return rec
|
| | |
|
| | | def readRecord(self, rec):
|
| | |
| | | self.JobLevel = rec.get(u'JobLevel', 0)
|
| | | self.LV = rec.get(u'LV', 0)
|
| | | self.RealmLV = rec.get(u'RealmLV', 0)
|
| | | self.Face = rec.get(u'Face', 0)
|
| | | self.FacePic = rec.get(u'FacePic', 0)
|
| | |
|
| | | #Can not implement adoLoadStr method:No key defined!
|
| | |
|
| | |
| | | JobLevel = %s,
|
| | | LV = %s,
|
| | | RealmLV = %s,
|
| | | Face = %s,
|
| | | FacePic = %s,
|
| | | ADOResult = %s,
|
| | | '''%(
|
| | | self.TeamID,
|
| | |
| | | self.JobLevel,
|
| | | self.LV,
|
| | | self.RealmLV,
|
| | | self.Face,
|
| | | self.FacePic,
|
| | | self.ADOResult,
|
| | | )
|
| | | return output
|
| | |
|
| | | def dumpString(self):
|
| | | output = '''%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s'''%(
|
| | | output = '''%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s'''%(
|
| | | self.TeamID,
|
| | | self.PlayerID,
|
| | | self.TeamIndex,
|
| | |
| | | self.JobLevel,
|
| | | self.LV,
|
| | | self.RealmLV,
|
| | | self.Face,
|
| | | self.FacePic,
|
| | | )
|
| | | return output
|
| | |
|
| | |
| | | else:
|
| | | self.PlayerName = Str[:33]
|
| | |
|
| | |
|
| | |
|
| | |
|
| | | #通用记录表#tagUniversalGameRec
|
| | |
| | | ('RealmLV', ctypes.c_ushort),
|
| | | ('OnlineType', ctypes.c_ubyte),
|
| | | ('RefCount', ctypes.c_ulong),
|
| | | ('Face', ctypes.c_ulong),
|
| | | ('FacePic', ctypes.c_ulong),
|
| | | ('ADOResult', ctypes.c_ulong),
|
| | | ]
|
| | |
|
| | |
| | | self.RealmLV, pos = CommFunc.ReadWORD(buf, pos)
|
| | | self.OnlineType, pos = CommFunc.ReadBYTE(buf, pos)
|
| | | self.RefCount, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.Face, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.FacePic, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | return self.getLength()
|
| | |
|
| | |
|
| | |
| | | rec[u'RealmLV'] = self.RealmLV
|
| | | rec[u'OnlineType'] = self.OnlineType
|
| | | rec[u'RefCount'] = self.RefCount
|
| | | rec[u'Face'] = self.Face
|
| | | rec[u'FacePic'] = self.FacePic
|
| | | return rec
|
| | |
|
| | | def readRecord(self, rec):
|
| | |
| | | self.RealmLV = rec.get(u'RealmLV', 0)
|
| | | self.OnlineType = rec.get(u'OnlineType', 0)
|
| | | self.RefCount = rec.get(u'RefCount', 0)
|
| | | self.Face = rec.get(u'Face', 0)
|
| | | self.FacePic = rec.get(u'FacePic', 0)
|
| | |
|
| | | def adoLoad(self, collection):
|
| | | '''使用KEY查找并读取'''
|
| | |
| | | RealmLV = %s,
|
| | | OnlineType = %s,
|
| | | RefCount = %s,
|
| | | Face = %s,
|
| | | FacePic = %s,
|
| | | ADOResult = %s,
|
| | | '''%(
|
| | | self.PlayerID,
|
| | |
| | | self.RealmLV,
|
| | | self.OnlineType,
|
| | | self.RefCount,
|
| | | self.Face,
|
| | | self.FacePic,
|
| | | self.ADOResult,
|
| | | )
|
| | | return output
|
| | |
|
| | | def dumpString(self):
|
| | | output = '''%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s'''%(
|
| | | output = '''%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s'''%(
|
| | | self.PlayerID,
|
| | | self.PlayerName,
|
| | | self.Job,
|
| | |
| | | self.RealmLV,
|
| | | self.OnlineType,
|
| | | self.RefCount,
|
| | | self.Face,
|
| | | self.FacePic,
|
| | | )
|
| | | return output
|
| | |
|
| | |
| | | ('PKScore', ctypes.c_ulong),
|
| | | ('DanLV', ctypes.c_ubyte),
|
| | | ('Time', ctypes.c_ulong),
|
| | | ('Face', ctypes.c_ulong),
|
| | | ('FacePic', ctypes.c_ulong),
|
| | | ('ADOResult', ctypes.c_ulong),
|
| | | ]
|
| | |
|
| | |
| | | self.PKScore, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.DanLV, pos = CommFunc.ReadBYTE(buf, pos)
|
| | | self.Time, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.Face, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.FacePic, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | return self.getLength()
|
| | |
|
| | |
|
| | |
| | | rec[u'PKScore'] = self.PKScore
|
| | | rec[u'DanLV'] = self.DanLV
|
| | | rec[u'Time'] = self.Time
|
| | | rec[u'Face'] = self.Face
|
| | | rec[u'FacePic'] = self.FacePic
|
| | | return rec
|
| | |
|
| | | def readRecord(self, rec):
|
| | |
| | | self.PKScore = rec.get(u'PKScore', 0)
|
| | | self.DanLV = rec.get(u'DanLV', 0)
|
| | | self.Time = rec.get(u'Time', 0)
|
| | | self.Face = rec.get(u'Face', 0)
|
| | | self.FacePic = rec.get(u'FacePic', 0)
|
| | |
|
| | | #Can not implement adoLoadStr method:No key defined!
|
| | | #Can not implement adoInsertStr method:No key defined!
|
| | |
| | | PKScore = %s,
|
| | | DanLV = %s,
|
| | | Time = %s,
|
| | | Face = %s,
|
| | | FacePic = %s,
|
| | | ADOResult = %s,
|
| | | '''%(
|
| | | self.ZoneID,
|
| | |
| | | self.PKScore,
|
| | | self.DanLV,
|
| | | self.Time,
|
| | | self.Face,
|
| | | self.FacePic,
|
| | | self.ADOResult,
|
| | | )
|
| | | return output
|
| | |
|
| | | def dumpString(self):
|
| | | output = '''%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s'''%(
|
| | | output = '''%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s'''%(
|
| | | self.ZoneID,
|
| | | self.SeasonID,
|
| | | self.PlayerID,
|
| | |
| | | self.PKScore,
|
| | | self.DanLV,
|
| | | self.Time,
|
| | | self.Face,
|
| | | self.FacePic,
|
| | | )
|
| | | return output
|
| | |
|
| | |
| | | self.TimeStr = Str[:19]
|
| | |
|
| | |
|
| | | #------------------------------------------------------
|
| | | # 跨服排行榜 #tagDBCrossBillboard
|
| | | class tagDBCrossBillboard(Structure):
|
| | | _pack_ = 1
|
| | | _fields_ = [
|
| | | ('GroupValue1', ctypes.c_ubyte),
|
| | | ('GroupValue2', ctypes.c_ubyte),
|
| | | ('GroupValue1', ctypes.c_ulong),
|
| | | ('GroupValue2', ctypes.c_ulong),
|
| | | ('BillboardType', ctypes.c_ubyte),
|
| | | ('ID', ctypes.c_ulong),
|
| | | ('ID2', ctypes.c_ulong),
|
| | | ('Name1', ctypes.c_char * 33),
|
| | | ('Name2', ctypes.c_char * 33),
|
| | | ('Name2', ctypes.c_char * 65),
|
| | | ('Type2', ctypes.c_ubyte),
|
| | | ('Value1', ctypes.c_ulong),
|
| | | ('Value2', ctypes.c_ulong),
|
| | | ('Value3', ctypes.c_ulong),
|
| | | ('Value4', ctypes.c_ulong),
|
| | | ('Value5', ctypes.c_ulong),
|
| | | ('Value6', ctypes.c_ulong),
|
| | | ('Value7', ctypes.c_ulong),
|
| | | ('Value8', ctypes.c_ulong),
|
| | | ('CmpValue', ctypes.c_ulong),
|
| | | ('CmpValue2', ctypes.c_ulong),
|
| | | ('CmpValue3', ctypes.c_ulong),
|
| | | ('DataLen', ctypes.c_ushort),
|
| | | ('UserData', ctypes.c_char_p),
|
| | | ('ADOResult', ctypes.c_ulong),
|
| | | ]
|
| | |
|
| | |
| | | Structure.__init__(self)
|
| | | self.clear()
|
| | |
|
| | |
|
| | | def clear(self):
|
| | | memset(addressof(self), 0, self.getLength())
|
| | | self.GroupValue1 = 0
|
| | | self.GroupValue2 = 0
|
| | | self.BillboardType = 0
|
| | | self.ID = 0
|
| | | self.ID2 = 0
|
| | | self.Name1 = ''
|
| | | self.Name2 = ''
|
| | | self.Type2 = 0
|
| | | self.Value1 = 0
|
| | | self.Value2 = 0
|
| | | self.Value3 = 0
|
| | | self.Value4 = 0
|
| | | self.Value5 = 0
|
| | | self.Value6 = 0
|
| | | self.Value7 = 0
|
| | | self.Value8 = 0
|
| | | self.CmpValue = 0
|
| | | self.CmpValue2 = 0
|
| | | self.CmpValue3 = 0
|
| | | self.DataLen = 0
|
| | | self.UserData = ''
|
| | |
|
| | | def readData(self, buf, pos = 0, length = 0):
|
| | | if not pos <= length:
|
| | |
| | | msg = error.formatMsg('error', error.ERROR_NO_149, 'len = %s while %s expected!'%(len(buf) - pos, self.getLength()))
|
| | | mylog.error(msg)
|
| | | self.clear()
|
| | | self.GroupValue1, pos = CommFunc.ReadBYTE(buf, pos)
|
| | | self.GroupValue2, pos = CommFunc.ReadBYTE(buf, pos)
|
| | | self.GroupValue1, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.GroupValue2, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.BillboardType, pos = CommFunc.ReadBYTE(buf, pos)
|
| | | self.ID, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.ID2, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.Name1, pos = CommFunc.ReadString(buf, pos, 33)
|
| | | self.Name2, pos = CommFunc.ReadString(buf, pos, 33)
|
| | | self.Name2, pos = CommFunc.ReadString(buf, pos, 65)
|
| | | self.Type2, pos = CommFunc.ReadBYTE(buf, pos)
|
| | | self.Value1, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.Value2, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.Value3, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.Value4, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.Value5, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.Value6, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.Value7, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.Value8, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.CmpValue, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.CmpValue2, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.CmpValue3, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.DataLen, pos = CommFunc.ReadWORD(buf, pos)
|
| | | tmp, pos = CommFunc.ReadString(buf, pos, self.DataLen)
|
| | | self.UserData = ctypes.c_char_p(tmp)
|
| | | return self.getLength()
|
| | |
|
| | |
|
| | | def getBuffer(self):
|
| | | buf = create_string_buffer(self.getLength())
|
| | | memmove(addressof(buf), addressof(self), self.getLength())
|
| | | return string_at(addressof(buf), self.getLength())
|
| | | buf = ''
|
| | | buf = CommFunc.WriteDWORD(buf, self.GroupValue1)
|
| | | buf = CommFunc.WriteDWORD(buf, self.GroupValue2)
|
| | | buf = CommFunc.WriteBYTE(buf, self.BillboardType)
|
| | | buf = CommFunc.WriteDWORD(buf, self.ID)
|
| | | buf = CommFunc.WriteDWORD(buf, self.ID2)
|
| | | buf = CommFunc.WriteString(buf, sizeof(ctypes.c_char) * 33, self.Name1)
|
| | | buf = CommFunc.WriteString(buf, sizeof(ctypes.c_char) * 65, self.Name2)
|
| | | buf = CommFunc.WriteBYTE(buf, self.Type2)
|
| | | buf = CommFunc.WriteDWORD(buf, self.Value1)
|
| | | buf = CommFunc.WriteDWORD(buf, self.Value2)
|
| | | buf = CommFunc.WriteDWORD(buf, self.Value3)
|
| | | buf = CommFunc.WriteDWORD(buf, self.Value4)
|
| | | buf = CommFunc.WriteDWORD(buf, self.Value5)
|
| | | buf = CommFunc.WriteDWORD(buf, self.Value6)
|
| | | buf = CommFunc.WriteDWORD(buf, self.Value7)
|
| | | buf = CommFunc.WriteDWORD(buf, self.Value8)
|
| | | buf = CommFunc.WriteDWORD(buf, self.CmpValue)
|
| | | buf = CommFunc.WriteDWORD(buf, self.CmpValue2)
|
| | | buf = CommFunc.WriteDWORD(buf, self.CmpValue3)
|
| | | buf = CommFunc.WriteWORD(buf, self.DataLen)
|
| | | buf = CommFunc.WriteString(buf, self.DataLen, self.UserData)
|
| | | return buf
|
| | |
|
| | | def getLength(self):
|
| | | return sizeof(tagDBCrossBillboard)
|
| | | length = 0
|
| | | length += sizeof(ctypes.c_ulong)
|
| | | length += sizeof(ctypes.c_ulong)
|
| | | length += sizeof(ctypes.c_ubyte)
|
| | | length += sizeof(ctypes.c_ulong)
|
| | | length += sizeof(ctypes.c_ulong)
|
| | | length += sizeof(ctypes.c_char) * 33
|
| | | length += sizeof(ctypes.c_char) * 65
|
| | | length += sizeof(ctypes.c_ubyte)
|
| | | length += sizeof(ctypes.c_ulong)
|
| | | length += sizeof(ctypes.c_ulong)
|
| | | length += sizeof(ctypes.c_ulong)
|
| | | length += sizeof(ctypes.c_ulong)
|
| | | length += sizeof(ctypes.c_ulong)
|
| | | length += sizeof(ctypes.c_ulong)
|
| | | length += sizeof(ctypes.c_ulong)
|
| | | length += sizeof(ctypes.c_ulong)
|
| | | length += sizeof(ctypes.c_ulong)
|
| | | length += sizeof(ctypes.c_ulong)
|
| | | length += sizeof(ctypes.c_ulong)
|
| | | length += sizeof(ctypes.c_ushort)
|
| | | length += self.DataLen
|
| | | return length
|
| | |
|
| | | def getRecord(self):
|
| | | '''组织存储记录'''
|
| | |
| | | rec[u'Type2'] = self.Type2
|
| | | rec[u'Value1'] = self.Value1
|
| | | rec[u'Value2'] = self.Value2
|
| | | rec[u'Value3'] = self.Value3
|
| | | rec[u'Value4'] = self.Value4
|
| | | rec[u'Value5'] = self.Value5
|
| | | rec[u'Value6'] = self.Value6
|
| | | rec[u'Value7'] = self.Value7
|
| | | rec[u'Value8'] = self.Value8
|
| | | rec[u'CmpValue'] = self.CmpValue
|
| | | rec[u'CmpValue2'] = self.CmpValue2
|
| | | rec[u'CmpValue3'] = self.CmpValue3
|
| | | rec[u'DataLen'] = self.DataLen
|
| | | rec[u'UserData'] = fix_incomingText(self.UserData)
|
| | | return rec
|
| | |
|
| | | def readRecord(self, rec):
|
| | |
| | | self.Type2 = rec.get(u'Type2', 0)
|
| | | self.Value1 = rec.get(u'Value1', 0)
|
| | | self.Value2 = rec.get(u'Value2', 0)
|
| | | self.Value3 = rec.get(u'Value3', 0)
|
| | | self.Value4 = rec.get(u'Value4', 0)
|
| | | self.Value5 = rec.get(u'Value5', 0)
|
| | | self.Value6 = rec.get(u'Value6', 0)
|
| | | self.Value7 = rec.get(u'Value7', 0)
|
| | | self.Value8 = rec.get(u'Value8', 0)
|
| | | self.CmpValue = rec.get(u'CmpValue', 0)
|
| | | self.CmpValue2 = rec.get(u'CmpValue2', 0)
|
| | | self.CmpValue3 = rec.get(u'CmpValue3', 0)
|
| | | self.DataLen = rec.get(u'DataLen', 0)
|
| | | self.UserData = fix_outgoingText(rec.get(u'UserData', u''))
|
| | |
|
| | | #Can not implement adoLoadStr method:No key defined!
|
| | | #Can not implement adoInsertStr method:No key defined!
|
| | |
| | | Type2 = %s,
|
| | | Value1 = %s,
|
| | | Value2 = %s,
|
| | | Value3 = %s,
|
| | | Value4 = %s,
|
| | | Value5 = %s,
|
| | | Value6 = %s,
|
| | | Value7 = %s,
|
| | | Value8 = %s,
|
| | | CmpValue = %s,
|
| | | CmpValue2 = %s,
|
| | | CmpValue3 = %s,
|
| | | DataLen = %s,
|
| | | UserData = %s,
|
| | | ADOResult = %s,
|
| | | '''%(
|
| | | self.GroupValue1,
|
| | |
| | | self.Type2,
|
| | | self.Value1,
|
| | | self.Value2,
|
| | | self.Value3,
|
| | | self.Value4,
|
| | | self.Value5,
|
| | | self.Value6,
|
| | | self.Value7,
|
| | | self.Value8,
|
| | | self.CmpValue,
|
| | | self.CmpValue2,
|
| | | self.CmpValue3,
|
| | | self.DataLen,
|
| | | self.UserData,
|
| | | self.ADOResult,
|
| | | )
|
| | | return output
|
| | |
|
| | | def dumpString(self):
|
| | | output = '''%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s'''%(
|
| | | output = '''%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s'''%(
|
| | | self.GroupValue1,
|
| | | self.GroupValue2,
|
| | | self.BillboardType,
|
| | |
| | | self.Type2,
|
| | | self.Value1,
|
| | | self.Value2,
|
| | | self.Value3,
|
| | | self.Value4,
|
| | | self.Value5,
|
| | | self.Value6,
|
| | | self.Value7,
|
| | | self.Value8,
|
| | | self.CmpValue,
|
| | | self.CmpValue2,
|
| | | self.CmpValue3,
|
| | | self.DataLen,
|
| | | self.UserData,
|
| | | )
|
| | | return output
|
| | |
|
| | |
| | | self.Name1 = Str[:33]
|
| | |
|
| | | def SetName2(self,Str):
|
| | | if len(Str)<=33:
|
| | | if len(Str)<=65:
|
| | | self.Name2 = Str
|
| | | else:
|
| | | self.Name2 = Str[:33]
|
| | | self.Name2 = Str[:65]
|
| | |
|
| | |
|
| | |
|
| | | |
| | | # 跨服补偿个人领取表 #tagDBCrossPersonalCompensation
|
| | | class tagDBCrossPersonalCompensation(Structure):
|
| | | _pack_ = 1
|
| | |
| | | )
|
| | | return output
|
| | |
|
| | |
|
| | | |
| | | # 福地矿物表 #tagDBPyMineAreaItem
|
| | | class tagDBPyMineAreaItem(Structure):
|
| | | _pack_ = 1
|
| | |
| | | )
|
| | | return output
|
| | |
|
| | |
|
| | | # 玩家记录表 #tagDBPlayerRecData
|
| | | class tagDBPlayerRecData(Structure):
|
| | | _pack_ = 1
|
| | | _fields_ = [
|
| | | ('PlayerID', ctypes.c_ulong),
|
| | | ('RecType', ctypes.c_ushort),
|
| | | ('Time', ctypes.c_double),
|
| | | ('Value1', ctypes.c_ulong),
|
| | | ('Value2', ctypes.c_ulong),
|
| | | ('Value3', ctypes.c_ulong),
|
| | | ('Value4', ctypes.c_ulong),
|
| | | ('Value5', ctypes.c_ulong),
|
| | | ('Value6', ctypes.c_ulong),
|
| | | ('Value7', ctypes.c_ulong),
|
| | | ('Value8', ctypes.c_ulong),
|
| | | ('UserDataLen', ctypes.c_ushort),
|
| | | ('UserData', ctypes.c_char_p),
|
| | | ('ADOResult', ctypes.c_ulong),
|
| | | ]
|
| | |
|
| | | def __init__(self):
|
| | | Structure.__init__(self)
|
| | | self.clear()
|
| | |
|
| | | def clear(self):
|
| | | self.PlayerID = 0
|
| | | self.RecType = 0
|
| | | self.Time = 0.0
|
| | | self.Value1 = 0
|
| | | self.Value2 = 0
|
| | | self.Value3 = 0
|
| | | self.Value4 = 0
|
| | | self.Value5 = 0
|
| | | self.Value6 = 0
|
| | | self.Value7 = 0
|
| | | self.Value8 = 0
|
| | | self.UserDataLen = 0
|
| | | self.UserData = ''
|
| | |
|
| | | def readData(self, buf, pos = 0, length = 0):
|
| | | if not pos <= length:
|
| | | msg = error.formatMsg('error', error.ERROR_NO_148, '(pos = %s) > (length = %s)'%(pos, length))
|
| | | mylog.error(msg)
|
| | | return -1
|
| | | if len(buf) < pos + self.getLength():
|
| | | msg = error.formatMsg('error', error.ERROR_NO_149, 'len = %s while %s expected!'%(len(buf) - pos, self.getLength()))
|
| | | mylog.error(msg)
|
| | | self.clear()
|
| | | self.PlayerID, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.RecType, pos = CommFunc.ReadWORD(buf, pos)
|
| | | self.Time, pos = CommFunc.ReadDouble(buf, pos)
|
| | | self.Value1, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.Value2, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.Value3, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.Value4, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.Value5, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.Value6, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.Value7, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.Value8, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.UserDataLen, pos = CommFunc.ReadWORD(buf, pos)
|
| | | tmp, pos = CommFunc.ReadString(buf, pos, self.UserDataLen)
|
| | | self.UserData = ctypes.c_char_p(tmp)
|
| | | return self.getLength()
|
| | |
|
| | | def getBuffer(self):
|
| | | buf = ''
|
| | | buf = CommFunc.WriteDWORD(buf, self.PlayerID)
|
| | | buf = CommFunc.WriteWORD(buf, self.RecType)
|
| | | buf = CommFunc.WriteDouble(buf, self.Time)
|
| | | buf = CommFunc.WriteDWORD(buf, self.Value1)
|
| | | buf = CommFunc.WriteDWORD(buf, self.Value2)
|
| | | buf = CommFunc.WriteDWORD(buf, self.Value3)
|
| | | buf = CommFunc.WriteDWORD(buf, self.Value4)
|
| | | buf = CommFunc.WriteDWORD(buf, self.Value5)
|
| | | buf = CommFunc.WriteDWORD(buf, self.Value6)
|
| | | buf = CommFunc.WriteDWORD(buf, self.Value7)
|
| | | buf = CommFunc.WriteDWORD(buf, self.Value8)
|
| | | buf = CommFunc.WriteWORD(buf, self.UserDataLen)
|
| | | buf = CommFunc.WriteString(buf, self.UserDataLen, self.UserData)
|
| | | return buf
|
| | |
|
| | | def getLength(self):
|
| | | length = 0
|
| | | length += sizeof(ctypes.c_ulong)
|
| | | length += sizeof(ctypes.c_ushort)
|
| | | length += sizeof(ctypes.c_double)
|
| | | length += sizeof(ctypes.c_ulong)
|
| | | length += sizeof(ctypes.c_ulong)
|
| | | length += sizeof(ctypes.c_ulong)
|
| | | length += sizeof(ctypes.c_ulong)
|
| | | length += sizeof(ctypes.c_ulong)
|
| | | length += sizeof(ctypes.c_ulong)
|
| | | length += sizeof(ctypes.c_ulong)
|
| | | length += sizeof(ctypes.c_ulong)
|
| | | length += sizeof(ctypes.c_ushort)
|
| | | length += self.UserDataLen
|
| | | return length
|
| | |
|
| | | def getRecord(self):
|
| | | '''组织存储记录'''
|
| | | rec = {}
|
| | | rec[u'PlayerID'] = self.PlayerID
|
| | | rec[u'RecType'] = self.RecType
|
| | | rec[u'Time'] = self.Time
|
| | | rec[u'Value1'] = self.Value1
|
| | | rec[u'Value2'] = self.Value2
|
| | | rec[u'Value3'] = self.Value3
|
| | | rec[u'Value4'] = self.Value4
|
| | | rec[u'Value5'] = self.Value5
|
| | | rec[u'Value6'] = self.Value6
|
| | | rec[u'Value7'] = self.Value7
|
| | | rec[u'Value8'] = self.Value8
|
| | | rec[u'UserDataLen'] = self.UserDataLen
|
| | | rec[u'UserData'] = fix_incomingText(self.UserData)
|
| | | return rec
|
| | |
|
| | | def readRecord(self, rec):
|
| | | '''由于MongoDB读出来是unicode,所有字符串需要进行转换'''
|
| | | self.PlayerID = rec.get(u'PlayerID', 0)
|
| | | self.RecType = rec.get(u'RecType', 0)
|
| | | self.Time = rec.get(u'Time', 0)
|
| | | self.Value1 = rec.get(u'Value1', 0)
|
| | | self.Value2 = rec.get(u'Value2', 0)
|
| | | self.Value3 = rec.get(u'Value3', 0)
|
| | | self.Value4 = rec.get(u'Value4', 0)
|
| | | self.Value5 = rec.get(u'Value5', 0)
|
| | | self.Value6 = rec.get(u'Value6', 0)
|
| | | self.Value7 = rec.get(u'Value7', 0)
|
| | | self.Value8 = rec.get(u'Value8', 0)
|
| | | self.UserDataLen = rec.get(u'UserDataLen', 0)
|
| | | self.UserData = fix_outgoingText(rec.get(u'UserData', u''))
|
| | |
|
| | | #Can not implement adoLoadStr method:No key defined!
|
| | |
|
| | | def adoInsert(self, collection):
|
| | | '''执行插入'''
|
| | |
|
| | | trycnt = 0
|
| | | rec = self.getRecord()
|
| | | while(True):
|
| | | try:
|
| | | collection.insert(rec, False, True)
|
| | | break
|
| | | except pymongo.errors.OperationFailure, err:
|
| | |
|
| | | if(DBConfig.TryCntOnWriteFail > trycnt):
|
| | | trycnt += 1
|
| | | continue
|
| | | |
| | | addADOExceptionCount()
|
| | | mylog.info("%s.%s:rec = %s"%(self.__class__.__name__, inspect.stack()[0][3], rec))
|
| | | msg = error.formatMsg('error', error.ERROR_NO_152, 'Insert failed!PlayerID = %s, error = %s, trycnt = %d'%(self.PlayerID, err, trycnt))
|
| | | mylog.error(msg)
|
| | |
|
| | | return False
|
| | | return True
|
| | |
|
| | | #Can not implement adoUpdateStr method:No key defined!
|
| | |
|
| | | def adoUpdateEx(self, collection, spec):
|
| | | '''执行更新'''
|
| | | trycnt = 0
|
| | | rec = self.getRecord()
|
| | | while(True):
|
| | | try:
|
| | | collection.update(spec, {'$set':rec}, False, False, True, True)
|
| | | break
|
| | | except pymongo.errors.OperationFailure, err:
|
| | | if(DBConfig.TryCntOnWriteFail > trycnt):
|
| | | trycnt += 1
|
| | | continue
|
| | | addADOExceptionCount()
|
| | | mylog.info("%s.%s:rec = %s"%(self.__class__.__name__, inspect.stack()[0][3], rec))
|
| | | msg = error.formatMsg('error', error.ERROR_NO_154, 'Update failed!PlayerID = %s, error = %s, trycnt = %d'%(self.PlayerID, err, trycnt))
|
| | | mylog.error(msg)
|
| | |
|
| | | return False
|
| | | return True
|
| | |
|
| | | #Can not implement adoCheckUpdateStr method:No key defined!
|
| | | #Can not implement adoCheckUpdateExStr method:No key defined!
|
| | |
|
| | | def getAdoRecords(self, resultCollection):
|
| | | '''查询结果打包成二进制流'''
|
| | | result = ''
|
| | | result = CommFunc.WriteDWORD(result, resultCollection.count())
|
| | | for rec in resultCollection:
|
| | | self.readRecord(rec)
|
| | | result += self.getBuffer()
|
| | | return result
|
| | |
|
| | |
|
| | | def adoQueryIndex(self, collection):
|
| | | '''用索引字段查找'''
|
| | | resultCollection = collection.find({'PlayerID':self.PlayerID})
|
| | | |
| | | return self.getAdoRecords(resultCollection)
|
| | |
|
| | |
|
| | | def adoQueryCustom(self, collection, queryDict):
|
| | | '''自定义查询'''
|
| | | resultCollection = collection.find(queryDict)
|
| | |
|
| | | return self.getAdoRecords(resultCollection)
|
| | |
|
| | |
|
| | | def adoQueryAll(self, collection):
|
| | | '''查询所有''' |
| | | resultCollection = collection.find()
|
| | | |
| | | return self.getAdoRecords(resultCollection)
|
| | |
|
| | |
|
| | | def adoDeleteByIndex(self, collection):
|
| | | '''根据索引删除'''
|
| | | trycnt = 0
|
| | | while(True):
|
| | | try:
|
| | | collection.remove({'PlayerID':self.PlayerID})
|
| | | break
|
| | | except pymongo.errors.OperationFailure, err:
|
| | | if(DBConfig.TryCntOnWriteFail > trycnt):
|
| | | trycnt += 1
|
| | | continue
|
| | | addADOExceptionCount()
|
| | | mylog.info("%s.%s:PlayerID = %s"%(self.__class__.__name__, inspect.stack()[0][3], self.PlayerID))
|
| | | msg = error.formatMsg('error', error.ERROR_NO_155, 'delete failure!self.PlayerID = %s, error = %s, trycnt = %d'%(self.PlayerID, err, trycnt))
|
| | | mylog.error(msg)
|
| | |
|
| | | return False
|
| | | return True
|
| | |
|
| | | def outputString(self):
|
| | | output = '''// 玩家记录表 #tagDBPlayerRecData:
|
| | | PlayerID = %s,
|
| | | RecType = %s,
|
| | | Time = %s,
|
| | | Value1 = %s,
|
| | | Value2 = %s,
|
| | | Value3 = %s,
|
| | | Value4 = %s,
|
| | | Value5 = %s,
|
| | | Value6 = %s,
|
| | | Value7 = %s,
|
| | | Value8 = %s,
|
| | | UserDataLen = %s,
|
| | | UserData = %s,
|
| | | ADOResult = %s,
|
| | | '''%(
|
| | | self.PlayerID,
|
| | | self.RecType,
|
| | | self.Time,
|
| | | self.Value1,
|
| | | self.Value2,
|
| | | self.Value3,
|
| | | self.Value4,
|
| | | self.Value5,
|
| | | self.Value6,
|
| | | self.Value7,
|
| | | self.Value8,
|
| | | self.UserDataLen,
|
| | | self.UserData,
|
| | | self.ADOResult,
|
| | | )
|
| | | return output
|
| | |
|
| | | def dumpString(self):
|
| | | output = '''%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s'''%(
|
| | | self.PlayerID,
|
| | | self.RecType,
|
| | | self.Time,
|
| | | self.Value1,
|
| | | self.Value2,
|
| | | self.Value3,
|
| | | self.Value4,
|
| | | self.Value5,
|
| | | self.Value6,
|
| | | self.Value7,
|
| | | self.Value8,
|
| | | self.UserDataLen,
|
| | | self.UserData,
|
| | | )
|
| | | return output
|
| | |
|
| | |
|
| | | # 功能队伍成员表 #tagDBPyFuncTeamMem
|
| | | class tagDBPyFuncTeamMem(Structure):
|
| | | _pack_ = 1
|
| | | _fields_ = [
|
| | | ('TeamID', ctypes.c_ulong),
|
| | | ('PlayerID', ctypes.c_ulong),
|
| | | ('Value1', ctypes.c_ulong),
|
| | | ('Value2', ctypes.c_ulong),
|
| | | ('Value3', ctypes.c_ulong),
|
| | | ('Value4', ctypes.c_ulong),
|
| | | ('Value5', ctypes.c_ulong),
|
| | | ('ADOResult', ctypes.c_ulong),
|
| | | ]
|
| | |
|
| | | def __init__(self):
|
| | | Structure.__init__(self)
|
| | | self.clear()
|
| | |
|
| | |
|
| | | def clear(self):
|
| | | memset(addressof(self), 0, self.getLength())
|
| | |
|
| | | def readData(self, buf, pos = 0, length = 0):
|
| | | if not pos <= length:
|
| | | msg = error.formatMsg('error', error.ERROR_NO_148, '(pos = %s) > (length = %s)'%(pos, length))
|
| | | mylog.error(msg)
|
| | | return -1
|
| | | if len(buf) < pos + self.getLength():
|
| | | msg = error.formatMsg('error', error.ERROR_NO_149, 'len = %s while %s expected!'%(len(buf) - pos, self.getLength()))
|
| | | mylog.error(msg)
|
| | | self.clear()
|
| | | self.TeamID, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.PlayerID, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.Value1, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.Value2, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.Value3, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.Value4, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.Value5, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | return self.getLength()
|
| | |
|
| | |
|
| | | def getBuffer(self):
|
| | | buf = create_string_buffer(self.getLength())
|
| | | memmove(addressof(buf), addressof(self), self.getLength())
|
| | | return string_at(addressof(buf), self.getLength())
|
| | |
|
| | | def getLength(self):
|
| | | return sizeof(tagDBPyFuncTeamMem)
|
| | |
|
| | | def getRecord(self):
|
| | | '''组织存储记录'''
|
| | | rec = {}
|
| | | rec[u'TeamID'] = self.TeamID
|
| | | rec[u'PlayerID'] = self.PlayerID
|
| | | rec[u'Value1'] = self.Value1
|
| | | rec[u'Value2'] = self.Value2
|
| | | rec[u'Value3'] = self.Value3
|
| | | rec[u'Value4'] = self.Value4
|
| | | rec[u'Value5'] = self.Value5
|
| | | return rec
|
| | |
|
| | | def readRecord(self, rec):
|
| | | '''由于MongoDB读出来是unicode,所有字符串需要进行转换'''
|
| | | self.TeamID = rec.get(u'TeamID', 0)
|
| | | self.PlayerID = rec.get(u'PlayerID', 0)
|
| | | self.Value1 = rec.get(u'Value1', 0)
|
| | | self.Value2 = rec.get(u'Value2', 0)
|
| | | self.Value3 = rec.get(u'Value3', 0)
|
| | | self.Value4 = rec.get(u'Value4', 0)
|
| | | self.Value5 = rec.get(u'Value5', 0)
|
| | |
|
| | | #Can not implement adoLoadStr method:No key defined!
|
| | | #Can not implement adoInsertStr method:No key defined!
|
| | | #Can not implement adoUpdateStr method:No key defined!
|
| | | #Can not implement adoUpdateStr method:No key defined!
|
| | | #Can not implement adoCheckUpdateStr method:No key defined!
|
| | | #Can not implement adoCheckUpdateExStr method:No key defined!
|
| | |
|
| | | def getAdoRecords(self, resultCollection):
|
| | | '''查询结果打包成二进制流'''
|
| | | result = ''
|
| | | result = CommFunc.WriteDWORD(result, resultCollection.count())
|
| | | for rec in resultCollection:
|
| | | self.readRecord(rec)
|
| | | result += self.getBuffer()
|
| | | return result
|
| | |
|
| | | #Can not implement adoQueryIndexStr method:No key defined!
|
| | |
|
| | | def adoQueryCustom(self, collection, queryDict):
|
| | | '''自定义查询'''
|
| | | resultCollection = collection.find(queryDict)
|
| | |
|
| | | return self.getAdoRecords(resultCollection)
|
| | |
|
| | |
|
| | | def adoQueryAll(self, collection):
|
| | | '''查询所有''' |
| | | resultCollection = collection.find()
|
| | | |
| | | return self.getAdoRecords(resultCollection)
|
| | |
|
| | | #Can not implement adoDeleteByIndexStr method:No key defined!
|
| | | def outputString(self):
|
| | | output = '''// 功能队伍成员表 #tagDBPyFuncTeamMem:
|
| | | TeamID = %s,
|
| | | PlayerID = %s,
|
| | | Value1 = %s,
|
| | | Value2 = %s,
|
| | | Value3 = %s,
|
| | | Value4 = %s,
|
| | | Value5 = %s,
|
| | | ADOResult = %s,
|
| | | '''%(
|
| | | self.TeamID,
|
| | | self.PlayerID,
|
| | | self.Value1,
|
| | | self.Value2,
|
| | | self.Value3,
|
| | | self.Value4,
|
| | | self.Value5,
|
| | | self.ADOResult,
|
| | | )
|
| | | return output
|
| | |
|
| | | def dumpString(self):
|
| | | output = '''%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s'''%(
|
| | | self.TeamID,
|
| | | self.PlayerID,
|
| | | self.Value1,
|
| | | self.Value2,
|
| | | self.Value3,
|
| | | self.Value4,
|
| | | self.Value5,
|
| | | )
|
| | | return output
|
| | |
|
| | |
|
| | | # 功能队伍表 #tagDBPyFuncTeam
|
| | | class tagDBPyFuncTeam(Structure):
|
| | | _pack_ = 1
|
| | | _fields_ = [
|
| | | ('TeamID', ctypes.c_ulong),
|
| | | ('TeamName', ctypes.c_char * 33),
|
| | | ('ZoneID', ctypes.c_ubyte),
|
| | | ('FuncMapID', ctypes.c_ulong),
|
| | | ('FuncMapEx', ctypes.c_ulong),
|
| | | ('CreateTime', ctypes.c_ulong),
|
| | | ('CaptainID', ctypes.c_ulong),
|
| | | ('MinLV', ctypes.c_ushort),
|
| | | ('MinFightPower', ctypes.c_ulong),
|
| | | ('MinFightPowerEx', ctypes.c_ulong),
|
| | | ('ServerOnly', ctypes.c_ubyte),
|
| | | ('NeedCheck', ctypes.c_ubyte),
|
| | | ('ApplyIDLen', ctypes.c_ushort),
|
| | | ('ApplyIDList', ctypes.c_char_p),
|
| | | ('Value1', ctypes.c_ulong),
|
| | | ('Value2', ctypes.c_ulong),
|
| | | ('Value3', ctypes.c_ulong),
|
| | | ('Value4', ctypes.c_ulong),
|
| | | ('Value5', ctypes.c_ulong),
|
| | | ('ADOResult', ctypes.c_ulong),
|
| | | ]
|
| | |
|
| | | def __init__(self):
|
| | | Structure.__init__(self)
|
| | | self.clear()
|
| | |
|
| | | def clear(self):
|
| | | self.TeamID = 0
|
| | | self.TeamName = ''
|
| | | self.ZoneID = 0
|
| | | self.FuncMapID = 0
|
| | | self.FuncMapEx = 0
|
| | | self.CreateTime = 0
|
| | | self.CaptainID = 0
|
| | | self.MinLV = 0
|
| | | self.MinFightPower = 0
|
| | | self.MinFightPowerEx = 0
|
| | | self.ServerOnly = 0
|
| | | self.NeedCheck = 0
|
| | | self.ApplyIDLen = 0
|
| | | self.ApplyIDList = ''
|
| | | self.Value1 = 0
|
| | | self.Value2 = 0
|
| | | self.Value3 = 0
|
| | | self.Value4 = 0
|
| | | self.Value5 = 0
|
| | |
|
| | | def readData(self, buf, pos = 0, length = 0):
|
| | | if not pos <= length:
|
| | | msg = error.formatMsg('error', error.ERROR_NO_148, '(pos = %s) > (length = %s)'%(pos, length))
|
| | | mylog.error(msg)
|
| | | return -1
|
| | | if len(buf) < pos + self.getLength():
|
| | | msg = error.formatMsg('error', error.ERROR_NO_149, 'len = %s while %s expected!'%(len(buf) - pos, self.getLength()))
|
| | | mylog.error(msg)
|
| | | self.clear()
|
| | | self.TeamID, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.TeamName, pos = CommFunc.ReadString(buf, pos, 33)
|
| | | self.ZoneID, pos = CommFunc.ReadBYTE(buf, pos)
|
| | | self.FuncMapID, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.FuncMapEx, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.CreateTime, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.CaptainID, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.MinLV, pos = CommFunc.ReadWORD(buf, pos)
|
| | | self.MinFightPower, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.MinFightPowerEx, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.ServerOnly, pos = CommFunc.ReadBYTE(buf, pos)
|
| | | self.NeedCheck, pos = CommFunc.ReadBYTE(buf, pos)
|
| | | self.ApplyIDLen, pos = CommFunc.ReadWORD(buf, pos)
|
| | | tmp, pos = CommFunc.ReadString(buf, pos, self.ApplyIDLen)
|
| | | self.ApplyIDList = ctypes.c_char_p(tmp)
|
| | | self.Value1, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.Value2, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.Value3, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.Value4, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.Value5, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | return self.getLength()
|
| | |
|
| | | def getBuffer(self):
|
| | | buf = ''
|
| | | buf = CommFunc.WriteDWORD(buf, self.TeamID)
|
| | | buf = CommFunc.WriteString(buf, sizeof(ctypes.c_char) * 33, self.TeamName)
|
| | | buf = CommFunc.WriteBYTE(buf, self.ZoneID)
|
| | | buf = CommFunc.WriteDWORD(buf, self.FuncMapID)
|
| | | buf = CommFunc.WriteDWORD(buf, self.FuncMapEx)
|
| | | buf = CommFunc.WriteDWORD(buf, self.CreateTime)
|
| | | buf = CommFunc.WriteDWORD(buf, self.CaptainID)
|
| | | buf = CommFunc.WriteWORD(buf, self.MinLV)
|
| | | buf = CommFunc.WriteDWORD(buf, self.MinFightPower)
|
| | | buf = CommFunc.WriteDWORD(buf, self.MinFightPowerEx)
|
| | | buf = CommFunc.WriteBYTE(buf, self.ServerOnly)
|
| | | buf = CommFunc.WriteBYTE(buf, self.NeedCheck)
|
| | | buf = CommFunc.WriteWORD(buf, self.ApplyIDLen)
|
| | | buf = CommFunc.WriteString(buf, self.ApplyIDLen, self.ApplyIDList)
|
| | | buf = CommFunc.WriteDWORD(buf, self.Value1)
|
| | | buf = CommFunc.WriteDWORD(buf, self.Value2)
|
| | | buf = CommFunc.WriteDWORD(buf, self.Value3)
|
| | | buf = CommFunc.WriteDWORD(buf, self.Value4)
|
| | | buf = CommFunc.WriteDWORD(buf, self.Value5)
|
| | | return buf
|
| | |
|
| | | def getLength(self):
|
| | | length = 0
|
| | | length += sizeof(ctypes.c_ulong)
|
| | | length += sizeof(ctypes.c_char) * 33
|
| | | length += sizeof(ctypes.c_ubyte)
|
| | | length += sizeof(ctypes.c_ulong)
|
| | | length += sizeof(ctypes.c_ulong)
|
| | | length += sizeof(ctypes.c_ulong)
|
| | | length += sizeof(ctypes.c_ulong)
|
| | | length += sizeof(ctypes.c_ushort)
|
| | | length += sizeof(ctypes.c_ulong)
|
| | | length += sizeof(ctypes.c_ulong)
|
| | | length += sizeof(ctypes.c_ubyte)
|
| | | length += sizeof(ctypes.c_ubyte)
|
| | | length += sizeof(ctypes.c_ushort)
|
| | | length += self.ApplyIDLen
|
| | | length += sizeof(ctypes.c_ulong)
|
| | | length += sizeof(ctypes.c_ulong)
|
| | | length += sizeof(ctypes.c_ulong)
|
| | | length += sizeof(ctypes.c_ulong)
|
| | | length += sizeof(ctypes.c_ulong)
|
| | | return length
|
| | |
|
| | | def getRecord(self):
|
| | | '''组织存储记录'''
|
| | | rec = {}
|
| | | rec[u'TeamID'] = self.TeamID
|
| | | rec[u'TeamName'] = fix_incomingText(self.TeamName)
|
| | | rec[u'ZoneID'] = self.ZoneID
|
| | | rec[u'FuncMapID'] = self.FuncMapID
|
| | | rec[u'FuncMapEx'] = self.FuncMapEx
|
| | | rec[u'CreateTime'] = self.CreateTime
|
| | | rec[u'CaptainID'] = self.CaptainID
|
| | | rec[u'MinLV'] = self.MinLV
|
| | | rec[u'MinFightPower'] = self.MinFightPower
|
| | | rec[u'MinFightPowerEx'] = self.MinFightPowerEx
|
| | | rec[u'ServerOnly'] = self.ServerOnly
|
| | | rec[u'NeedCheck'] = self.NeedCheck
|
| | | rec[u'ApplyIDLen'] = self.ApplyIDLen
|
| | | rec[u'ApplyIDList'] = fix_incomingText(self.ApplyIDList)
|
| | | rec[u'Value1'] = self.Value1
|
| | | rec[u'Value2'] = self.Value2
|
| | | rec[u'Value3'] = self.Value3
|
| | | rec[u'Value4'] = self.Value4
|
| | | rec[u'Value5'] = self.Value5
|
| | | return rec
|
| | |
|
| | | def readRecord(self, rec):
|
| | | '''由于MongoDB读出来是unicode,所有字符串需要进行转换'''
|
| | | self.TeamID = rec.get(u'TeamID', 0)
|
| | | self.TeamName = fix_outgoingText(rec.get(u'TeamName', u''))
|
| | | self.ZoneID = rec.get(u'ZoneID', 0)
|
| | | self.FuncMapID = rec.get(u'FuncMapID', 0)
|
| | | self.FuncMapEx = rec.get(u'FuncMapEx', 0)
|
| | | self.CreateTime = rec.get(u'CreateTime', 0)
|
| | | self.CaptainID = rec.get(u'CaptainID', 0)
|
| | | self.MinLV = rec.get(u'MinLV', 0)
|
| | | self.MinFightPower = rec.get(u'MinFightPower', 0)
|
| | | self.MinFightPowerEx = rec.get(u'MinFightPowerEx', 0)
|
| | | self.ServerOnly = rec.get(u'ServerOnly', 0)
|
| | | self.NeedCheck = rec.get(u'NeedCheck', 0)
|
| | | self.ApplyIDLen = rec.get(u'ApplyIDLen', 0)
|
| | | self.ApplyIDList = fix_outgoingText(rec.get(u'ApplyIDList', u''))
|
| | | self.Value1 = rec.get(u'Value1', 0)
|
| | | self.Value2 = rec.get(u'Value2', 0)
|
| | | self.Value3 = rec.get(u'Value3', 0)
|
| | | self.Value4 = rec.get(u'Value4', 0)
|
| | | self.Value5 = rec.get(u'Value5', 0)
|
| | |
|
| | | #Can not implement adoLoadStr method:No key defined!
|
| | | #Can not implement adoInsertStr method:No key defined!
|
| | | #Can not implement adoUpdateStr method:No key defined!
|
| | | #Can not implement adoUpdateStr method:No key defined!
|
| | | #Can not implement adoCheckUpdateStr method:No key defined!
|
| | | #Can not implement adoCheckUpdateExStr method:No key defined!
|
| | |
|
| | | def getAdoRecords(self, resultCollection):
|
| | | '''查询结果打包成二进制流'''
|
| | | result = ''
|
| | | result = CommFunc.WriteDWORD(result, resultCollection.count())
|
| | | for rec in resultCollection:
|
| | | self.readRecord(rec)
|
| | | result += self.getBuffer()
|
| | | return result
|
| | |
|
| | | #Can not implement adoQueryIndexStr method:No key defined!
|
| | |
|
| | | def adoQueryCustom(self, collection, queryDict):
|
| | | '''自定义查询'''
|
| | | resultCollection = collection.find(queryDict)
|
| | |
|
| | | return self.getAdoRecords(resultCollection)
|
| | |
|
| | |
|
| | | def adoQueryAll(self, collection):
|
| | | '''查询所有''' |
| | | resultCollection = collection.find()
|
| | | |
| | | return self.getAdoRecords(resultCollection)
|
| | |
|
| | | #Can not implement adoDeleteByIndexStr method:No key defined!
|
| | | def outputString(self):
|
| | | output = '''// 功能队伍表 #tagDBPyFuncTeam:
|
| | | TeamID = %s,
|
| | | TeamName = %s,
|
| | | ZoneID = %s,
|
| | | FuncMapID = %s,
|
| | | FuncMapEx = %s,
|
| | | CreateTime = %s,
|
| | | CaptainID = %s,
|
| | | MinLV = %s,
|
| | | MinFightPower = %s,
|
| | | MinFightPowerEx = %s,
|
| | | ServerOnly = %s,
|
| | | NeedCheck = %s,
|
| | | ApplyIDLen = %s,
|
| | | ApplyIDList = %s,
|
| | | Value1 = %s,
|
| | | Value2 = %s,
|
| | | Value3 = %s,
|
| | | Value4 = %s,
|
| | | Value5 = %s,
|
| | | ADOResult = %s,
|
| | | '''%(
|
| | | self.TeamID,
|
| | | self.TeamName,
|
| | | self.ZoneID,
|
| | | self.FuncMapID,
|
| | | self.FuncMapEx,
|
| | | self.CreateTime,
|
| | | self.CaptainID,
|
| | | self.MinLV,
|
| | | self.MinFightPower,
|
| | | self.MinFightPowerEx,
|
| | | self.ServerOnly,
|
| | | self.NeedCheck,
|
| | | self.ApplyIDLen,
|
| | | self.ApplyIDList,
|
| | | self.Value1,
|
| | | self.Value2,
|
| | | self.Value3,
|
| | | self.Value4,
|
| | | self.Value5,
|
| | | self.ADOResult,
|
| | | )
|
| | | return output
|
| | |
|
| | | def dumpString(self):
|
| | | output = '''%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s'''%(
|
| | | self.TeamID,
|
| | | self.TeamName,
|
| | | self.ZoneID,
|
| | | self.FuncMapID,
|
| | | self.FuncMapEx,
|
| | | self.CreateTime,
|
| | | self.CaptainID,
|
| | | self.MinLV,
|
| | | self.MinFightPower,
|
| | | self.MinFightPowerEx,
|
| | | self.ServerOnly,
|
| | | self.NeedCheck,
|
| | | self.ApplyIDLen,
|
| | | self.ApplyIDList,
|
| | | self.Value1,
|
| | | self.Value2,
|
| | | self.Value3,
|
| | | self.Value4,
|
| | | self.Value5,
|
| | | )
|
| | | return output
|
| | |
|
| | | #Char数组类型Set接口,使用该接口对此类型数据赋值,防止赋值的数据过长报错
|
| | | def SetTeamName(self,Str):
|
| | | if len(Str)<=33:
|
| | | self.TeamName = Str
|
| | | else:
|
| | | self.TeamName = Str[:33]
|
| | |
|
| | |
|
| | | # 通用记录表新 #tagDBGameRec
|
| | | class tagDBGameRec(Structure):
|
| | | _pack_ = 1
|
| | | _fields_ = [
|
| | | ('RecType', ctypes.c_ushort),
|
| | | ('RecID', ctypes.c_ulong),
|
| | | ('Time', ctypes.c_double),
|
| | | ('Value1', ctypes.c_ulong),
|
| | | ('Value2', ctypes.c_ulong),
|
| | | ('Value3', ctypes.c_ulong),
|
| | | ('Value4', ctypes.c_ulong),
|
| | | ('Value5', ctypes.c_ulong),
|
| | | ('Value6', ctypes.c_ulong),
|
| | | ('Value7', ctypes.c_ulong),
|
| | | ('Value8', ctypes.c_ulong),
|
| | | ('UserDataLen', ctypes.c_ushort),
|
| | | ('UserData', ctypes.c_char_p),
|
| | | ('ADOResult', ctypes.c_ulong),
|
| | | ]
|
| | |
|
| | | def __init__(self):
|
| | | Structure.__init__(self)
|
| | | self.clear()
|
| | |
|
| | | def clear(self):
|
| | | self.RecType = 0
|
| | | self.RecID = 0
|
| | | self.Time = 0.0
|
| | | self.Value1 = 0
|
| | | self.Value2 = 0
|
| | | self.Value3 = 0
|
| | | self.Value4 = 0
|
| | | self.Value5 = 0
|
| | | self.Value6 = 0
|
| | | self.Value7 = 0
|
| | | self.Value8 = 0
|
| | | self.UserDataLen = 0
|
| | | self.UserData = ''
|
| | |
|
| | | def readData(self, buf, pos = 0, length = 0):
|
| | | if not pos <= length:
|
| | | msg = error.formatMsg('error', error.ERROR_NO_148, '(pos = %s) > (length = %s)'%(pos, length))
|
| | | mylog.error(msg)
|
| | | return -1
|
| | | if len(buf) < pos + self.getLength():
|
| | | msg = error.formatMsg('error', error.ERROR_NO_149, 'len = %s while %s expected!'%(len(buf) - pos, self.getLength()))
|
| | | mylog.error(msg)
|
| | | self.clear()
|
| | | self.RecType, pos = CommFunc.ReadWORD(buf, pos)
|
| | | self.RecID, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.Time, pos = CommFunc.ReadDouble(buf, pos)
|
| | | self.Value1, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.Value2, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.Value3, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.Value4, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.Value5, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.Value6, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.Value7, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.Value8, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.UserDataLen, pos = CommFunc.ReadWORD(buf, pos)
|
| | | tmp, pos = CommFunc.ReadString(buf, pos, self.UserDataLen)
|
| | | self.UserData = ctypes.c_char_p(tmp)
|
| | | return self.getLength()
|
| | |
|
| | | def getBuffer(self):
|
| | | buf = ''
|
| | | buf = CommFunc.WriteWORD(buf, self.RecType)
|
| | | buf = CommFunc.WriteDWORD(buf, self.RecID)
|
| | | buf = CommFunc.WriteDouble(buf, self.Time)
|
| | | buf = CommFunc.WriteDWORD(buf, self.Value1)
|
| | | buf = CommFunc.WriteDWORD(buf, self.Value2)
|
| | | buf = CommFunc.WriteDWORD(buf, self.Value3)
|
| | | buf = CommFunc.WriteDWORD(buf, self.Value4)
|
| | | buf = CommFunc.WriteDWORD(buf, self.Value5)
|
| | | buf = CommFunc.WriteDWORD(buf, self.Value6)
|
| | | buf = CommFunc.WriteDWORD(buf, self.Value7)
|
| | | buf = CommFunc.WriteDWORD(buf, self.Value8)
|
| | | buf = CommFunc.WriteWORD(buf, self.UserDataLen)
|
| | | buf = CommFunc.WriteString(buf, self.UserDataLen, self.UserData)
|
| | | return buf
|
| | |
|
| | | def getLength(self):
|
| | | length = 0
|
| | | length += sizeof(ctypes.c_ushort)
|
| | | length += sizeof(ctypes.c_ulong)
|
| | | length += sizeof(ctypes.c_double)
|
| | | length += sizeof(ctypes.c_ulong)
|
| | | length += sizeof(ctypes.c_ulong)
|
| | | length += sizeof(ctypes.c_ulong)
|
| | | length += sizeof(ctypes.c_ulong)
|
| | | length += sizeof(ctypes.c_ulong)
|
| | | length += sizeof(ctypes.c_ulong)
|
| | | length += sizeof(ctypes.c_ulong)
|
| | | length += sizeof(ctypes.c_ulong)
|
| | | length += sizeof(ctypes.c_ushort)
|
| | | length += self.UserDataLen
|
| | | return length
|
| | |
|
| | | def getRecord(self):
|
| | | '''组织存储记录'''
|
| | | rec = {}
|
| | | rec[u'RecType'] = self.RecType
|
| | | rec[u'RecID'] = self.RecID
|
| | | rec[u'Time'] = self.Time
|
| | | rec[u'Value1'] = self.Value1
|
| | | rec[u'Value2'] = self.Value2
|
| | | rec[u'Value3'] = self.Value3
|
| | | rec[u'Value4'] = self.Value4
|
| | | rec[u'Value5'] = self.Value5
|
| | | rec[u'Value6'] = self.Value6
|
| | | rec[u'Value7'] = self.Value7
|
| | | rec[u'Value8'] = self.Value8
|
| | | rec[u'UserDataLen'] = self.UserDataLen
|
| | | rec[u'UserData'] = fix_incomingText(self.UserData)
|
| | | return rec
|
| | |
|
| | | def readRecord(self, rec):
|
| | | '''由于MongoDB读出来是unicode,所有字符串需要进行转换'''
|
| | | self.RecType = rec.get(u'RecType', 0)
|
| | | self.RecID = rec.get(u'RecID', 0)
|
| | | self.Time = rec.get(u'Time', 0)
|
| | | self.Value1 = rec.get(u'Value1', 0)
|
| | | self.Value2 = rec.get(u'Value2', 0)
|
| | | self.Value3 = rec.get(u'Value3', 0)
|
| | | self.Value4 = rec.get(u'Value4', 0)
|
| | | self.Value5 = rec.get(u'Value5', 0)
|
| | | self.Value6 = rec.get(u'Value6', 0)
|
| | | self.Value7 = rec.get(u'Value7', 0)
|
| | | self.Value8 = rec.get(u'Value8', 0)
|
| | | self.UserDataLen = rec.get(u'UserDataLen', 0)
|
| | | self.UserData = fix_outgoingText(rec.get(u'UserData', u''))
|
| | |
|
| | | #Can not implement adoLoadStr method:No key defined!
|
| | | #Can not implement adoInsertStr method:No key defined!
|
| | | #Can not implement adoUpdateStr method:No key defined!
|
| | | #Can not implement adoUpdateStr method:No key defined!
|
| | | #Can not implement adoCheckUpdateStr method:No key defined!
|
| | | #Can not implement adoCheckUpdateExStr method:No key defined!
|
| | |
|
| | | def getAdoRecords(self, resultCollection):
|
| | | '''查询结果打包成二进制流'''
|
| | | result = ''
|
| | | result = CommFunc.WriteDWORD(result, resultCollection.count())
|
| | | for rec in resultCollection:
|
| | | self.readRecord(rec)
|
| | | result += self.getBuffer()
|
| | | return result
|
| | |
|
| | | #Can not implement adoQueryIndexStr method:No key defined!
|
| | |
|
| | | def adoQueryCustom(self, collection, queryDict):
|
| | | '''自定义查询'''
|
| | | resultCollection = collection.find(queryDict)
|
| | |
|
| | | return self.getAdoRecords(resultCollection)
|
| | |
|
| | |
|
| | | def adoQueryAll(self, collection):
|
| | | '''查询所有''' |
| | | resultCollection = collection.find()
|
| | | |
| | | return self.getAdoRecords(resultCollection)
|
| | |
|
| | | #Can not implement adoDeleteByIndexStr method:No key defined!
|
| | | def outputString(self):
|
| | | output = '''// 通用记录表新 #tagDBGameRec:
|
| | | RecType = %s,
|
| | | RecID = %s,
|
| | | Time = %s,
|
| | | Value1 = %s,
|
| | | Value2 = %s,
|
| | | Value3 = %s,
|
| | | Value4 = %s,
|
| | | Value5 = %s,
|
| | | Value6 = %s,
|
| | | Value7 = %s,
|
| | | Value8 = %s,
|
| | | UserDataLen = %s,
|
| | | UserData = %s,
|
| | | ADOResult = %s,
|
| | | '''%(
|
| | | self.RecType,
|
| | | self.RecID,
|
| | | self.Time,
|
| | | self.Value1,
|
| | | self.Value2,
|
| | | self.Value3,
|
| | | self.Value4,
|
| | | self.Value5,
|
| | | self.Value6,
|
| | | self.Value7,
|
| | | self.Value8,
|
| | | self.UserDataLen,
|
| | | self.UserData,
|
| | | self.ADOResult,
|
| | | )
|
| | | return output
|
| | |
|
| | | def dumpString(self):
|
| | | output = '''%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s\t%1s'''%(
|
| | | self.RecType,
|
| | | self.RecID,
|
| | | self.Time,
|
| | | self.Value1,
|
| | | self.Value2,
|
| | | self.Value3,
|
| | | self.Value4,
|
| | | self.Value5,
|
| | | self.Value6,
|
| | | self.Value7,
|
| | | self.Value8,
|
| | | self.UserDataLen,
|
| | | self.UserData,
|
| | | )
|
| | | return output
|
| | |
|
| | |
|
| | | # 玩家数据打包表 #tagDBPlayerPackData
|
| | | class tagDBPlayerPackData(Structure):
|
| | | _pack_ = 1
|
| | | _fields_ = [
|
| | | ('PlayerID', ctypes.c_ulong),
|
| | | ('UpdTime', ctypes.c_ulong),
|
| | | ('PackDataSize', ctypes.c_ulong),
|
| | | ('PackData', ctypes.c_char_p),
|
| | | ('ADOResult', ctypes.c_ulong),
|
| | | ]
|
| | |
|
| | | def __init__(self):
|
| | | Structure.__init__(self)
|
| | | self.clear()
|
| | |
|
| | | def clear(self):
|
| | | self.PlayerID = 0
|
| | | self.UpdTime = 0
|
| | | self.PackDataSize = 0
|
| | | self.PackData = ''
|
| | |
|
| | | def readData(self, buf, pos = 0, length = 0):
|
| | | if not pos <= length:
|
| | | msg = error.formatMsg('error', error.ERROR_NO_148, '(pos = %s) > (length = %s)'%(pos, length))
|
| | | mylog.error(msg)
|
| | | return -1
|
| | | if len(buf) < pos + self.getLength():
|
| | | msg = error.formatMsg('error', error.ERROR_NO_149, 'len = %s while %s expected!'%(len(buf) - pos, self.getLength()))
|
| | | mylog.error(msg)
|
| | | self.clear()
|
| | | self.PlayerID, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.UpdTime, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | self.PackDataSize, pos = CommFunc.ReadDWORD(buf, pos)
|
| | | tmp, pos = CommFunc.ReadString(buf, pos, self.PackDataSize)
|
| | | self.PackData = ctypes.c_char_p(tmp)
|
| | | return self.getLength()
|
| | |
|
| | | def getBuffer(self):
|
| | | buf = ''
|
| | | buf = CommFunc.WriteDWORD(buf, self.PlayerID)
|
| | | buf = CommFunc.WriteDWORD(buf, self.UpdTime)
|
| | | buf = CommFunc.WriteDWORD(buf, self.PackDataSize)
|
| | | buf = CommFunc.WriteString(buf, self.PackDataSize, self.PackData)
|
| | | return buf
|
| | |
|
| | | def getLength(self):
|
| | | length = 0
|
| | | length += sizeof(ctypes.c_ulong)
|
| | | length += sizeof(ctypes.c_ulong)
|
| | | length += sizeof(ctypes.c_ulong)
|
| | | length += self.PackDataSize
|
| | | return length
|
| | |
|
| | | def getRecord(self):
|
| | | '''组织存储记录'''
|
| | | rec = {}
|
| | | rec[u'PlayerID'] = self.PlayerID
|
| | | rec[u'UpdTime'] = self.UpdTime
|
| | | rec[u'PackDataSize'] = self.PackDataSize
|
| | | rec[u'PackData'] = fix_incomingText(self.PackData)
|
| | | return rec
|
| | |
|
| | | def readRecord(self, rec):
|
| | | '''由于MongoDB读出来是unicode,所有字符串需要进行转换'''
|
| | | self.PlayerID = rec.get(u'PlayerID', 0)
|
| | | self.UpdTime = rec.get(u'UpdTime', 0)
|
| | | self.PackDataSize = rec.get(u'PackDataSize', 0)
|
| | | self.PackData = fix_outgoingText(rec.get(u'PackData', u''))
|
| | |
|
| | | #Can not implement adoLoadStr method:No key defined!
|
| | | #Can not implement adoInsertStr method:No key defined!
|
| | | #Can not implement adoUpdateStr method:No key defined!
|
| | | #Can not implement adoUpdateStr method:No key defined!
|
| | | #Can not implement adoCheckUpdateStr method:No key defined!
|
| | | #Can not implement adoCheckUpdateExStr method:No key defined!
|
| | |
|
| | | def getAdoRecords(self, resultCollection):
|
| | | '''查询结果打包成二进制流'''
|
| | | result = ''
|
| | | result = CommFunc.WriteDWORD(result, resultCollection.count())
|
| | | for rec in resultCollection:
|
| | | self.readRecord(rec)
|
| | | result += self.getBuffer()
|
| | | return result
|
| | |
|
| | | #Can not implement adoQueryIndexStr method:No key defined!
|
| | |
|
| | | def adoQueryCustom(self, collection, queryDict):
|
| | | '''自定义查询'''
|
| | | resultCollection = collection.find(queryDict)
|
| | |
|
| | | return self.getAdoRecords(resultCollection)
|
| | |
|
| | |
|
| | | def adoQueryAll(self, collection):
|
| | | '''查询所有''' |
| | | resultCollection = collection.find()
|
| | | |
| | | return self.getAdoRecords(resultCollection)
|
| | |
|
| | | #Can not implement adoDeleteByIndexStr method:No key defined!
|
| | | def outputString(self):
|
| | | output = '''// 玩家数据打包表 #tagDBPlayerPackData:
|
| | | PlayerID = %s,
|
| | | UpdTime = %s,
|
| | | PackDataSize = %s,
|
| | | PackData = %s,
|
| | | ADOResult = %s,
|
| | | '''%(
|
| | | self.PlayerID,
|
| | | self.UpdTime,
|
| | | self.PackDataSize,
|
| | | self.PackData,
|
| | | self.ADOResult,
|
| | | )
|
| | | return output
|
| | |
|
| | | def dumpString(self):
|
| | | output = '''%1s\t%1s\t%1s\t%1s'''%(
|
| | | self.PlayerID,
|
| | | self.UpdTime,
|
| | | self.PackDataSize,
|
| | | self.PackData,
|
| | | )
|
| | | return output
|
| | |
|
| | |
| | | gstSendDBMergeClientMsg = 127 # 通过groupID向DB发送消息,DB以gstBroadcastMergeClient广播
|
| | | gstSendDBMergeClientListMsg = 128 # 通过group组向DB发送消息,DB以gstBroadcastMergeClient广播
|
| | | gstMergePlayerData = 129 #// 向跨服汇报玩家(子服)数据
|
| | | gstMax = 130 #下面的数值 需要保持为 gstMax + 1
|
| | | gstDBLogic = 130 # GameServer 向db请求逻辑处理并返回,请求ID,类型,附加数据 |
| | | gstMax = 131 #下面的数值 需要保持为 gstMax + 1
|
| | |
|
| | |
|
| | | ########################### ELoginServerToDataServer define #############################
|
| | | #LoginServer发送到DataServer的封包类型
|
| | |
| | | dgBroadcastMergeClient = 0x60 + 23
|
| | | dgMergerChildToCenter = 0x60 + 24
|
| | | dgLoginMergeServer = 0x60 + 25
|
| | | dgKick = 0x60 + 26
|
| | | dgDBGameServerToDBLogicResult = 0x60 + 26 #GameServer向DB请求的回复信息tagDGGameServerToDBLogicResult
|
| | |
|
| | | ########################### TBalanceServerToMapServer define #############################
|
| | | #数据库回应封包类型#TBalanceServerToMapServer
|
| | | gmMapInitOk = 1
|
| | |
| | | import DataRecordPack
|
| | | import GameWorld
|
| | | import CtrlDB
|
| | | import base64
|
| | |
|
| | |
|
| | | #-------------------------------------------------------------------------------
|
| | |
|
| | |
| | | port = DBConfig.IDDispatchServerPort
|
| | | addr = (host, port)
|
| | | BUF_SIZE = 1024
|
| | | curVersion = ""
|
| | | centerVersion = ""
|
| | | try:
|
| | | cfGameVer = ConfigParser.ConfigParser()
|
| | | cfGameVer.read("GameVersion.ini")
|
| | | cfGameVer.read(os.path.join(GlobalFunctions.getAppPath(), 'GameVersion.ini'))
|
| | |
|
| | | gameID = cfGameVer.get("config", "GameID")
|
| | | curVersion = cfGameVer.get("config", "Version")
|
| | |
| | | except:
|
| | | mylog.error("IDDispatch CheckGameVersion Connect unknown Exception")
|
| | |
|
| | | return
|
| | | return curVersion, centerVersion
|
| | |
|
| | | import thread
|
| | | lockPlayerID = thread.allocate_lock()
|
| | |
| | | if not PyGameData.g_UserCtrlDBFirstInit:
|
| | | PyGameData.g_UserCtrlDBFirstInit = True
|
| | | self.__PlayerBackupSave()
|
| | | CheckGameVersion()
|
| | |
|
| | | #后续也要增加公共数据保存如家族等,考虑保存失败可以直接关闭地图
|
| | |
|
| | |
| | | oFuncGrade.End()
|
| | |
|
| | | if requestType == CommonDefine.gstGeneralDBOper:
|
| | | oFuncGrade = self.GetFuncGrade('gstMergeGeneralReturn')
|
| | | oFuncGrade = self.GetFuncGrade('gstGeneralDBOper')
|
| | | oFuncGrade.Start()
|
| | | self.OnGeneralDBOper(db, pack)
|
| | | oFuncGrade.End()
|
| | | return True
|
| | | |
| | | if requestType == CommonDefine.gstDBLogic:
|
| | | oFuncGrade = self.GetFuncGrade('gstDBLogic')
|
| | | oFuncGrade.Start()
|
| | | self.OnGameServerToDBLogic(db, pack)
|
| | | oFuncGrade.End()
|
| | | return True
|
| | |
|
| | |
| | | self.sendGameServerDBOperResult(pack.getSessionID(), result, resultSet, errorMsg)
|
| | | return
|
| | | mylog.warning('oper %s not support!'%oper)
|
| | |
|
| | |
|
| | | def OnGameServerToDBLogic(self, db, pack):
|
| | | buf = pack.getBuffer()
|
| | | recvPack = RecvPackProtocol.tagGDGameServerToDBLogic()
|
| | | pos = 0
|
| | | recvPack.ReadData(buf, pos)
|
| | | queryType = recvPack.QueryType
|
| | | mylog.debug('pack = %s'%(recvPack.OutputString()))
|
| | |
|
| | | if queryType == CommonDefine.gstDBLogic_PlayerPackDataReq:
|
| | | #请求玩家打包数据
|
| | | playerID = recvPack.ID
|
| | | packData = self.getPlayerPackData(playerID) # 有直接取,没有的话再从db整合数据
|
| | | if packData:
|
| | | result = 1
|
| | | mylog.debug("packData get from cache. playerID=%s" % playerID)
|
| | | else:
|
| | | result, playerData = self.GetPlayerDataByPlayerID(db, playerID)
|
| | | mylog.debug("packData get from db. playerID=%s,result=%s" % (playerID, result))
|
| | | if result:
|
| | | packData = base64.b64encode(playerData)
|
| | | self.updPlayerPackData(playerID, packData)
|
| | | self.SendGameServerToDBLogicResult(pack.getSessionID(), result, recvPack, packData)
|
| | | return
|
| | | |
| | | if queryType == CommonDefine.gstDBLogic_PlayerPackDataUpd:
|
| | | #更新玩家打包数据,仅子服用,不需要回复GameServer
|
| | | playerID = recvPack.ID
|
| | | packData = recvPack.Data
|
| | | self.updPlayerPackData(playerID, packData)
|
| | | return
|
| | | |
| | | if queryType == CommonDefine.gstDBLogic_GMCmd:
|
| | | dbAnswerList = GMShell.DBGMCommand(recvPack.Data)
|
| | | self.SendGameServerToDBLogicResult(pack.getSessionID(), 1, recvPack, str(dbAnswerList))
|
| | | return
|
| | | |
| | | return
|
| | | |
| | | def SendGameServerToDBLogicResult(self, sessionID, result, recvPack, resultSet):
|
| | | '''回复GameServer发送的SendDBLogic,可以不回复,由具体类型决定
|
| | | @param result: 结果:1成功,0失败
|
| | | @param recvPack: GameServer发来的数据包,Data可原值返回,也可修改后返回,由具体类型决定
|
| | | @param resultSet: 回复数据
|
| | | '''
|
| | | sendPack = SendPackProtocol.tagDGGameServerToDBLogicResult()
|
| | | sendPack.Type = CommonDefine.dgDBGameServerToDBLogicResult
|
| | | sendPack.Result = result
|
| | | sendPack.ID = recvPack.ID
|
| | | sendPack.QueryType = recvPack.QueryType
|
| | | sendPack.Data = recvPack.Data
|
| | | sendPack.DataLen = len(sendPack.Data)
|
| | | sendPack.ResultSet = resultSet
|
| | | sendPack.ResultSetLen = len(sendPack.ResultSet)
|
| | | self.packSend(sessionID, 0, 0, CommonDefine.atInner, MMORPGPack.stGame,
|
| | | MMORPGPack.stData, sendPack.GetBuffer())
|
| | | |
| | | mylog.debug("回复 SendGameServerToDBLogicResult")
|
| | | return
|
| | | |
| | | def GetPlayerDataByPlayerID(self, db, playerID):
|
| | | dbPlayer = DataServerPlayerData.tagDBPlayer()
|
| | | dbPlayer.PlayerID = playerID
|
| | | collection = db[UCN_DBPlayer]
|
| | | loadOK = dbPlayer.adoLoadCEx(collection, {'PlayerID':playerID})
|
| | | if not loadOK:
|
| | | mylog.warning('GetPlayerDataByPlayerID Exception playerID = %s'%(dbPlayer.PlayerID))
|
| | | return 0, ''
|
| | | |
| | | #测试
|
| | | mylog.info("accid = %s"%(dbPlayer.AccID))
|
| | | |
| | | #读取物品等其他数据
|
| | | queryDict = {'PlayerID':dbPlayer.PlayerID}
|
| | | collection = db[UCN_RoleItem]
|
| | | itemData = self.readPlayerPackSaveData(collection, queryDict, DataServerPlayerData.tagRoleItem, True)
|
| | | |
| | | collection = db[UCN_RoleMission]
|
| | | missionData = self.readPlayerPackSaveData(collection, queryDict, DataServerPlayerData.tagRoleMission)
|
| | |
|
| | | collection = db[UCN_RoleMissionDict]
|
| | | roleMissionDictData = self.readPlayerPackSaveData(collection, queryDict, DataServerPlayerData.tagRoleMissionDict)
|
| | |
|
| | | collection = db[UCN_RoleSkill]
|
| | | roleSkillData = self.readPlayerPackSaveData(collection, queryDict, DataServerPlayerData.tagRoleSkill)
|
| | | |
| | | collection = db[UCN_RoleBuff]
|
| | | roleBuffData = self.readPlayerPackSaveData(collection, queryDict, DataServerPlayerData.tagRoleBuff)
|
| | | |
| | | collection = db[UCN_RoleRepeatTime]
|
| | | roleRepeatTimeData = self.readPlayerPackSaveData(collection, queryDict, DataServerPlayerData.tagRoleRepeatTime)
|
| | | |
| | | collection = db[UCN_PlayerHorseTable]
|
| | | roleHorseData = self.readPlayerPackSaveData(collection, queryDict, DataServerPlayerData.tagPlayerHorseTable)
|
| | | |
| | | collection = db[UCN_GMOper]
|
| | | gmOperData = self.readPlayerPackSaveData(collection, queryDict, DataServerPlayerData.tagGMOper)
|
| | | |
| | | collection = db[UCN_RolePet]
|
| | | rolePetData = self.readPlayerPackSaveData(collection, queryDict, DataServerPlayerData.tagRolePet)
|
| | | |
| | | collection = db[UCN_PetSkill]
|
| | | petSkillData = self.readPlayerPackSaveData(collection, queryDict, DataServerPlayerData.tagPetSkill)
|
| | | |
| | | collection = db[UCN_RoleNomalDict]
|
| | | roleNormalDictData = self.readPlayerPackSaveData(collection, queryDict, DataServerPlayerData.tagRoleNomalDict)
|
| | | |
| | | collection = db[UCN_PlayerDienstgrad]
|
| | | roleDienstgradData = self.readPlayerPackSaveData(collection, queryDict, DataServerPlayerData.tagPlayerDienstgrad)
|
| | | |
| | | collection = db[UCN_BattleFormation]
|
| | | battleFormationData = self.readPlayerPackSaveData(collection, queryDict, DataServerPlayerData.tagBattleFormation)
|
| | | |
| | | #读取禁止IP数据
|
| | | gmIP = DataServerPlayerData.tagDBGMIP()
|
| | | gmIP.AccID = dbPlayer.AccID.lower()
|
| | | collection = db[UCN_DBGMIP]
|
| | | gmIPData = gmIP.adoQueryIndex(collection)
|
| | | |
| | | return 1, dbPlayer.getBuffer() + itemData + missionData + roleMissionDictData + roleSkillData + roleBuffData + roleRepeatTimeData + roleHorseData + gmOperData\
|
| | | + gmIPData + rolePetData + petSkillData + roleNormalDictData + roleDienstgradData+battleFormationData
|
| | | |
| | |
|
| | |
|
| | | # 查询返回0/1 代表是否成功
|
| | | def OnMergeQueryRegisterResult(self, db, pack):
|
| | | g_mergeRegisterPlayerDict = PyGameData.g_mergeRegisterPlayerDict
|
| | |
| | | return (False, playerRec.PlayerID, '')
|
| | | oFuncGrade.End()
|
| | | #记录下线日志流向
|
| | | if playerRec.FacePic == 0: # 约定为下线标识
|
| | | if playerRec.CountryLastWeekHornor == 0: # 约定为下线标识
|
| | | self.recPlayerLogoff(playerRec)
|
| | | #保存物品等其他数据
|
| | | #不再支持单表模式
|
| | |
| | | if len(infoList) > 3:
|
| | | accountRec.DeviceFlag = md5.md5(infoList[1]).hexdigest()
|
| | | # 倒数第二个元素为客户端版本号 仙宝奇缘新定义
|
| | | accountRec.ClientVersion = infoList[-2]
|
| | | accountRec.SetClientVersion(infoList[-2])
|
| | |
|
| | | PegasusCollectorProxy.EventReport(9001, "OperatorID=%s&Step=%s&AccountID=%s&Flag=1000&DeviceFlag=%s"%(
|
| | | accountRec.AppID, 1, CommFunc.GetPlatformAccID(authAccID), accountRec.DeviceFlag))
|
| | |
| | | def onGetGameServerPlayerData(self, db, pack):
|
| | | data = ''
|
| | |
|
| | | #玩家打包数据表较大,不同步GameServer,由db自己管理
|
| | | #collection = db[UCN_DBPlayerPackData]
|
| | | #DBPlayerPackData = DataServerPlayerData.tagDBPlayerPackData()
|
| | | #data += DBPlayerPackData.adoQueryAll(collection)
|
| | | #mylog.debug("tagDBPlayerPackData ok")
|
| | | |
| | | collection = db[UCN_DBGameRec]
|
| | | DBGameRec = DataServerPlayerData.tagDBGameRec()
|
| | | data += DBGameRec.adoQueryAll(collection)
|
| | | mylog.debug("tagDBGameRec ok")
|
| | | |
| | | collection = db[UCN_DBPyFuncTeam]
|
| | | DBPyFuncTeam = DataServerPlayerData.tagDBPyFuncTeam()
|
| | | data += DBPyFuncTeam.adoQueryAll(collection)
|
| | | mylog.debug("tagDBPyFuncTeam ok")
|
| | | |
| | | collection = db[UCN_DBPyFuncTeamMem]
|
| | | DBPyFuncTeamMem = DataServerPlayerData.tagDBPyFuncTeamMem()
|
| | | data += DBPyFuncTeamMem.adoQueryAll(collection)
|
| | | mylog.debug("tagDBPyFuncTeamMem ok")
|
| | | |
| | | collection = db[UCN_DBPlayerRecData]
|
| | | DBPlayerRecData = DataServerPlayerData.tagDBPlayerRecData()
|
| | | data += DBPlayerRecData.adoQueryAll(collection)
|
| | | mylog.debug("tagDBPlayerRecData ok")
|
| | |
|
| | | collection = db[UCN_DBPyMineAreaAward]
|
| | | DBPyMineAreaAward = DataServerPlayerData.tagDBPyMineAreaAward()
|
| | | data += DBPyMineAreaAward.adoQueryAll(collection)
|
| | |
| | | #mylog.debug("GameData = %s"%b2a_hex(decompressGameData))
|
| | | gameDataReadPos = 0
|
| | | try:
|
| | | #gameDataReadPos = self.savegameServerWorldData(decompressGameData, gameDataReadPos, UCN_DBPlayerPackData, DataServerPlayerData.tagDBPlayerPackData, db)
|
| | | gameDataReadPos = self.savegameServerWorldData(decompressGameData, gameDataReadPos, UCN_DBGameRec, DataServerPlayerData.tagDBGameRec, db)
|
| | | 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)
|
| | |
| | | #mylog.debug("GameData = %s"%b2a_hex(decompressGameData))
|
| | | gameDataReadPos = 0
|
| | | try:
|
| | | #gameDataReadPos = self.savegameServerWorldData(decompressGameData, gameDataReadPos, UCN_DBPlayerPackData, DataServerPlayerData.tagDBPlayerPackData, db)
|
| | | gameDataReadPos = self.savegameServerWorldData(decompressGameData, gameDataReadPos, UCN_DBGameRec, DataServerPlayerData.tagDBGameRec, db)
|
| | | 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)
|
| | |
| | | return DumpString
|
| | |
|
| | | #------------------------------------------------------
|
| | | #GameSever向DB请求信息#tagGDGameServerToDBLogic
|
| | |
|
| | | class tagGDGameServerToDBLogic(Structure):
|
| | | Type = 0 #(BYTE Type)//封包类型
|
| | | ID = 0 #(DWORD ID)//查询对象ID
|
| | | QueryType = 0 #(BYTE QueryType)//查询事件类型
|
| | | DataLen = 0 #(DWORD DataLen)
|
| | | Data = "" #(String Data)//附加信息
|
| | | data = None
|
| | |
|
| | | def __init__(self):
|
| | | self.Clear()
|
| | | return
|
| | |
|
| | | def ReadData(self, _lpData, _pos=0, _Len=0):
|
| | | self.Clear()
|
| | | self.Type,_pos = CommFunc.ReadBYTE(_lpData, _pos)
|
| | | self.ID,_pos = CommFunc.ReadDWORD(_lpData, _pos)
|
| | | self.QueryType,_pos = CommFunc.ReadBYTE(_lpData, _pos)
|
| | | self.DataLen,_pos = CommFunc.ReadDWORD(_lpData, _pos)
|
| | | self.Data,_pos = CommFunc.ReadString(_lpData, _pos,self.DataLen)
|
| | | return _pos
|
| | |
|
| | | def Clear(self):
|
| | | self.Type = 0
|
| | | self.ID = 0
|
| | | self.QueryType = 0
|
| | | self.DataLen = 0
|
| | | self.Data = ""
|
| | | return
|
| | |
|
| | | def GetLength(self):
|
| | | length = 0
|
| | | length += 1
|
| | | length += 4
|
| | | length += 1
|
| | | length += 4
|
| | | length += len(self.Data)
|
| | |
|
| | | return length
|
| | |
|
| | | def GetBuffer(self):
|
| | | data = ''
|
| | | data = CommFunc.WriteBYTE(data, self.Type)
|
| | | data = CommFunc.WriteDWORD(data, self.ID)
|
| | | data = CommFunc.WriteBYTE(data, self.QueryType)
|
| | | data = CommFunc.WriteDWORD(data, self.DataLen)
|
| | | data = CommFunc.WriteString(data, self.DataLen, self.Data)
|
| | | return data
|
| | |
|
| | | def OutputString(self):
|
| | | DumpString = '''
|
| | | Type:%d,
|
| | | ID:%d,
|
| | | QueryType:%d,
|
| | | DataLen:%d,
|
| | | Data:%s
|
| | | '''\
|
| | | %(
|
| | | self.Type,
|
| | | self.ID,
|
| | | self.QueryType,
|
| | | self.DataLen,
|
| | | self.Data
|
| | | )
|
| | | return DumpString
|
| | |
|
| | | #------------------------------------------------------
|
| | | #向指定子服发送消息#tagGDMergeMsgToClient
|
| | |
|
| | | class tagGDMergeMsgToClient(Structure):
|
| | |
| | | )
|
| | | return DumpString
|
| | |
|
| | | #------------------------------------------------------
|
| | | #GameServer向DB请求的回复信息tagDGGameServerToDBLogicResult
|
| | |
|
| | | class tagDGGameServerToDBLogicResult(Structure):
|
| | | Type = 0 #(BYTE Type)
|
| | | Result = 0 #(BYTE Result)//结果:1成功;0失败
|
| | | ID = 0 #(DWORD ID)//查询的ID
|
| | | QueryType = 0 #(BYTE QueryType)//查询的类型
|
| | | DataLen = 0 #(DWORD DataLen)
|
| | | Data = "" #(String Data)//原样返回的附加数据
|
| | | ResultSetLen = 0 #(DWORD ResultSetLen)
|
| | | ResultSet = "" #(String ResultSet)//结果集
|
| | | data = None
|
| | |
|
| | | def __init__(self):
|
| | | self.Clear()
|
| | | return
|
| | |
|
| | | def ReadData(self, _lpData, _pos=0, _Len=0):
|
| | | self.Clear()
|
| | | self.Type,_pos = CommFunc.ReadBYTE(_lpData, _pos)
|
| | | self.Result,_pos = CommFunc.ReadBYTE(_lpData, _pos)
|
| | | self.ID,_pos = CommFunc.ReadDWORD(_lpData, _pos)
|
| | | self.QueryType,_pos = CommFunc.ReadBYTE(_lpData, _pos)
|
| | | self.DataLen,_pos = CommFunc.ReadDWORD(_lpData, _pos)
|
| | | self.Data,_pos = CommFunc.ReadString(_lpData, _pos,self.DataLen)
|
| | | self.ResultSetLen,_pos = CommFunc.ReadDWORD(_lpData, _pos)
|
| | | self.ResultSet,_pos = CommFunc.ReadString(_lpData, _pos,self.ResultSetLen)
|
| | | return _pos
|
| | |
|
| | | def Clear(self):
|
| | | self.Type = 0
|
| | | self.Result = 0
|
| | | self.ID = 0
|
| | | self.QueryType = 0
|
| | | self.DataLen = 0
|
| | | self.Data = ""
|
| | | self.ResultSetLen = 0
|
| | | self.ResultSet = ""
|
| | | return
|
| | |
|
| | | def GetLength(self):
|
| | | length = 0
|
| | | length += 1
|
| | | length += 1
|
| | | length += 4
|
| | | length += 1
|
| | | length += 4
|
| | | length += len(self.Data)
|
| | | length += 4
|
| | | length += len(self.ResultSet)
|
| | |
|
| | | return length
|
| | |
|
| | | def GetBuffer(self):
|
| | | data = ''
|
| | | data = CommFunc.WriteBYTE(data, self.Type)
|
| | | data = CommFunc.WriteBYTE(data, self.Result)
|
| | | data = CommFunc.WriteDWORD(data, self.ID)
|
| | | data = CommFunc.WriteBYTE(data, self.QueryType)
|
| | | data = CommFunc.WriteDWORD(data, self.DataLen)
|
| | | data = CommFunc.WriteString(data, self.DataLen, self.Data)
|
| | | data = CommFunc.WriteDWORD(data, self.ResultSetLen)
|
| | | data = CommFunc.WriteString(data, self.ResultSetLen, self.ResultSet)
|
| | | return data
|
| | |
|
| | | def OutputString(self):
|
| | | DumpString = '''
|
| | | Type:%d,
|
| | | Result:%d,
|
| | | ID:%d,
|
| | | QueryType:%d,
|
| | | DataLen:%d,
|
| | | Data:%s,
|
| | | ResultSetLen:%d,
|
| | | ResultSet:%s
|
| | | '''\
|
| | | %(
|
| | | self.Type,
|
| | | self.Result,
|
| | | self.ID,
|
| | | self.QueryType,
|
| | | self.DataLen,
|
| | | self.Data,
|
| | | self.ResultSetLen,
|
| | | self.ResultSet
|
| | | )
|
| | | return DumpString
|
| | |
|
| | | #通知GameServer可用的家族ID列表#tagDGCanUseFamilyIDList
|
| | |
|
| | | class tagDGCanUseFamilyIDList(Structure):
|