Error message templates */ protected $messageTemplates = [ self::FALSE_EXTENSION => 'File has an incorrect extension', self::NOT_FOUND => 'File is not readable or does not exist', ]; /** * Options for this validator * * @var array */ protected $options = [ 'case' => false, // Validate case sensitive 'extension' => '', // List of extensions 'allowNonExistentFile' => false, // Allow validation even if file does not exist ]; /** @var array Error message template variables */ protected $messageVariables = [ 'extension' => ['options' => 'extension'], ]; /** * Sets validator options * * @param string|array|Traversable $options */ public function __construct($options = null) { if ($options instanceof Traversable) { $options = ArrayUtils::iteratorToArray($options); } $case = null; if (1 < func_num_args()) { $case = func_get_arg(1); } if (is_array($options)) { if (isset($options['case'])) { $case = $options['case']; unset($options['case']); } if (! array_key_exists('extension', $options)) { $options = ['extension' => $options]; } } else { $options = ['extension' => $options]; } if ($case !== null) { $options['case'] = $case; } parent::__construct($options); } /** * Returns the case option * * @return bool */ public function getCase() { return $this->options['case']; } /** * Sets the case to use * * @param bool $case * @return $this Provides a fluent interface */ public function setCase($case) { $this->options['case'] = (bool) $case; return $this; } /** * Returns the set file extension * * @return array */ public function getExtension() { if ( ! array_key_exists('extension', $this->options) || ! is_string($this->options['extension']) ) { return []; } return explode(',', $this->options['extension']); } /** * Sets the file extensions * * @param string|array $extension The extensions to validate * @return $this Provides a fluent interface */ public function setExtension($extension) { $this->options['extension'] = null; $this->addExtension($extension); return $this; } /** * Adds the file extensions * * @param string|array $extension The extensions to add for validation * @return $this Provides a fluent interface */ public function addExtension($extension) { $extensions = $this->getExtension(); if (is_string($extension)) { $extension = explode(',', $extension); } foreach ($extension as $content) { if (empty($content) || ! is_string($content)) { continue; } $extensions[] = trim($content); } $extensions = array_unique($extensions); // Sanity check to ensure no empty values foreach ($extensions as $key => $ext) { if (empty($ext)) { unset($extensions[$key]); } } $this->options['extension'] = implode(',', $extensions); return $this; } /** * Returns whether or not to allow validation of non-existent files. * * @return bool */ public function getAllowNonExistentFile() { return $this->options['allowNonExistentFile']; } /** * Sets the flag indicating whether or not to allow validation of non-existent files. * * @param bool $flag Whether or not to allow validation of non-existent files. * @return $this Provides a fluent interface */ public function setAllowNonExistentFile($flag) { $this->options['allowNonExistentFile'] = (bool) $flag; return $this; } /** * Returns true if and only if the file extension of $value is included in the * set extension list * * @param string|array $value Real file to check for extension * @param array $file File data from \Laminas\File\Transfer\Transfer (optional) * @return bool */ public function isValid($value, $file = null) { $fileInfo = $this->getFileInfo($value, $file); // Is file readable ? if ( ! $this->getAllowNonExistentFile() && (empty($fileInfo['file']) || false === is_readable($fileInfo['file'])) ) { $this->error(self::NOT_FOUND); return false; } $this->setValue($fileInfo['filename']); $extension = substr($fileInfo['filename'], strrpos($fileInfo['filename'], '.') + 1); $extensions = $this->getExtension(); if ($this->getCase() && (in_array($extension, $extensions))) { return true; } elseif (! $this->getCase()) { foreach ($extensions as $ext) { if (strtolower($ext) === strtolower($extension)) { return true; } } } $this->error(self::FALSE_EXTENSION); return false; } }