Code Coverage |
||||||||||
Classes and Traits |
Functions and Methods |
Lines |
||||||||
Total | |
0.00% |
0 / 1 |
|
0.00% |
0 / 7 |
CRAP | |
0.00% |
0 / 39 |
UserStorage | |
0.00% |
0 / 1 |
|
0.00% |
0 / 7 |
90 | |
0.00% |
0 / 39 |
__construct | |
0.00% |
0 / 1 |
2 | |
0.00% |
0 / 3 |
|||
createInstance | |
0.00% |
0 / 1 |
2 | |
0.00% |
0 / 9 |
|||
doSaveFieldItems | |
0.00% |
0 / 1 |
6 | |
0.00% |
0 / 6 |
|||
isColumnSerial | |
0.00% |
0 / 1 |
6 | |
0.00% |
0 / 2 |
|||
updateLastLoginTimestamp | |
0.00% |
0 / 1 |
2 | |
0.00% |
0 / 6 |
|||
updateLastAccessTimestamp | |
0.00% |
0 / 1 |
2 | |
0.00% |
0 / 8 |
|||
deleteRoleReferences | |
0.00% |
0 / 1 |
2 | |
0.00% |
0 / 5 |
<?php | |
/** | |
* @file | |
* Contains \Drupal\user\UserStorage. | |
*/ | |
namespace Drupal\user; | |
use Drupal\Core\Database\Connection; | |
use Drupal\Core\Cache\CacheBackendInterface; | |
use Drupal\Core\Entity\ContentEntityInterface; | |
use Drupal\Core\Entity\EntityManagerInterface; | |
use Drupal\Core\Entity\EntityTypeInterface; | |
use Drupal\Core\Entity\Sql\SqlContentEntityStorage; | |
use Drupal\Core\Password\PasswordInterface; | |
use Drupal\Core\Session\AccountInterface; | |
use Drupal\Core\Language\LanguageManagerInterface; | |
use Symfony\Component\DependencyInjection\ContainerInterface; | |
/** | |
* Controller class for users. | |
* | |
* This extends the Drupal\Core\Entity\Sql\SqlContentEntityStorage class, | |
* adding required special handling for user objects. | |
*/ | |
class UserStorage extends SqlContentEntityStorage implements UserStorageInterface { | |
/** | |
* Provides the password hashing service object. | |
* | |
* @var \Drupal\Core\Password\PasswordInterface | |
*/ | |
protected $password; | |
/** | |
* Constructs a new UserStorage object. | |
* | |
* @param \Drupal\Core\Entity\EntityTypeInterface $entity_type | |
* The entity type definition. | |
* @param \Drupal\Core\Database\Connection $database | |
* The database connection to be used. | |
* @param \Drupal\Core\Entity\EntityManagerInterface $entity_manager | |
* The entity manager. | |
* @param \Drupal\Core\Cache\CacheBackendInterface $cache_backend | |
* Cache backend instance to use. | |
* @param \Drupal\Core\Password\PasswordInterface $password | |
* The password hashing service. | |
* @param \Drupal\Core\Language\LanguageManagerInterface $language_manager | |
* The language manager. | |
*/ | |
public function __construct(EntityTypeInterface $entity_type, Connection $database, EntityManagerInterface $entity_manager, CacheBackendInterface $cache, PasswordInterface $password, LanguageManagerInterface $language_manager) { | |
parent::__construct($entity_type, $database, $entity_manager, $cache, $language_manager); | |
$this->password = $password; | |
} | |
/** | |
* {@inheritdoc} | |
*/ | |
public static function createInstance(ContainerInterface $container, EntityTypeInterface $entity_type) { | |
return new static( | |
$entity_type, | |
$container->get('database'), | |
$container->get('entity.manager'), | |
$container->get('cache.entity'), | |
$container->get('password'), | |
$container->get('language_manager') | |
); | |
} | |
/** | |
* {@inheritdoc} | |
*/ | |
protected function doSaveFieldItems(ContentEntityInterface $entity, array $names = []) { | |
// The anonymous user account is saved with the fixed user ID of 0. | |
// Therefore we need to check for NULL explicitly. | |
if ($entity->id() === NULL) { | |
$entity->uid->value = $this->database->nextId($this->database->query('SELECT MAX(uid) FROM {users}')->fetchField()); | |
$entity->enforceIsNew(); | |
} | |
return parent::doSaveFieldItems($entity, $names); | |
} | |
/** | |
* {@inheritdoc} | |
*/ | |
protected function isColumnSerial($table_name, $schema_name) { | |
// User storage does not use a serial column for the user id. | |
return $table_name == $this->revisionTable && $schema_name == $this->revisionKey; | |
} | |
/** | |
* {@inheritdoc} | |
*/ | |
public function updateLastLoginTimestamp(UserInterface $account) { | |
$this->database->update('users_field_data') | |
->fields(array('login' => $account->getLastLoginTime())) | |
->condition('uid', $account->id()) | |
->execute(); | |
// Ensure that the entity cache is cleared. | |
$this->resetCache(array($account->id())); | |
} | |
/** | |
* {@inheritdoc} | |
*/ | |
public function updateLastAccessTimestamp(AccountInterface $account, $timestamp) { | |
$this->database->update('users_field_data') | |
->fields(array( | |
'access' => $timestamp, | |
)) | |
->condition('uid', $account->id()) | |
->execute(); | |
// Ensure that the entity cache is cleared. | |
$this->resetCache(array($account->id())); | |
} | |
/** | |
* {@inheritdoc} | |
*/ | |
public function deleteRoleReferences(array $rids) { | |
// Remove the role from all users. | |
$this->database->delete('user__roles') | |
->condition('roles_target_id', $rids) | |
->execute(); | |
$this->resetCache(); | |
} | |
} |