eca-1.0.x-dev/modules/content/src/Plugin/EntitySaveTrait.php

modules/content/src/Plugin/EntitySaveTrait.php
<?php

namespace Drupal\eca_content\Plugin;

use Drupal\Component\Plugin\Exception\InvalidPluginDefinitionException;
use Drupal\Component\Plugin\Exception\PluginNotFoundException;
use Drupal\Core\Entity\EntityInterface;
use Drupal\eca\EntityOriginalTrait;

/**
 * Trait for saving an entity within ECA operations.
 */
trait EntitySaveTrait {

  use EntityOriginalTrait;

  /**
   * Saves an entity.
   *
   * @param \Drupal\Core\Entity\EntityInterface $entity
   *   The entity to save.
   *
   * @return int|null
   *   Either SAVED_NEW or SAVED_UPDATED, depending on the operation performed.
   *   Returns NULL when no saving was performed at all.
   *
   * @throws \Drupal\Core\Entity\EntityStorageException
   *   In case of failures an exception is thrown.
   */
  protected function saveEntity(EntityInterface $entity): ?int {
    // For nested updates, the original object may need a refresh.
    // @see https://www.drupal.org/project/eca/issues/3331810
    $original = $this->getOriginal($entity);
    if (isset($original) && !$entity->isNew()) {
      // Behave the same as \Drupal\Core\Entity\EntityStorageBase::doPreSave.
      $id = $entity->getOriginalId() ?? $entity->id();
      // Don't check if $id is NULL because this is implied the entity not being
      // new.
      // @see https://www.drupal.org/project/eca/issues/3540487
      $etm = $this->entityTypeManager ?? \Drupal::entityTypeManager();
      try {
        $this->setOriginal($entity, $etm->getStorage($entity->getEntityTypeId())->loadUnchanged($id));
      }
      catch (InvalidPluginDefinitionException | PluginNotFoundException $e) {
        // This exception can not happen because the plugin is definitely
        // available, otherwise the $entity would be available either.
      }
    }

    return $entity->save();
  }

}

Главная | Обратная связь

drupal hosting | друпал хостинг | it patrol .inc