ILIAS  trunk Revision v11.0_alpha-1702-gfd3ecb7f852
All Data Structures Namespaces Files Functions Variables Enumerations Enumerator Modules Pages
class.ilAuthProviderShibboleth.php
Go to the documentation of this file.
1 <?php
2 
24 {
25  private ILIAS $ilias;
27 
29  {
30  global $DIC;
31  $this->ilias = $DIC['ilias'];
32  $this->settings = $DIC->settings();
33  parent::__construct($credentials);
34  }
35 
43  public function doAuthentication(ilAuthStatus $status): bool
44  {
45  $shib_server_data = shibServerData::getInstance();
46 
47  if ($shib_server_data->getLogin() !== '' && $shib_server_data->getLogin() !== '0') {
48  $shib_user = shibUser::buildInstance($shib_server_data);
49  // for backword compatibility of hook environment variables
50  $new_user = $shib_user->isNew(); // For shib_data_conv included Script
51  $settings = new ilShibbolethSettings();
52  $account_creation = $settings->getAccountCreation();
53  if (!$new_user) {
54  $shib_user->updateFields();
55  // Include custom code that can be used to further modify
56  // certain Shibboleth user attributes
57  if (
58  $this->ilias->getSetting('shib_data_conv') &&
59  $this->ilias->getSetting('shib_data_conv') !== '' &&
60  is_readable($this->ilias->getSetting('shib_data_conv'))
61  ) {
63  include($this->ilias->getSetting('shib_data_conv'));
64  }
65  $shib_user = ilShibbolethPluginWrapper::getInstance()->beforeUpdateUser($shib_user);
66  $shib_user->update();
67  $shib_user = ilShibbolethPluginWrapper::getInstance()->afterUpdateUser($shib_user);
69  } elseif ($account_creation !== ilShibbolethSettings::ACCOUNT_CREATION_DISABLED) {
70  $shib_user->createFields();
71  $shib_user->setPref('hits_per_page', $this->settings->get('hits_per_page'));
72 
73  // Modify user data before creating the user
74  // Include custom code that can be used to further modify
75  // certain Shibboleth user attributes
76  if (
77  $this->ilias->getSetting('shib_data_conv') &&
78  $this->ilias->getSetting('shib_data_conv', '') !== '' &&
79  is_readable($this->ilias->getSetting('shib_data_conv'))
80  ) {
82  include($this->ilias->getSetting('shib_data_conv'));
83  }
84  $shib_user = ilShibbolethPluginWrapper::getInstance()->beforeCreateUser($shib_user);
85  if ($account_creation === ilShibbolethSettings::ACCOUNT_CREATION_WITH_APPROVAL) {
86  $shib_user->setActive(false);
87  }
88  $shib_user->create();
89  $shib_user->saveAsNew();
90  $shib_user->updateOwner();
91  $shib_user->writePrefs();
92  $shib_user = ilShibbolethPluginWrapper::getInstance()->afterCreateUser($shib_user);
94  }
95 
96  if (!$new_user || $account_creation === ilShibbolethSettings::ACCOUNT_CREATION_ENABLED) {
98  $status->setAuthenticatedUserId(ilObjUser::_lookupId($shib_user->getLogin()));
99  } elseif ($account_creation === ilShibbolethSettings::ACCOUNT_CREATION_WITH_APPROVAL) {
101  $status->setReason('err_inactive');
102  } else {
104  $status->setReason('err_disabled');
105  }
106 
107  } else {
108  $this->getLogger()->info('Shibboleth authentication failed.');
109  $this->handleAuthenticationFail($status, 'err_wrong_login');
110  return false;
111  }
112 
113  return true;
114  }
115 }
Interface of auth credentials.
const STATUS_AUTHENTICATION_FAILED
Interface Observer Contains several chained tasks and infos about them.
static doAssignments(int $a_usr_id, array $a_data)
static _lookupId($a_user_str)
handleAuthenticationFail(ilAuthStatus $status, string $a_reason)
Handle failed authentication.
Base class for authentication providers (ldap, apache, ...)
setStatus(int $a_status)
Set auth status.
$_SERVER['HTTP_HOST']
Definition: raiseError.php:26
global $DIC
Definition: shib_login.php:22
ilAuthCredentials $credentials
static updateAssignments(int $a_usr_id, array $a_data)
Class ilObjForumAdministration.
static buildInstance(shibServerData $shibServerData)
getLogger()
Get logger.
$new_user
__construct(Container $dic, ilPlugin $plugin)
This file is part of ILIAS, a powerful learning management system published by ILIAS open source e-Le...
setReason(string $a_reason)
Set reason.
setAuthenticatedUserId(int $a_id)
Auth status implementation.
Class ilShibbolethSettings.
__construct(ilAuthCredentials $credentials)