aboutsummaryrefslogtreecommitdiffstats
path: root/phpBB/phpbb/session.php
diff options
context:
space:
mode:
Diffstat (limited to 'phpBB/phpbb/session.php')
-rw-r--r--phpBB/phpbb/session.php18
1 files changed, 16 insertions, 2 deletions
diff --git a/phpBB/phpbb/session.php b/phpBB/phpbb/session.php
index d286dc9cfc..c663977882 100644
--- a/phpBB/phpbb/session.php
+++ b/phpBB/phpbb/session.php
@@ -410,7 +410,14 @@ class session
// Check whether the session is still valid if we have one
$method = basename(trim($config['auth_method']));
- $provider = $phpbb_container->get('auth.provider.' . $method);
+ $provider_collection = $phpbb_container->get('auth.provider_collection');
+
+ // Revert to db auth provider if selected method does not exist
+ if (!isset($provider_collection['auth.provider.' . $method]))
+ {
+ $method = 'db';
+ }
+ $provider = $provider_collection['auth.provider.' . $method];
if (!($provider instanceof \phpbb\auth\provider\provider_interface))
{
@@ -579,7 +586,14 @@ class session
$method = basename(trim($config['auth_method']));
- $provider = $phpbb_container->get('auth.provider.' . $method);
+ $provider_collection = $phpbb_container->get('auth.provider_collection');
+
+ // Revert to db auth provider if selected method does not exist
+ if (!isset($provider_collection['auth.provider.' . $method]))
+ {
+ $method = 'db';
+ }
+ $provider = $provider_collection['auth.provider.' . $method];
$this->data = $provider->autologin();
if (sizeof($this->data))