Skip to main content
Drupal API
User account menu
  • Log in

Breadcrumb

  1. Drupal Core 11.1.x
  2. FileExtensionConstraintValidator.php

class FileExtensionConstraintValidator

Validates the file extension constraint.

Hierarchy

  • class \Symfony\Component\Validator\ConstraintValidator implements \Symfony\Component\Validator\ConstraintValidatorInterface
    • class \Drupal\file\Plugin\Validation\Constraint\BaseFileConstraintValidator extends \Symfony\Component\Validator\ConstraintValidator
      • class \Drupal\file\Plugin\Validation\Constraint\FileExtensionConstraintValidator extends \Drupal\file\Plugin\Validation\Constraint\BaseFileConstraintValidator

Expanded class hierarchy of FileExtensionConstraintValidator

File

core/modules/file/src/Plugin/Validation/Constraint/FileExtensionConstraintValidator.php, line 13

Namespace

Drupal\file\Plugin\Validation\Constraint
View source
class FileExtensionConstraintValidator extends BaseFileConstraintValidator {
    
    /**
     * {@inheritdoc}
     */
    public function validate(mixed $value, Constraint $constraint) : void {
        $file = $this->assertValueIsFile($value);
        if (!$constraint instanceof FileExtensionConstraint) {
            throw new UnexpectedTypeException($constraint, FileExtensionConstraint::class);
        }
        $extensions = $constraint->extensions;
        $regex = '/\\.(' . preg_replace('/ +/', '|', preg_quote($extensions)) . ')$/i';
        // Filename may differ from the basename, for instance in case files
        // migrated from D7 file entities. Because of that new files are saved
        // temporarily with a generated file name, without the original extension,
        // we will use the generated filename property for extension validation only
        // in case of temporary files; and use the file system file name in case of
        // permanent files.
        $subject = $file->isTemporary() ? $file->getFilename() : $file->getFileUri();
        if (!preg_match($regex, $subject)) {
            $this->context
                ->addViolation($constraint->message, [
                '%files-allowed' => $extensions,
            ]);
        }
    }

}

Members

Title Sort descending Modifiers Object type Summary Overriden Title
BaseFileConstraintValidator::assertValueIsFile protected function Checks the value is of type FileInterface.
ConstraintValidator::$context protected property
ConstraintValidator::formatTypeOf protected function Returns a string representation of the type of the value.
ConstraintValidator::formatValue protected function Returns a string representation of the value.
ConstraintValidator::formatValues protected function Returns a string representation of a list of values.
ConstraintValidator::initialize public function Initializes the constraint validator. Overrides ConstraintValidatorInterface::initialize
ConstraintValidator::OBJECT_TO_STRING public constant Whether to cast objects with a "__toString()" method to strings.
ConstraintValidator::PRETTY_DATE public constant Whether to format {@link \DateTime} objects, either with the {@link \IntlDateFormatter}
(if it is available) or as RFC-3339 dates ("Y-m-d H:i:s").
FileExtensionConstraintValidator::validate public function Checks if the passed value is valid. Overrides ConstraintValidatorInterface::validate

API Navigation

  • Drupal Core 11.1.x
  • Topics
  • Classes
  • Functions
  • Constants
  • Globals
  • Files
  • Namespaces
  • Deprecated
  • Services
RSS feed
Powered by Drupal