diff options
author | David Baker <dbkr@users.noreply.github.com> | 2017-09-26 18:12:17 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-09-26 18:12:17 +0100 |
commit | ccc67d445b412f7634448796d2585665b988c153 (patch) | |
tree | d6730847b7cf97ca5b2a0ea792b0f502c5704f8e /synapse/config | |
parent | Merge branch 'develop' of github.com:matrix-org/synapse into release-v0.23.0 (diff) | |
parent | unnecessary parens (diff) | |
download | synapse-ccc67d445b412f7634448796d2585665b988c153.tar.xz |
Merge pull request #2473 from matrix-org/dbkr/factor_out_module_loading
Factor out module loading to a separate place
Diffstat (limited to 'synapse/config')
-rw-r--r-- | synapse/config/password_auth_providers.py | 22 |
1 files changed, 10 insertions, 12 deletions
diff --git a/synapse/config/password_auth_providers.py b/synapse/config/password_auth_providers.py index 83762d089a..90824cab7f 100644 --- a/synapse/config/password_auth_providers.py +++ b/synapse/config/password_auth_providers.py @@ -15,13 +15,15 @@ from ._base import Config, ConfigError -import importlib +from synapse.util.module_loader import load_module class PasswordAuthProviderConfig(Config): def read_config(self, config): self.password_providers = [] + provider_config = None + # We want to be backwards compatible with the old `ldap_config` # param. ldap_config = config.get("ldap_config", {}) @@ -38,19 +40,15 @@ class PasswordAuthProviderConfig(Config): if provider['module'] == "synapse.util.ldap_auth_provider.LdapAuthProvider": from ldap_auth_provider import LdapAuthProvider provider_class = LdapAuthProvider + try: + provider_config = provider_class.parse_config(provider["config"]) + except Exception as e: + raise ConfigError( + "Failed to parse config for %r: %r" % (provider['module'], e) + ) else: - # We need to import the module, and then pick the class out of - # that, so we split based on the last dot. - module, clz = provider['module'].rsplit(".", 1) - module = importlib.import_module(module) - provider_class = getattr(module, clz) + (provider_class, provider_config) = load_module(provider) - try: - provider_config = provider_class.parse_config(provider["config"]) - except Exception as e: - raise ConfigError( - "Failed to parse config for %r: %r" % (provider['module'], e) - ) self.password_providers.append((provider_class, provider_config)) def default_config(self, **kwargs): |