2015-03-03 22:10:12 +00:00
|
|
|
from direct.distributed.AstronInternalRepository import AstronInternalRepository
|
|
|
|
from otp.distributed.OtpDoGlobals import *
|
2015-07-12 16:48:58 +00:00
|
|
|
from toontown.distributed.ToontownNetMessengerAI import ToontownNetMessengerAI
|
2015-07-13 17:04:39 +00:00
|
|
|
from direct.distributed.PyDatagram import PyDatagram
|
2015-08-05 19:41:39 +00:00
|
|
|
mongodb_url = ConfigVariableString('mongodb-url', 'mongodb://localhost', 'Specifies the URL of the MongoDB server that' ' stores all gameserver data.')
|
|
|
|
mongodb_replicaset = ConfigVariableString('mongodb-replicaset', '', 'Specifies the replica set of the gameserver data DB.')
|
|
|
|
|
2015-07-13 17:04:39 +00:00
|
|
|
import traceback
|
|
|
|
import sys
|
2015-03-03 22:10:12 +00:00
|
|
|
|
|
|
|
class ToontownInternalRepository(AstronInternalRepository):
|
|
|
|
GameGlobalsId = OTP_DO_ID_TOONTOWN
|
|
|
|
dbId = 4003
|
|
|
|
|
|
|
|
def __init__(self, baseChannel, serverId=None, dcFileNames=None,
|
|
|
|
dcSuffix='AI', connectMethod=None, threadedNet=None):
|
|
|
|
AstronInternalRepository.__init__(
|
|
|
|
self, baseChannel, serverId=serverId, dcFileNames=dcFileNames,
|
|
|
|
dcSuffix=dcSuffix, connectMethod=connectMethod, threadedNet=threadedNet)
|
2015-08-05 19:41:39 +00:00
|
|
|
|
2015-07-12 16:48:58 +00:00
|
|
|
def handleConnected(self):
|
|
|
|
self.__messenger = ToontownNetMessengerAI(self)
|
2015-07-18 16:57:36 +00:00
|
|
|
if config.GetBool('want-mongo', False):
|
2015-08-05 19:41:39 +00:00
|
|
|
import pymongo, urlparse
|
|
|
|
mongourl = mongodb_url.getValue()
|
|
|
|
replicaset = mongodb_replicaset.getValue()
|
|
|
|
db = (urlparse.urlparse(mongourl).path or '/Astron_Dev')[1:]
|
|
|
|
if replicaset:
|
|
|
|
self.mongo = pymongo.MongoClient(mongourl, replicaset=replicaset)
|
|
|
|
else:
|
|
|
|
self.mongo = pymongo.MongoClient(mongourl)
|
|
|
|
self.dbConn = self.mongo[db]
|
2015-07-18 16:57:36 +00:00
|
|
|
self.dbGlobalCursor = self.dbConn.toontownstride
|
|
|
|
self.dbCursor = self.dbGlobalCursor['air-%d' % self.ourChannel]
|
|
|
|
else:
|
|
|
|
self.dbConn = None
|
|
|
|
self.dbGlobalCursor = None
|
|
|
|
self.dbCursor = None
|
2015-08-05 19:41:39 +00:00
|
|
|
|
2015-07-12 16:48:58 +00:00
|
|
|
def sendNetEvent(self, message, sentArgs=[]):
|
|
|
|
self.__messenger.send(message, sentArgs)
|
2015-08-05 19:41:39 +00:00
|
|
|
|
2015-07-12 16:48:58 +00:00
|
|
|
def addExitEvent(self, message):
|
|
|
|
dg = self.__messenger.prepare(message)
|
|
|
|
self.addPostRemove(dg)
|
2015-08-05 19:41:39 +00:00
|
|
|
|
2015-07-12 16:48:58 +00:00
|
|
|
def handleDatagram(self, di):
|
|
|
|
msgType = self.getMsgType()
|
2015-08-05 19:41:39 +00:00
|
|
|
|
2015-07-12 16:48:58 +00:00
|
|
|
if msgType == self.__messenger.msgType:
|
|
|
|
self.__messenger.handle(msgType, di)
|
|
|
|
return
|
2015-08-05 19:41:39 +00:00
|
|
|
|
2015-07-12 16:48:58 +00:00
|
|
|
AstronInternalRepository.handleDatagram(self, di)
|
2015-03-03 22:10:12 +00:00
|
|
|
|
|
|
|
def getAvatarIdFromSender(self):
|
2015-07-13 17:04:39 +00:00
|
|
|
return int(self.getMsgSender() & 0xFFFFFFFF)
|
2015-03-03 22:10:12 +00:00
|
|
|
|
|
|
|
def getAccountIdFromSender(self):
|
2015-07-13 17:04:39 +00:00
|
|
|
return int((self.getMsgSender()>>32) & 0xFFFFFFFF)
|
2015-03-03 22:10:12 +00:00
|
|
|
|
|
|
|
def _isValidPlayerLocation(self, parentId, zoneId):
|
|
|
|
if zoneId < 1000 and zoneId != 1:
|
|
|
|
return False
|
|
|
|
|
|
|
|
return True
|
2015-07-13 17:04:39 +00:00
|
|
|
|
|
|
|
def readerPollOnce(self):
|
|
|
|
try:
|
|
|
|
return AstronInternalRepository.readerPollOnce(self)
|
|
|
|
except SystemExit, KeyboardInterrupt:
|
|
|
|
raise
|
2015-08-05 19:41:39 +00:00
|
|
|
|
2015-07-13 17:04:39 +00:00
|
|
|
except Exception as e:
|
|
|
|
if self.getAvatarIdFromSender() > 100000000:
|
|
|
|
dg = PyDatagram()
|
|
|
|
dg.addServerHeader(self.getMsgSender(), self.ourChannel, CLIENTAGENT_EJECT)
|
|
|
|
dg.addUint16(166)
|
|
|
|
dg.addString('You were disconnected to prevent a district reset.')
|
|
|
|
self.send(dg)
|
2015-08-05 19:41:39 +00:00
|
|
|
|
2015-07-13 17:04:39 +00:00
|
|
|
self.writeServerEvent('INTERNAL-EXCEPTION', self.getAvatarIdFromSender(), self.getAccountIdFromSender(), repr(e), traceback.format_exc())
|
|
|
|
self.notify.warning('INTERNAL-EXCEPTION: %s (%s)' % (repr(e), self.getAvatarIdFromSender()))
|
|
|
|
print traceback.format_exc()
|
|
|
|
sys.exc_clear()
|
2015-08-05 19:41:39 +00:00
|
|
|
|
2015-07-13 17:04:39 +00:00
|
|
|
return 1
|