Dans Drupal 8, vous pouvez charger une entité avec:
$node = \Drupal::entityManager()->getStorage('node')->load(123);
Cela recherche les définitions d'entité et constate que le nœud est défini par Drupal \ node \ Entity \ Node - donc (je suppose) Drupal \ node \ NodeStorage instanciera une nouvelle instance Drupal \ node \ Entity \ Node .
Ce que j'aimerais réaliser, c'est sous- classer Drupal \ node \ Entity \ Node et pouvoir instancier cette sous-classe quand c'est approprié. Par exemple, si j'ai un article sur un ensemble de nœuds, il y aurait une classe:
namespace Drupal\my_module\Entity\Article;
class Article extends Drupal\node\Entity\Node {
}
Et j'appellerais:
$node = \Drupal::entityManager()->getStorage('node_article')->load(123);
Et le retour serait ma Article
sous - classe.
Je peux y parvenir en créant un nouveau type d'entité et en le reliant à une autre définition d'entité existante, par exemple l'exemple d'article de nœud serait cette classe:
namespace Drupal\my_module\Entity;
use Drupal\node\Entity\Node;
/**
* @ContentEntityType(
* id = "node_article",
* label = @Translation("Content"),
* bundle_label = @Translation("Content type"),
* handlers = {
* "storage" = "Drupal\node\NodeStorage",
* "storage_schema" = "Drupal\node\NodeStorageSchema",
* "view_builder" = "Drupal\node\NodeViewBuilder",
* "access" = "Drupal\node\NodeAccessControlHandler",
* "views_data" = "Drupal\node\NodeViewsData",
* "form" = {
* "default" = "Drupal\node\NodeForm",
* "delete" = "Drupal\node\Form\NodeDeleteForm",
* "edit" = "Drupal\node\NodeForm"
* },
* "route_provider" = {
* "html" = "Drupal\node\Entity\NodeRouteProvider",
* },
* "list_builder" = "Drupal\node\NodeListBuilder",
* "translation" = "Drupal\node\NodeTranslationHandler"
* },
* base_table = "node",
* data_table = "node_field_data",
* revision_table = "node_revision",
* revision_data_table = "node_field_revision",
* translatable = TRUE,
* list_cache_contexts = { "user.node_grants:view" },
* entity_keys = {
* "id" = "nid",
* "revision" = "vid",
* "bundle" = "type",
* "label" = "title",
* "langcode" = "langcode",
* "uuid" = "uuid",
* "status" = "status",
* "uid" = "uid",
* },
* bundle_entity_type = "node_type",
* field_ui_base_route = "entity.node_type.edit_form",
* common_reference_target = TRUE,
* permission_granularity = "bundle",
* links = {
* "canonical" = "/node/{node}",
* "delete-form" = "/node/{node}/delete",
* "edit-form" = "/node/{node}/edit",
* "version-history" = "/node/{node}/revisions",
* "revision" = "/node/{node}/revisions/{node_revision}/view",
* }
* )
*/
class Article extends Node { }
// Results my Article sub type.
$node = \Drupal::entityManager()->getStorage('node_article')->load(123);
Cela fonctionne bien (autant que je peux voir); cependant, ça sent. Il ajoute un nouveau type d'entité, ce qui n'est pas vrai et pourrait entraîner d'autres problèmes à l'avenir.
Comment définir une sous-classe pour un ensemble d'entités afin que le chargement de l'entité renvoie un objet de cette classe?
hook_entity_type_alter()
pour effectuer le changement plus proprement, mais je ne sais pas comment vous limiteriez cela à un ensemble spécifique