1801d2b9fb
UD/AI + Client boots up.
68 lines
2.3 KiB
Python
68 lines
2.3 KiB
Python
from panda3d.core import *
|
|
from direct.distributed.MsgTypes import *
|
|
from direct.directnotify import DirectNotifyGlobal
|
|
from . import LoginBase
|
|
from direct.distributed.PyDatagram import PyDatagram
|
|
|
|
class LoginTTAccount(LoginBase.LoginBase):
|
|
notify = DirectNotifyGlobal.directNotify.newCategory('LoginTTAcct')
|
|
|
|
def __init__(self, cr):
|
|
LoginBase.LoginBase.__init__(self, cr)
|
|
self.useTTSpecificLogin = base.config.GetBool('tt-specific-login', 0)
|
|
self.notify.info('self.useTTSpecificLogin =%s' % self.useTTSpecificLogin)
|
|
|
|
def supportsRelogin(self):
|
|
return 1
|
|
|
|
def sendLoginMsg(self):
|
|
cr = self.cr
|
|
datagram = PyDatagram()
|
|
if self.useTTSpecificLogin:
|
|
datagram.addUint16(CLIENT_LOGIN_TOONTOWN)
|
|
self.__addPlayToken(datagram)
|
|
datagram.addString(cr.serverVersion)
|
|
datagram.addUint32(cr.hashVal)
|
|
self.__addTokenType(datagram)
|
|
datagram.addString('YES' if cr.wantMagicWords else 'NO')
|
|
else:
|
|
datagram.addUint16(CLIENT_LOGIN_2)
|
|
self.__addPlayToken(datagram)
|
|
datagram.addString(cr.serverVersion)
|
|
datagram.addUint32(cr.hashVal)
|
|
self.__addTokenType(datagram)
|
|
datagram.addString(cr.validateDownload)
|
|
datagram.addString(cr.wantMagicWords)
|
|
cr.send(datagram)
|
|
|
|
def resendPlayToken(self):
|
|
cr = self.cr
|
|
datagram = PyDatagram()
|
|
datagram.addUint16(CLIENT_SET_SECURITY)
|
|
self.__addPlayToken(datagram)
|
|
self.__addTokenType(datagram)
|
|
cr.send(datagram)
|
|
|
|
def __addPlayToken(self, datagram):
|
|
self.playToken = self.playToken.strip()
|
|
datagram.addString(self.playToken)
|
|
|
|
def __addTokenType(self, datagram):
|
|
if self.useTTSpecificLogin:
|
|
datagram.addInt32(CLIENT_LOGIN_3_DISL_TOKEN)
|
|
elif self.playTokenIsEncrypted:
|
|
datagram.addInt32(CLIENT_LOGIN_2_PLAY_TOKEN)
|
|
else:
|
|
datagram.addInt32(CLIENT_LOGIN_2_PLAY_TOKEN)
|
|
|
|
def getErrorCode(self):
|
|
return 0
|
|
|
|
def needToSetParentPassword(self):
|
|
return 0
|
|
|
|
def authenticateParentPassword(self, loginName, password, parentPassword):
|
|
return True, None
|
|
|
|
def authenticateDelete(self, loginName, password):
|
|
return True, None
|