"File does not match the given md5 hashes", self::NOT_DETECTED => "An md5 hash could not be evaluated for the given file", self::NOT_FOUND => "File is not readable or does not exist", ]; /** * Options for this validator * * @var string */ protected $options = [ 'algorithm' => 'md5', 'hash' => null, ]; /** * Returns all set md5 hashes * * @return array */ public function getMd5() { return $this->getHash(); } /** * Sets the md5 hash for one or multiple files * * @param string|array $options * @return Hash Provides a fluent interface */ public function setMd5($options) { $this->setHash($options); return $this; } /** * Adds the md5 hash for one or multiple files * * @param string|array $options * @return Hash Provides a fluent interface */ public function addMd5($options) { $this->addHash($options); return $this; } /** * Returns true if and only if the given file confirms the set hash * * @param string|array $value Filename to check for hash * @param array $file File data from \Zend\File\Transfer\Transfer (optional) * @return bool */ public function isValid($value, $file = null) { if (is_string($value) && is_array($file)) { // Legacy Zend\Transfer API support $filename = $file['name']; $file = $file['tmp_name']; } elseif (is_array($value)) { if (!isset($value['tmp_name']) || !isset($value['name'])) { throw new Exception\InvalidArgumentException( 'Value array must be in $_FILES format' ); } $file = $value['tmp_name']; $filename = $value['name']; } else { $file = $value; $filename = basename($file); } $this->setValue($filename); // Is file readable ? if (empty($file) || false === stream_resolve_include_path($file)) { $this->error(self::NOT_FOUND); return false; } $hashes = array_unique(array_keys($this->getHash())); $filehash = hash_file('md5', $file); if ($filehash === false) { $this->error(self::NOT_DETECTED); return false; } foreach ($hashes as $hash) { if ($filehash === $hash) { return true; } } $this->error(self::DOES_NOT_MATCH); return false; } }