public function SetUnpublishingDate::doExecute in Scheduler 2.x
Same name and namespace in other branches
- 8 scheduler_rules_integration/src/Plugin/RulesAction/SetUnpublishingDate.php \Drupal\scheduler_rules_integration\Plugin\RulesAction\SetUnpublishingDate::doExecute()
Set the unpublish_on date on the entity.
Parameters
\Drupal\Core\Entity\EntityInterface $entity: The entity to be scheduled for unpublishing.
int $date: The date for unpublishing.
File
- scheduler_rules_integration/src/ Plugin/ RulesAction/ SetUnpublishingDate.php, line 25 
Class
- SetUnpublishingDate
- Provides a 'Set date for scheduled unpublishing' action.
Namespace
Drupal\scheduler_rules_integration\Plugin\RulesActionCode
public function doExecute(EntityInterface $entity, $date) {
  $config = \Drupal::config('scheduler.settings');
  $bundle_field = $entity
    ->getEntityType()
    ->get('entity_keys')['bundle'];
  if ($entity->{$bundle_field}->entity
    ->getThirdPartySetting('scheduler', 'unpublish_enable', $config
    ->get('default_unpublish_enable'))) {
    $entity
      ->set('unpublish_on', $date);
    // When this action is invoked and it operates on the entity being edited
    // then hook_entity_presave() will be executed automatically. But if this
    // action is being used to schedule a different entity then we need to
    // call the functions directly here.
    scheduler_entity_presave($entity);
  }
  else {
    // The action cannot be executed because the content type is not enabled
    // for scheduled unpublishing.
    $this
      ->notEnabledWarning($entity, 'unpublish');
  }
}