# -*- coding: utf-8 -*-
-# Copyright (c) 2013, 2014, 2015 kaliko <kaliko@azylum.org>
+# Copyright (c) 2013, 2014, 2015, 2020 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, PluginConfException
+from .utils.utils import exception_log, SigHup, MPDSimaException
# core plugins
from .plugins.core.history import History
from .plugins.core.mpdoptions import MpdOptions
sys.exit(1)
logger.info('Loading {0} plugin: {name} ({doc})'.format(
source, **plugin_obj.info()))
- try:
- sima.register_plugin(plugin_obj)
- except PluginConfException as err:
- logger.error(err)
- sys.exit(2)
+ sima.register_plugin(plugin_obj)
def start(sopt, restart=False):
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()
import random
# third parties components
+from musicpd import CommandError
# local import
from ...lib.plugin import Plugin
from ...lib.track import Track
-from ...utils.utils import PluginConfException, PluginException
+from ...utils.utils import PluginException
def forge_filter(cfg):
tags = set(cfg.keys()) & Tags.supported_tags
def _control_conf(self):
sup_tags = Tags.supported_tags
+ config_tags = {k for k, v in self.plugin_conf.items()
+ if (v and k not in ['filter', 'priority'])}
if not self.plugin_conf.get('filter', None) and \
- self.plugin_conf.keys().isdisjoint(sup_tags):
- self.log.error(
- 'Found no config for %s plugin! Need at least "filter" or a supported tag' % self)
+ config_tags.isdisjoint(sup_tags):
+ self.log.error('Found no config for %s plugin! '
+ 'Need at least "filter" or a supported tag', self)
self.log.info('Supported Tags are : %s', ', '.join(sup_tags))
- raise PluginConfException('plugin misconfiguration')
+ raise PluginException('plugin misconfiguration')
+ if config_tags.difference(sup_tags):
+ self.log.error('Found unsupported tag in config: %s',
+ config_tags.difference(sup_tags))
+ raise PluginException('plugin misconfiguration')
def _setup_tagsneeded(self):
+ config_tags = {k for k, v in self.plugin_conf.items() if v}
self.log.debug('%s plugin needs the followinng metadata: %s',
- self, set(self.plugin_conf.keys()) & Tags.supported_tags)
- tags = set(self.plugin_conf.keys()) & Tags.supported_tags
+ self, config_tags & Tags.supported_tags)
+ tags = config_tags & Tags.supported_tags
self.player.needed_tags |= tags
def _get_history(self):
self.log.error('Need at least MPD 0.21 to use Tags plugin (filters required)')
self.player.disconnect()
raise PluginException('MPD >= 0.21 required')
+ # Check filter is valid
+ try:
+ self.player.find(self.plugin_conf['filter'])
+ except CommandError:
+ raise PluginException('Badly formated filter in tags plugin configuration: "%s"'
+ % self.plugin_conf['filter'])
def callback_need_track(self):
candidates = []
return result
return wrapper
-# http client exceptions (for webservices)
+class MPDSimaException(Exception):
+ pass
-class WSError(Exception):
+# http client exceptions (for webservices)
+class WSError(MPDSimaException):
pass
class WSNotFound(WSError):
class WSHTTPError(WSError):
pass
-class MPDSimaException(Exception):
- pass
-
class PluginException(MPDSimaException):
pass
-class PluginConfException(MPDSimaException):
- pass
-
# VIM MODLINE
# vim: ai ts=4 sw=4 sts=4 expandtab