| | |
| | | return pos
|
| | |
|
| | | def recPlayerLogoff(self, dbPlayer):
|
| | | req = DataServerLogData.tagDBPlayerLogInfoOnLogOff()
|
| | | req.AccID = dbPlayer.AccID
|
| | | req.PlayerName = dbPlayer.PlayerName
|
| | | req.AccState = dbPlayer.AccState
|
| | | req.LV = dbPlayer.LV
|
| | | req.Gold = dbPlayer.Gold
|
| | | req.GoldPaper = dbPlayer.GoldPaper
|
| | | req.Silver = dbPlayer.Silver
|
| | | req.SilverPaper = dbPlayer.SilverPaper
|
| | | req.GMLevel = dbPlayer.GMLevel
|
| | | req.Job = dbPlayer.Job
|
| | | req.TJGTime = dbPlayer.HappyPoint # 脱机挂时间
|
| | | req.TJGState = dbPlayer.State # 0正常登录,1脱机登录,2脱机登录死亡
|
| | | req.LastLogoffTime = time()
|
| | | req.PlayerID = dbPlayer.PlayerID
|
| | | req.IsOnline = 0 #默认0因关服时没收到loginserver全部下线包
|
| | | sendBuf = ''
|
| | | sendBuf = CommFunc.WriteBYTE(sendBuf, CommonDefine.gstSavePlayerInfoLogOnLogOff)
|
| | | sendBuf = CommFunc.WriteString(sendBuf, req.getLength(), req.getBuffer())
|
| | | self.sendDBRequest(sendBuf)
|
| | | # req = DataServerLogData.tagDBPlayerLogInfoOnLogOff()
|
| | | # req.AccID = dbPlayer.AccID
|
| | | # req.PlayerName = dbPlayer.PlayerName
|
| | | # req.AccState = dbPlayer.AccState
|
| | | # req.LV = dbPlayer.LV
|
| | | # req.Gold = dbPlayer.Gold
|
| | | # req.GoldPaper = dbPlayer.GoldPaper
|
| | | # req.Silver = dbPlayer.Silver
|
| | | # req.SilverPaper = dbPlayer.SilverPaper
|
| | | # req.GMLevel = dbPlayer.GMLevel
|
| | | # req.Job = dbPlayer.Job
|
| | | # req.TJGTime = dbPlayer.HappyPoint # 脱机挂时间
|
| | | # req.TJGState = dbPlayer.State # 0正常登录,1脱机登录,2脱机登录死亡
|
| | | # req.LastLogoffTime = time()
|
| | | # req.PlayerID = dbPlayer.PlayerID
|
| | | # req.IsOnline = 0 #默认0因关服时没收到loginserver全部下线包
|
| | | # sendBuf = ''
|
| | | # sendBuf = CommFunc.WriteBYTE(sendBuf, CommonDefine.gstSavePlayerInfoLogOnLogOff)
|
| | | # sendBuf = CommFunc.WriteString(sendBuf, req.getLength(), req.getBuffer())
|
| | | # self.sendDBRequest(sendBuf)
|
| | | return
|
| | |
|
| | |
|
| | | def onSavePlayerDataCRCError(self, db, pack, saveDataWithCRC):
|
| | |
| | | # self.sendDBRequest(dbPlayerFobiddenLogReq)
|
| | | self.sendAccForbiddenLogReq(accid.lower(), isForbidden)
|
| | |
|
| | | accForbiddenLogReq = ''
|
| | | accForbiddenLogReq = CommFunc.WriteBYTE(accForbiddenLogReq, CommonDefine.gstAccForbiddenLog)
|
| | | accForbiddenLog = DataServerLogData.tagAccForbiddenLog()
|
| | | accForbiddenLog.AccID = accid.lower()
|
| | | accForbiddenLog.PlayerID = playerID
|
| | | accForbiddenLog.Oper = isForbidden
|
| | | accForbiddenLog.OperTime = operTime
|
| | | accForbiddenLog.TimeLimit = timeLimit
|
| | | accForbiddenLog.GMAccID = operGMAccid
|
| | | accForbiddenLog.Msg = msg
|
| | | accForbiddenLogReq = CommFunc.WriteString(accForbiddenLogReq, accForbiddenLog.getLength(), accForbiddenLog.getBuffer())
|
| | | self.sendDBRequest(accForbiddenLogReq)
|
| | | # accForbiddenLogReq = ''
|
| | | # accForbiddenLogReq = CommFunc.WriteBYTE(accForbiddenLogReq, CommonDefine.gstAccForbiddenLog)
|
| | | # accForbiddenLog = DataServerLogData.tagAccForbiddenLog()
|
| | | # accForbiddenLog.AccID = accid.lower()
|
| | | # accForbiddenLog.PlayerID = playerID
|
| | | # accForbiddenLog.Oper = isForbidden
|
| | | # accForbiddenLog.OperTime = operTime
|
| | | # accForbiddenLog.TimeLimit = timeLimit
|
| | | # accForbiddenLog.GMAccID = operGMAccid
|
| | | # accForbiddenLog.Msg = msg
|
| | | # accForbiddenLogReq = CommFunc.WriteString(accForbiddenLogReq, accForbiddenLog.getLength(), accForbiddenLog.getBuffer())
|
| | | # self.sendDBRequest(accForbiddenLogReq)
|
| | | return
|
| | |
|
| | | def extractGMOper(self, accid, gmOper, gmOperData):
|
| | | pos = 0
|
| | |
| | | #=======================================================================================
|
| | |
|
| | | # 记录玩家点券变化日志
|
| | | oDBPlayerLogInfoOnCoinChange = DataServerLogData.tagDBPlayerLogInfoOnCoinChange() |
| | | oDBPlayerLogInfoOnCoinChange.AccID = oCoinChangeReq.Acc
|
| | | oDBPlayerLogInfoOnCoinChange.Coin = oCoinChangeReq.Coin
|
| | | self.sendDBRequest(chr(CommonDefine.gstSavePlayerInfoLogOnOnCoinChange) + oDBPlayerLogInfoOnCoinChange.getBuffer())
|
| | | # oDBPlayerLogInfoOnCoinChange = DataServerLogData.tagDBPlayerLogInfoOnCoinChange() |
| | | # oDBPlayerLogInfoOnCoinChange.AccID = oCoinChangeReq.Acc
|
| | | # oDBPlayerLogInfoOnCoinChange.Coin = oCoinChangeReq.Coin
|
| | | # self.sendDBRequest(chr(CommonDefine.gstSavePlayerInfoLogOnOnCoinChange) + oDBPlayerLogInfoOnCoinChange.getBuffer())
|
| | | except:
|
| | | msg = error.formatMsg('error', error.ERROR_NO_88, "OnCoinChange throw exception\n%s"%traceback.format_exc())
|
| | | mylog.error(msg)
|
| | |
| | | return False
|
| | | self.sendString(pack, sendPack.GetBuffer())
|
| | |
|
| | | #通知写补偿日志
|
| | | for i in xrange(sendPack.Count):
|
| | | dbData = sendPack.Datas[i]
|
| | | saveLog = DataServerLogData.tagExpiationLog()
|
| | | saveLog.ReceiveDate = time()
|
| | | saveLog.ExpiationIndex = dbData.ExpiationIndex;
|
| | | saveLog.AccID = dbData.AccID
|
| | | saveLog.MakerName = dbData.MakerName
|
| | | saveLog.CreateTime = dbData.CreateTime
|
| | | saveLog.ExpiationTime = dbData.ExpiationTime;
|
| | | saveLog.Gold = dbData.Gold;
|
| | | saveLog.GoldPaper = dbData.GoldPaper;
|
| | | saveLog.Silver = dbData.Silver;
|
| | | saveLog.SilverPaper = dbData.SilverPaper;
|
| | | saveLog.ItemTypeID = dbData.ItemTypeID;
|
| | | saveLog.Count = dbData.Count;
|
| | | saveLog.IsLocked = dbData.IsLocked;
|
| | | saveLog.ItemPlaceType = dbData.ItemPlaceType;
|
| | | saveLog.ItemPlaceIndex = dbData.ItemPlaceIndex;
|
| | | saveLog.IsBind = dbData.IsBind;
|
| | | saveLog.ItemStarLV = dbData.ItemStarLV;
|
| | | saveLog.IdentifyPar = dbData.IdentifyPar;
|
| | | saveLog.CurDurg = dbData.CurDurg;
|
| | | saveLog.MaxDurg = dbData.MaxDurg;
|
| | | saveLog.CanPlaceStoneCount = dbData.CanPlaceStoneCount;
|
| | | saveLog.ItemProperty = dbData.ItemProperty;
|
| | | saveLog.SoulProperty = dbData.SoulProperty;
|
| | | saveLog.Maker = dbData.Maker;
|
| | | saveLog.Stone1 = dbData.Stone1;
|
| | | saveLog.Stone2 = dbData.Stone2;
|
| | | saveLog.Stone3 = dbData.Stone3;
|
| | | saveLog.Stone4 = dbData.Stone4;
|
| | | saveLog.Stone5 = dbData.Stone5;
|
| | | saveLog.Stone6 = dbData.Stone6;
|
| | | saveLog.Stone7 = dbData.Stone7;
|
| | | saveLog.Stone8 = dbData.Stone8;
|
| | | saveLog.Stone9 = dbData.Stone9;
|
| | | saveLog.RemainHour = dbData.RemainHour;
|
| | | saveLog.ElementEffect = dbData.ElementEffect;
|
| | | saveLog.IsSuite = dbData.IsSuite;
|
| | | saveLog.FitLV = dbData.FitLV;
|
| | | saveLog.EquipAddSkillCnt = dbData.EquipAddSkillCnt;
|
| | | saveLog.ExpireTime = dbData.ExpireTime;
|
| | | saveLog.BaseAtkPlus = dbData.BaseAtkPlus;
|
| | | saveLog.BaseDefPlus = dbData.BaseDefPlus;
|
| | | saveLog.AddSkillData = dbData.AddSkillData
|
| | | saveLog.BaseHP = dbData.BaseHP;
|
| | | saveLog.BaseMagicDef = dbData.BaseMagicDef;
|
| | | saveLog.EquipMinAtkValue = dbData.EquipMinAtkValue;
|
| | | saveLog.Proficiency = dbData.Proficiency;
|
| | | saveLog.RelMaxAddSkillCnt = dbData.RelMaxAddSkillCnt;
|
| | | saveLog.FamilyActiveValue = dbData.FamilyActiveValue; |
| | | self.sendDBRequest(chr(CommonDefine.gstGetExpiationLog) + saveLog.getBuffer())
|
| | | # #通知写补偿日志
|
| | | # for i in xrange(sendPack.Count):
|
| | | # dbData = sendPack.Datas[i]
|
| | | # saveLog = DataServerLogData.tagExpiationLog()
|
| | | # saveLog.ReceiveDate = time()
|
| | | # saveLog.ExpiationIndex = dbData.ExpiationIndex;
|
| | | # saveLog.AccID = dbData.AccID
|
| | | # saveLog.MakerName = dbData.MakerName
|
| | | # saveLog.CreateTime = dbData.CreateTime
|
| | | # saveLog.ExpiationTime = dbData.ExpiationTime;
|
| | | # saveLog.Gold = dbData.Gold;
|
| | | # saveLog.GoldPaper = dbData.GoldPaper;
|
| | | # saveLog.Silver = dbData.Silver;
|
| | | # saveLog.SilverPaper = dbData.SilverPaper;
|
| | | # saveLog.ItemTypeID = dbData.ItemTypeID;
|
| | | # saveLog.Count = dbData.Count;
|
| | | # saveLog.IsLocked = dbData.IsLocked;
|
| | | # saveLog.ItemPlaceType = dbData.ItemPlaceType;
|
| | | # saveLog.ItemPlaceIndex = dbData.ItemPlaceIndex;
|
| | | # saveLog.IsBind = dbData.IsBind;
|
| | | # saveLog.ItemStarLV = dbData.ItemStarLV;
|
| | | # saveLog.IdentifyPar = dbData.IdentifyPar;
|
| | | # saveLog.CurDurg = dbData.CurDurg;
|
| | | # saveLog.MaxDurg = dbData.MaxDurg;
|
| | | # saveLog.CanPlaceStoneCount = dbData.CanPlaceStoneCount;
|
| | | # saveLog.ItemProperty = dbData.ItemProperty;
|
| | | # saveLog.SoulProperty = dbData.SoulProperty;
|
| | | # saveLog.Maker = dbData.Maker;
|
| | | # saveLog.Stone1 = dbData.Stone1;
|
| | | # saveLog.Stone2 = dbData.Stone2;
|
| | | # saveLog.Stone3 = dbData.Stone3;
|
| | | # saveLog.Stone4 = dbData.Stone4;
|
| | | # saveLog.Stone5 = dbData.Stone5;
|
| | | # saveLog.Stone6 = dbData.Stone6;
|
| | | # saveLog.Stone7 = dbData.Stone7;
|
| | | # saveLog.Stone8 = dbData.Stone8;
|
| | | # saveLog.Stone9 = dbData.Stone9;
|
| | | # saveLog.RemainHour = dbData.RemainHour;
|
| | | # saveLog.ElementEffect = dbData.ElementEffect;
|
| | | # saveLog.IsSuite = dbData.IsSuite;
|
| | | # saveLog.FitLV = dbData.FitLV;
|
| | | # saveLog.EquipAddSkillCnt = dbData.EquipAddSkillCnt;
|
| | | # saveLog.ExpireTime = dbData.ExpireTime;
|
| | | # saveLog.BaseAtkPlus = dbData.BaseAtkPlus;
|
| | | # saveLog.BaseDefPlus = dbData.BaseDefPlus;
|
| | | # saveLog.AddSkillData = dbData.AddSkillData
|
| | | # saveLog.BaseHP = dbData.BaseHP;
|
| | | # saveLog.BaseMagicDef = dbData.BaseMagicDef;
|
| | | # saveLog.EquipMinAtkValue = dbData.EquipMinAtkValue;
|
| | | # saveLog.Proficiency = dbData.Proficiency;
|
| | | # saveLog.RelMaxAddSkillCnt = dbData.RelMaxAddSkillCnt;
|
| | | # saveLog.FamilyActiveValue = dbData.FamilyActiveValue; |
| | | # self.sendDBRequest(chr(CommonDefine.gstGetExpiationLog) + saveLog.getBuffer())
|
| | | return True
|
| | | # curPack = RecvPackProtocol.tagDGetValueByAcc()
|
| | | # curPack.ReadData(pack.getBuffer())
|
| | |
| | | return False
|
| | |
|
| | | #存日志
|
| | | saveLog = DataServerLogData.tagPetExpiationLog()
|
| | | saveLog.ReceiveDate = time();
|
| | | # saveLog = DataServerLogData.tagPetExpiationLog()
|
| | | # saveLog.ReceiveDate = time();
|
| | |
|
| | | saveLog.ExpiationIndex = dbData.ExpiationIndex;
|
| | | saveLog.AccID = dbData.AccID
|
| | | saveLog.ExpiationTime = dbData.ExpiationTime;
|
| | | saveLog.NPCID = dbData.NPCID;
|
| | | saveLog.Lv = dbData.Lv;
|
| | | saveLog.Exp = dbData.Exp;
|
| | | saveLog.BindType = dbData.BindType;
|
| | | saveLog.UseCreatorDrugCnt = dbData.UseCreatorDrugCnt;
|
| | | saveLog.Friendliness = dbData.Friendliness;
|
| | | saveLog.SkillIDList = dbData.SkillIDList
|
| | | saveLog.HPTalent = dbData.HPTalent;
|
| | | saveLog.PhysicAtkTalent = dbData.PhysicAtkTalent;
|
| | | saveLog.MagicAtkTalent = dbData.MagicAtkTalent;
|
| | | saveLog.PhysicDefTalent = dbData.PhysicDefTalent;
|
| | | saveLog.MagicDefTalent = dbData.MagicDefTalent;
|
| | | # saveLog.ExpiationIndex = dbData.ExpiationIndex;
|
| | | # saveLog.AccID = dbData.AccID
|
| | | # saveLog.ExpiationTime = dbData.ExpiationTime;
|
| | | # saveLog.NPCID = dbData.NPCID;
|
| | | # saveLog.Lv = dbData.Lv;
|
| | | # saveLog.Exp = dbData.Exp;
|
| | | # saveLog.BindType = dbData.BindType;
|
| | | # saveLog.UseCreatorDrugCnt = dbData.UseCreatorDrugCnt;
|
| | | # saveLog.Friendliness = dbData.Friendliness;
|
| | | # saveLog.SkillIDList = dbData.SkillIDList
|
| | | # saveLog.HPTalent = dbData.HPTalent;
|
| | | # saveLog.PhysicAtkTalent = dbData.PhysicAtkTalent;
|
| | | # saveLog.MagicAtkTalent = dbData.MagicAtkTalent;
|
| | | # saveLog.PhysicDefTalent = dbData.PhysicDefTalent;
|
| | | # saveLog.MagicDefTalent = dbData.MagicDefTalent;
|
| | |
|
| | | self.sendDBRequest(chr(CommonDefine.gstGetPetExpiationLog) + saveLog.getBuffer(), pack)
|
| | | # self.sendDBRequest(chr(CommonDefine.gstGetPetExpiationLog) + saveLog.getBuffer(), pack)
|
| | | return True
|
| | |
|
| | | def gstUpdateServerDataVersionNO(self, db, pack):
|
| | |
| | | def OnUpdateTotalSavePoint(self, db, pack):
|
| | | try:
|
| | | mylog.info("begin process gstUpdateTotalSavePoint")
|
| | | recvPack = RecvPackProtocol.tagBDStringTypeSend()
|
| | | recvPack.ReadData(pack.getBuffer())
|
| | | # recvPack = RecvPackProtocol.tagBDStringTypeSend()
|
| | | # recvPack.ReadData(pack.getBuffer())
|
| | |
|
| | | dbData = DataServerLogData.tagDBPlayerSaveCoinLog()
|
| | | if -1 == dbData.readData(recvPack.Data):
|
| | | msg = error.formatMsg('error', error.ERROR_NO_95, "tagDBPlayerSaveCoinLog:lack of pack data:data = %s,datalen = %d"%(b2a_hex(recvPack.Data), len(recvPack.Data)))
|
| | | mylog.error(msg) |
| | | return False |
| | | # dbData = DataServerLogData.tagDBPlayerSaveCoinLog()
|
| | | # if -1 == dbData.readData(recvPack.Data):
|
| | | # msg = error.formatMsg('error', error.ERROR_NO_95, "tagDBPlayerSaveCoinLog:lack of pack data:data = %s,datalen = %d"%(b2a_hex(recvPack.Data), len(recvPack.Data)))
|
| | | # mylog.error(msg) |
| | | # return False |
| | |
|
| | | col = db[UCN_DSAccount]
|
| | | dbDoc = DataServerPlayerData.tagDSAccount()
|
| | | dbDoc.AccID = recvPack.AccID
|
| | | ret = dbDoc.adoLoadC(col)
|
| | | if ret:
|
| | | dbDoc.TotalSavePoint += dbData.Coin
|
| | | else:
|
| | | dbDoc.TotalSavePoint = 0
|
| | | # col = db[UCN_DSAccount]
|
| | | # dbDoc = DataServerPlayerData.tagDSAccount()
|
| | | # dbDoc.AccID = recvPack.AccID
|
| | | # ret = dbDoc.adoLoadC(col)
|
| | | # if ret:
|
| | | # dbDoc.TotalSavePoint += dbData.Coin
|
| | | # else:
|
| | | # dbDoc.TotalSavePoint = 0
|
| | |
|
| | | if not dbDoc.adoCheckUpdateC(col):
|
| | | msg = error.formatMsg('error', error.ERROR_NO_86, "UpdateTotalSavePoint failed,data = %s,datalen = %d"%(b2a_hex(recvPack.Data), len(recvPack.Data)))
|
| | | mylog.error(msg)
|
| | | return False |
| | | # if not dbDoc.adoCheckUpdateC(col):
|
| | | # msg = error.formatMsg('error', error.ERROR_NO_86, "UpdateTotalSavePoint failed,data = %s,datalen = %d"%(b2a_hex(recvPack.Data), len(recvPack.Data)))
|
| | | # mylog.error(msg)
|
| | | # return False |
| | |
|
| | | except:
|
| | | msg = error.formatMsg('error', error.ERROR_NO_96, "OnUpdateTotalSavePoint throw a exception, packdata = %s, packdata len = %d\n%s"(b2a_hex(pack.getBuffer()), len(pack.getBuffer()), traceback.format_exc()))
|
| | |
| | | return False;
|
| | |
|
| | | #插入ChinLog表记录
|
| | | curLog = DataServerLogData.tagAccTransactionLog()
|
| | | curLog.TransactionID = doc.CheckValue
|
| | | curLog.AccID = recvData.Acc
|
| | | curLog.OperReason = "gstAddAccItem"
|
| | | curLog.ProcessTime = time();
|
| | | curLog.ItemID = recvData.ItemID;
|
| | | curLog.ItemCount = recvData.ItemCnt;
|
| | | self.sendDBRequest(chr(CommonDefine.gstItemTransactionLog) + curLog.getBuffer()) |
| | | # curLog = DataServerLogData.tagAccTransactionLog()
|
| | | # curLog.TransactionID = doc.CheckValue
|
| | | # curLog.AccID = recvData.Acc
|
| | | # curLog.OperReason = "gstAddAccItem"
|
| | | # curLog.ProcessTime = time();
|
| | | # curLog.ItemID = recvData.ItemID;
|
| | | # curLog.ItemCount = recvData.ItemCnt;
|
| | | # self.sendDBRequest(chr(CommonDefine.gstItemTransactionLog) + curLog.getBuffer()) |
| | |
|
| | | #回报BalanceServer插入成功
|
| | | #dgAddAccItemOK
|