D7net
Home
Console
Upload
information
Create File
Create Folder
About
Tools
:
/
opt
/
psa
/
admin
/
plib
/
vendor
/
laminas
/
laminas-validator
/
src
/
File
/
Filename :
Exists.php
back
Copy
<?php namespace Laminas\Validator\File; use Laminas\Validator\AbstractValidator; use Laminas\Validator\Exception; use Traversable; use function array_key_exists; use function array_unique; use function explode; use function file_exists; use function implode; use function is_array; use function is_string; use function trim; use const DIRECTORY_SEPARATOR; /** * Validator which checks if the file already exists in the directory */ class Exists extends AbstractValidator { use FileInformationTrait; /** * @const string Error constants */ public const DOES_NOT_EXIST = 'fileExistsDoesNotExist'; /** @var array Error message templates */ protected $messageTemplates = [ self::DOES_NOT_EXIST => 'File does not exist', ]; /** * Options for this validator * * @var array */ protected $options = [ 'directory' => null, // internal list of directories ]; /** @var array Error message template variables */ protected $messageVariables = [ 'directory' => ['options' => 'directory'], ]; /** * Sets validator options * * @param string|array|Traversable $options */ public function __construct($options = null) { if (is_string($options)) { $options = explode(',', $options); } if (is_array($options) && ! array_key_exists('directory', $options)) { $options = ['directory' => $options]; } parent::__construct($options); } /** * Returns the set file directories which are checked * * @deprecated Since 2.61.0 - All getters and setters will be removed in 3.0 * * @param bool $asArray Returns the values as array; when false, a concatenated string is returned * @return string|null */ public function getDirectory($asArray = false) { $asArray = (bool) $asArray; $directory = $this->options['directory']; if ($asArray && isset($directory)) { $directory = explode(',', (string) $directory); } return $directory; } /** * Sets the file directory which will be checked * * @deprecated Since 2.61.0 - All getters and setters will be removed in 3.0 * * @param string|array $directory The directories to validate * @return self Provides a fluent interface */ public function setDirectory($directory) { $this->options['directory'] = null; $this->addDirectory($directory); return $this; } /** * Adds the file directory which will be checked * * @deprecated Since 2.61.0 - All getters and setters will be removed in 3.0 * * @param string|array $directory The directory to add for validation * @return self Provides a fluent interface * @throws Exception\InvalidArgumentException */ public function addDirectory($directory) { $directories = $this->getDirectory(true); if (! isset($directories)) { $directories = []; } if (is_string($directory)) { $directory = explode(',', $directory); } elseif (! is_array($directory)) { throw new Exception\InvalidArgumentException('Invalid options to validator provided'); } foreach ($directory as $content) { if (empty($content) || ! is_string($content)) { continue; } $directories[] = trim($content); } $directories = array_unique($directories); // Sanity check to ensure no empty values foreach ($directories as $key => $dir) { if (empty($dir)) { unset($directories[$key]); } } $this->options['directory'] = ! empty($directory) ? implode(',', $directories) : null; return $this; } /** * Returns true if and only if the file already exists in the set directories * * @param string|array $value Real file to check for existence * @param array $file File data from \Laminas\File\Transfer\Transfer (optional) * @return bool */ public function isValid($value, $file = null) { $fileInfo = $this->getFileInfo($value, $file, false, true); $this->setValue($fileInfo['filename']); $check = false; $directories = $this->getDirectory(true); if (! isset($directories)) { $check = true; if (! file_exists($fileInfo['file'])) { $this->error(self::DOES_NOT_EXIST); return false; } } else { foreach ($directories as $directory) { if (! isset($directory) || '' === $directory) { continue; } $check = true; if (! file_exists($directory . DIRECTORY_SEPARATOR . $fileInfo['basename'])) { $this->error(self::DOES_NOT_EXIST); return false; } } } if (! $check) { $this->error(self::DOES_NOT_EXIST); return false; } return true; } }