W3cubDocs

/Drupal 8

protected function ContentEntityStorageBase::doSave

protected ContentEntityStorageBase::doSave($id, EntityInterface $entity)

Performs storage-specific saving of the entity.

Parameters

int|string $id: The original entity ID.

\Drupal\Core\Entity\EntityInterface $entity: The entity to save.

Return value

bool|int If the record insert or update failed, returns FALSE. If it succeeded, returns SAVED_NEW or SAVED_UPDATED, depending on the operation performed.

Overrides EntityStorageBase::doSave

File

core/lib/Drupal/Core/Entity/ContentEntityStorageBase.php, line 244

Class

ContentEntityStorageBase
Base class for content entity storage handlers.

Namespace

Drupal\Core\Entity

Code

protected function doSave($id, EntityInterface $entity) {
  /** @var \Drupal\Core\Entity\ContentEntityInterface $entity */

  if ($entity->isNew()) {
    // Ensure the entity is still seen as new after assigning it an id, while
    // storing its data.
    $entity->enforceIsNew();
    if ($this->entityType->isRevisionable()) {
      $entity->setNewRevision();
    }
    $return = SAVED_NEW;
  }
  else {
    // @todo Consider returning a different value when saving a non-default
    //   entity revision. See https://www.drupal.org/node/2509360.
    $return = $entity->isDefaultRevision() ? SAVED_UPDATED : FALSE;
  }

  $this->populateAffectedRevisionTranslations($entity);
  $this->doSaveFieldItems($entity);

  return $return;
}

© 2001–2016 by the original authors
Licensed under the GNU General Public License, version 2 and later.
Drupal is a registered trademark of Dries Buytaert.
https://api.drupal.org/api/drupal/core!lib!Drupal!Core!Entity!ContentEntityStorageBase.php/function/ContentEntityStorageBase::doSave/8.1.x