HEX
Server: Apache
System: Linux vps-cdc32557.vps.ovh.ca 5.15.0-156-generic #166-Ubuntu SMP Sat Aug 9 00:02:46 UTC 2025 x86_64
User: hanode (1017)
PHP: 7.4.33
Disabled: pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare,
Upload Files
File: /home/hanode/public_html/wp-content/plugins/taxonomy-images/plugin/includes/cache-class.php
<?php

/**
 * @package     Taxonomy Images
 * @subpackage  Cache
 */

namespace Plugins\Taxonomy_Images;

if ( ! defined( 'ABSPATH' ) ) exit; // Exit if accessed directly

class Cache {

	/**
	 * Cache Queried Images
	 *
	 * Cache all term images associated with posts in
	 * the main WordPress query.
	 *
	 * @param  array  Post objects.
	 *
	 * @internal  Private. Called via the `template_redirect` action.
	 */
	public function cache_queried_images() {

		global $posts;

		$this->cache_post_term_images( $posts );

	}

	/**
	 * Cache Post Term Images
	 *
	 * Sets the WordPress object cache for all term images
	 * associated to the posts in the provided array. This
	 * function has been created to minimize queries when
	 * using this plugins get_the_terms() style function.
	 *
	 * @param  array  Post objects.
	 */
	private function cache_post_term_images( $posts ) {

		$term_ids = $this->get_post_term_ids( $posts );
		$image_ids = $this->get_term_image_ids( $term_ids );

		if ( empty( $image_ids ) ) {
			return;
		}

		// Get images so they are cached
		$images = get_posts( array(
			'include'   => $image_ids,
			'post_type' => 'attachment'
		) );

	}

	/**
	 * Get Post Term IDs
	 *
	 * Get all term_ids for posts that may have assocaited images.
	 *
	 * @param   array  $posts  Post ojects.
	 * @return  array          Term IDs.
	 */
	private function get_post_term_ids( $posts ) {

		$term_ids = array();

		foreach ( (array) $posts as $post ) {

			if ( ! isset( $post->ID ) || ! isset( $post->post_type ) ) {
				continue;
			}

			$taxonomies = $this->get_post_type_taxonomies( $post->post_type );

			if ( empty( $taxonomies ) ) {
				continue;
			}

			foreach ( $taxonomies as $taxonomy ) {

				$the_terms = get_the_terms( $post->ID, $taxonomy );

				foreach ( (array) $the_terms as $term ) {
					if ( ! isset( $term->term_id ) ) {
						continue;
					}
					$term_ids[] = $term->term_id;
				}

			}

		}

		return array_filter( array_unique( $term_ids ) );

	}

	/**
	 * Get Post Type Taxonomies
	 * 
	 * @todo  Only get taxonomies for which Taxonomy Images are enabled in settings.
	 *
	 * @param   string  $post_type  Post type.
	 * @return  array               Taxonomies.
	 */
	private function get_post_type_taxonomies( $post_type ) {

		return get_object_taxonomies( $post->post_type );

	}

	/**
	 * Get Term Image IDs
	 *
	 * Get all image IDs for supplied terms.
	 *
	 * @param   array  $term_ids  Term IDs.
	 * @return  array             Image attachment IDs.
	 */
	private function get_term_image_ids( $term_ids ) {

		$image_ids = array();

		foreach ( $term_ids as $term_id ) {

			$t = new Term_Image( $term_id );
			$image_id = $t->get_image_id();

			if ( empty( $image_id ) ) {
				continue;
			}

			$image_ids[] = $image_id;

		}

		return $image_ids;

	}

}