mirror of
https://github.com/EGroupware/egroupware.git
synced 2025-01-23 14:28:45 +01:00
WIP Mail REST API: fix broken fallback auth
This commit is contained in:
parent
4d2eb72ce3
commit
f8c4d7c8e3
@ -81,34 +81,39 @@ class Auth
|
||||
*/
|
||||
static function backend($type=null, $save_in_session=true)
|
||||
{
|
||||
if (is_null($type))
|
||||
if (!isset($type))
|
||||
{
|
||||
$type = self::backendType() ?: null;
|
||||
}
|
||||
// do we have a hostname specific auth type set
|
||||
if (is_null($type) && !empty($GLOBALS['egw_info']['server']['auth_type_host']) &&
|
||||
if (!isset($type) && !empty($GLOBALS['egw_info']['server']['auth_type_host']) &&
|
||||
Header\Http::host() === $GLOBALS['egw_info']['server']['auth_type_hostname'])
|
||||
{
|
||||
$type = $GLOBALS['egw_info']['server']['auth_type_host'];
|
||||
}
|
||||
if (is_null($type)) $type = $GLOBALS['egw_info']['server']['auth_type'];
|
||||
if (!isset($type))
|
||||
{
|
||||
$type = $GLOBALS['egw_info']['server']['auth_type'];
|
||||
|
||||
$account_storage = $GLOBALS['egw_info']['server']['account_storage'] ?? $type;
|
||||
if (!empty($GLOBALS['egw_info']['server']['auth_fallback']) && $type !== $account_storage)
|
||||
{
|
||||
$backend = new Auth\Fallback($type, $account_storage);
|
||||
self::log("Instantiated Auth\\Fallback('$type', '$account_storage')");
|
||||
$account_repository = $GLOBALS['egw_info']['server']['account_repository'] ?? $type;
|
||||
if (!empty($GLOBALS['egw_info']['server']['auth_fallback']) && $type !== $account_repository)
|
||||
{
|
||||
$backend = new Auth\Fallback($type, $account_repository);
|
||||
self::log("Instantiated Auth\\Fallback('$type', '$account_repository')");
|
||||
$type = "fallback:$type:$account_repository";
|
||||
}
|
||||
}
|
||||
else
|
||||
if (!isset($backend))
|
||||
{
|
||||
$backend_class = __CLASS__.'\\'.ucfirst($type);
|
||||
[$t, $p1, $p2] = explode(':', $type)+[null,null,null];
|
||||
$backend_class = __CLASS__.'\\'.ucfirst($t);
|
||||
|
||||
// try old location / name, if not found
|
||||
if (!class_exists($backend_class) && class_exists('auth_'.$type))
|
||||
if (!class_exists($backend_class) && class_exists('auth_'.$t))
|
||||
{
|
||||
$backend_class = 'auth_'.$type;
|
||||
$backend_class = 'auth_'.$t;
|
||||
}
|
||||
$backend = new $backend_class;
|
||||
$backend = new $backend_class($p1, $p2);
|
||||
self::log("Instantiated $backend_class() (for type '$type')");
|
||||
}
|
||||
|
||||
|
@ -43,9 +43,10 @@ class Fallback implements Backend
|
||||
*/
|
||||
function __construct($primary='ldap',$fallback='sql')
|
||||
{
|
||||
$this->primary_backend = Api\Auth::backend(str_replace('auth_', '', $primary));
|
||||
// do NOT save our backends in session, as we want "fallback" to be saved
|
||||
$this->primary_backend = Api\Auth::backend(str_replace('auth_', '', $primary), false);
|
||||
|
||||
$this->fallback_backend = Api\Auth::backend(str_replace('auth_', '', $fallback));
|
||||
$this->fallback_backend = Api\Auth::backend(str_replace('auth_', '', $fallback), false);
|
||||
}
|
||||
|
||||
/**
|
||||
|
Loading…
Reference in New Issue
Block a user