function ContextHandlerIntegrityTrait::checkContextConfigIntegrity

Performs the integrity check.

Parameters

\Drupal\Core\Plugin\ContextAwarePluginInterface $plugin: The plugin with its defined context.

\Drupal\rules\Context\ExecutionMetadataStateInterface $metadata_state: The current configuration state with all defined variables that are available.

Return value

\Drupal\rules\Engine\IntegrityViolationList The list of integrity violations.

2 calls to ContextHandlerIntegrityTrait::checkContextConfigIntegrity()
ActionExpression::checkIntegrity in src/Plugin/RulesExpression/ActionExpression.php
Verifies that this expression is configured correctly.
ConditionExpression::checkIntegrity in src/Plugin/RulesExpression/ConditionExpression.php
Verifies that this expression is configured correctly.

File

src/Context/ContextHandlerIntegrityTrait.php, line 35

Class

ContextHandlerIntegrityTrait
Extends the context handler trait with support for checking integrity.

Namespace

Drupal\rules\Context

Code

protected function checkContextConfigIntegrity(CoreContextAwarePluginInterface $plugin, ExecutionMetadataStateInterface $metadata_state) {
  $violation_list = new IntegrityViolationList();
  $context_definitions = $plugin->getContextDefinitions();
  // Make sure that all provided variables by this plugin are added to the
  // execution metadata state.
  $this->addProvidedContextDefinitions($plugin, $metadata_state);
  foreach ($context_definitions as $name => $context_definition) {
    // Check if a data selector is configured that maps to the state.
    if (isset($this->configuration['context_mapping'][$name])) {
      try {
        $data_definition = $this->getMappedDefinition($name, $metadata_state);
        $this->checkDataTypeCompatible($context_definition, $data_definition, $name, $violation_list);
      } catch (IntegrityException $e) {
        $violation = new IntegrityViolation();
        $violation->setMessage($this->t('Data selector %selector for context %context_name is invalid. @message', [
          '%selector' => $this->configuration['context_mapping'][$name],
          '%context_name' => $context_definition->getLabel(),
          '@message' => $e->getMessage(),
        ]));
        $violation->setContextName($name);
        $violation->setUuid($this->getUuid());
        $violation_list->add($violation);
      }
      if ($context_definition instanceof RulesContextDefinitionInterface && $context_definition->getAssignmentRestriction() === RulesContextDefinitionInterface::ASSIGNMENT_RESTRICTION_INPUT) {
        $violation = new IntegrityViolation();
        $violation->setMessage($this->t('The context %context_name may not be configured using a selector.', [
          '%context_name' => $context_definition->getLabel(),
        ]));
        $violation->setContextName($name);
        $violation->setUuid($this->getUuid());
        $violation_list->add($violation);
      }
    }
    elseif (isset($this->configuration['context_values'][$name])) {
      if ($context_definition instanceof RulesContextDefinitionInterface && $context_definition->getAssignmentRestriction() === RulesContextDefinitionInterface::ASSIGNMENT_RESTRICTION_SELECTOR) {
        $violation = new IntegrityViolation();
        $violation->setMessage($this->t('The context %context_name may only be configured using a selector.', [
          '%context_name' => $context_definition->getLabel(),
        ]));
        $violation->setContextName($name);
        $violation->setUuid($this->getUuid());
        $violation_list->add($violation);
      }
    }
    elseif ($context_definition->isRequired() && $context_definition->getDefaultValue() === NULL) {
      $violation = new IntegrityViolation();
      $violation->setMessage($this->t('The required context %context_name is missing.', [
        '%context_name' => $context_definition->getLabel(),
      ]));
      $violation->setContextName($name);
      $violation->setUuid($this->getUuid());
      $violation_list->add($violation);
    }
  }
  if ($plugin instanceof ContextProviderInterface) {
    $provided_context_definitions = $plugin->getProvidedContextDefinitions();
    foreach ($provided_context_definitions as $name => $context_definition) {
      if (isset($this->configuration['provides_mapping'][$name]) && !preg_match('/^[0-9a-zA-Z_]*$/', $this->configuration['provides_mapping'][$name])) {
        $violation = new IntegrityViolation();
        $violation->setMessage($this->t('Provided variable name %name contains not allowed characters.', [
          '%name' => $this->configuration['provides_mapping'][$name],
        ]));
        $violation->setContextName($name);
        $violation->setUuid($this->getUuid());
        $violation_list->add($violation);
      }
    }
  }
  return $violation_list;
}