From 235ce5716edc2f7cbe80fdccf26eac7269587839 Mon Sep 17 00:00:00 2001
From: Jake Vanderwerf <get@jakevanderwerf.ca>
Date: Mon, 08 Jun 2026 04:38:18 +0000
Subject: [PATCH] =FavouritesManager.php and FavouritesRoutes.php fixes. Moving all logic to FavouritesManager.php. Still some left to do
---
inc/managers/Cache.php | 36 +++++++++++++++++++++++++++++++-----
1 files changed, 31 insertions(+), 5 deletions(-)
diff --git a/inc/managers/Cache.php b/inc/managers/Cache.php
index 6460971..c144013 100644
--- a/inc/managers/Cache.php
+++ b/inc/managers/Cache.php
@@ -18,6 +18,8 @@
private static array $instances = [];
private bool $hasRedis;
+ private bool $varyByAuth = false;
+ private bool $varyByUser = false;
private function __construct(string $group, int $ttl)
{
@@ -58,6 +60,29 @@
add_action('deleted_user_meta', [self::class, 'onUserMetaDelete'], 10, 2);
}
+ public function auth(): static
+ {
+ $this->varyByAuth = true;
+ return $this;
+ }
+
+ public function user(): static
+ {
+ $this->varyByUser = true;
+ return $this;
+ }
+
+ private function resolveKey(int|string $key): string
+ {
+ if ($this->varyByUser) {
+ return $key . ':u' . get_current_user_id();
+ }
+ if ($this->varyByAuth) {
+ return $key . ':' . (is_user_logged_in() ? 'auth' : 'guest');
+ }
+ return (string) $key;
+ }
+
/* ---------------------------------------------------------------------
* Factory
* ------------------------------------------------------------------- */
@@ -358,12 +383,13 @@
?int $ttl = null
): mixed {
if (is_array($key)) {
- $id = $this->generateKey($key);
+ $key = $this->generateKey($key);
}
+ $instanceTags = array_map(fn($tag) => [$this->group, $tag], $this->getTags());
$tags = array_unique(array_merge(
- $this->getTags(),
- array_map('sanitize_key', $tags)
- ));
+ $instanceTags,
+ array_map(fn($tag) => [sanitize_key($tag[0]), $tag[1]], $tags)
+ ), SORT_REGULAR);
$value = wp_cache_get($key, $this->group);
@@ -491,7 +517,7 @@
****************************************************/
public static function onTermChange(int $termId, int $ttId, string $taxonomy): void
{
-// error_log('[Clearing cache for term change: '.$termId.']');
+ error_log('[Clearing cache for term change: '.$termId.']');
self::invalidateItem('taxonomy', $termId);
}
--
Gitblit v1.10.0