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

78 lines
2.5 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.web.websocket_helper import websocket_helper
logger = logging.getLogger(__name__)
class MainPrompt(cmd.Cmd):
2021-08-18 15:11:53 +00:00
def __init__(self, tasks_manager, migration_manager):
super().__init__()
self.tasks_manager = tasks_manager
2021-08-18 15:11:53 +00:00
self.migration_manager = migration_manager
# overrides the default Prompt
prompt = f"Crafty Controller v{helper.get_version_string()} > "
@staticmethod
def emptyline():
pass
#pylint: disable=unused-argument
def do_exit(self, line):
2021-12-09 23:35:00 +00:00
self.tasks_manager._main_graceful_exit()
self.universal_exit()
2021-08-18 15:11:53 +00:00
def do_migrations(self, line):
2022-01-15 00:23:50 +00:00
if line == 'up':
2021-08-18 15:11:53 +00:00
self.migration_manager.up()
2022-01-15 00:23:50 +00:00
elif line == 'down':
2021-08-18 15:11:53 +00:00
self.migration_manager.down()
2022-01-15 00:23:50 +00:00
elif line == 'done':
2021-08-18 15:11:53 +00:00
console.info(self.migration_manager.done)
2022-01-15 00:23:50 +00:00
elif line == 'todo':
2021-08-18 15:11:53 +00:00
console.info(self.migration_manager.todo)
2022-01-15 00:23:50 +00:00
elif line == 'diff':
2021-08-18 15:11:53 +00:00
console.info(self.migration_manager.diff)
2022-01-15 00:23:50 +00:00
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}')
2022-01-15 00:23:50 +00:00
elif line.startswith('add '):
2021-08-18 15:11:53 +00:00
migration_name = line[len('add '):]
self.migration_manager.create(migration_name, False)
else:
console.info('Unknown migration command')
2022-01-15 00:23:50 +00:00
@staticmethod
def do_threads(_line):
for thread in threading.enumerate():
2022-01-15 00:23:50 +00:00
if sys.version_info >= (3, 8):
print(f'Name: {thread.name} Identifier: {thread.ident} TID/PID: {thread.native_id}')
else:
print(f'Name: {thread.name} Identifier: {thread.ident}')
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 00:23:50 +00:00
2021-08-18 15:11:53 +00:00
@staticmethod
def help_migrations():
console.help("Only for advanced users. Use with caution")