You are here

protected function NodeStorageSchema::getEntitySchema in Zircon Profile 8

Same name and namespace in other branches
  1. 8.0 core/modules/node/src/NodeStorageSchema.php \Drupal\node\NodeStorageSchema::getEntitySchema()

Gets the entity schema for the specified entity type.

Entity types may override this method in order to optimize the generated schema of the entity tables. However, only cross-field optimizations should be added here; e.g., an index spanning multiple fields. Optimizations that apply to a single field have to be added via SqlContentEntityStorageSchema::getSharedTableFieldSchema() instead.

Parameters

\Drupal\Core\Entity\ContentEntityTypeInterface $entity_type: The entity type definition.

bool $reset: (optional) If set to TRUE static cache will be ignored and a new schema array generation will be performed. Defaults to FALSE.

Return value

array A Schema API array describing the entity schema, excluding dedicated field tables.

Throws

\Drupal\Core\Field\FieldException

Overrides SqlContentEntityStorageSchema::getEntitySchema

File

core/modules/node/src/NodeStorageSchema.php, line 22
Contains \Drupal\node\NodeStorageSchema.

Class

NodeStorageSchema
Defines the node schema handler.

Namespace

Drupal\node

Code

protected function getEntitySchema(ContentEntityTypeInterface $entity_type, $reset = FALSE) {
  $schema = parent::getEntitySchema($entity_type, $reset);
  $schema['node_field_data']['indexes'] += array(
    'node__frontpage' => array(
      'promote',
      'status',
      'sticky',
      'created',
    ),
    'node__status_type' => array(
      'status',
      'type',
      'nid',
    ),
    'node__title_type' => array(
      'title',
      array(
        'type',
        4,
      ),
    ),
  );
  return $schema;
}