+ make getCacheTag a more smarts - accepts identifiers and returned cache tags with base class name and an addition - more tags with base class name and accepted identifiers
* getCacheTag return array * clear cache accepted unnecessary model argument - if it presented - then clear cache only by cache tag with passed model id + some helper methods, like a formatCacheTag, forceArray for string or collection conversion into array
This commit is contained in:
		| @ -1,26 +1,80 @@ | ||||
| <?php namespace Wpstudio\Helpers\Classes\Observer; | ||||
|  | ||||
| use Illuminate\Database\Eloquent\Model; | ||||
| use Illuminate\Support\Collection; | ||||
| use Cache; | ||||
|  | ||||
| abstract class BaseObserver implements Observer | ||||
| { | ||||
|     protected static string $class; | ||||
|  | ||||
|     /** | ||||
|      * Очистка кэша | ||||
|      * @return void | ||||
|      */ | ||||
|     public static function clearCache(): void | ||||
|     public static function clearCache(?Model $model = null): void | ||||
|     { | ||||
|         $tags = [self::getCacheTag()]; | ||||
|  | ||||
|         \Cache::tags($tags)->flush(); | ||||
|         Cache::tags( | ||||
|             static::getCacheTag( | ||||
|                 !is_null($model) ? $model->getKey() : null, | ||||
|                 [], | ||||
|                 true | ||||
|             ) | ||||
|         )->flush(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Получение тэка кеша | ||||
|      * @return string | ||||
|      * @param int|Collection|array|null $identifiers | ||||
|      * @param array|null $additionalPieces | ||||
|      * @param bool $excludeBaseClassNameTagWithoutIdentifiers | ||||
|      * @desc $excludeBaseClassNameTagWithoutIdentifiers - выключает из результирующего массива тег кеша только с базовым классом, если переданы идентификаторы | ||||
|      * @desc То есть в итоговой выборке - не будет тега, без идентификатора, если вообще идентификаторы переданы | ||||
|      * @return array | ||||
|      */ | ||||
|     public static function getCacheTag(): string | ||||
|     public static function getCacheTag($identifiers = null, ?array $additionalPieces = [], bool $excludeBaseClassNameTagWithoutIdentifiers = false): array | ||||
|     { | ||||
|         return static::getClass(); | ||||
|         return static::getCacheTagsWithMaybeIdentifiers(static::getClass(), $identifiers, $additionalPieces, $excludeBaseClassNameTagWithoutIdentifiers); | ||||
|     } | ||||
|  | ||||
|     public static function formatCacheTag(array $pieces): string | ||||
|     { | ||||
|         return implode('.', $pieces); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @param int|Collection|array|null $value | ||||
|      * @return array | ||||
|      */ | ||||
|     private static function forceArray($value = null): array | ||||
|     { | ||||
|         return $value instanceof Collection ? $value->toArray() : (array)$value; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @param string $baseClassName | ||||
|      * @param int|Collection|array|null $iterateIdentifiers | ||||
|      * @param array|null $additionalTagPieces | ||||
|      * @param bool $excludeBaseClassNameTagWithoutIdentifiers | ||||
|      * @return array | ||||
|      */ | ||||
|     private static function getCacheTagsWithMaybeIdentifiers(string $baseClassName, $iterateIdentifiers = [], ?array $additionalTagPieces = [], bool $excludeBaseClassNameTagWithoutIdentifiers = false): array | ||||
|     { | ||||
|         $iterateIdentifiers = static::forceArray($iterateIdentifiers); | ||||
|  | ||||
|         $cacheTags = []; | ||||
|  | ||||
|         if (!$excludeBaseClassNameTagWithoutIdentifiers || !$iterateIdentifiers) { | ||||
|             $cacheTags = (array)static::formatCacheTag(array_merge([$baseClassName], $additionalTagPieces)); | ||||
|         } | ||||
|  | ||||
|         if ($iterateIdentifiers) { | ||||
|             $cacheTags = array_merge( | ||||
|                 $cacheTags, | ||||
|                 array_map( | ||||
|                     fn ($identifier) => static::formatCacheTag( | ||||
|                         array_merge([$baseClassName, $identifier], $additionalTagPieces) | ||||
|                     ), | ||||
|                     $iterateIdentifiers | ||||
|                 ) | ||||
|             ); | ||||
|         } | ||||
|  | ||||
|         return $cacheTags; | ||||
|     } | ||||
| } | ||||
|  | ||||
		Reference in New Issue
	
	Block a user