# -*- coding: utf-8 -*-
-# Copyright (c) 2013, 2014, 2015 kaliko <kaliko@azylum.org>
+# Copyright (c) 2013, 2014, 2015, 2020,2021 kaliko <kaliko@azylum.org>
#
# This file is part of sima
#
from .lib.simadb import SimaDB
from .utils.config import ConfMan
from .utils.startopt import StartOpt
-from .utils.utils import exception_log, SigHup
+from .utils.utils import exception_log, SigHup, MPDSimaException
# core plugins
from .plugins.core.history import History
from .plugins.core.mpdoptions import MpdOptions
"""starts application
"""
# loads configuration
- config = ConfMan(sopt.options).config
+ cfg_mgmt = ConfMan(sopt.options)
+ config = cfg_mgmt.config
# set logger
logger = logging.getLogger('sima')
logfile = config.get('log', 'logfile', fallback=None)
verbosity = config.get('log', 'verbosity')
set_logger(verbosity, logfile)
logger.debug('Command line say: %s', sopt.options)
+
+ if sopt.options.get('command'):
+ cmd = sopt.options.get('command')
+ if cmd == "generate-config":
+ config.write(sys.stdout, space_around_delimiters=True)
+ sys.exit(0)
+ logger.info('Running "%s" and exit' % cmd)
+ if cmd == "config-test":
+ logger.info('Config location: "%s"', cfg_mgmt.conf_file)
+ from .utils.configtest import config_test
+ config_test(config)
+ sys.exit(0)
+ if cmd == "create-db":
+ db_file = config.get('sima', 'db_file')
+ if not isfile(db_file):
+ logger.info('Creating database in "%s"', db_file)
+ open(db_file, 'a').close()
+ SimaDB(db_path=db_file).create_db()
+ if sopt.options.get('create_db', None):
+ logger.info('Done, bye...')
+ else:
+ logger.info('Database already there, not overwriting %s', db_file)
+ sys.exit(0)
+ if cmd == "purge-history":
+ db_file = config.get('sima', 'db_file')
+ if not isfile(db_file):
+ logger.warning('No db found: %s', db_file)
+ sys.exit(1)
+ SimaDB(db_path=db_file).purge_history(duration=0)
+ sys.exit(0)
+
+
+ # TODO: To remove eventually in next major realese v0.18
# Create Database
db_file = config.get('sima', 'db_file')
if (sopt.options.get('create_db', None)
SimaDB(db_path=db_file).create_db()
if sopt.options.get('create_db', None):
logger.info('Done, bye...')
- sys.exit(0)
+ sys.exit(0)
+ # TODO: To remove eventually in next major realese v0.18
if sopt.options.get('generate_config'):
config.write(sys.stdout, space_around_delimiters=True)
sys.exit(0)
core_plugins = [History, MpdOptions]
config['sima']['musicbrainzid'] = 'False'
for cplgn in core_plugins:
- logger.debug('Register core {name} ({doc})'.format(**cplgn.info()))
+ logger.debug('Register core %(name)s (%(doc)s)', cplgn.info())
sima.register_core_plugin(cplgn)
- logger.debug('core loaded, prioriy: {}'.format(' > '.join(map(str, sima.core_plugins))))
+ logger.debug('core loaded, prioriy: %s', ' > '.join(map(str, sima.core_plugins)))
# Loading internal plugins
load_plugins(sima, 'internal')
-
# Loading contrib plugins
load_plugins(sima, 'contrib')
logger.info('plugins loaded, prioriy: %s', ' > '.join(map(str, sima.plugins)))
Catches Unhandled exception
"""
# pylint: disable=broad-except
+ logger = logging.getLogger('sima')
try:
start(sopt, restart)
except SigHup: # SigHup inherit from Exception
run(sopt, True)
+ except MPDSimaException as err:
+ logger.error(err)
+ sys.exit(2)
except Exception: # Unhandled exception
exception_log()