3 declare(strict_types=1);
47 if (!$this->
getSettings()->
get(
'apache_enable_auth',
'0')) {
48 $this->
getLogger()->info(
'Apache auth disabled.');
54 !$this->
getSettings()->
get(
'apache_auth_indicator_name',
'') ||
55 !$this->
getSettings()->
get(
'apache_auth_indicator_value',
'')
57 $this->
getLogger()->warning(
'Apache auth indicator match failure.');
62 $validIndicatorValues = array_filter(array_map(
64 str_getcsv($this->
getSettings()->
get(
'apache_auth_indicator_value',
''))
69 !in_array(
$_SERVER[$this->
getSettings()->
get(
'apache_auth_indicator_name',
'')], $validIndicatorValues,
true)
71 $this->
getLogger()->warning(
'Apache authentication failed (indicator name <-> value');
83 $this->
getLogger()->info(
'No username given');
89 if ($this->
getSettings()->
get(
'apache_enable_ldap',
'0')) {
96 $this->
getLogger()->info(
'Cannot find user id for external account: ' . $this->
getCredentials()->getUsername());
108 $this->force_new_account =
true;
109 if ($this->
getSettings()->
get(
'apache_enable_ldap',
'0')) {
116 $this->force_new_account =
true;
117 if ($this->
getSettings()->
get(
'apache_enable_ldap',
'0')) {
129 $this->migration_account =
$name;
139 if ($this->
getSettings()->
get(
'apache_ldap_sid',
'0')) {
140 return 'ldap_' . $this->
getSettings()->get(
'apache_ldap_sid',
'');
149 (
int) $this->
getSettings()->
get(
'apache_ldap_sid',
'0')
152 $this->
getLogger()->debug(
'Using ldap data source with server configuration: ' .
$server->getName());
156 $sync->setUserData([]);
157 $sync->forceCreation($this->force_new_account);
158 $sync->forceReadLdapData(
true);
161 $internal_account = $sync->sync();
162 $this->
getLogger()->debug(
'Internal account: ' . $internal_account);
164 $this->
getLogger()->info(
'Login failed with message: ' . $e->getMessage());
172 $this->
getLogger()->info(
'Login failed with message: ' . $e->getMessage());
177 $this->
getLogger()->info(
'Authentication failed: account migration required for external account: ' . $this->
getCredentials()->getUsername());
This file is part of ILIAS, a powerful learning management system published by ILIAS open source e-Le...
string $migration_account
migrateAccount(ilAuthStatus $status)
Create new account.
Interface of auth credentials.
static getInstanceByServerId(int $a_server_id)
Get instance by server id.
doAuthentication(ilAuthStatus $status)
This file is part of ILIAS, a powerful learning management system published by ILIAS open source e-Le...
handleLDAPDataSource(ilAuthStatus $status)
Synchronization of user accounts used in auth container ldap, cas,...
static _lookupId($a_user_str)
createNewAccount(ilAuthStatus $status)
Create new ILIAS account for external_account.
static _checkExternalAuthAccount(string $a_auth, string $a_account, bool $tryFallback=true)
check whether external account and authentication method matches with a user
This file is part of ILIAS, a powerful learning management system published by ILIAS open source e-Le...
handleAuthenticationFail(ilAuthStatus $status, string $a_reason)
Handle failed authentication.
Base class for authentication providers (ldap, apache, ...)
setExternalAccount(string $a_ext)
Set external account (unique for each auth mode)
getTriggerAuthMode()
Get auth mode which triggered the account migration 2_1 for ldap account migration with server id 1 1...
setExternalAccountName(string $name)
setStatus(int $a_status)
Set auth status.
const APACHE_AUTH_TYPE_DIRECT_MAPPING
static isLogin(string $a_login)
ilAuthCredentials $credentials
getExternalAccountName()
Get external account name.
__construct(ilAuthCredentials $credentials)
getUserAuthModeName()
Get user auth mode name ldap_1 for ldap account migration with server id 1 apache for apache auth...
const STATUS_AUTHENTICATED
__construct(Container $dic, ilPlugin $plugin)
const APACHE_AUTH_TYPE_BY_FUNCTION
const APACHE_AUTH_TYPE_EXTENDED_MAPPING
setAuthenticatedUserId(int $a_id)
Auth status implementation.
const STATUS_ACCOUNT_MIGRATION_REQUIRED