~disableGM , ~enableGM + anybody can use magic words (but ppl are kicked)

This commit is contained in:
John 2015-06-20 15:42:38 +03:00
parent 5a76de3d72
commit 7352c9df43
7 changed files with 35 additions and 10 deletions

View file

@ -20,9 +20,6 @@ class MagicWordManager(DistributedObject.DistributedObject):
DistributedObject.DistributedObject.disable(self) DistributedObject.DistributedObject.disable(self)
def handleMagicWord(self, magicWord): def handleMagicWord(self, magicWord):
if not self.cr.wantMagicWords:
return
if magicWord.startswith('~~'): if magicWord.startswith('~~'):
if lastClickedNametag == None: if lastClickedNametag == None:
target = base.localAvatar target = base.localAvatar

View file

@ -343,8 +343,6 @@ class DistributedPlayer(DistributedAvatar.DistributedAvatar, PlayerBase.PlayerBa
def setAdminAccess(self, access): def setAdminAccess(self, access):
self.adminAccess = access self.adminAccess = access
self.considerUnderstandable() self.considerUnderstandable()
if self.isLocal():
self.cr.wantMagicWords = self.isAdmin()
def getAdminAccess(self): def getAdminAccess(self):
return self.adminAccess return self.adminAccess

View file

@ -217,4 +217,35 @@ def accessLevel(accessLevel, storage='PERSISTENT'):
return "%s's access level has been set to %d." % (target.getName(), accessLevel) return "%s's access level has been set to %d." % (target.getName(), accessLevel)
else: else:
target.d_setSystemMessage(0, '%s set your access level to %d temporarily!' % (invoker.getName(), accessLevel)) target.d_setSystemMessage(0, '%s set your access level to %d temporarily!' % (invoker.getName(), accessLevel))
return "%s's access level has been set to %d temporarily." % (target.getName(), accessLevel) return "%s's access level has been set to %d temporarily." % (target.getName(), accessLevel)
@magicWord(category=CATEGORY_COMMUNITY_MANAGER)
def disableGM():
"""
Temporarily disable GM features.
"""
target = spellbook.getTarget()
if hasattr(target, 'oldAccess'):
return 'GM features are already disabled!\nTo enable, use ~enableGM.'
if not target.isAdmin():
return 'Target is not an admin!'
target.oldAccess = target.adminAccess
target.d_setAdminAccess(100)
return 'GM features are disabled!'
@magicWord(category=CATEGORY_COMMUNITY_MANAGER)
def enableGM():
"""
Enable GM features.
"""
target = spellbook.getTarget()
if not hasattr(target, 'oldAccess'):
return 'GM features are not disabled!'
target.d_setAdminAccess(target.oldAccess)
del target.oldAccess
return 'GM features are enabled!'

View file

@ -123,7 +123,7 @@ class ChatManager(DirectObject.DirectObject):
def enterMainMenu(self): def enterMainMenu(self):
self.checkObscurred() self.checkObscurred()
if self.localAvatar.canChat() or self.cr.wantMagicWords: if self.localAvatar.canChat():
if self.wantBackgroundFocus: if self.wantBackgroundFocus:
self.chatInputNormal.chatEntry['backgroundFocus'] = 1 self.chatInputNormal.chatEntry['backgroundFocus'] = 1
self.acceptOnce('enterNormalChat', self.fsm.request, ['normalChat']) self.acceptOnce('enterNormalChat', self.fsm.request, ['normalChat'])

View file

@ -17,7 +17,7 @@ class TalkAssistant(DirectObject.DirectObject):
pass pass
def sendOpenTalk(self, message): def sendOpenTalk(self, message):
if base.cr.wantMagicWords and len(message) > 0 and message[0] == '~': if len(message) > 0 and message[0] == '~':
messenger.send('magicWord', [message]) messenger.send('magicWord', [message])
else: else:
chatFlags = CFSpeech | CFTimeout chatFlags = CFSpeech | CFTimeout

View file

@ -30,7 +30,6 @@ class OTPClientRepository(ClientRepositoryBase):
self.createAvatarClass = None self.createAvatarClass = None
self.systemMessageSfx = None self.systemMessageSfx = None
self.playToken = launcher.getPlayToken() self.playToken = launcher.getPlayToken()
self.wantMagicWords = False
self.parentMgr.registerParent(OTPGlobals.SPRender, base.render) self.parentMgr.registerParent(OTPGlobals.SPRender, base.render)
self.parentMgr.registerParent(OTPGlobals.SPHidden, NodePath()) self.parentMgr.registerParent(OTPGlobals.SPHidden, NodePath())

View file

@ -2360,4 +2360,4 @@ AccessToString = {
500: '\x01androidGreen\x01Developer\x02', 500: '\x01androidGreen\x01Developer\x02',
600: '\x01cobalt\x01Admin\x02', 600: '\x01cobalt\x01Admin\x02',
700: '\x01azure\x01System Admin\x02' 700: '\x01azure\x01System Admin\x02'
} }