Mercurial > hg > isophonics-drupal-site
diff core/modules/user/src/UserStorageSchema.php @ 0:4c8ae668cc8c
Initial import (non-working)
author | Chris Cannam |
---|---|
date | Wed, 29 Nov 2017 16:09:58 +0000 |
parents | |
children | 129ea1e6d783 |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/core/modules/user/src/UserStorageSchema.php Wed Nov 29 16:09:58 2017 +0000 @@ -0,0 +1,69 @@ +<?php + +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'] += [ + 'user__name' => ['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; + } + +}