ComplexDataConstraint.php

Same filename and directory in other branches
  1. 11.x core/lib/Drupal/Core/Validation/Plugin/Validation/Constraint/ComplexDataConstraint.php
  2. 10 core/lib/Drupal/Core/Validation/Plugin/Validation/Constraint/ComplexDataConstraint.php
  3. 9 core/lib/Drupal/Core/Validation/Plugin/Validation/Constraint/ComplexDataConstraint.php
  4. 8.9.x core/lib/Drupal/Core/Validation/Plugin/Validation/Constraint/ComplexDataConstraint.php

Namespace

Drupal\Core\Validation\Plugin\Validation\Constraint

File

core/lib/Drupal/Core/Validation/Plugin/Validation/Constraint/ComplexDataConstraint.php

View source
<?php

namespace Drupal\Core\Validation\Plugin\Validation\Constraint;

use Drupal\Core\StringTranslation\TranslatableMarkup;
use Drupal\Core\Validation\Attribute\Constraint;
use Symfony\Component\Validator\Attribute\HasNamedArguments;
use Symfony\Component\Validator\Constraint as SymfonyConstraint;

/**
 * Complex data constraint.
 *
 * Validates properties of complex data structures.
 */
class ComplexDataConstraint extends SymfonyConstraint {
  
  /**
   * An array of constraints for contained properties, keyed by property name.
   *
   * @var array
   */
  public $properties;
  public function __construct(mixed $options = NULL, ?array $properties = NULL, ?array $groups = NULL, mixed $payload = NULL, ...$otherProperties) {
    // Allow skipping the 'properties' key in the options.
    if (is_array($options)) {
      if (!array_key_exists('properties', $options)) {
        $options = [
          'properties' => $options,
        ];
      }
    }
    elseif ($properties === NULL && !empty($otherProperties)) {
      $properties = $otherProperties;
    }
    parent::__construct($options, $groups, $payload);
    $this->properties = $properties ?? $this->properties;
    $constraint_manager = \Drupal::service('validation.constraint');
    // Instantiate constraint objects for array definitions.
    foreach ($this->properties as &$constraints) {
      foreach ($constraints as $id => $options) {
        if (!is_object($options)) {
          $constraints[$id] = $constraint_manager->create($id, $options);
        }
      }
    }
  }
  
  /**
   * {@inheritdoc}
   */
  public function getDefaultOption() : ?string {
    return 'properties';
  }
  
  /**
   * {@inheritdoc}
   */
  public function getRequiredOptions() : array {
    return [
      'properties',
    ];
  }

}

Classes

Title Deprecated Summary
ComplexDataConstraint Complex data constraint.

Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.