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’ 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;
}
}