From e9967fa22781d922ba4eb8fb44fe72d200ac4b14 Mon Sep 17 00:00:00 2001
From: Jake Vanderwerf <get@jakevanderwerf.ca>
Date: Mon, 10 Nov 2025 21:04:10 +0000
Subject: [PATCH] =IconsManager.php update

---
 inc/managers/UserTermsManager.php |   55 ++++++++++++++++++++++++++++---------------------------
 1 files changed, 28 insertions(+), 27 deletions(-)

diff --git a/inc/managers/UserTermsManager.php b/inc/managers/UserTermsManager.php
index efde9cd..b900dff 100644
--- a/inc/managers/UserTermsManager.php
+++ b/inc/managers/UserTermsManager.php
@@ -23,8 +23,6 @@
         global $wpdb;
 		$this->wpdb = $wpdb;
         $this->table_name = $this->wpdb->prefix . BASE . 'user_term_index';
-        // Get cache manager instance
-        $this->cache = new CacheManager($this->cacheGroup, $this->ttl);
 
         // Register hooks
         add_action('save_post', [$this, 'updatePostUserTerms'], 10, 3);
@@ -43,14 +41,11 @@
      */
     public function clearUserCache(int $user_id, string|null $taxonomy = null):void
     {
+		$cache = CacheManager::for($user_id.'_term_relationships');
         if ($taxonomy) {
-            // Clear specific taxonomy cache
-            $pattern = "user_{$user_id}_" . str_replace(BASE, '', $taxonomy);
-            $this->cache->clearPattern($pattern);
+            $cache->delete(jvbNoBase($taxonomy));
         } else {
-            // Clear all user term caches
-            $pattern = "user_{$user_id}_";
-            $this->cache->clearPattern($pattern);
+			$cache->invalidate();
         }
     }
 
@@ -69,6 +64,10 @@
         if (wp_is_post_autosave($post_id) || wp_is_post_revision($post_id)) {
             return;
         }
+		// SAFETY: Skip attachments and other non-content post types
+		if (in_array($post->post_type, jvbIgnoredPostTypes())) {
+			return;
+		}
 
         // Skip non-custom post types
         $post_type = get_post_type($post);
@@ -414,12 +413,13 @@
         $this->wpdb->query("TRUNCATE TABLE {$this->table_name}");
 
         // Get all users with posts
-        $users = $this->wpdb->get_col("
-            SELECT DISTINCT post_author
-            FROM {$this->wpdb->posts}
-            WHERE post_status = 'publish'
-            AND post_type LIKE '" . BASE . "%'
-        ");
+		$users = $this->wpdb->get_col($this->wpdb->prepare(
+			"SELECT DISTINCT post_author
+			FROM {$this->wpdb->posts}
+			WHERE post_status = 'publish'
+			AND post_type LIKE %s",
+			$this->wpdb->esc_like(BASE) . '%'
+		));
 
         JVB()->queue()->queueOperation(
             'rebuild_user_term_index',
@@ -495,14 +495,14 @@
                 $this->clearUserCache($user_id);
 
                 // Get all the user's published posts
-                $posts = $this->wpdb->get_col($this->wpdb->prepare(
-                    "SELECT ID FROM {$this->wpdb->posts}
-            WHERE post_author = %d
-            AND post_status = 'publish'
-            AND post_type LIKE '%s'",
-                    $user_id,
-					BASE
-                ));
+				$posts = $this->wpdb->get_col($this->wpdb->prepare(
+					"SELECT ID FROM {$this->wpdb->posts}
+					WHERE post_author = %d
+					AND post_status = 'publish'
+					AND post_type LIKE %s",
+					$user_id,
+					$this->wpdb->esc_like(BASE) . '%'
+				));
 
                 $processed_terms = 0;
 
@@ -592,7 +592,8 @@
     private function fetchUserTerms(int $user_id, string $taxonomy, array $args):array
     {
         $taxonomy = jvbCheckBase($taxonomy);
-        $key = $this->cache->generateKey(array_merge(
+		$cache = CacheManager::for($user_id.'_term_relationships');
+        $key = $cache->generateKey(array_merge(
             [
                 'user'      => $user_id,
                 'taxonomy'  => $taxonomy,
@@ -600,9 +601,9 @@
             $args
         ));
         if (!$args['skip_cache']) {
-            $cache = $this->cache->get($key);
-            if ($cache) {
-                return $cache;
+            $cached = $cache->get($key);
+            if ($cached) {
+                return $cached;
             }
         }
 
@@ -654,7 +655,7 @@
             $this->wpdb->prepare($query, $query_args),
             ARRAY_A
         );
-        $this->cache->set($key, $results);
+        $cache->set($key, $results);
 
         return $results;
     }

--
Gitblit v1.10.0