mirror of
https://salsa.debian.org/freeipa-team/freeipa.git
synced 2025-01-11 08:41:55 -06:00
plugable: simplify API plugin initialization code
Use a flat dictionary to track plugins in API rather than nested dictionaries. https://fedorahosted.org/freeipa/ticket/4739 Reviewed-By: David Kupka <dkupka@redhat.com>
This commit is contained in:
parent
ed4c2d9252
commit
19cf6e9509
@ -574,41 +574,37 @@ class API(ReadOnly):
|
|||||||
raise TypeError('plugin must be a class; got %r' % klass)
|
raise TypeError('plugin must be a class; got %r' % klass)
|
||||||
|
|
||||||
# Find the base class or raise SubclassError:
|
# Find the base class or raise SubclassError:
|
||||||
found = False
|
|
||||||
for base in self.bases:
|
for base in self.bases:
|
||||||
if not issubclass(klass, base):
|
if issubclass(klass, self.bases):
|
||||||
continue
|
break
|
||||||
|
else:
|
||||||
sub_d = self.__plugins.setdefault(base, {})
|
|
||||||
found = True
|
|
||||||
|
|
||||||
# Check override:
|
|
||||||
if klass.__name__ in sub_d:
|
|
||||||
if not override:
|
|
||||||
# Must use override=True to override:
|
|
||||||
raise errors.PluginOverrideError(
|
|
||||||
base=base.__name__,
|
|
||||||
name=klass.__name__,
|
|
||||||
plugin=klass,
|
|
||||||
)
|
|
||||||
else:
|
|
||||||
if override:
|
|
||||||
# There was nothing already registered to override:
|
|
||||||
raise errors.PluginMissingOverrideError(
|
|
||||||
base=base.__name__,
|
|
||||||
name=klass.__name__,
|
|
||||||
plugin=klass,
|
|
||||||
)
|
|
||||||
|
|
||||||
# The plugin is okay, add to sub_d:
|
|
||||||
sub_d[klass.__name__] = klass
|
|
||||||
|
|
||||||
if not found:
|
|
||||||
raise errors.PluginSubclassError(
|
raise errors.PluginSubclassError(
|
||||||
plugin=klass,
|
plugin=klass,
|
||||||
bases=self.bases,
|
bases=self.bases,
|
||||||
)
|
)
|
||||||
|
|
||||||
|
# Check override:
|
||||||
|
prev = self.__plugins.get(klass.__name__)
|
||||||
|
if prev:
|
||||||
|
if not override:
|
||||||
|
# Must use override=True to override:
|
||||||
|
raise errors.PluginOverrideError(
|
||||||
|
base=base.__name__,
|
||||||
|
name=klass.__name__,
|
||||||
|
plugin=klass,
|
||||||
|
)
|
||||||
|
else:
|
||||||
|
if override:
|
||||||
|
# There was nothing already registered to override:
|
||||||
|
raise errors.PluginMissingOverrideError(
|
||||||
|
base=base.__name__,
|
||||||
|
name=klass.__name__,
|
||||||
|
plugin=klass,
|
||||||
|
)
|
||||||
|
|
||||||
|
# The plugin is okay, add to sub_d:
|
||||||
|
self.__plugins[klass.__name__] = klass
|
||||||
|
|
||||||
def finalize(self):
|
def finalize(self):
|
||||||
"""
|
"""
|
||||||
Finalize the registration, instantiate the plugins.
|
Finalize the registration, instantiate the plugins.
|
||||||
@ -625,10 +621,11 @@ class API(ReadOnly):
|
|||||||
|
|
||||||
for base in self.bases:
|
for base in self.bases:
|
||||||
name = base.__name__
|
name = base.__name__
|
||||||
sub_d = self.__plugins.get(base, {})
|
|
||||||
|
|
||||||
members = []
|
members = []
|
||||||
for klass in sub_d.values():
|
|
||||||
|
for klass in self.__plugins.values():
|
||||||
|
if not issubclass(klass, base):
|
||||||
|
continue
|
||||||
try:
|
try:
|
||||||
instance = plugins[klass]
|
instance = plugins[klass]
|
||||||
except KeyError:
|
except KeyError:
|
||||||
|
Loading…
Reference in New Issue
Block a user