MenuLinkContentStorage.php

Same filename and directory in other branches
  1. 8.9.x core/modules/menu_link_content/src/MenuLinkContentStorage.php
  2. 10 core/modules/menu_link_content/src/MenuLinkContentStorage.php
  3. 11.x core/modules/menu_link_content/src/MenuLinkContentStorage.php

Namespace

Drupal\menu_link_content

File

core/modules/menu_link_content/src/MenuLinkContentStorage.php

View source
<?php

namespace Drupal\menu_link_content;

use Drupal\Core\Entity\Sql\SqlContentEntityStorage;

/**
 * Storage handler for menu_link_content entities.
 */
class MenuLinkContentStorage extends SqlContentEntityStorage implements MenuLinkContentStorageInterface {
  
  /**
   * {@inheritdoc}
   */
  public function getMenuLinkIdsWithPendingRevisions() {
    $table_mapping = $this->getTableMapping();
    $id_field = $table_mapping->getColumnNames($this->entityType
      ->getKey('id'))['value'];
    $revision_field = $table_mapping->getColumnNames($this->entityType
      ->getKey('revision'))['value'];
    $rta_field = $table_mapping->getColumnNames($this->entityType
      ->getKey('revision_translation_affected'))['value'];
    $langcode_field = $table_mapping->getColumnNames($this->entityType
      ->getKey('langcode'))['value'];
    $revision_default_field = $table_mapping->getColumnNames($this->entityType
      ->getRevisionMetadataKey('revision_default'))['value'];
    $query = $this->database
      ->select($this->getRevisionDataTable(), 'mlfr');
    $query->fields('mlfr', [
      $id_field,
    ]);
    $query->addExpression("MAX([mlfr].[{$revision_field}])", $revision_field);
    $query->join($this->getRevisionTable(), 'mlr', "[mlfr].[{$revision_field}] = [mlr].[{$revision_field}] AND [mlr].[{$revision_default_field}] = 0");
    $inner_select = $this->database
      ->select($this->getRevisionDataTable(), 't');
    $inner_select->condition("t.{$rta_field}", '1');
    $inner_select->fields('t', [
      $id_field,
      $langcode_field,
    ]);
    $inner_select->addExpression("MAX([t].[{$revision_field}])", $revision_field);
    $inner_select->groupBy("t.{$id_field}")
      ->groupBy("t.{$langcode_field}");
    $query->join($inner_select, 'mr', "[mlfr].[{$revision_field}] = [mr].[{$revision_field}] AND [mlfr].[{$langcode_field}] = [mr].[{$langcode_field}]");
    $query->groupBy("mlfr.{$id_field}");
    return $query->execute()
      ->fetchAllKeyed(1, 0);
  }

}

Classes

Title Deprecated Summary
MenuLinkContentStorage Storage handler for menu_link_content entities.

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