mirror of
https://github.com/Sneed-Group/Poodletooth-iLand
synced 2025-01-09 17:53:50 +00:00
72 lines
2.8 KiB
Python
72 lines
2.8 KiB
Python
import __builtin__
|
|
|
|
|
|
__builtin__.process = 'ai'
|
|
|
|
|
|
# Temporary hack patch:
|
|
__builtin__.__dict__.update(__import__('pandac.PandaModules', fromlist=['*']).__dict__)
|
|
from direct.extensions_native import HTTPChannel_extensions
|
|
|
|
import argparse
|
|
import gc
|
|
|
|
# Panda3D 1.10.0 is 63.
|
|
gc.disable()
|
|
|
|
parser = argparse.ArgumentParser()
|
|
parser.add_argument('--base-channel', help='The base channel that the server may use.')
|
|
parser.add_argument('--max-channels', help='The number of channels the server may use.')
|
|
parser.add_argument('--stateserver', help="The control channel of this AI's designated State Server.")
|
|
parser.add_argument('--district-name', help="What this AI Server's district will be named.")
|
|
parser.add_argument('--astron-ip', help="The IP address of the Astron Message Director to connect to.")
|
|
parser.add_argument('--eventlogger-ip', help="The IP address of the Astron Event Logger to log to.")
|
|
parser.add_argument('config', nargs='*', default=['dependencies/config/general.prc', 'dependencies/config/release/dev.prc'], help="PRC file(s) to load.")
|
|
args = parser.parse_args()
|
|
|
|
for prc in args.config:
|
|
loadPrcFile(prc)
|
|
|
|
if os.path.isfile('dependencies/config/local.prc'):
|
|
loadPrcFile('dependencies/config/local.prc')
|
|
|
|
localconfig = ''
|
|
if args.base_channel: localconfig += 'air-base-channel %s\n' % args.base_channel
|
|
if args.max_channels: localconfig += 'air-channel-allocation %s\n' % args.max_channels
|
|
if args.stateserver: localconfig += 'air-stateserver %s\n' % args.stateserver
|
|
if args.district_name: localconfig += 'district-name %s\n' % args.district_name
|
|
if args.astron_ip: localconfig += 'air-connect %s\n' % args.astron_ip
|
|
if args.eventlogger_ip: localconfig += 'eventlog-host %s\n' % args.eventlogger_ip
|
|
loadPrcFileData('Command-line', localconfig)
|
|
|
|
from otp.ai.AIBaseGlobal import *
|
|
|
|
from toontown.ai.ToontownAIRepository import ToontownAIRepository
|
|
simbase.air = ToontownAIRepository(config.GetInt('air-base-channel', 401000000),
|
|
config.GetInt('air-stateserver', 4002),
|
|
config.GetString('district-name', 'Devhaven'))
|
|
host = config.GetString('air-connect', '127.0.0.1')
|
|
port = 7100
|
|
if ':' in host:
|
|
host, port = host.split(':', 1)
|
|
port = int(port)
|
|
simbase.air.connect(host, port)
|
|
|
|
isServer = config.GetBool('is-server', False)
|
|
|
|
try:
|
|
run()
|
|
gc.enable()
|
|
except SystemExit:
|
|
raise
|
|
except Exception:
|
|
info = describeException()
|
|
|
|
simbase.air.writeServerEvent('ai-exception', avId=simbase.air.getAvatarIdFromSender(), accId=simbase.air.getAccountIdFromSender(), exception=info)
|
|
|
|
if isServer:
|
|
import datetime
|
|
with open(config.GetString('ai-crash-log-name', '/opt/var/log/%s-ai-crash-%s.txt' % (config.GetString('district-name', 'Devhaven'), datetime.datetime.now())), 'w+') as file:
|
|
file.write(info + "\n")
|
|
|
|
raise
|