EntityTypeInfo.php

Same filename in this branch
  1. 11.x core/modules/content_moderation/src/EntityTypeInfo.php
  2. 11.x core/modules/workspaces/src/EntityTypeInfo.php
Same filename in other branches
  1. 9 core/modules/content_moderation/src/EntityTypeInfo.php
  2. 9 core/modules/workspaces/src/EntityTypeInfo.php
  3. 8.9.x core/modules/content_moderation/src/EntityTypeInfo.php
  4. 8.9.x core/modules/workspaces/src/EntityTypeInfo.php
  5. 10 core/modules/content_moderation/src/EntityTypeInfo.php
  6. 10 core/modules/workspaces/src/EntityTypeInfo.php

Namespace

Drupal\workspaces\Hook

File

core/modules/workspaces/src/Hook/EntityTypeInfo.php

View source
<?php

declare (strict_types=1);
namespace Drupal\workspaces\Hook;

use Drupal\Core\Entity\EntityPublishedInterface;
use Drupal\Core\Entity\EntityTypeInterface;
use Drupal\Core\Field\BaseFieldDefinition;
use Drupal\Core\Hook\Attribute\Hook;
use Drupal\Core\StringTranslation\TranslatableMarkup;
use Drupal\workspaces\Entity\Handler\BlockContentWorkspaceHandler;
use Drupal\workspaces\Entity\Handler\DefaultWorkspaceHandler;
use Drupal\workspaces\Entity\Handler\IgnoredWorkspaceHandler;
use Drupal\workspaces\WorkspaceInformationInterface;

/**
 * Defines a class for reacting to entity type information hooks.
 *
 * This class contains primarily compile-time or cache-clear-time hooks. Runtime
 * hooks should be placed in EntityOperations.
 */
class EntityTypeInfo {
    public function __construct(WorkspaceInformationInterface $workspaceInfo) {
    }
    
    /**
     * Implements hook_entity_type_build().
     *
     * Adds workspace support info to eligible entity types.
     */
    public function entityTypeBuild(array &$entity_types) : void {
        foreach ($entity_types as $entity_type) {
            if ($entity_type->hasHandlerClass('workspace')) {
                continue;
            }
            // Revisionable and publishable entity types are always supported.
            if ($entity_type->entityClassImplements(EntityPublishedInterface::class) && $entity_type->isRevisionable()) {
                $entity_type->setHandlerClass('workspace', DefaultWorkspaceHandler::class);
                // Support for custom blocks has to be determined on a per-entity
                // basis.
                if ($entity_type->id() === 'block_content') {
                    $entity_type->setHandlerClass('workspace', BlockContentWorkspaceHandler::class);
                }
            }
            // The 'file' entity type is allowed to perform CRUD operations inside a
            // workspace without being tracked.
            if ($entity_type->id() === 'file') {
                $entity_type->setHandlerClass('workspace', IgnoredWorkspaceHandler::class);
            }
            // Internal entity types are allowed to perform CRUD operations inside a
            // workspace.
            if ($entity_type->isInternal()) {
                $entity_type->setHandlerClass('workspace', IgnoredWorkspaceHandler::class);
            }
        }
    }
    
    /**
     * Implements hook_entity_type_alter().
     *
     * Adds workspace configuration to appropriate entity types.
     */
    public function entityTypeAlter(array &$entity_types) : void {
        foreach ($entity_types as $entity_type) {
            if (!$this->workspaceInfo
                ->isEntityTypeSupported($entity_type)) {
                continue;
            }
            // Workspace-support status has been declared in the "build" phase, now we
            // can use that information and add additional configuration in the
            // "alter" phase.
            $entity_type->addConstraint('EntityWorkspaceConflict');
            $entity_type->setRevisionMetadataKey('workspace', 'workspace');
            // Non-default workspaces display the active revision on the canonical
            // route of an entity, so the latest version route is no longer needed.
            $link_templates = $entity_type->get('links');
            unset($link_templates['latest-version']);
            $entity_type->set('links', $link_templates);
        }
    }
    
    /**
     * Implements hook_field_info_alter().
     */
    public function fieldInfoAlter(array &$definitions) : void {
        if (isset($definitions['entity_reference'])) {
            $definitions['entity_reference']['constraints']['EntityReferenceSupportedNewEntities'] = [];
        }
        // Allow path aliases to be changed in workspace-specific pending revisions.
        if (isset($definitions['path'])) {
            unset($definitions['path']['constraints']['PathAlias']);
        }
    }
    
    /**
     * Implements hook_entity_base_field_info().
     */
    public function entityBaseFieldInfo(EntityTypeInterface $entity_type) : array {
        if ($this->workspaceInfo
            ->isEntityTypeSupported($entity_type)) {
            $field_name = $entity_type->getRevisionMetadataKey('workspace');
            $fields[$field_name] = BaseFieldDefinition::create('entity_reference')->setLabel(new TranslatableMarkup('Workspace'))
                ->setDescription(new TranslatableMarkup('Indicates the workspace that this revision belongs to.'))
                ->setSetting('target_type', 'workspace')
                ->setInternal(TRUE)
                ->setTranslatable(FALSE)
                ->setRevisionable(TRUE);
            return $fields;
        }
        return [];
    }

}

Classes

Title Deprecated Summary
EntityTypeInfo Defines a class for reacting to entity type information hooks.

Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.