2015-03-03 22:10:12 +00:00
|
|
|
import os
|
|
|
|
import datetime
|
|
|
|
from pandac.PandaModules import *
|
|
|
|
from direct.directnotify import DirectNotifyGlobal
|
|
|
|
from direct.distributed import DistributedObject
|
|
|
|
from direct.showbase import AppRunnerGlobal
|
|
|
|
from otp.chat.WhiteList import WhiteList
|
|
|
|
from toontown.toonbase import TTLocalizer
|
|
|
|
|
|
|
|
class TTWhiteList(WhiteList, DistributedObject.DistributedObject):
|
|
|
|
RedownloadTaskName = 'RedownloadWhitelistTask'
|
|
|
|
WhitelistBaseDir = config.GetString('whitelist-base-dir', '')
|
|
|
|
WhitelistStageDir = config.GetString('whitelist-stage-dir', 'whitelist')
|
|
|
|
WhitelistOverHttp = config.GetBool('whitelist-over-http', False)
|
|
|
|
WhitelistFileName = config.GetString('whitelist-filename', 'twhitelist.dat')
|
|
|
|
|
|
|
|
def __init__(self):
|
|
|
|
self.redownloadingWhitelist = False
|
|
|
|
self.startRedownload = datetime.datetime.now()
|
|
|
|
self.endRedownload = datetime.datetime.now()
|
|
|
|
self.percentDownloaded = 0.0
|
|
|
|
self.notify = DirectNotifyGlobal.directNotify.newCategory('TTWhiteList')
|
|
|
|
vfs = VirtualFileSystem.getGlobalPtr()
|
|
|
|
filename = Filename('twhitelist.dat')
|
|
|
|
searchPath = DSearchPath()
|
|
|
|
searchPath.appendDirectory(Filename('/phase_4/etc'))
|
|
|
|
if __debug__:
|
2015-03-03 22:14:57 +00:00
|
|
|
searchPath.appendDirectory(Filename('../resources/phase_4/etc'))
|
2015-03-03 22:10:12 +00:00
|
|
|
found = vfs.resolveFilename(filename, searchPath)
|
|
|
|
if not found:
|
|
|
|
self.notify.info("Couldn't find whitelist data file!")
|
|
|
|
data = vfs.readFile(filename, 1)
|
|
|
|
lines = data.split('\n')
|
|
|
|
WhiteList.__init__(self, lines)
|
|
|
|
if self.WhitelistOverHttp:
|
|
|
|
self.redownloadWhitelist()
|
|
|
|
self.defaultWord = TTLocalizer.ChatGarblerDefault[0]
|
|
|
|
|
|
|
|
def unload(self):
|
|
|
|
self.removeDownloadingTextTask()
|
|
|
|
|
|
|
|
def redownloadWhitelist(self):
|
|
|
|
self.percentDownload = 0.0
|
|
|
|
self.notify.info('starting redownloadWhitelist')
|
|
|
|
self.startRedownload = datetime.datetime.now()
|
|
|
|
self.redownloadingWhitelist = True
|
|
|
|
self.addDownloadingTextTask()
|
|
|
|
self.whitelistUrl = self.getWhitelistUrl()
|
|
|
|
self.whitelistDir = Filename(self.findWhitelistDir())
|
|
|
|
Filename(self.whitelistDir + '/.').makeDir()
|
|
|
|
http = HTTPClient.getGlobalPtr()
|
|
|
|
self.url = self.whitelistUrl + self.WhitelistFileName
|
|
|
|
self.ch = http.makeChannel(True)
|
|
|
|
localFilename = Filename(self.whitelistDir, 'twhitelist.dat')
|
|
|
|
self.ch.getHeader(DocumentSpec(self.url))
|
|
|
|
size = self.ch.getFileSize()
|
|
|
|
doc = self.ch.getDocumentSpec()
|
|
|
|
localSize = localFilename.getFileSize()
|
|
|
|
outOfDate = True
|
|
|
|
if size == localSize:
|
|
|
|
if doc.hasDate():
|
|
|
|
date = doc.getDate()
|
|
|
|
localDate = HTTPDate(localFilename.getTimestamp())
|
|
|
|
if localDate.compareTo(date) > 0:
|
|
|
|
outOfDate = False
|
|
|
|
self.notify.info('Whitelist is up to date')
|
|
|
|
taskMgr.remove(self.RedownloadTaskName)
|
|
|
|
if outOfDate and self.ch.isValid():
|
|
|
|
self.ch.beginGetDocument(doc)
|
|
|
|
self.ch.downloadToFile(localFilename)
|
|
|
|
taskMgr.add(self.downloadWhitelistTask, self.RedownloadTaskName)
|
|
|
|
else:
|
|
|
|
self.updateWhitelist()
|
|
|
|
|
|
|
|
def getWhitelistUrl(self):
|
|
|
|
result = base.config.GetString('fallback-whitelist-url', 'http://cdn.toontown.disney.go.com/toontown/en/')
|
|
|
|
override = base.config.GetString('whitelist-url', '')
|
|
|
|
if override:
|
|
|
|
self.notify.info('got an override url, using %s for the whitelist' % override)
|
|
|
|
result = override
|
|
|
|
else:
|
|
|
|
try:
|
|
|
|
launcherUrl = base.launcher.getValue('GAME_WHITELIST_URL', '')
|
|
|
|
if launcherUrl:
|
|
|
|
result = launcherUrl
|
|
|
|
self.notify.info('got GAME_WHITELIST_URL from launcher using %s' % result)
|
|
|
|
else:
|
|
|
|
self.notify.info('blank GAME_WHITELIST_URL from launcher, using %s' % result)
|
|
|
|
except:
|
|
|
|
self.notify.warning('got exception getting GAME_WHITELIST_URL from launcher, using %s' % result)
|
|
|
|
|
|
|
|
return result
|
|
|
|
|
|
|
|
def addDownloadingTextTask(self):
|
|
|
|
self.removeDownloadingTextTask()
|
|
|
|
task = taskMgr.doMethodLater(1, self.loadingTextTask, 'WhitelistDownloadingTextTask')
|
|
|
|
task.startTime = globalClock.getFrameTime()
|
|
|
|
self.loadingTextTask(task)
|
|
|
|
|
|
|
|
def removeDownloadingTextTask(self):
|
|
|
|
taskMgr.remove('WhitelistDownloadingTextTask')
|
|
|
|
|
|
|
|
def loadingTextTask(self, task):
|
|
|
|
timeIndex = int(globalClock.getFrameTime() - task.startTime) % 3
|
|
|
|
timeStrs = (TTLocalizer.NewsPageDownloadingNews0, TTLocalizer.NewsPageDownloadingNews1, TTLocalizer.NewsPageDownloadingNews2)
|
|
|
|
textToDisplay = timeStrs[timeIndex] % int(self.percentDownloaded * 100)
|
|
|
|
return task.again
|
|
|
|
|
|
|
|
def findWhitelistDir(self):
|
|
|
|
if self.WhitelistOverHttp:
|
|
|
|
return self.WhitelistStageDir
|
|
|
|
searchPath = DSearchPath()
|
|
|
|
if AppRunnerGlobal.appRunner:
|
|
|
|
searchPath.appendDirectory(Filename.expandFrom('$TT_3_5_ROOT/phase_3.5/models/news'))
|
|
|
|
else:
|
|
|
|
basePath = os.path.expandvars('$TTMODELS') or './ttmodels'
|
|
|
|
searchPath.appendDirectory(Filename.fromOsSpecific(basePath + '/built/' + self.NewsBaseDir))
|
|
|
|
searchPath.appendDirectory(Filename(self.NewsBaseDir))
|
|
|
|
pfile = Filename(self.WhitelistFileName)
|
|
|
|
found = vfs.resolveFilename(pfile, searchPath)
|
|
|
|
if not found:
|
|
|
|
self.notify.warning('findWhitelistDir - no path: %s' % self.WhitelistFileName)
|
|
|
|
self.setErrorMessage(TTLocalizer.NewsPageErrorDownloadingFile % self.WhitelistFileName)
|
|
|
|
return None
|
|
|
|
self.notify.debug('found whitelist file %s' % pfile)
|
|
|
|
realDir = pfile.getDirname()
|
|
|
|
return realDir
|
|
|
|
|
|
|
|
def downloadWhitelistTask(self, task):
|
|
|
|
if self.ch.run():
|
|
|
|
return task.cont
|
|
|
|
doc = self.ch.getDocumentSpec()
|
|
|
|
date = ''
|
|
|
|
if doc.hasDate():
|
|
|
|
date = doc.getDate().getString()
|
|
|
|
if not self.ch.isValid():
|
|
|
|
self.notify.warning('Unable to download %s' % self.url)
|
|
|
|
self.redownloadingWhitelist = False
|
|
|
|
return task.done
|
|
|
|
self.notify.info('Done downloading whitelist file')
|
|
|
|
self.updateWhitelist()
|
|
|
|
return task.done
|
|
|
|
|
|
|
|
def updateWhitelist(self):
|
|
|
|
localFilename = Filename(self.whitelistDir, 'twhitelist.dat')
|
|
|
|
if not localFilename.exists():
|
|
|
|
return
|
|
|
|
data = vfs.readFile(localFilename, 1)
|
|
|
|
lines = data.split('\n')
|
|
|
|
self.words = []
|
|
|
|
for line in lines:
|
|
|
|
self.words.append(line.strip('\n\r').lower())
|
|
|
|
|
|
|
|
self.words.sort()
|
|
|
|
self.numWords = len(self.words)
|
|
|
|
self.defaultWord = TTLocalizer.ChatGarblerDefault[0]
|
|
|
|
|
|
|
|
def handleNewWhitelist(self):
|
|
|
|
self.redownloadWhitelist()
|