HEX
Server: nginx/1.26.1
System: Linux main-vm 5.15.0-153-generic #163-Ubuntu SMP Thu Aug 7 16:37:18 UTC 2025 x86_64
User: root (0)
PHP: 8.2.19
Disabled: NONE
Upload Files
File: /var/www/rocioprime/wp-content/plugins/siteseo/classes/Actions/Front/Metas/DescriptionMeta.php
<?php
/*
* SiteSEO
* https://siteseo.io/
* (c) SiteSEO Team <[email protected]>
*/

/*
Copyright 2016 - 2024 - Benjamin Denis  (email : [email protected])
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License, version 2, as
published by the Free Software Foundation.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
GNU General Public License for more details.

You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
*/

namespace SiteSEO\Actions\Front\Metas;

defined('ABSPATH') or exit('Cheatin&#8217; uh?');

use SiteSEO\Core\Hooks\ExecuteHooksFrontend;

class DescriptionMeta implements ExecuteHooksFrontend {
	
	public $tagsToStringService;
	
	public function __construct() {
		$this->tagsToStringService = siteseo_get_service('TagsToString');
	}

	/**
	 * @since 4.4.0
	 *
	 * @return void
	 */
	public function hooks() {
		add_action('wp_head', [$this, 'render'], 1);
	}

	public function render() {
		if (apply_filters('siteseo_old_wp_head_description', true)) {
			return;
		}

		$content = $this->getContent();

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

		$html = '<meta name="description" content="' . $content . '" />';
		$html .= "\n";
		echo wp_kses($html, ['meta' => ['name' => true, 'content' => true]]);
	}

	/**
	 * @since 4.4.0
	 *
	 * @return string
	 *
	 * @param mixed $variablesArray
	 * @param mixed $variablesReplace
	 */
	protected function getHomeDescriptionTemplate($variablesArray, $variablesReplace) {
		if ( ! function_exists('siteseo_get_service')) {
			$descriptionOption = siteseo_get_service('TitleOption')->getHomeDescriptionTitle();
			if (empty($descriptionOption)) {
				return '';
			}
			$descriptionOption   = esc_attr($descriptionOption);

			return str_replace($variablesArray, $variablesReplace, $descriptionOption);
		}

		$title   = siteseo_get_service('TitleOption')->getHomeDescriptionTitle();
		$context = siteseo_get_service('ContextPage')->getContext();

		return $this->tagsToStringService->replace($title, $context);
	}

	protected function getContent() {
		$context = siteseo_get_service('ContextPage')->getContext();
		
		// TODO: remove if not needed
		require_once SITESEO_MAIN.'/options-titles-metas.php';

		$variables = null;
		$variables = apply_filters('siteseo_dyn_variables_fn', $variables);

		$post									 = $variables['post'];
		$term									 = $variables['term'];
		$siteseo_titles_title_template		   = $variables['siteseo_titles_title_template'];
		$descriptionTemplate					  = $variables['siteseo_titles_description_template'];
		$siteseo_paged						   = $variables['siteseo_paged'];
		$the_author_meta						  = $variables['the_author_meta'];
		$sep									  = $variables['sep'];
		$siteseo_excerpt						 = $variables['siteseo_excerpt'];
		$post_category							= $variables['post_category'];
		$post_tag								 = $variables['post_tag'];
		$post_thumbnail_url					   = $variables['post_thumbnail_url'];
		$get_search_query						 = $variables['get_search_query'];
		$woo_single_cat_html					  = $variables['woo_single_cat_html'];
		$woo_single_tag_html					  = $variables['woo_single_tag_html'];
		$woo_single_price						 = $variables['woo_single_price'];
		$woo_single_price_exc_tax				 = $variables['woo_single_price_exc_tax'];
		$woo_single_sku						   = $variables['woo_single_sku'];
		$author_bio							   = $variables['author_bio'];
		$siteseo_get_the_excerpt				 = $variables['siteseo_get_the_excerpt'];
		$siteseo_titles_template_variables_array = $variables['siteseo_titles_template_variables_array'];
		$siteseo_titles_template_replace_array   = $variables['siteseo_titles_template_replace_array'];
		$siteseo_excerpt_length				  = $variables['siteseo_excerpt_length'];
		$page_id								  = get_option('page_for_posts');
		
		$descriptionOption = siteseo_get_service('TitleOption')->getHomeDescriptionTitle();
		
		if (is_front_page() && is_home() && isset($post) && '' == get_post_meta($post->ID, '_siteseo_titles_desc', true)) { //HOMEPAGE
			if ( ! empty($descriptionOption)) {
				$descriptionTemplate = $this->getHomeDescriptionTemplate($siteseo_titles_template_variables_array, $siteseo_titles_template_replace_array);
			}
		} elseif (is_front_page() && isset($post) && '' == get_post_meta($post->ID, '_siteseo_titles_desc', true)) { //STATIC HOMEPAGE
			if ( ! empty($descriptionOption)) {
				$descriptionTemplate = $this->getHomeDescriptionTemplate($siteseo_titles_template_variables_array, $siteseo_titles_template_replace_array);
			}
		} elseif (is_home() && '' != get_post_meta($page_id, '_siteseo_titles_desc', true)) { //BLOG PAGE
			if (get_post_meta($page_id, '_siteseo_titles_desc', true)) {
				$description_meta = esc_html(get_post_meta($page_id, '_siteseo_titles_desc', true));
				$description	  = $description_meta;

				$descriptionTemplate = str_replace($siteseo_titles_template_variables_array, $siteseo_titles_template_replace_array, $description);
			}
		} elseif (is_home() && ('posts' == get_option('show_on_front'))) { //YOUR LATEST POSTS
			if ( ! function_exists('siteseo_get_service')) {
				if ( ! empty($descriptionOption)) {
					$description		 = esc_attr($descriptionOption);
					$descriptionTemplate = str_replace($siteseo_titles_template_variables_array, $siteseo_titles_template_replace_array, $description);
				}
			} else {
				$description		 = siteseo_get_service('TitleOption')->getHomeDescriptionTitle();
				$descriptionTemplate = $this->tagsToStringService->replace($description, $context);
			}
		} elseif (function_exists('bp_is_group') && bp_is_group()) {
			if ('' != siteseo_get_service('TitleOption')->getBpGroupsDesc()) {
				$description = esc_attr(siteseo_get_service('TitleOption')->getBpGroupsDesc());

				$descriptionTemplate = str_replace($siteseo_titles_template_variables_array, $siteseo_titles_template_replace_array, $description);
			}
		} elseif (is_singular()) { //IS SINGLE
				if (get_post_meta($post->ID, '_siteseo_titles_desc', true)) { //IS METABOXE
					$description = esc_attr(get_post_meta($post->ID, '_siteseo_titles_desc', true));

					preg_match_all('/%%_cf_(.*?)%%/', $description, $matches); //custom fields

					if ( ! empty($matches)) {
						$siteseo_titles_cf_template_variables_array = [];
						$siteseo_titles_cf_template_replace_array   = [];

						foreach ($matches['0'] as $key => $value) {
							$siteseo_titles_cf_template_variables_array[] = $value;
						}

						foreach ($matches['1'] as $key => $value) {
							$siteseo_titles_cf_template_replace_array[] = esc_attr(get_post_meta($post->ID, $value, true));
						}
					}

					preg_match_all('/%%_ct_(.*?)%%/', $description, $matches2); //custom terms taxonomy

					if ( ! empty($matches2)) {
						$siteseo_titles_ct_template_variables_array = [];
						$siteseo_titles_ct_template_replace_array   = [];

						foreach ($matches2['0'] as $key => $value) {
							$siteseo_titles_ct_template_variables_array[] = $value;
						}

						foreach ($matches2['1'] as $key => $value) {
							$term = wp_get_post_terms($post->ID, $value);
							if ( ! is_wp_error($term)) {
								$terms									   = esc_attr($term[0]->name);
								$siteseo_titles_ct_template_replace_array[] = apply_filters('siteseo_titles_custom_tax', $terms, $value);
							}
						}
					}

					preg_match_all('/%%_ucf_(.*?)%%/', $description, $matches3); //user meta

					if ( ! empty($matches3)) {
						$siteseo_titles_ucf_template_variables_array = [];
						$siteseo_titles_ucf_template_replace_array   = [];

						foreach ($matches3['0'] as $key => $value) {
							$siteseo_titles_ucf_template_variables_array[] = $value;
						}

						foreach ($matches3['1'] as $key => $value) {
							$siteseo_titles_ucf_template_replace_array[] = esc_attr(get_user_meta(get_current_user_id(), $value, true));
						}
					}

					//Default
					$descriptionTemplate = str_replace($siteseo_titles_template_variables_array, $siteseo_titles_template_replace_array, $description);

					//Custom fields
					if ( ! empty($matches) && ! empty($siteseo_titles_cf_template_variables_array) && ! empty($siteseo_titles_cf_template_replace_array)) {
						$descriptionTemplate = str_replace($siteseo_titles_cf_template_variables_array, $siteseo_titles_cf_template_replace_array, $descriptionTemplate);
					}

					//Custom terms taxonomy
					if ( ! empty($matches2) && ! empty($siteseo_titles_ct_template_variables_array) && ! empty($siteseo_titles_ct_template_replace_array)) {
						$descriptionTemplate = str_replace($siteseo_titles_ct_template_variables_array, $siteseo_titles_ct_template_replace_array, $descriptionTemplate);
					}

					//User meta
					if ( ! empty($matches3) && ! empty($siteseo_titles_ucf_template_variables_array) && ! empty($siteseo_titles_ucf_template_replace_array)) {
						$descriptionTemplate = str_replace($siteseo_titles_ucf_template_variables_array, $siteseo_titles_ucf_template_replace_array, $descriptionTemplate);
					}
				} elseif ('' != siteseo_titles_single_desc_option()) { //IS GLOBAL
					$description = esc_attr(siteseo_titles_single_desc_option());

					preg_match_all('/%%_cf_(.*?)%%/', $description, $matches); //custom fields

					if ( ! empty($matches)) {
						$siteseo_titles_cf_template_variables_array = [];
						$siteseo_titles_cf_template_replace_array   = [];

						foreach ($matches['0'] as $key => $value) {
							$siteseo_titles_cf_template_variables_array[] = $value;
						}

						foreach ($matches['1'] as $key => $value) {
							$siteseo_titles_cf_template_replace_array[] = esc_attr(get_post_meta($post->ID, $value, true));
						}
					}

					preg_match_all('/%%_ct_(.*?)%%/', $description, $matches2); //custom terms taxonomy

					if ( ! empty($matches2)) {
						$siteseo_titles_ct_template_variables_array = [];
						$siteseo_titles_ct_template_replace_array   = [];

						foreach ($matches2['0'] as $key => $value) {
							$siteseo_titles_ct_template_variables_array[] = $value;
						}

						foreach ($matches2['1'] as $key => $value) {
							$term = wp_get_post_terms($post->ID, $value);
							if ( ! is_wp_error($term)) {
								$terms									   = esc_attr($term[0]->name);
								$siteseo_titles_ct_template_replace_array[] = apply_filters('siteseo_titles_custom_tax', $terms, $value);
							}
						}
					}

					preg_match_all('/%%_ucf_(.*?)%%/', $description, $matches3); //user meta

					if ( ! empty($matches3)) {
						$siteseo_titles_ucf_template_variables_array = [];
						$siteseo_titles_ucf_template_replace_array   = [];

						foreach ($matches3['0'] as $key => $value) {
							$siteseo_titles_ucf_template_variables_array[] = $value;
						}

						foreach ($matches3['1'] as $key => $value) {
							$siteseo_titles_ucf_template_replace_array[] = esc_attr(get_user_meta(get_current_user_id(), $value, true));
						}
					}

					//Default
					$descriptionTemplate = str_replace($siteseo_titles_template_variables_array, $siteseo_titles_template_replace_array, $description);

					//Custom fields
					if ( ! empty($matches) && ! empty($siteseo_titles_cf_template_variables_array) && ! empty($siteseo_titles_cf_template_replace_array)) {
						$descriptionTemplate = str_replace($siteseo_titles_cf_template_variables_array, $siteseo_titles_cf_template_replace_array, $descriptionTemplate);
					}

					//Custom terms taxonomy
					if ( ! empty($matches2) && ! empty($siteseo_titles_ct_template_variables_array) && ! empty($siteseo_titles_ct_template_replace_array)) {
						$descriptionTemplate = str_replace($siteseo_titles_ct_template_variables_array, $siteseo_titles_ct_template_replace_array, $descriptionTemplate);
					}

					//User meta
					if ( ! empty($matches3) && ! empty($siteseo_titles_ucf_template_variables_array) && ! empty($siteseo_titles_ucf_template_replace_array)) {
						$descriptionTemplate = str_replace($siteseo_titles_ucf_template_variables_array, $siteseo_titles_ucf_template_replace_array, $descriptionTemplate);
					}
				} else {
					setup_postdata($post);
					if ('' != $siteseo_get_the_excerpt || '' != get_the_content()) { //DEFAULT EXCERPT OR THE CONTENT
						$description = wp_trim_words(stripslashes_deep(wp_filter_nohtml_kses($siteseo_get_the_excerpt)), $siteseo_excerpt_length);

						$descriptionTemplate = str_replace($siteseo_titles_template_variables_array, $siteseo_titles_template_replace_array, $description);
					}
				}
		} elseif (is_post_type_archive() && siteseo_titles_archive_desc_option()) { //IS POST TYPE ARCHIVE
			$description = esc_attr(siteseo_titles_archive_desc_option());

			$descriptionTemplate = str_replace($siteseo_titles_template_variables_array, $siteseo_titles_template_replace_array, $description);
		} elseif ((is_tax() || is_category() || is_tag()) && siteseo_titles_tax_desc_option()) { //IS TAX
			$description = esc_attr(siteseo_titles_tax_desc_option());

			if (get_term_meta(get_queried_object()->{'term_id'}, '_siteseo_titles_desc', true)) {
				$descriptionTemplate = esc_attr(get_term_meta(get_queried_object()->{'term_id'}, '_siteseo_titles_desc', true));
				$descriptionTemplate = str_replace($siteseo_titles_template_variables_array, $siteseo_titles_template_replace_array, $descriptionTemplate);
			} else {
				$descriptionTemplate = str_replace($siteseo_titles_template_variables_array, $siteseo_titles_template_replace_array, $description);
			}
		} elseif (is_author() && siteseo_get_service('TitleOption')->getArchivesAuthorDescription()) { //IS AUTHOR
			$description = esc_attr(siteseo_get_service('TitleOption')->getArchivesAuthorDescription());

			preg_match_all('/%%_ucf_(.*?)%%/', $description, $matches); //custom fields

			if ( ! empty($matches)) {
				$siteseo_titles_cf_template_variables_array = [];
				$siteseo_titles_cf_template_replace_array   = [];

				foreach ($matches['0'] as $key => $value) {
					$siteseo_titles_cf_template_variables_array[] = $value;
				}

				foreach ($matches['1'] as $key => $value) {
					$siteseo_titles_cf_template_replace_array[] = esc_attr(get_user_meta(get_current_user_id(), $value, true));
				}
			}

			//Default
			$descriptionTemplate = esc_attr(siteseo_get_service('TitleOption')->getArchivesAuthorDescription());

			//Custom fields
			if ( ! empty($matches) && ! empty($siteseo_titles_cf_template_variables_array) && ! empty($siteseo_titles_cf_template_replace_array)) {
				$descriptionTemplate = str_replace($siteseo_titles_cf_template_variables_array, $siteseo_titles_cf_template_replace_array, $descriptionTemplate);
			}

			$descriptionTemplate = str_replace($siteseo_titles_template_variables_array, $siteseo_titles_template_replace_array, $descriptionTemplate);
		} elseif (is_date() && siteseo_get_service('TitleOption')->getArchivesDateDesc()) { //IS DATE
			$description = esc_attr(siteseo_get_service('TitleOption')->getArchivesDateDesc());

			$descriptionTemplate = str_replace($siteseo_titles_template_variables_array, $siteseo_titles_template_replace_array, $description);
		} elseif (is_search() && siteseo_get_service('TitleOption')->getArchivesSearchDesc()) { //IS SEARCH
			$description = esc_attr(siteseo_get_service('TitleOption')->getArchivesSearchDesc());

			$descriptionTemplate = str_replace($siteseo_titles_template_variables_array, $siteseo_titles_template_replace_array, $description);
		} elseif (is_404() && siteseo_get_service('TitleOption')->getArchives404Desc()) { //IS 404
			$description = esc_attr(siteseo_get_service('TitleOption')->getArchives404Desc());

			$descriptionTemplate = str_replace($siteseo_titles_template_variables_array, $siteseo_titles_template_replace_array, $description);
		}
		//Hook on meta description - 'siteseo_titles_desc'
		if (has_filter('siteseo_titles_desc')) {
			$descriptionTemplate = apply_filters('siteseo_titles_desc', $descriptionTemplate);
		}

		//Return meta desc tag
		return $descriptionTemplate;
	}
}