class ExternalAuth in External Authentication 8
Same name and namespace in other branches
- 2.0.x src/ExternalAuth.php \Drupal\externalauth\ExternalAuth
Class ExternalAuth.
@package Drupal\externalauth
Hierarchy
- class \Drupal\externalauth\ExternalAuth implements ExternalAuthInterface uses DeprecatedServicePropertyTrait
Expanded class hierarchy of ExternalAuth
1 file declares its use of ExternalAuth
- ExternalAuthTest.php in tests/
src/ Unit/ ExternalAuthTest.php
1 string reference to 'ExternalAuth'
1 service uses ExternalAuth
File
- src/
ExternalAuth.php, line 21
Namespace
Drupal\externalauthView source
class ExternalAuth implements ExternalAuthInterface {
use DeprecatedServicePropertyTrait;
/**
* {@inheritdoc}
*/
protected $deprecatedProperties = [
'entityManager' => 'entity.manager',
];
/**
* The entity type manager service.
*
* @var \Drupal\Core\Entity\EntityTypeManagerInterface
*/
protected $entityTypeManager;
/**
* The authmap service.
*
* @var \Drupal\externalauth\AuthmapInterface
*/
protected $authmap;
/**
* A logger instance.
*
* @var \Psr\Log\LoggerInterface
*/
protected $logger;
/**
* The event dispatcher.
*
* @var \Symfony\Component\EventDispatcher\EventDispatcherInterface
*/
protected $eventDispatcher;
/**
* {@inheritdoc}
*
* @param \Drupal\Core\Entity\EntityTypeManagerInterface $entity_type_manager
* The entity type manager service.
* @param AuthmapInterface $authmap
* The authmap service.
* @param \Psr\Log\LoggerInterface $logger
* A logger instance.
* @param \Symfony\Component\EventDispatcher\EventDispatcherInterface $event_dispatcher
* The event dispatcher.
*/
public function __construct(EntityTypeManagerInterface $entity_type_manager, AuthmapInterface $authmap, LoggerInterface $logger, EventDispatcherInterface $event_dispatcher) {
$this->entityTypeManager = $entity_type_manager;
$this->authmap = $authmap;
$this->logger = $logger;
$this->eventDispatcher = $event_dispatcher;
}
/**
* {@inheritdoc}
*/
public function load($authname, $provider) {
if ($uid = $this->authmap
->getUid($authname, $provider)) {
return $this->entityTypeManager
->getStorage('user')
->load($uid);
}
return FALSE;
}
/**
* {@inheritdoc}
*/
public function login($authname, $provider) {
$account = $this
->load($authname, $provider);
if ($account) {
return $this
->userLoginFinalize($account, $authname, $provider);
}
return FALSE;
}
/**
* {@inheritdoc}
*/
public function register($authname, $provider, array $account_data = [], $authmap_data = NULL) {
if (!empty($account_data['name'])) {
$username = $account_data['name'];
unset($account_data['name']);
}
else {
$username = $provider . '_' . $authname;
}
$authmap_event = $this->eventDispatcher
->dispatch(ExternalAuthEvents::AUTHMAP_ALTER, new ExternalAuthAuthmapAlterEvent($provider, $authname, $username, $authmap_data));
$entity_storage = $this->entityTypeManager
->getStorage('user');
$account_search = $entity_storage
->loadByProperties([
'name' => $authmap_event
->getUsername(),
]);
if ($account = reset($account_search)) {
throw new ExternalAuthRegisterException(sprintf('User could not be registered. There is already an account with username "%s"', $authmap_event
->getUsername()));
}
// Set up the account data to be used for the user entity.
$account_data = array_merge([
'name' => $authmap_event
->getUsername(),
'init' => $provider . '_' . $authmap_event
->getAuthname(),
'status' => 1,
'access' => 0,
], $account_data);
$account = $entity_storage
->create($account_data);
$account
->enforceIsNew();
$account
->save();
$this->authmap
->save($account, $provider, $authmap_event
->getAuthname(), $authmap_event
->getData());
$this->eventDispatcher
->dispatch(ExternalAuthEvents::REGISTER, new ExternalAuthRegisterEvent($account, $provider, $authmap_event
->getAuthname(), $authmap_event
->getData()));
$this->logger
->notice('External registration of user %name from provider %provider and authname %authname', [
'%name' => $account
->getAccountName(),
'%provider' => $provider,
'%authname' => $authname,
]);
return $account;
}
/**
* {@inheritdoc}
*/
public function loginRegister($authname, $provider, array $account_data = [], $authmap_data = NULL) {
$account = $this
->login($authname, $provider);
if (!$account) {
$account = $this
->register($authname, $provider, $account_data, $authmap_data);
return $this
->userLoginFinalize($account, $authname, $provider);
}
return $account;
}
/**
* {@inheritdoc}
*
* @codeCoverageIgnore
*/
public function userLoginFinalize(UserInterface $account, $authname, $provider) {
user_login_finalize($account);
$this->logger
->notice('External login of user %name', [
'%name' => $account
->getAccountName(),
]);
$this->eventDispatcher
->dispatch(ExternalAuthEvents::LOGIN, new ExternalAuthLoginEvent($account, $provider, $authname));
return $account;
}
/**
* {@inheritdoc}
*/
public function linkExistingAccount($authname, $provider, UserInterface $account) {
// If a mapping (for the same provider) to this account already exists, we
// silently skip saving this auth mapping.
if (!$this->authmap
->get($account
->id(), $provider)) {
$authmap_event = $this->eventDispatcher
->dispatch(ExternalAuthEvents::AUTHMAP_ALTER, new ExternalAuthAuthmapAlterEvent($provider, $authname, $account
->getAccountName(), NULL));
$this->authmap
->save($account, $provider, $authmap_event
->getAuthname(), $authmap_event
->getData());
}
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
DeprecatedServicePropertyTrait:: |
public | function | Allows to access deprecated/removed properties. | |
ExternalAuth:: |
protected | property | The authmap service. | |
ExternalAuth:: |
protected | property | ||
ExternalAuth:: |
protected | property | The entity type manager service. | |
ExternalAuth:: |
protected | property | The event dispatcher. | |
ExternalAuth:: |
protected | property | A logger instance. | |
ExternalAuth:: |
public | function |
Link a pre-existing Drupal user to a given authname. Overrides ExternalAuthInterface:: |
|
ExternalAuth:: |
public | function |
Load a Drupal user based on an external authname. Overrides ExternalAuthInterface:: |
|
ExternalAuth:: |
public | function |
Log a Drupal user in based on an external authname. Overrides ExternalAuthInterface:: |
|
ExternalAuth:: |
public | function |
Login and optionally register a Drupal user based on an external authname. Overrides ExternalAuthInterface:: |
|
ExternalAuth:: |
public | function |
Register a Drupal user based on an external authname. Overrides ExternalAuthInterface:: |
|
ExternalAuth:: |
public | function |
@codeCoverageIgnore Overrides ExternalAuthInterface:: |
|
ExternalAuth:: |
public | function |