ContentEntityBase::preSave

public function ContentEntityBase::preSave

public ContentEntityBase::preSave(EntityStorageInterface $storage)

Acts on an entity before the presave hook is invoked.

Used before the entity is saved and before invoking the presave hook. Note that in case of translatable content entities this callback is only fired on their current translation. It is up to the developer to iterate over all translations if needed. This is different from its counterpart in the Field API, FieldItemListInterface::preSave(), which is fired on all field translations automatically. @todo Adjust existing implementations and the documentation according to https://www.drupal.org/node/2577609 to have a consistent API.

Parameters

\Drupal\Core\Entity\EntityStorageInterface $storage: The entity storage object.

Throws

\Exception When there is a problem that should prevent saving the entity.

Overrides Entity::preSave

See also

\Drupal\Core\Field\FieldItemListInterface::preSave()

File

core/lib/Drupal/Core/Entity/ContentEntityBase.php, line 348

Class

ContentEntityBase
Implements Entity Field API specific enhancements to the Entity class.

Namespace

Drupal\Core\Entity

Code

public function preSave(EntityStorageInterface $storage) {
  // An entity requiring validation should not be saved if it has not been
  // actually validated.
  if ($this->validationRequired && !$this->validated) {
    // @todo Make this an assertion in https://www.drupal.org/node/2408013.
    throw new \LogicException('Entity validation was skipped.');
  }
  else {
    $this->validated = FALSE;
  }

  parent::preSave($storage);
}

© 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!ContentEntityBase.php/function/ContentEntityBase::preSave/8.1.x

在线笔记
App下载
App下载

扫描二维码

下载编程狮App

公众号
微信公众号

编程狮公众号

意见反馈
返回顶部