mirror of
https://gitlab.com/crafty-controller/crafty-4.git
synced 2025-01-31 12:56:11 +01:00
2528c123f2
Checks when crafty starts for internet and a port forward for Crafty's https port. Checks on server launch for internet connection and for port forwarding for executed server.
170 lines
5.6 KiB
Python
170 lines
5.6 KiB
Python
import os
|
|
import sys
|
|
import json
|
|
import time
|
|
import argparse
|
|
import logging.config
|
|
import signal
|
|
|
|
""" Our custom classes / pip packages """
|
|
from app.classes.shared.console import console
|
|
from app.classes.shared.helpers import helper
|
|
from app.classes.shared.models import installer, database
|
|
|
|
from app.classes.shared.tasks import TasksManager
|
|
from app.classes.shared.controller import Controller
|
|
from app.classes.shared.migration import MigrationManager
|
|
|
|
from app.classes.shared.cmd import MainPrompt
|
|
|
|
|
|
def do_intro():
|
|
logger.info("***** Crafty Controller Started *****")
|
|
|
|
version = helper.get_version_string()
|
|
|
|
intro = """
|
|
{lines}
|
|
#\t\tWelcome to Crafty Controller - v.{version}\t\t #
|
|
{lines}
|
|
# \tServer Manager / Web Portal for your Minecraft server \t #
|
|
# \t\tHomepage: www.craftycontrol.com\t\t\t #
|
|
{lines}
|
|
""".format(lines="/" * 75, version=version)
|
|
|
|
console.magenta(intro)
|
|
|
|
|
|
def setup_logging(debug=True):
|
|
logging_config_file = os.path.join(os.path.curdir,
|
|
'app',
|
|
'config',
|
|
'logging.json'
|
|
)
|
|
|
|
if os.path.exists(logging_config_file):
|
|
# open our logging config file
|
|
with open(logging_config_file, 'rt') as f:
|
|
logging_config = json.load(f)
|
|
if debug:
|
|
logging_config['loggers']['']['level'] = 'DEBUG'
|
|
|
|
logging.config.dictConfig(logging_config)
|
|
|
|
else:
|
|
logging.basicConfig(level=logging.DEBUG)
|
|
logging.warning("Unable to read logging config from {}".format(logging_config_file))
|
|
console.critical("Unable to read logging config from {}".format(logging_config_file))
|
|
|
|
|
|
""" Our Main Starter """
|
|
if __name__ == '__main__':
|
|
parser = argparse.ArgumentParser("Crafty Controller - A Server Management System")
|
|
|
|
parser.add_argument('-i', '--ignore',
|
|
action='store_true',
|
|
help="Ignore session.lock files"
|
|
)
|
|
|
|
parser.add_argument('-v', '--verbose',
|
|
action='store_true',
|
|
help="Sets logging level to debug."
|
|
)
|
|
|
|
parser.add_argument('-d', '--daemon',
|
|
action='store_true',
|
|
help="Runs Crafty in daemon mode (no prompt)"
|
|
)
|
|
|
|
args = parser.parse_args()
|
|
|
|
helper.ensure_logging_setup()
|
|
|
|
setup_logging(debug=args.verbose)
|
|
|
|
# setting up the logger object
|
|
logger = logging.getLogger(__name__)
|
|
print("Logging set to: {} ".format(logger.level))
|
|
|
|
# print our pretty start message
|
|
do_intro()
|
|
|
|
# our session file, helps prevent multiple controller agents on the same machine.
|
|
helper.create_session_file(ignore=args.ignore)
|
|
|
|
|
|
migration_manager = MigrationManager(database)
|
|
migration_manager.up() # Automatically runs migrations
|
|
|
|
# do our installer stuff
|
|
fresh_install = installer.is_fresh_install()
|
|
|
|
if fresh_install:
|
|
console.debug("Fresh install detected")
|
|
installer.default_settings()
|
|
else:
|
|
console.debug("Existing install detected")
|
|
|
|
# now the tables are created, we can load the tasks_manger and server controller
|
|
controller = Controller()
|
|
tasks_manager = TasksManager(controller)
|
|
tasks_manager.start_webserver()
|
|
|
|
# slowing down reporting just for a 1/2 second so messages look cleaner
|
|
time.sleep(.5)
|
|
|
|
# init servers
|
|
logger.info("Initializing all servers defined")
|
|
console.info("Initializing all servers defined")
|
|
controller.init_all_servers()
|
|
servers = controller.list_defined_servers()
|
|
|
|
# start stats logging
|
|
tasks_manager.start_stats_recording()
|
|
|
|
# once the controller is up and stats are logging, we can kick off the scheduler officially
|
|
tasks_manager.start_scheduler()
|
|
|
|
# refresh our cache and schedule for every 12 hoursour cache refresh for serverjars.com
|
|
tasks_manager.serverjar_cache_refresher()
|
|
|
|
# this should always be last
|
|
tasks_manager.start_main_kill_switch_watcher()
|
|
|
|
if not helper.check_internet():
|
|
console.error("We have detected the machine running Crafty has no connection to the internet. Client connections to the server may be limited.")
|
|
elif not helper.check_port(helper.get_setting('https_port')):
|
|
console.error("We have detected Crafty's port, {} may not be open on the host network or a firewall is blocking it. Remote client connections to Crafty may be limited.".format(helper.get_setting('https_port')))
|
|
|
|
Crafty = MainPrompt(tasks_manager, migration_manager)
|
|
|
|
def sigterm_handler(signum, current_stack_frame):
|
|
print() # for newline
|
|
logger.info("Recieved SIGTERM, stopping Crafty")
|
|
console.info("Recieved SIGTERM, stopping Crafty")
|
|
Crafty.universal_exit()
|
|
|
|
signal.signal(signal.SIGTERM, sigterm_handler)
|
|
|
|
if not args.daemon:
|
|
try:
|
|
Crafty.cmdloop()
|
|
except KeyboardInterrupt:
|
|
print() # for newline
|
|
logger.info("Recieved SIGINT, stopping Crafty")
|
|
console.info("Recieved SIGINT, stopping Crafty")
|
|
Crafty.universal_exit()
|
|
else:
|
|
print("Crafty started in daemon mode, no shell will be printed")
|
|
while True:
|
|
try:
|
|
if tasks_manager.get_main_thread_run_status():
|
|
break
|
|
time.sleep(1)
|
|
except KeyboardInterrupt:
|
|
logger.info("Recieved SIGINT, stopping Crafty")
|
|
console.info("Recieved SIGINT, stopping Crafty")
|
|
break
|
|
|
|
Crafty.universal_exit()
|