hxp
2024-07-04 eda1c4429db2e7a3b1b79eee0cba0fc7abec7290
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
#!/usr/bin/python
# -*- coding: GBK -*-
#-------------------------------------------------------------------------------
#
##@package GM.Commands.GMT_CrossServerMaintain
#
# @todo:¿ç·þ·þÎñÆ÷ά»¤
# @author hxp
# @date 2018-12-29
# @version 1.0
#
# ÏêϸÃèÊö: ¿ç·þ·þÎñÆ÷ά»¤
#
#-------------------------------------------------------------------------------
#"""Version = 2018-12-29 02:30"""
#-------------------------------------------------------------------------------
 
import DataRecordPack
import CrossRealmPlayer
import ShareDefine
import GameWorld
import GMCommon
 
#---------------------------------------------------------------------
 
## Ö´ÐÐÂß¼­
#  @param curPlayer µ±Ç°Íæ¼Ò
#  @param gmCmdDict: ÃüÁî×Öµä
#  @return None
#  @remarks º¯ÊýÏêϸ˵Ã÷.
def OnExec(orderId, gmCmdDict):
    
    GameWorld.Log("GMT_CrossServerMaintain gmCmdDict=%s" % str(gmCmdDict))
    
    if not GameWorld.IsCrossServer():
        GMCommon.GMCommandResult(orderId, gmCmdDict, GMCommon.Def_IsNotCrossServer)
        return
    
    operate = gmCmdDict.get('operate', '')
    
    # ×´Ì¬²éѯ
    if operate == "query":
        isOpen = GameWorld.GetGameWorld().GetDictByKey(ShareDefine.Def_Notify_WorldKey_CrossServerOpen)
        GMCommon.GMCommandResult(orderId, gmCmdDict, GMCommon.Def_ServerOpen if isOpen else GMCommon.Def_ServerClose)
        return
    
    # ×´Ì¬¸ü¸Ä        
    if operate == "on":
        isOpen = 1
    elif operate == "off":
        isOpen = 0
    else:
        GMCommon.GMCommandResult(orderId, gmCmdDict, GMCommon.Def_ParamErr)
        return
    
    # ±ä¸ü·þÎñÆ÷ά»¤
    CrossRealmPlayer.DoChangeCrossServerState(isOpen)
    
    # ¼Ç¼Á÷Ïò
    DataRecordPack.DR_ToolGMOperate(0, '', '', 'GMT_CrossServerMaintain', str(gmCmdDict))
    # »Ø¸´
    GMCommon.GMCommandResult(orderId, gmCmdDict, GMCommon.Def_Success) 
    return