#!/usr/bin/python  
 | 
# -*- coding: GBK -*-  
 | 
#---------------------------------------------------------------------  
 | 
#  
 | 
#---------------------------------------------------------------------  
 | 
##@package GMT_ItemExpiation.py  
 | 
# GMÃüÁîÍæ¼ÒÎïÆ·²¹³¥  
 | 
#  
 | 
# @author wdb  
 | 
# @date 2012-06-21  
 | 
# @version 1.5  
 | 
#  
 | 
# @note  
 | 
# @change: "2012-07-12 18:00" wdb Ôö¼Ó±àÂëÊôÐÔ  
 | 
# @change: "2012-07-13 10:00" wdb Ð޸ĻñµÃÍæ¼Òid´íÎó  
 | 
# @change: "2012-07-30 11:30" wdb GM»Ø¸´Ï¸»¯£¬´úÂëÓÅ»¯  
 | 
# @change: "2011-09-21 13:00" whx ÐÞ¸ÄÍæ¼Ò²»ÔÚÏß²»²¹³¥  
 | 
# @change: "2012-09-25 18:00" whx ÐÞ¸ÄÍæ¼Ò²»´æÔÚ²»²¹³¥  
 | 
#---------------------------------------------------------------------  
 | 
"""Version = 2012-09-25 18:00"""  
 | 
#---------------------------------------------------------------------  
 | 
#µ¼Èë  
 | 
import GMCommon  
 | 
from MangoDBCommon import (fix_incomingText, fix_outgoingText)  
 | 
from Collections import DataServerPlayerData  
 | 
from Common import(mylog, CommFuncEx)  
 | 
from Collections.CollectionDefine import *  
 | 
from MangoDBCommon import seq  
 | 
DBConfig = __import__('Config.DBConfig')  
 | 
#---------------------------------------------------------------------  
 | 
#È«¾Ö±äÁ¿  
 | 
  
 | 
#---------------------------------------------------------------------  
 | 
  
 | 
## ÊÕµ½gmÃüÁîÖ´ÐÐ  
 | 
# @param gmCmdDict:gmÃüÁî×Öµä  
 | 
# @return None   
 | 
def OnExec(gmCmdDict):  
 | 
    playerFind = gmCmdDict.get(GMCommon.Def_GMKey_PlayerFind, '')  
 | 
    itemID = GMCommon.ToIntDef(gmCmdDict.get('itemID', ''))  
 | 
    itemCount = GMCommon.ToIntDef(gmCmdDict.get('itemCount', ''))  
 | 
      
 | 
    if playerFind == '' or itemID <= 0 or itemCount <= 0:  
 | 
        return GMCommon.Def_ParamErr, ''                 
 | 
  
 | 
    # »Ø¸´gm²ÎÊý´íÎó  
 | 
    return GMCommon.Def_DoQueryUserDB, ''  
 | 
  
 | 
      
 | 
## ²éѯlogdb·µ»Ø  
 | 
# @param logdb:logdb  
 | 
# @param data:´«ÈëµÄÐÅÏ¢  
 | 
# @param gmCmdDict:gmÃüÁî×Öµä  
 | 
# @return None   
 | 
def LogDBResponse(logdb, data, gmCmdDict):         
 | 
    return GMCommon.Def_PlayerOfLine, ''  
 | 
  
 | 
  
 | 
## ²éѯuserdb·µ»Ø  
 | 
# @param userdb:userdb  
 | 
# @param data:´«ÈëµÄÐÅÏ¢  
 | 
# @param gmCmdDict:gmÃüÁî×Öµä  
 | 
# @return None   
 | 
def UserDBResponse(userdb, data, gmCmdDict):  
 | 
    playerFind = gmCmdDict.get(GMCommon.Def_GMKey_PlayerFind, '')  
 | 
    queryType = gmCmdDict.get(GMCommon.Def_GMKey_QueryType, '')  
 | 
      
 | 
    itemID = GMCommon.ToIntDef(gmCmdDict.get('itemID', ''), 0)  
 | 
    itemCount = GMCommon.ToIntDef(gmCmdDict.get('itemCount', ''), 0)  
 | 
      
 | 
    # queryType²»ÊÇaccID£¬·¢Ë͵ÄÐÅÏ¢ÊÇÍæ¼ÒµÄÃû×Ö£¬ È¡µÃÍæ¼Òaccid    
 | 
    playerAccID = ""  
 | 
    if queryType == 'playerName':  
 | 
        playerAccID = GMCommon.GetPlayerAccID(userdb, {'PlayerName':fix_incomingText(playerFind), 'IsDeleted':0})  
 | 
          
 | 
    elif queryType == 'accID':  
 | 
        playerAccID = GMCommon.GetPlayerAccID(userdb, {'AccID':fix_incomingText(playerFind), 'IsDeleted':0})  
 | 
      
 | 
    else:  
 | 
        return GMCommon.Def_ParamErr, ''  
 | 
      
 | 
    if playerAccID == '':  
 | 
        return GMCommon.Def_NoTag, ''  
 | 
          
 | 
    con = userdb[UCN_Expiation]  
 | 
    doc = DataServerPlayerData.tagExpiation()  
 | 
    doc.AccID = playerAccID  
 | 
    doc.ExpiationTime = CommFuncEx.TDateTime_Now()  
 | 
    doc.ExpiationIndex = seq(userdb, UCN_Expiation, 'ExpiationIndex',  
 | 
                             DBConfig.tagExpiation_ExpiationIndex_FEED,   
 | 
                             DBConfig.tagExpiation_ExpiationIndex_STEP)  
 | 
  
 | 
    doc.ItemTypeID = itemID  
 | 
    doc.Count = itemCount  
 | 
      
 | 
    if not doc.adoInsert(con):  
 | 
        return GMCommon.Def_InsertFail, ''  
 | 
      
 | 
    # ¼Ç¼Á÷Ïò  
 | 
    dataDic = {"PlayerID":0, 'AccID':playerAccID}  
 | 
      
 | 
    GMCommon.SendEventPack(gmCmdDict.get(GMCommon.Def_GMKey_Type, ''), dataDic, str(gmCmdDict))   
 | 
    return GMCommon.Def_Success, ''  
 | 
  
 | 
  
 | 
  
 | 
  
 | 
  
 |