Catch exceptions in password_providers (#8636)

Signed-off-by: Nicolai Søborg <git@xn--sb-lka.org>
This commit is contained in:
Nicolai Søborg 2020-11-11 14:24:53 +01:00 committed by GitHub
parent c059413001
commit 4c7587ef99
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 10 additions and 4 deletions

1
changelog.d/8636.misc Normal file
View file

@ -0,0 +1 @@
Catch exceptions during initialization of `password_providers`. Contributed by Nicolai Søborg.

View file

@ -181,10 +181,15 @@ class AuthHandler(BaseHandler):
# better way to break the loop # better way to break the loop
account_handler = ModuleApi(hs, self) account_handler = ModuleApi(hs, self)
self.password_providers = [ self.password_providers = []
for module, config in hs.config.password_providers:
try:
self.password_providers.append(
module(config=config, account_handler=account_handler) module(config=config, account_handler=account_handler)
for module, config in hs.config.password_providers )
] except Exception as e:
logger.error("Error while initializing %r: %s", module, e)
raise
logger.info("Extra password_providers: %r", self.password_providers) logger.info("Extra password_providers: %r", self.password_providers)