19 declare(strict_types=1);
46 if (!$this->
settings->get(
'apache_enable_auth',
'0')) {
47 $this->
getLogger()->info(
'Apache auth disabled.');
53 !$this->
settings->get(self::ENV_APACHE_AUTH_INDICATOR_NAME,
'') ||
54 !$this->
settings->get(
'apache_auth_indicator_value',
'')
56 $this->
getLogger()->warning(
'Apache auth indicator match failure.');
61 $validIndicatorValues = array_filter(
array_map(
63 str_getcsv($this->
settings->get(
'apache_auth_indicator_value',
''))
67 !isset(
$_SERVER[$this->
settings->get(self::ENV_APACHE_AUTH_INDICATOR_NAME,
'')]) ||
68 !in_array(
$_SERVER[$this->
settings->get(self::ENV_APACHE_AUTH_INDICATOR_NAME,
'')], $validIndicatorValues,
true)
70 $this->
getLogger()->warning(
'Apache authentication failed (indicator name <-> value');
82 $this->
getLogger()->info(
'No username given');
88 if ($this->
settings->get(self::APACHE_ENABLE_LDAP,
'0')) {
95 $this->
getLogger()->info(
'Cannot find user id for external account: ' . $this->
getCredentials()->getUsername());
107 $this->force_new_account =
true;
108 if ($this->
settings->get(self::APACHE_ENABLE_LDAP,
'0')) {
115 $this->force_new_account =
true;
116 if ($this->
settings->get(self::APACHE_ENABLE_LDAP,
'0')) {
128 $this->migration_account = $name;
138 if ($this->
settings->get(self::APACHE_LDAP_SID,
'0')) {
139 return 'ldap_' . $this->
settings->get(self::APACHE_LDAP_SID,
'');
148 (
int) $this->
settings->get(self::APACHE_LDAP_SID,
'0')
151 $this->
getLogger()->debug(
'Using ldap data source with server configuration: ' .
$server->getName());
155 $sync->setUserData([]);
156 $sync->forceCreation($this->force_new_account);
157 $sync->forceReadLdapData(
true);
160 $internal_account = $sync->sync();
161 $this->
getLogger()->debug(
'Internal account: ' . $internal_account);
163 $this->
getLogger()->info(
'Login failed with message: ' . $e->getMessage());
170 $this->
getLogger()->info(
'Login failed with message: ' . $e->getMessage());
175 $this->
getLogger()->info(
'Authentication failed: account migration required for external account: ' . $this->
getCredentials()->getUsername());
string $migration_account
migrateAccount(ilAuthStatus $status)
Create new account.
const ENV_APACHE_AUTH_INDICATOR_NAME
Interface of auth credentials.
static getInstanceByServerId(int $a_server_id)
Get instance by server id.
doAuthentication(ilAuthStatus $status)
Thrown in case of failed synchronisation settings.
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
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.
readonly ilSetting $settings
__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