Code Coverage |
||||||||||
Classes and Traits |
Functions and Methods |
Lines |
||||||||
| Total | |
0.00% |
0 / 1 |
|
0.00% |
0 / 3 |
CRAP | |
0.00% |
0 / 29 |
| UserStorageSchema | |
0.00% |
0 / 1 |
|
0.00% |
0 / 3 |
90 | |
0.00% |
0 / 29 |
| getEntitySchema | |
0.00% |
0 / 1 |
2 | |
0.00% |
0 / 6 |
|||
| processIdentifierSchema | |
0.00% |
0 / 1 |
6 | |
0.00% |
0 / 4 |
|||
| getSharedTableFieldSchema | |
0.00% |
0 / 1 |
42 | |
0.00% |
0 / 19 |
|||
| <?php | |
| /** | |
| * @file | |
| * Contains \Drupal\user\UserStorageSchema. | |
| */ | |
| namespace Drupal\user; | |
| use Drupal\Core\Entity\ContentEntityTypeInterface; | |
| use Drupal\Core\Entity\Sql\SqlContentEntityStorageSchema; | |
| use Drupal\Core\Field\FieldStorageDefinitionInterface; | |
| /** | |
| * Defines the user schema handler. | |
| */ | |
| class UserStorageSchema extends SqlContentEntityStorageSchema { | |
| /** | |
| * {@inheritdoc} | |
| */ | |
| protected function getEntitySchema(ContentEntityTypeInterface $entity_type, $reset = FALSE) { | |
| $schema = parent::getEntitySchema($entity_type, $reset); | |
| $schema['users_field_data']['unique keys'] += array( | |
| 'user__name' => array('name', 'langcode'), | |
| ); | |
| return $schema; | |
| } | |
| /** | |
| * {@inheritdoc} | |
| */ | |
| protected function processIdentifierSchema(&$schema, $key) { | |
| // The "users" table does not use serial identifiers. | |
| if ($key != $this->entityType->getKey('id')) { | |
| parent::processIdentifierSchema($schema, $key); | |
| } | |
| } | |
| /** | |
| * {@inheritdoc} | |
| */ | |
| protected function getSharedTableFieldSchema(FieldStorageDefinitionInterface $storage_definition, $table_name, array $column_mapping) { | |
| $schema = parent::getSharedTableFieldSchema($storage_definition, $table_name, $column_mapping); | |
| $field_name = $storage_definition->getName(); | |
| if ($table_name == 'users_field_data') { | |
| switch ($field_name) { | |
| case 'name': | |
| // Improves the performance of the user__name index defined | |
| // in getEntitySchema(). | |
| $schema['fields'][$field_name]['not null'] = TRUE; | |
| // Make sure the field is no longer than 191 characters so we can | |
| // add a unique constraint in MySQL. | |
| $schema['fields'][$field_name]['length'] = USERNAME_MAX_LENGTH; | |
| break; | |
| case 'mail': | |
| $this->addSharedTableFieldIndex($storage_definition, $schema); | |
| break; | |
| case 'access': | |
| case 'created': | |
| $this->addSharedTableFieldIndex($storage_definition, $schema, TRUE); | |
| break; | |
| } | |
| } | |
| return $schema; | |
| } | |
| } |