[Д] [HashGetType]: Добавлен параметр ByHash (для получения класса хеша путём передачи ему уже вычисленного хэша). [О] [FileHash]: __construct - $hashBy по умолчанию теперь HashGetType::ByHash. [Д] [FileHash]: Добавлены функции сериализации и десериализации (теперь класс реализует интерфейс ISerializable). [Д] [FileHash]: Добавлена функции валидации хэша Validate.
		
			
				
	
	
		
			108 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			108 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | ||
| 
 | ||
| namespace goodboyalex\php_components_pack\classes;
 | ||
| 
 | ||
| use goodboyalex\php_components_pack\enums\HashGetType;
 | ||
| use goodboyalex\php_components_pack\extensions\StringExtension;
 | ||
| use goodboyalex\php_components_pack\interfaces\ISerializable;
 | ||
| 
 | ||
| /**
 | ||
|  * Класс для работы с хэшем файла или строки.
 | ||
|  *
 | ||
|  * @author Александр Бабаев
 | ||
|  * @package php_components_pack
 | ||
|  * @version 1.0.1
 | ||
|  * @since 1.0.5
 | ||
|  */
 | ||
| final class FileHash implements ISerializable
 | ||
| {
 | ||
|     /**
 | ||
|      * @var string $Hash Хэш файла.
 | ||
|      */
 | ||
|     private(set) string $Hash;
 | ||
| 
 | ||
|     /**
 | ||
|      * Конструктор.
 | ||
|      *
 | ||
|      * @param string $str Хэщ, строка или имя файла.
 | ||
|      * @param HashGetType $hashBy Тип получения хэша.
 | ||
|      */
 | ||
|     public function __construct (string $str = "", HashGetType $hashBy = HashGetType::ByHash)
 | ||
|     {
 | ||
|         $this->Hash = match ($hashBy) {
 | ||
|             HashGetType::ByString => $this->pGetHash($str),
 | ||
|             HashGetType::ByFile => $this->pGetFileHash($str),
 | ||
|             HashGetType::ByHash => $str
 | ||
|         };
 | ||
|     }
 | ||
| 
 | ||
|     /**
 | ||
|      * Получение хэша файла по строке.
 | ||
|      *
 | ||
|      * @param string $str Строка.
 | ||
|      *
 | ||
|      * @return string Хэш строки.
 | ||
|      */
 | ||
|     private function pGetHash (string $str): string
 | ||
|     {
 | ||
|         return hash('sha256', $str);
 | ||
|     }
 | ||
| 
 | ||
|     /**
 | ||
|      * Получение хэша файла по имени файла.
 | ||
|      *
 | ||
|      * @param string $fileName Имя файла.
 | ||
|      *
 | ||
|      * @return string Хэш файла.
 | ||
|      */
 | ||
|     private function pGetFileHash (string $fileName): string
 | ||
|     {
 | ||
|         return hash_file('sha256', $fileName);
 | ||
|     }
 | ||
| 
 | ||
|     /**
 | ||
|      * Сравнивает текущий хэш с хэшем <code>otherHash</code> и выдаёт <code>true</code>, если совпадают, и
 | ||
|      * <code>false</code>, если не совпадают.
 | ||
|      *
 | ||
|      * @param FileHash $otherHash Другой хэш.
 | ||
|      *
 | ||
|      * @return bool <code>true</code>, если совпадают, и <code>false</code>, если не совпадают.
 | ||
|      */
 | ||
|     public function IsEqual (FileHash $otherHash): bool
 | ||
|     {
 | ||
|         return StringExtension::Compare($this->Hash, $otherHash->Hash, true) === 0;
 | ||
|     }
 | ||
| 
 | ||
|     /**
 | ||
|      * Проверяет, совпадает ли хэш с хэшем/файлом/строкой <code>str</code>.
 | ||
|      *
 | ||
|      * @param string $str Хэш, строка или имя файла.
 | ||
|      * @param HashGetType $hashBy Тип получения хэша.
 | ||
|      *
 | ||
|      * @return bool <code>true</code>, если совпадают, и <code>false</code>, если не совпадают.
 | ||
|      */
 | ||
|     public function Validate (string $str, HashGetType $hashBy): bool
 | ||
|     {
 | ||
|         return match ($hashBy) {
 | ||
|             HashGetType::ByString => $this->pGetHash($str) == $this->Hash,
 | ||
|             HashGetType::ByFile => $this->pGetFileHash($str) == $this->Hash,
 | ||
|             HashGetType::ByHash => $str == $this->Hash,
 | ||
|         };
 | ||
|     }
 | ||
| 
 | ||
|     /**
 | ||
|      * @inheritDoc
 | ||
|      */
 | ||
|     public function Serialize (): string
 | ||
|     {
 | ||
|         return serialize($this->Hash);
 | ||
|     }
 | ||
| 
 | ||
|     /**
 | ||
|      * @inheritDoc
 | ||
|      */
 | ||
|     public function UnSerialize (string $serialized): void
 | ||
|     {
 | ||
|         $this->Hash = unserialize($serialized);
 | ||
|     }
 | ||
| } |