platypush/platypush/context/__init__.py

116 lines
3.1 KiB
Python
Raw Normal View History

2017-12-24 13:15:37 +01:00
import importlib
import logging
from threading import Lock
from ..config import Config
2018-06-06 20:09:18 +02:00
logger = logging.getLogger(__name__)
# Map: backend_name -> backend_instance
backends = {}
# Map: plugin_name -> plugin_instance
plugins = {}
# Map: plugin_name -> init_lock to make sure that a plugin isn't initialized
# multiple times
plugins_init_locks = {}
# Reference to the main application bus
main_bus = None
2017-12-24 13:15:37 +01:00
def register_backends(bus=None, global_scope=False, **kwargs):
""" Initialize the backend objects based on the configuration and returns
a name -> backend_instance map.
Params:
bus -- If specific (it usually should), the messages processed by the
backends will be posted on this bus.
kwargs -- Any additional key-value parameters required to initialize the backends
"""
global main_bus
if bus:
main_bus = bus
2017-12-24 13:15:37 +01:00
if global_scope:
global backends
else:
backends = {}
for (name, cfg) in Config.get_backends().items():
module = importlib.import_module('platypush.backend.' + name)
# e.g. backend.pushbullet main class: PushbulletBackend
cls_name = ''
for token in module.__name__.title().split('.')[2:]:
cls_name += token.title()
cls_name += 'Backend'
try:
b = getattr(module, cls_name)(bus=bus, **cfg, **kwargs)
backends[name] = b
except AttributeError as e:
2018-06-06 20:09:18 +02:00
logger.warning('No such class in {}: {}'.format(
module.__name__, cls_name))
raise RuntimeError(e)
return backends
def get_backend(name):
""" Returns the backend instance identified by name if it exists """
global backends
2018-07-15 02:57:12 +02:00
return backends.get(name)
def get_plugin(plugin_name, reload=False):
""" Registers a plugin instance by name if not registered already, or
returns the registered plugin instance"""
global plugins
global plugins_init_locks
if plugin_name not in plugins_init_locks:
plugins_init_locks[plugin_name] = Lock()
2018-09-16 23:45:20 +02:00
if plugin_name in plugins and not reload:
return plugins[plugin_name]
try:
plugin = importlib.import_module('platypush.plugins.' + plugin_name)
2018-02-20 22:58:13 +01:00
except ImportError as e:
2018-06-06 20:09:18 +02:00
logger.warning('No such plugin: {}'.format(plugin_name))
raise RuntimeError(e)
# e.g. plugins.music.mpd main class: MusicMpdPlugin
cls_name = ''
for token in plugin_name.split('.'):
cls_name += token.title()
cls_name += 'Plugin'
plugin_conf = Config.get_plugins()[plugin_name] \
if plugin_name in Config.get_plugins() else {}
try:
plugin_class = getattr(plugin, cls_name)
with plugins_init_locks[plugin_name]:
plugins[plugin_name] = plugin_class(**plugin_conf)
except AttributeError as e:
2018-06-06 20:09:18 +02:00
logger.warning('No such class in {}: {}'.format(plugin_name, cls_name))
raise RuntimeError(e)
return plugins[plugin_name]
def get_bus():
global main_bus
return main_bus
def register_plugin(name, plugin, **kwargs):
""" Registers a plugin instance by name """
global plugins
# vim:sw=4:ts=4:et: