crafty-4/app/classes/shared/command.py

91 lines
2.9 KiB
Python
Raw Normal View History

import sys
import cmd
import time
import threading
import logging
from app.classes.shared.console import console
from app.classes.shared.helpers import helper
from app.classes.shared.import3 import import3
from app.classes.web.websocket_helper import websocket_helper
logger = logging.getLogger(__name__)
2022-03-08 04:40:44 +00:00
class MainPrompt(cmd.Cmd):
2021-08-18 18:11:53 +03:00
def __init__(self, tasks_manager, migration_manager):
super().__init__()
self.tasks_manager = tasks_manager
2021-08-18 18:11:53 +03:00
self.migration_manager = migration_manager
# overrides the default Prompt
prompt = f"Crafty Controller v{helper.get_version_string()} > "
# see MR !233 for pylint exemptino reason
@staticmethod
def emptyline(): # pylint: disable=arguments-differ
pass
def do_exit(self, _line):
2021-12-09 18:35:00 -05:00
self.tasks_manager._main_graceful_exit()
self.universal_exit()
2021-08-18 18:11:53 +03:00
def do_migrations(self, line):
if line == "up":
2021-08-18 18:11:53 +03:00
self.migration_manager.up()
elif line == "down":
2021-08-18 18:11:53 +03:00
self.migration_manager.down()
elif line == "done":
2021-08-18 18:11:53 +03:00
console.info(self.migration_manager.done)
elif line == "todo":
2021-08-18 18:11:53 +03:00
console.info(self.migration_manager.todo)
elif line == "diff":
2021-08-18 18:11:53 +03:00
console.info(self.migration_manager.diff)
elif line == "info":
console.info(f"Done: {self.migration_manager.done}")
console.info(f"FS: {self.migration_manager.todo}")
console.info(f"Todo: {self.migration_manager.diff}")
elif line.startswith("add "):
migration_name = line[len("add ") :]
2021-08-18 18:11:53 +03:00
self.migration_manager.create(migration_name, False)
else:
console.info("Unknown migration command")
2022-01-15 02:23:50 +02:00
@staticmethod
def do_threads(_line):
for thread in threading.enumerate():
2022-01-15 02:23:50 +02:00
if sys.version_info >= (3, 8):
print(
f"Name: {thread.name} Identifier: "
f"{thread.ident} TID/PID: {thread.native_id}"
)
2022-01-15 02:23:50 +02:00
else:
print(f"Name: {thread.name} Identifier: {thread.ident}")
2022-03-18 23:59:10 -04:00
def do_import3(self, _line):
import3.start_import()
def universal_exit(self):
logger.info("Stopping all server daemons / threads")
console.info(
"Stopping all server daemons / threads - This may take a few seconds"
)
websocket_helper.disconnect_all()
console.info("Waiting for main thread to stop")
while True:
if self.tasks_manager.get_main_thread_run_status():
sys.exit(0)
time.sleep(1)
@staticmethod
def help_exit():
console.help("Stops the server if running, Exits the program")
2022-01-15 02:23:50 +02:00
2021-08-18 18:11:53 +03:00
@staticmethod
def help_migrations():
console.help("Only for advanced users. Use with caution")
2022-03-20 12:14:51 -05:00
@staticmethod
def help_import3():
2022-03-18 23:59:10 -04:00
console.help("Import users and servers from Crafty 3")