FileDelete.php in File Entity (fieldable files) 8.2
File
src/Plugin/Action/FileDelete.php
View source
<?php
namespace Drupal\file_entity\Plugin\Action;
use Drupal\Core\Access\AccessResult;
use Drupal\Core\Action\ActionBase;
use Drupal\Core\Plugin\ContainerFactoryPluginInterface;
use Drupal\Core\Session\AccountInterface;
use Drupal\Core\TempStore\PrivateTempStoreFactory;
use Drupal\file\FileInterface;
use Symfony\Component\DependencyInjection\ContainerInterface;
class FileDelete extends ActionBase implements ContainerFactoryPluginInterface {
protected $tempStore;
public function __construct(array $configuration, $plugin_id, $plugin_definition, PrivateTempStoreFactory $temp_store_factory) {
parent::__construct($configuration, $plugin_id, $plugin_definition);
$this->tempStore = $temp_store_factory
->get('file_multiple_delete_confirm');
}
public static function create(ContainerInterface $container, array $configuration, $plugin_id, $plugin_definition) {
return new static($configuration, $plugin_id, $plugin_definition, $container
->get('tempstore.private'));
}
public function execute($entity = NULL) {
$this
->executeMultiple(array(
$entity,
));
}
public function executeMultiple(array $entities) {
$entities_by_id = [];
foreach ($entities as $entity) {
$entities_by_id[$entity
->id()] = $entity;
}
$this->tempStore
->set('delete', $entities_by_id);
}
public function access($object, AccountInterface $account = NULL, $return_as_object = FALSE) {
$result = AccessResult::allowedIf($object instanceof FileInterface)
->andIf(AccessResult::allowedIf($object
->access('delete')));
return $return_as_object ? $result : $result
->isAllowed();
}
}