ifthenelse-8.x-1.x-dev-no-core/modules/contrib/if_then_else/src/core/Nodes/Conditions/UserHasEntityFieldAccessCondition/UserHasEntityFieldAccessCondition.php

modules/contrib/if_then_else/src/core/Nodes/Conditions/UserHasEntityFieldAccessCondition/UserHasEntityFieldAccessCondition.php
<?php

namespace Drupal\if_then_else\core\Nodes\Conditions\UserHasEntityFieldAccessCondition;

use Drupal\if_then_else\core\Nodes\Conditions\Condition;
use Drupal\if_then_else\Event\NodeSubscriptionEvent;
use Drupal\if_then_else\Event\NodeValidationEvent;

/**
 * User has entity field access condition class.
 */
class UserHasEntityFieldAccessCondition extends Condition {

  /**
   * {@inheritdoc}
   */
  public static function getName() {
    return 'user_has_entity_field_access_condition';
  }

  /**
   * {@inheritdoc}
   */
  public function registerNode(NodeSubscriptionEvent $event) {
    // Fetch all fields for config entity bundles.
    $if_then_else_utilities = \Drupal::service('ifthenelse.utilities');
    $form_entity_info = $if_then_else_utilities->getContentEntitiesAndBundles();
    $form_fields = $if_then_else_utilities->getFieldsByEntityBundleId($form_entity_info);
    $event->nodes[static::getName()] = [
      'label' => t('User Has Entity Field Access'),
      'type' => 'condition',
      'class' => 'Drupal\\if_then_else\\core\\Nodes\\Conditions\\UserHasEntityFieldAccessCondition\\UserHasEntityFieldAccessCondition',
      'library' => 'if_then_else/UserHasEntityFieldAccessCondition',
      'control_class_name' => 'UserHasEntityFieldAccessConditionControl',
      'form_fields' => $form_fields,
      'opt_options' => [
        ['code' => 'view', 'name' => 'View'],
        ['code' => 'edit', 'name' => 'Edit'],
      ],
      'inputs' => [
        'entity' => [
          'label' => t('Entity'),
          'description' => t('The entity to check access on.'),
          'sockets' => ['object.entity'],
          'required' => TRUE,
        ],
        'user' => [
          'label' => t('User'),
          'description' => t('The user account to check access against.'),
          'sockets' => ['object.entity.user'],
          'required' => TRUE,
        ],
      ],
      'outputs' => [
        'success' => [
          'label' => t('Success'),
          'description' => t('TRUE if the user has access to the field on the entity, FALSE otherwise.'),
          'socket' => 'bool',
        ],
      ],
    ];
  }

  /**
   * {@inheritdoc}
   */
  public function validateNode(NodeValidationEvent $event) {
    $data = $event->node->data;
    if (empty($data->form_fields)|| empty($data->opt_form_fields)) {
      $event->errors[] = t('Select both field and operation in "@node_name".', ['@node_name' => $event->node->name]);
    }
  }

  /**
   * {@inheritdoc}
   */
  public function process() {
    $entity = $this->inputs['entity'];
    $user = $this->inputs['user'];

    $selected_field = $this->data->form_fields[0]->code;
    $selected_operation = $this->data->opt_form_fields[0]->code;
    if (!$entity->hasField($selected_field)) {
      $this->outputs['success'] =  FALSE;
      return;
    }

    $access = \Drupal::entityTypeManager()->getAccessControlHandler($entity->getEntityTypeId());
    if(!$access->access($entity, $selected_operation, $user)){
      $this->outputs['success'] =  FALSE;
      return;
    }
    $definition = $entity->getFieldDefinition($selected_field);
    $items = $entity->get($selected_field);

    if ($access->fieldAccess($selected_operation, $definition, $user, $items)) {
      $this->outputs['success'] =  TRUE;
      return;
    }

  }

}

Главная | Обратная связь

drupal hosting | друпал хостинг | it patrol .inc