diff options
-rw-r--r-- | ipalib/plugable.py | 5 | ||||
-rw-r--r-- | ipaserver/plugins/misc.py | 9 |
2 files changed, 8 insertions, 6 deletions
diff --git a/ipalib/plugable.py b/ipalib/plugable.py index 8284cca39..5a5d02fb0 100644 --- a/ipalib/plugable.py +++ b/ipalib/plugable.py @@ -671,7 +671,6 @@ class API(ReadOnly): self.__do_if_not_done('load_plugins') production_mode = self.is_production_mode() - plugin_info = {} for base in self.bases: name = base.__name__ @@ -679,9 +678,6 @@ class API(ReadOnly): for klass in six.itervalues(self.__plugins): if not any(issubclass(b, base) for b in klass.bases): continue - plugin_info.setdefault( - '%s.%s' % (klass.__module__, klass.name), - []).append(name) if not self.env.plugins_on_demand: self._get(klass.name) @@ -698,7 +694,6 @@ class API(ReadOnly): assert islocked(instance) self.__finalized = True - self.plugins = tuple((k, tuple(v)) for k, v in plugin_info.items()) if not production_mode: lock(self) diff --git a/ipaserver/plugins/misc.py b/ipaserver/plugins/misc.py index 0628bb19b..7618e23a9 100644 --- a/ipaserver/plugins/misc.py +++ b/ipaserver/plugins/misc.py @@ -133,6 +133,13 @@ class plugins(LocalOrRemote): ) def execute(self, **options): + result = {} + for namespace in self.api: + for plugin in self.api[namespace](): + cls = type(plugin) + key = '{}.{}'.format(cls.__module__, cls.__name__) + result.setdefault(key, []).append(namespace) + return dict( - result=dict(self.api.plugins), + result=result, ) |