Drupal 8.0.0 beta 12. More info: https://www.drupal.org/node/2514176
This commit is contained in:
		
						commit
						9921556621
					
				
					 13277 changed files with 1459781 additions and 0 deletions
				
			
		
							
								
								
									
										131
									
								
								core/modules/user/src/UserStorage.php
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										131
									
								
								core/modules/user/src/UserStorage.php
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,131 @@ | |||
| <?php | ||||
| 
 | ||||
| /** | ||||
|  * @file | ||||
|  * Contains \Drupal\user\UserStorage. | ||||
|  */ | ||||
| 
 | ||||
| namespace Drupal\user; | ||||
| 
 | ||||
| use Drupal\Core\Database\Connection; | ||||
| use Drupal\Core\Cache\CacheBackendInterface; | ||||
| use Drupal\Core\Entity\EntityInterface; | ||||
| 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} | ||||
|    */ | ||||
|   public function save(EntityInterface $entity) { | ||||
|     // 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::save($entity); | ||||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * {@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(); | ||||
|   } | ||||
| 
 | ||||
| } | ||||
		Reference in a new issue
	
	 Pantheon Automation
						Pantheon Automation