#!/usr/bin/python
|
# -*- coding: GBK -*-
|
#---------------------------------------------------------------------
|
#
|
#---------------------------------------------------------------------
|
##@package GameServerRefresh
|
# @todo: GameServer·â°ü¹ÜÀíÆ÷
|
#
|
# @author: eggxp
|
# @date 2010-4-28
|
# @version 2.7
|
#
|
# @note: ½ÓÊÕGameServer·â°ü, Ö´ÐÐÂß¼
|
#
|
# @change: "2010-08-19 17:30" panwei °´¸ñʽ¹æ·¶µ÷Õû, ¹Ø±Õµ÷ÊÔÐÅÏ¢
|
# @change: "2010-12-27 17:10" panwei µØÍ¼±¶ÂʸüÐÂ֪ͨȫ·þÍæ¼Ò
|
# @change: "2011-01-09 18:00" panwei Ôª±¦½»Òׯ½Ì¨¹ýÆÚ¶©µ¥, δÁìȡԪ±¦¶©µ¥ÐÂÔö»º´æ
|
# @change: "2011-06-21 16:00" panwei ÐÂÔöRouteServerInitOKº¯Êý´¦Àí, Èçδ³õʼ»¯²»¿ÉÇл»¸±±¾
|
# @change: "2011-06-30 17:00" panwei ÐÂÔö0405, GameServer_PlayerCoinToGold·â°ü´¦Àí
|
# @change: "2012-01-30 19:00" wdb µãȯ¶Ò»»Ôª±¦·â°üÔö¼ÓÔùË͵ãȯ×Ö¶Î
|
# @change: "2012-01-31 10:00" wdb ´«µÝ²ÎÊýÐÞ¸Ä
|
# @change: "2012-03-29 17:00" jiang ½ÇÉ«ÔÚGameServer³õʼ»¯Íê³ÉÒÔºó²éѯһ´ÎÊÇ·ñÔÚÉêÇëµÄ¼Ò×åÉóºËÖÐ
|
# @change: "2012-05-06 19:30" jiang ½ÇÉ«ÔÚGameServer³õʼ»¯Íê³ÉÒÔºóÇëÇó¼ÇÂ¼Íæ¼Ò¼Ò×åÐÅÏ¢ÓÃÓÚ¿ª·þ»î¶¯½±ÀøÁìÈ¡
|
# @change: "2012-05-14 16:00" jiang È¥³ýÇëÇó¼ÇÂ¼Íæ¼Ò¼Ò×åÐÅÏ¢ÓÃÓÚ¿ª·þ»î¶¯½±ÀøÁìÈ¡
|
# @change: "2012-06-29 15:00" whx ²¹³¥ÔÚGameServer Initʱ´¥·¢
|
# @change: "2014-02-11 15:00" Alee ʱ¼ä´¦ÀíÖ®ºóÔÙÖ´Ðй¦ÄÜÂß¼(½ÚÈÕÀñ°ü)
|
# @change: "2014-12-25 15:10" xmnathan ÅÅÐаñ³ÆºÅÉÏÏßˢзÅÔÚGameSever_PlayerInitOKÖ®ºóÖ´ÐÐ
|
# @change: "2015-06-24 17:50" xmnathan InterfaceServer_Dll_CashRequest³äÖµµãȯ¶Ò»»£¬Ôö¼Óͬ¶©µ¥·â°üÖØÈë·À·¶
|
# @change: "2016-07-20 14:30" hxp µãȯ¶Ò»»Ë¢ÐÂÔö¼ÓÁ÷ÏòÀàÐÍ
|
#------------------------------------------------------------------------------
|
"""Version = 2016-07-20 14:30"""
|
#------------------------------------------------------------------------------
|
import GameWorld
|
import PlayerControl
|
import PlayerEventCounter
|
import ChConfig
|
import PlayerCoin
|
import ChPlayer
|
#---------------------------------------------------------------------
|
#¼ÇÂ¼Íæ¼Ò³õʼ»¯¹ý³ÌÖС£»ýÀ۵ķâ°ü
|
OnHourKey = 'PlayerGSInitOK_OnHourKey'
|
OnDayKey = 'PlayerGSInitOK_OnDayKey'
|
OnWeekKey = 'PlayerGSInitOK_OnWeekKey'
|
OnMonthKey = 'PlayerGSInitOK_OnMonthKey'
|
OnYearKey = 'PlayerGSInitOK_OnYearKey'
|
OnDayExKey = 'PlayerGSInitOK_OnDayExKey'
|
OnWeekExKey = 'PlayerGSInitOK_OnWeekExKey'
|
OnMonthExKey = 'PlayerGSInitOK_OnMonthExKey'
|
#---------------------------------------------------------------------
|
#Íæ¼ÒÀ뿪¸±±¾
|
Def_RouteServerInitOK_LeaveFBKey = 'RouteServerInitOK_LeaveFBKey' #Íæ¼ÒÀ뿪¸±±¾
|
|
#===============================================================================
|
# //////////////////////////////////////////////////////////////
|
# //01 14 Íæ¼ÒÔÚGameServer³õʼ»¯³É¹¦#tagMPlayerGameServerInitOK
|
# tagMPlayerGameServerInitOK * GettagMPlayerGameServerInitOK();
|
#
|
# class IPY_MPlayerGameServerInitOK
|
# {
|
# public:
|
# //ÎÞÒâÒå
|
# int GetType();
|
# };
|
#===============================================================================
|
## 01 14 Íæ¼ÒÔÚGameServer³õʼ»¯³É¹¦
|
# @param index Íæ¼ÒË÷Òý
|
# @param tick µ±Ç°Ê±¼ä
|
# @return None
|
# @remarks º¯ÊýÏêϸ˵Ã÷.
|
def GameSever_PlayerInitOK(index , tick):
|
curPlayer = GameWorld.GetPlayerManager().GetPlayerByIndex(index)
|
#2009-12-17 ÒòµØÍ¼·þÎñÆ÷ÓпÉÄܹرÕÖØ¿ª£¬ÕâÀïÒªÅж¨¿Õ
|
if not curPlayer:
|
GameWorld.ErrLog('GameSever_PlayerInitError playerIndex = %s'%(index))
|
return
|
|
#ÉèÖóõʼ»¯³É¹¦
|
curPlayer.SetGameServerInitOK(True)
|
|
#ʱ¼ä»º´æ·â°ü
|
if Get_PlayerGameServerInitOK_OnHour(curPlayer):
|
PlayerEventCounter.PlayerOnHour(curPlayer)
|
Set_PlayerGameServerInitOK_OnHour(curPlayer, 0)
|
|
if Get_PlayerGameServerInitOK_OnDay(curPlayer):
|
PlayerEventCounter.PlayerOnDay(curPlayer)
|
Set_PlayerGameServerInitOK_OnDay(curPlayer, 0)
|
|
#if Get_PlayerGameServerInitOK_OnDayEx(curPlayer):
|
# PlayerEventCounter.PlayerOnDayEx(curPlayer)
|
# Set_PlayerGameServerInitOK_OnDayEx(curPlayer, 0)
|
|
if Get_PlayerGameServerInitOK_OnWeek(curPlayer):
|
PlayerEventCounter.PlayerOnWeek(curPlayer)
|
Set_PlayerGameServerInitOK_OnWeek(curPlayer, 0)
|
|
#if Get_PlayerGameServerInitOK_OnWeekEx(curPlayer):
|
# PlayerEventCounter.PlayerOnWeekEx(curPlayer)
|
# Set_PlayerGameServerInitOK_OnWeekEx(curPlayer, 0)
|
|
if Get_PlayerGameServerInitOK_OnMonth(curPlayer):
|
PlayerEventCounter.PlayerOnMonth(curPlayer)
|
Set_PlayerGameServerInitOK_OnMonth(curPlayer, 0)
|
|
#if Get_PlayerGameServerInitOK_OnMonthEx(curPlayer):
|
# PlayerEventCounter.PlayerOnMonthEx(curPlayer)
|
# Set_PlayerGameServerInitOK_OnMonthEx(curPlayer, 0)
|
|
if Get_PlayerGameServerInitOK_OnYear(curPlayer):
|
PlayerEventCounter.PlayerOnYear(curPlayer)
|
Set_PlayerGameServerInitOK_OnYear(curPlayer, 0)
|
|
#Ë¢ÐÂÅÅÐаñ³ÆºÅ
|
#PlayerDienstgrad.RefreshBillBoardDienstgrad(curPlayer)
|
|
GameWorld.Log('GameSever_PlayerInitOK' , curPlayer.GetID())
|
ChPlayer.DoPlayerRealLoginOK(curPlayer, tick)
|
return
|
#---------------------------------------------------------------------
|
## ±£´æOnHour
|
# @param curPlayer µ±Ç°Íæ¼Ò
|
# @param value keyÖµ
|
# @return None
|
# @remarks º¯ÊýÏêϸ˵Ã÷.
|
def Set_PlayerGameServerInitOK_OnHour(curPlayer, value):
|
curPlayer.SetDict(OnHourKey, value)
|
#GameWorld.Log('Set_PlayerGameServerInitOK_OnHour , value = %s'%( value ) , curPlayer.GetID())
|
return
|
|
## »ñÈ¡Íæ¼Ò×Öµä OnHour
|
# @param curPlayer µ±Ç°Íæ¼Ò
|
# @return None
|
# @remarks º¯ÊýÏêϸ˵Ã÷.
|
def Get_PlayerGameServerInitOK_OnHour(curPlayer):
|
return curPlayer.GetDictByKey(OnHourKey)
|
|
## ±£´æOnDay
|
# @param curPlayer µ±Ç°Íæ¼Ò
|
# @param value keyÖµ
|
# @return None
|
# @remarks º¯ÊýÏêϸ˵Ã÷.
|
def Set_PlayerGameServerInitOK_OnDay(curPlayer, value):
|
curPlayer.SetDict(OnDayKey, value)
|
#GameWorld.Log('Set_PlayerGameServerInitOK_OnDay, value = %s'%( value ) , curPlayer.GetID())
|
return
|
|
## »ñÈ¡Íæ¼Ò×Öµä OnDay
|
# @param curPlayer µ±Ç°Íæ¼Ò
|
# @return None
|
# @remarks º¯ÊýÏêϸ˵Ã÷.
|
def Get_PlayerGameServerInitOK_OnDay(curPlayer):
|
return curPlayer.GetDictByKey(OnDayKey)
|
|
def Set_PlayerGameServerInitOK_OnDayEx(curPlayer, value): return curPlayer.SetDict(OnDayExKey, value)
|
def Get_PlayerGameServerInitOK_OnDayEx(curPlayer): return curPlayer.GetDictByKey(OnDayExKey)
|
|
## ±£´æOnWeek
|
# @param curPlayer µ±Ç°Íæ¼Ò
|
# @param value keyÖµ
|
# @return None
|
# @remarks º¯ÊýÏêϸ˵Ã÷.
|
def Set_PlayerGameServerInitOK_OnWeek(curPlayer, value):
|
curPlayer.SetDict(OnWeekKey, value)
|
#GameWorld.Log('Set_PlayerGameServerInitOK_OnWeek, value = %s'%( value ) , curPlayer.GetID())
|
return
|
|
## »ñÈ¡Íæ¼Ò×Öµä OnWeek
|
# @param curPlayer µ±Ç°Íæ¼Ò
|
# @return None
|
# @remarks º¯ÊýÏêϸ˵Ã÷.
|
def Get_PlayerGameServerInitOK_OnWeek(curPlayer):
|
return curPlayer.GetDictByKey(OnWeekKey)
|
|
def Set_PlayerGameServerInitOK_OnWeekEx(curPlayer, value): return curPlayer.SetDict(OnWeekExKey, value)
|
def Get_PlayerGameServerInitOK_OnWeekEx(curPlayer): return curPlayer.GetDictByKey(OnWeekExKey)
|
|
## ±£´æOnMonth
|
# @param curPlayer µ±Ç°Íæ¼Ò
|
# @param value keyÖµ
|
# @return None
|
# @remarks º¯ÊýÏêϸ˵Ã÷.
|
def Set_PlayerGameServerInitOK_OnMonth(curPlayer , value):
|
curPlayer.SetDict(OnMonthKey , value)
|
#GameWorld.Log('Set_PlayerGameServerInitOK_OnMonth, value = %s'%( value ) , curPlayer.GetID())
|
return
|
|
## »ñÈ¡Íæ¼Ò×Öµä OnMonth
|
# @param curPlayer µ±Ç°Íæ¼Ò
|
# @return None
|
# @remarks º¯ÊýÏêϸ˵Ã÷.
|
def Get_PlayerGameServerInitOK_OnMonth(curPlayer):
|
return curPlayer.GetDictByKey(OnMonthKey)
|
|
def Set_PlayerGameServerInitOK_OnMonthEx(curPlayer, value): return curPlayer.SetDict(OnMonthExKey, value)
|
def Get_PlayerGameServerInitOK_OnMonthEx(curPlayer): return curPlayer.GetDictByKey(OnMonthExKey)
|
|
## ±£´æOnYear
|
# @param curPlayer µ±Ç°Íæ¼Ò
|
# @param value keyÖµ
|
# @return None
|
# @remarks º¯ÊýÏêϸ˵Ã÷.
|
def Set_PlayerGameServerInitOK_OnYear(curPlayer, value):
|
curPlayer.SetDict(OnYearKey, value)
|
#GameWorld.Log('Set_PlayerGameServerInitOK_OnYear, value = %s'%( value ) , curPlayer.GetID())
|
return
|
|
## »ñÈ¡Íæ¼Ò×Öµä OnYear
|
# @param curPlayer µ±Ç°Íæ¼Ò
|
# @return None
|
# @remarks º¯ÊýÏêϸ˵Ã÷.
|
def Get_PlayerGameServerInitOK_OnYear(curPlayer):
|
return curPlayer.GetDictByKey(OnYearKey)
|
|
#===============================================================================
|
# //01 15 Íæ¼ÒÔÚRouteServer³õʼ»¯³É¹¦#tagPlayerRouteServerInitOK
|
# structtagPlayerRouteServerInitOK
|
# {
|
# tag HeadHead;
|
# BYTE Type; //±£Áô£¬ÎÞÒâÒå
|
# };
|
#===============================================================================
|
## 01 15 Íæ¼ÒÔÚRouteServer³õʼ»¯³É¹¦#tagPlayerRouteServerInitOK
|
# @param index Íæ¼ÒË÷Òý
|
# @param tick µ±Ç°Ê±¼ä
|
# @return None
|
# @remarks º¯ÊýÏêϸ˵Ã÷.
|
def RouteServer_PlayerInitOK(index, tick):
|
#===============================================================================
|
# #Õâ¸öº¯Êý½öÔÚÍæ¼ÒµÇ½³É¹¦ºó²Å´¥·¢Ò»´Î
|
#===============================================================================
|
curPlayer = GameWorld.GetPlayerManager().GetPlayerByIndex(index)
|
#ÕâÀïÒªÅж¨¿Õ
|
if not curPlayer:
|
GameWorld.ErrLog('RouteServer_PlayerInitError playerIndex = %s'%(index))
|
return
|
|
#===============================================================================
|
# #ÉèÖÃRouteServer³õʼ»¯³É¹¦
|
# curPlayer.SetRouteServerInitOK(True)
|
#===============================================================================
|
#ÉèÖýű¾×Öµä½Ó¿Ú, ´Ë½Ó¿Ú´æÊý¾Ý¿â, ÏÂÏßÇå³ýÒ»´Î
|
PlayerControl.NomalDictSetProperty(curPlayer, ChConfig.Def_Player_Dict_RouteServerInitOK, 1)
|
|
#»º´æµÄÀ뿪¸±±¾·â°ü
|
if Get_PlayerRouteServerInitOK_OnLeaveFB(curPlayer):
|
PlayerControl.PlayerLeaveFB(curPlayer)
|
Set_PlayerRouteServerInitOK_OnLeaveFB(curPlayer, 0)
|
|
return
|
|
#---------------------------------------------------------------------
|
## ±£´æÀ뿪¸±±¾ÐÅÏ¢
|
# @param curPlayer µ±Ç°Íæ¼Ò
|
# @param value keyÖµ
|
# @return None
|
# @remarks º¯ÊýÏêϸ˵Ã÷.
|
def Set_PlayerRouteServerInitOK_OnLeaveFB(curPlayer, value):
|
curPlayer.SetDict(Def_RouteServerInitOK_LeaveFBKey, value)
|
return
|
|
## »ñÈ¡±£´æÀ뿪¸±±¾ÐÅÏ¢
|
# @param curPlayer µ±Ç°Íæ¼Ò
|
# @return None
|
# @remarks º¯ÊýÏêϸ˵Ã÷.
|
def Get_PlayerRouteServerInitOK_OnLeaveFB(curPlayer):
|
return curPlayer.GetDictByKey(Def_RouteServerInitOK_LeaveFBKey)
|
|
# DBÍÆË͹ýÀ´µÄ³äÖµÐÅÏ¢
|
def PushRecharge(index, tick):
|
curPlayer = GameWorld.GetPlayerManager().GetPlayerByIndex(index)
|
if not curPlayer or curPlayer.IsEmpty():
|
#¿ÉÄܸպÃÏÂÏßµ¼ÖÂÍæ¼Ò¶ÔÏóΪ¿Õ
|
return
|
cPlayerCoin = PlayerCoin.CPY_PlayerCoinToGold()
|
cPlayerCoin.useCoin = curPlayer.GetOrderAmount()
|
cPlayerCoin.orderID = curPlayer.GetOrderID()
|
cPlayerCoin.orderInfo = curPlayer.GetOrderInfo()
|
cPlayerCoin.isAddBourseMoney = True
|
|
GameWorld.DebugLog("PushRecharge-%s-%s-%s"%(cPlayerCoin.useCoin, cPlayerCoin.orderID, cPlayerCoin.orderInfo))
|
PlayerCoin.PlayerCoinToGold(curPlayer, cPlayerCoin, ChConfig.Def_GiveMoney_CoinToGold)
|
return
|
|