View source
<?php
namespace Drupal\workbench_access;
use Drupal\Core\Config\ConfigFactoryInterface;
use Drupal\Core\Entity\ContentEntityInterface;
use Drupal\Core\Entity\EntityTypeManagerInterface;
use Drupal\Core\Plugin\ContainerFactoryPluginInterface;
use Drupal\Core\Plugin\PluginWithFormsTrait;
use Drupal\workbench_access\Entity\AccessSchemeInterface;
use Drupal\workbench_access\Plugin\views\filter\Section;
use Drupal\Component\Plugin\PluginBase;
use Drupal\Core\Access\AccessResult;
use Drupal\Core\Database\Query\Condition;
use Drupal\Core\Entity\EntityInterface;
use Drupal\Core\Form\FormStateInterface;
use Drupal\Core\Session\AccountInterface;
use Drupal\Core\StringTranslation\StringTranslationTrait;
use Symfony\Component\DependencyInjection\ContainerInterface;
abstract class AccessControlHierarchyBase extends PluginBase implements AccessControlHierarchyInterface, ContainerFactoryPluginInterface {
use PluginWithFormsTrait;
use StringTranslationTrait;
protected $configFactory;
protected $tree;
protected $userSectionStorage;
protected $config;
protected $entityTypeManager;
public function __construct(array $configuration, $plugin_id, $plugin_definition, UserSectionStorageInterface $user_section_storage, ConfigFactoryInterface $configFactory, EntityTypeManagerInterface $entityTypeManager) {
parent::__construct($configuration, $plugin_id, $plugin_definition);
$this->config = $configFactory
->get('workbench_access.settings');
$this->userSectionStorage = $user_section_storage;
$this->entityTypeManager = $entityTypeManager;
$this
->setConfiguration($configuration);
}
public static function create(ContainerInterface $container, array $configuration, $plugin_id, $plugin_definition) {
return new static($configuration, $plugin_id, $plugin_definition, $container
->get('workbench_access.user_section_storage'), $container
->get('config.factory'), $container
->get('entity_type.manager'));
}
public function setConfiguration(array $configuration) {
$this->configuration = $configuration + $this
->defaultConfiguration();
}
public function defaultConfiguration() {
return [];
}
public function getConfiguration() {
return $this->configuration;
}
public function id() {
return $this->pluginDefinition['id'];
}
public function label() {
return $this->pluginDefinition['label'];
}
public function entityType() {
return $this->pluginDefinition['entity'];
}
public function calculateDependencies() {
return [];
}
public function getTree() {
return [];
}
public function resetTree() {
unset($this->tree);
}
public function load($id) {
if (!isset($this->tree)) {
$this->tree = $this
->getTree();
}
foreach ($this->tree as $parent => $data) {
if (isset($data[$id])) {
return $data[$id];
}
}
}
public function checkEntityAccess(AccessSchemeInterface $scheme, EntityInterface $entity, $op, AccountInterface $account) {
if (!$this
->applies($entity
->getEntityTypeId(), $entity
->bundle())) {
return AccessResult::neutral();
}
$entity_sections = $this
->getEntityValues($entity);
$deny_on_empty = $this->config
->get('deny_on_empty');
if (!$deny_on_empty && empty($entity_sections)) {
return AccessResult::neutral();
}
$user_sections = $this->userSectionStorage
->getUserSections($scheme, $account);
if (empty($user_sections)) {
return AccessResult::forbidden();
}
if (WorkbenchAccessManager::checkTree($scheme, $entity_sections, $user_sections)) {
return AccessResult::neutral();
}
return AccessResult::forbidden();
}
public function disallowedOptions($field) {
$options = [];
if (isset($field['widget']['#default_value']) && isset($field['widget']['#options'])) {
if (is_array($field['widget']['#default_value'])) {
$default_value_array = array_flip($field['widget']['#default_value']);
}
else {
$default_value_array = [
$field['widget']['#default_value'] => $field['widget']['#default_value'],
];
}
$options = array_diff_key($default_value_array, $field['widget']['#options']);
}
return array_keys($options);
}
public function getApplicableFields($entity_type, $bundle) {
return [];
}
public static function submitEntity(array &$form, FormStateInterface $form_state) {
foreach (\Drupal::entityTypeManager()
->getStorage('access_scheme')
->loadMultiple() as $access_scheme) {
$scheme = $access_scheme
->getAccessScheme();
$hidden_values = $form_state
->getValue('workbench_access_disallowed');
if (!empty($hidden_values)) {
$entity = $form_state
->getFormObject()
->getEntity();
$scheme
->massageFormValues($entity, $form_state, $hidden_values);
}
}
}
public function getViewsJoin($entity_type, $key, $alias = NULL) {
return [];
}
public function addWhere(Section $filter, array $values) {
$join_data = $this
->getViewsJoin($filter
->getEntityType(), $filter->realField);
if (count($join_data) == 1) {
$filter->query
->addWhere($filter->options['group'], "{$filter->tableAlias}.{$filter->realField}", array_values($values), $filter->operator);
}
else {
$or = new Condition('OR');
foreach ($join_data as $field => $data) {
$alias = $data['table_alias'] . '.' . $data['real_field'];
$or
->condition($alias, array_values($values), $filter->operator);
}
$filter->query
->addWhere($filter->options['group'], $or);
}
}
public function viewsData(array &$data, AccessSchemeInterface $scheme) {
}
public function massageFormValues(ContentEntityInterface $entity, FormStateInterface $form_state, array $hidden_values) {
}
public function buildConfigurationForm(array $form, FormStateInterface $form_state) {
return [];
}
public function submitConfigurationForm(array &$form, FormStateInterface $form_state) {
}
public function validateConfigurationForm(array &$form, FormStateInterface $form_state) {
}
public function onDependencyRemoval(array $dependencies) {
return FALSE;
}
public function alterForm(AccessSchemeInterface $scheme, array &$form, FormStateInterface &$form_state, ContentEntityInterface $entity) {
}
}