mirror of
https://github.com/EGroupware/egroupware.git
synced 2025-01-14 18:08:21 +01:00
config got "lost" after deleting the cache, caused by it being automatic unserialized
This commit is contained in:
parent
dd0a860f7e
commit
55b615af5f
@ -2,6 +2,20 @@
|
|||||||
/**
|
/**
|
||||||
* EGroupware API - Authentication against multiple backends
|
* EGroupware API - Authentication against multiple backends
|
||||||
*
|
*
|
||||||
|
* @link https://www.egroupware.org
|
||||||
|
* @author Ralf Becker <rb@egroupware.org>
|
||||||
|
* @license http://opensource.org/licenses/lgpl-license.php LGPL - GNU Lesser General Public License
|
||||||
|
* @package api
|
||||||
|
* @subpackage auth
|
||||||
|
*/
|
||||||
|
|
||||||
|
namespace EGroupware\Api\Auth;
|
||||||
|
|
||||||
|
use EGroupware\Api;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Authentication agains multiple backends
|
||||||
|
*
|
||||||
* The first backend against which authentication succeeds is used, so you either need *somehow* to make sure usernames are unique,
|
* The first backend against which authentication succeeds is used, so you either need *somehow* to make sure usernames are unique,
|
||||||
* or the backends in the *right* order. The name of the succeeding backend is stored in the instance cache.
|
* or the backends in the *right* order. The name of the succeeding backend is stored in the instance cache.
|
||||||
*
|
*
|
||||||
@ -19,22 +33,6 @@
|
|||||||
* },
|
* },
|
||||||
* optional further backend objects
|
* optional further backend objects
|
||||||
* }
|
* }
|
||||||
*
|
|
||||||
* @link https://www.egroupware.org
|
|
||||||
* @author Ralf Becker <rb@egroupware.org>
|
|
||||||
* @license http://opensource.org/licenses/lgpl-license.php LGPL - GNU Lesser General Public License
|
|
||||||
* @package api
|
|
||||||
* @subpackage auth
|
|
||||||
*/
|
|
||||||
|
|
||||||
namespace EGroupware\Api\Auth;
|
|
||||||
|
|
||||||
use EGroupware\Api;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Authentication agains a LDAP Server with fallback to SQL
|
|
||||||
*
|
|
||||||
* For other fallback types, simply change auth backends in constructor call
|
|
||||||
*/
|
*/
|
||||||
class Multiple implements Backend
|
class Multiple implements Backend
|
||||||
{
|
{
|
||||||
@ -63,7 +61,7 @@ class Multiple implements Backend
|
|||||||
/**
|
/**
|
||||||
* Parse configuration
|
* Parse configuration
|
||||||
*
|
*
|
||||||
* @param string $config
|
* @param string|array $config auth_multiple configuration
|
||||||
* @param boolean $checks true: run some extra checks, used in setup to check config is sane
|
* @param boolean $checks true: run some extra checks, used in setup to check config is sane
|
||||||
* @return array
|
* @return array
|
||||||
* @throws \Exception on invalid configuration
|
* @throws \Exception on invalid configuration
|
||||||
@ -71,10 +69,13 @@ class Multiple implements Backend
|
|||||||
static public function parseConfig($config, $checks=false)
|
static public function parseConfig($config, $checks=false)
|
||||||
{
|
{
|
||||||
try
|
try
|
||||||
|
{
|
||||||
|
if (!is_array($config))
|
||||||
{
|
{
|
||||||
$config = $config[0] === '{' ? json_decode($config, true, 512, JSON_THROW_ON_ERROR) :
|
$config = $config[0] === '{' ? json_decode($config, true, 512, JSON_THROW_ON_ERROR) :
|
||||||
array_combine($csv = preg_split('/,\s*/', $config), array_fill(0, count($csv), null));
|
array_combine($csv = preg_split('/,\s*/', $config), array_fill(0, count($csv), null));
|
||||||
}
|
}
|
||||||
|
}
|
||||||
catch(\JsonException $e) {
|
catch(\JsonException $e) {
|
||||||
throw new \Exception('Invalid JSON: '.$e->getMessage());
|
throw new \Exception('Invalid JSON: '.$e->getMessage());
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user