import logging
from botocore.hooks import HierarchicalEmitter
log = logging.getLogger('awscli.plugin')
BUILTIN_PLUGINS = {'__builtin__': 'awscli.handlers'}
def load_plugins(plugin_mapping, event_hooks=None, include_builtins=True):
"""
:type plugin_mapping: dict
:param plugin_mapping: A dict of plugin name to import path,
e.g. ``{"plugingName": "package.modulefoo"}``.
:type event_hooks: ``EventHooks``
:param event_hooks: Event hook emitter. If one if not provided,
an emitter will be created and returned. Otherwise, the
passed in ``event_hooks`` will be used to initialize plugins.
:type include_builtins: bool
:param include_builtins: If True, the builtin awscli plugins (specified in
``BUILTIN_PLUGINS``) will be included in the list of plugins to load.
:rtype: HierarchicalEmitter
:return: An event emitter object.
"""
if include_builtins:
plugin_mapping.update(BUILTIN_PLUGINS)
modules = _import_plugins(plugin_mapping)
if event_hooks is None:
event_hooks = HierarchicalEmitter()
for name, plugin in zip(plugin_mapping.keys(), modules):
log.debug("Initializing plugin %s: %s", name, plugin)
plugin.awscli_initialize(event_hooks)
return event_hooks
def _import_plugins(plugin_names):
plugins = []
for name, path in plugin_names.items():
log.debug("Importing plugin %s: %s", name, path)
if '.' not in path:
plugins.append(__import__(path))
else:
package, module = path.rsplit('.', 1)
module = __import__(path, fromlist=[module])
plugins.append(module)
return plugins