summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--ipalib/plugable.py5
-rw-r--r--ipaserver/plugins/misc.py9
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,
)