File: /home/rockyroadprintin/www/wp-content/plugins/wp-rocket/inc/functions/i18n.php
<?php
defined( 'ABSPATH' ) || exit;
/**
 * Get all langs to display in admin bar for WPML
 *
 * @since 1.3.0
 *
 * @return array $langlinks List of active languages
 */
function get_rocket_wpml_langs_for_admin_bar() {  // phpcs:ignore WordPress.NamingConventions.PrefixAllGlobals
	global $sitepress;
	$langlinks = [];
	// Making all languages the first option either when it's set or not.
	$langlinks[] = [
		'code'    => 'all',
		'current' => 'all' === $sitepress->get_current_language(),
		'anchor'  => __( 'All languages', 'rocket' ),
		'flag'    => '<img class="icl_als_iclflag" src="' . ICL_PLUGIN_URL . '/res/img/icon16.png" alt="all" width="16" height="16" />',
	];
	foreach ( $sitepress->get_active_languages() as $lang ) {
		// Get flag.
		$flag     = $sitepress->get_flag( $lang['code'] );
		$flag_url = ICL_PLUGIN_URL . '/res/flags/' . $flag->flag;
		if ( $flag->from_template ) {
			$wp_upload_dir = wp_upload_dir();
			$flag_url      = $wp_upload_dir['baseurl'] . '/flags/' . $flag->flag;
		}
		$langlinks[] = [
			'code'    => $lang['code'],
			'current' => $lang['code'] === $sitepress->get_current_language(),
			'anchor'  => $lang['display_name'],
			'flag'    => '<img class="icl_als_iclflag" src="' . esc_url( $flag_url ) . '" alt="' . esc_attr( $lang['code'] ) . '" width="18" height="12" />',
		];
	}
	return $langlinks;
}
/**
 * Get all langs to display in admin bar for qTranslate
 *
 * @since 2.7 add fork param
 * @since 1.3.5
 *
 * @param string $fork qTranslate fork name.
 * @return array $langlinks List of active languages
 */
function get_rocket_qtranslate_langs_for_admin_bar( $fork = '' ) { // phpcs:ignore WordPress.NamingConventions.PrefixAllGlobals
	global $q_config;
	$langlinks   = [];
	$currentlang = [];
	foreach ( $q_config['enabled_languages'] as $lang ) {
		$langlinks[ $lang ] = [
			'code'   => $lang,
			'anchor' => $q_config['language_name'][ $lang ],
			'flag'   => '<img src="' . esc_url( trailingslashit( WP_CONTENT_URL ) . $q_config['flag_location'] . $q_config['flag'][ $lang ] ) . '" alt="' . esc_attr( $q_config['language_name'][ $lang ] ) . '" width="18" height="12" />',
		];
	}
	if ( isset( $_GET['lang'] ) ) { // phpcs:ignore WordPress.Security.NonceVerification.Recommended
		$lang = sanitize_key( $_GET['lang'] ); // phpcs:ignore WordPress.Security.NonceVerification.Recommended
		if ( 'x' === $fork ) {
			if ( qtranxf_isEnabled( $lang ) ) {
				$currentlang[ $lang ] = $langlinks[ $lang ];
				unset( $langlinks[ $lang ] );
				$langlinks = $currentlang + $langlinks;
			}
		} elseif ( qtrans_isEnabled( $lang ) ) {
			$currentlang[ $lang ] = $langlinks[ $lang ];
			unset( $langlinks[ $lang ] );
			$langlinks = $currentlang + $langlinks;
		}
	}
	return $langlinks;
}
/**
 * Get all langs to display in admin bar for Polylang
 *
 * @since 2.2
 *
 * @return array $langlinks List of active languages
 */
function get_rocket_polylang_langs_for_admin_bar() { // phpcs:ignore WordPress.NamingConventions.PrefixAllGlobals
	global $polylang;
	$langlinks   = [];
	$currentlang = [];
	$langs       = [];
	$img         = '';
	$pll = function_exists( 'PLL' ) ? PLL() : $polylang;
	if ( isset( $pll ) ) {
		$langs = $pll->model->get_languages_list();
		if ( ! empty( $langs ) ) {
			foreach ( $langs as $lang ) {
				if ( ! empty( $lang->flag ) ) {
					$img = strpos( $lang->flag, 'img' ) !== false ? $lang->flag . ' ' : $lang->flag;
				}
				if ( isset( $pll->curlang->slug ) && $lang->slug === $pll->curlang->slug ) {
					$currentlang[ $lang->slug ] = [
						'code'   => $lang->slug,
						'anchor' => $lang->name,
						'flag'   => $img,
					];
				} else {
					$langlinks[ $lang->slug ] = [
						'code'   => $lang->slug,
						'anchor' => $lang->name,
						'flag'   => $img,
					];
				}
			}
		}
	}
	return $currentlang + $langlinks;
}
/**
 * Tell if a translation plugin is activated.
 *
 * @since 2.0
 * @since 3.2.1 Return an identifier on success instead of true.
 *
 * @return string An identifier corresponding to the active plugin.
 */
function rocket_has_i18n() {
	global $sitepress, $q_config, $polylang;
	if ( ! empty( $sitepress ) && is_object( $sitepress ) && method_exists( $sitepress, 'get_active_languages' ) ) {
		// WPML.
		return 'wpml';
	}
	if ( ! empty( $polylang ) && function_exists( 'pll_languages_list' ) ) {
		$languages = pll_languages_list();
		if ( empty( $languages ) ) {
			return '';
		}
		// Polylang, Polylang Pro.
		return 'polylang';
	}
	if ( ! empty( $q_config ) && is_array( $q_config ) ) {
		if ( function_exists( 'qtranxf_convertURL' ) ) {
			// qTranslate-x.
			return 'qtranslate-x';
		}
		if ( function_exists( 'qtrans_convertURL' ) ) {
			// qTranslate.
			return 'qtranslate';
		}
	}
	$identifier = '';
	$default    = $identifier;
	/**
	 * Filters the value of i18n plugin detection
	 *
	 * @param string $identifier An identifier value.
	 */
	$identifier = apply_filters( 'rocket_has_i18n', $identifier );
	if ( ! is_string( $identifier ) ) {
		$identifier = $default;
	}
	return $identifier;
}
/**
 * Get infos of all active languages.
 *
 * @since 2.0
 *
 * @return array A list of language codes.
 */
function get_rocket_i18n_code() { // phpcs:ignore WordPress.NamingConventions.PrefixAllGlobals
	$i18n_plugin = rocket_has_i18n();
	if ( ! $i18n_plugin ) {
		return [];
	}
	if ( 'wpml' === $i18n_plugin ) {
		// WPML.
		return array_keys( $GLOBALS['sitepress']->get_active_languages() );
	}
	if ( 'qtranslate' === $i18n_plugin || 'qtranslate-x' === $i18n_plugin ) {
		// qTranslate, qTranslate-x.
		return ! empty( $GLOBALS['q_config']['enabled_languages'] ) ? $GLOBALS['q_config']['enabled_languages'] : [];
	}
	if ( 'polylang' === $i18n_plugin ) {
		// Polylang, Polylang Pro.
		return pll_languages_list();
	}
	$codes   = [];
	$default = $codes;
	/**
	 * Filters the active languages codes list
	 *
	 * @param array $codes Array of languages codes.
	 */
	$codes = apply_filters( 'rocket_get_i18n_code', $codes );
	if ( ! is_array( $codes ) ) {
		$codes = $default;
	}
	return $codes;
}
/**
 * Get all active languages host
 *
 * @since 2.6.8
 *
 * @return array $urls List of all active languages host
 */
function get_rocket_i18n_host() { // phpcs:ignore WordPress.NamingConventions.PrefixAllGlobals
	$langs_host = [];
	$langs      = get_rocket_i18n_uri();
	if ( empty( $langs ) ) {
		return $langs_host;
	}
	foreach ( $langs as $lang ) {
		$langs_host[] = wp_parse_url( $lang, PHP_URL_HOST );
	}
	return $langs_host;
}
/**
 * Get all active languages URI.
 *
 * @since 2.0
 *
 * @return array $urls List of all active languages URI.
 */
function get_rocket_i18n_uri() { // phpcs:ignore WordPress.NamingConventions.PrefixAllGlobals
	$i18n_plugin = rocket_has_i18n();
	$urls        = [];
	if ( 'wpml' === $i18n_plugin ) {
		// WPML.
		foreach ( get_rocket_i18n_code() as $lang ) {
			$urls[] = $GLOBALS['sitepress']->language_url( $lang );
		}
	} elseif ( 'qtranslate' === $i18n_plugin || 'qtranslate-x' === $i18n_plugin ) {
		// qTranslate, qTranslate-x.
		foreach ( get_rocket_i18n_code() as $lang ) {
			if ( 'qtranslate' === $i18n_plugin ) {
				$urls[] = qtrans_convertURL( home_url(), $lang, true );
			} else {
				$urls[] = qtranxf_convertURL( home_url(), $lang, true );
			}
		}
	} elseif ( 'polylang' === $i18n_plugin ) {
		// Polylang, Polylang Pro.
		$pll = function_exists( 'PLL' ) ? PLL() : $GLOBALS['polylang'];
		if ( ! empty( $pll ) && is_object( $pll ) ) {
			if ( ! defined( 'POLYLANG_VERSION' ) || version_compare( POLYLANG_VERSION, '3.4', '<' ) ) {
				$urls = wp_list_pluck( $pll->model->get_languages_list(), 'search_url' );
			}else {
				$languages = $pll->model->get_languages_list();
				foreach ( $languages as $language ) {
					$urls[] = $language->get_home_url();
				}
			}
		}
	}
	/**
	 * Filters the value of all active languages URI
	 *
	 * @param array Array of active languages URI.
	 */
	$urls = apply_filters( 'rocket_get_i18n_uri', $urls );
	if (
		! is_array( $urls )
		||
		empty( $urls )
	) {
		$urls[] = home_url();
	}
	return $urls;
}
/**
 * Get directories paths to preserve languages when purging a domain.
 * This function is required when the domains of languages (other than the default) are managed by subdirectories.
 * By default, when you clear the cache of the french website with the domain example.com, all subdirectory like /en/
 * and /de/ are deleted. But, if you have a domain for your english and german websites with example.com/en/ and
 * example.com/de/, you want to keep the /en/ and /de/ directory when the french domain is cleared.
 *
 * @since 3.5.5 Normalize paths + micro-optimization by passing in the cache path.
 * @since 2.0
 *
 * @param string $current_lang The current language code.
 * @param string $cache_path   Optional. WP Rocket's cache path.
 *
 * @return array                A list of directories path to preserve.
 */
function get_rocket_i18n_to_preserve( $current_lang, $cache_path = '' ) { // phpcs:ignore WordPress.NamingConventions.PrefixAllGlobals
	// Must not be an empty string.
	if ( empty( $current_lang ) ) {
		return [];
	}
	// Must not be anything else but a string.
	if ( ! is_string( $current_lang ) ) {
		return [];
	}
	$i18n_plugin = rocket_has_i18n();
	if ( ! $i18n_plugin ) {
		return [];
	}
	$langs = get_rocket_i18n_code();
	if ( empty( $langs ) ) {
		return [];
	}
	// Remove current lang to the preserve dirs.
	$langs = array_diff( $langs, [ $current_lang ] );
	if ( '' === $cache_path ) {
		$cache_path = _rocket_get_wp_rocket_cache_path();
	}
	// Stock all URLs of langs to preserve.
	$langs_to_preserve = [];
	foreach ( $langs as $lang ) {
		$parse_url           = get_rocket_parse_url( get_rocket_i18n_home_url( $lang ) );
		$langs_to_preserve[] = _rocket_normalize_path(
			"{$cache_path}{$parse_url['host']}(.*)/" . trim( $parse_url['path'], '/' ),
			true // escape directory separators for regex.
		);
	}
	/**
	 * Filter directories path to preserve of cache purge.
	 *
	 * @since 2.1
	 *
	 * @param array $langs_to_preserve List of directories path to preserve.
	 */
	return (array) apply_filters( 'rocket_langs_to_preserve', $langs_to_preserve );
}
/**
 * Get all languages subdomains URLs
 *
 * @since 2.1
 *
 * @return array $urls List of languages subdomains URLs
 */
function get_rocket_i18n_subdomains() { // phpcs:ignore WordPress.NamingConventions.PrefixAllGlobals
	$i18n_plugin = rocket_has_i18n();
	if ( ! $i18n_plugin ) {
		return [];
	}
	$urls    = [];
	$default = $urls;
	switch ( $i18n_plugin ) {
		// WPML.
		case 'wpml':
			$option = get_option( 'icl_sitepress_settings' );
			if ( 2 === (int) $option['language_negotiation_type'] ) {
				$urls = get_rocket_i18n_uri();
			}
			break;
		// qTranslate.
		case 'qtranslate':
			if ( 3 === (int) $GLOBALS['q_config']['url_mode'] ) {
				$urls = get_rocket_i18n_uri();
			}
			break;
		// qTranslate-x.
		case 'qtranslate-x':
			if ( 3 === (int) $GLOBALS['q_config']['url_mode'] || 4 === (int) $GLOBALS['q_config']['url_mode'] ) {
				$urls = get_rocket_i18n_uri();
			}
			break;
		// Polylang, Polylang Pro.
		case 'polylang':
			$pll = function_exists( 'PLL' ) ? PLL() : $GLOBALS['polylang'];
			if ( ! empty( $pll ) && is_object( $pll ) && ( 2 === (int) $pll->options['force_lang'] || 3 === (int) $pll->options['force_lang'] ) ) {
				$urls = get_rocket_i18n_uri();
			}
			break;
		default:
			/**
			 * Filters the list of languages subdomains URLs
			 *
			 * @param array $urls Array of languages subdomains URLs.
			 */
			$urls = apply_filters( 'rocket_i18n_subdomains', $urls );
			if ( ! is_array( $urls ) ) {
				$urls = $default;
			}
	}
	return $urls;
}
/**
 * Get home URL of a specific lang.
 *
 * @since 2.2
 *
 * @param  string $lang The language code. Default is an empty string.
 * @return string $url
 */
function get_rocket_i18n_home_url( $lang = '' ) { // phpcs:ignore WordPress.NamingConventions.PrefixAllGlobals
	$i18n_plugin = rocket_has_i18n();
	$home_url = home_url();
	$default  = $home_url;
	if ( ! $i18n_plugin ) {
		return $home_url;
	}
	switch ( $i18n_plugin ) {
		// WPML.
		case 'wpml':
			$home_url = $GLOBALS['sitepress']->language_url( $lang );
			break;
			// qTranslate.
		case 'qtranslate':
			$home_url = qtrans_convertURL( home_url(), $lang, true );
			break;
			// qTranslate-x.
		case 'qtranslate-x':
			$home_url = qtranxf_convertURL( home_url(), $lang, true );
			break;
			// Polylang, Polylang Pro.
		case 'polylang':
			$pll = function_exists( 'PLL' ) ? PLL() : $GLOBALS['polylang'];
			if ( ! empty( $pll->options['force_lang'] ) && isset( $pll->links ) ) {
				$home_url = pll_home_url( $lang );
			}
			break;
		default:
			/**
			 * Filters the home URL value for a specific language
			 *
			 * @param string $home_url Home URL.
			 * @param string $lang     The language code.
			 */
			$home_url = apply_filters( 'rocket_i18n_home_url', $home_url, $lang );
			if ( ! is_string( $home_url ) ) {
				$home_url = $default;
			}
	}
	return $home_url;
}
/**
 * Get all translated path of a specific post with ID.
 *
 * @since 2.4
 *
 * @param  int    $post_id   Post ID.
 * @param  string $post_type Post Type.
 * @param  string $regex     Regex to include at the end.
 * @return array
 */
function get_rocket_i18n_translated_post_urls( $post_id, $post_type = 'page', $regex = '' ) { // phpcs:ignore WordPress.NamingConventions.PrefixAllGlobals
	$url  = get_permalink( $post_id );
	$path = wp_parse_url( $url, PHP_URL_PATH );
	if ( empty( $path ) ) {
		return [];
	}
	$i18n_plugin = rocket_has_i18n();
	$urls    = [];
	$default = $urls;
	switch ( $i18n_plugin ) {
		// WPML.
		case 'wpml':
			$langs = get_rocket_i18n_code();
			if ( $langs ) {
				foreach ( $langs as $lang ) {
					$urls[] = wp_parse_url( get_permalink( icl_object_id( $post_id, $post_type, true, $lang ) ), PHP_URL_PATH ) . $regex;
				}
			}
			break;
		// qTranslate & qTranslate-x.
		case 'qtranslate':
		case 'qtranslate-x':
			$langs  = $GLOBALS['q_config']['enabled_languages'];
			$langs  = array_diff( $langs, [ $GLOBALS['q_config']['default_language'] ] );
			$urls[] = wp_parse_url( $url, PHP_URL_PATH ) . $regex;
			if ( $langs ) {
				foreach ( $langs as $lang ) {
					if ( 'qtranslate' === $i18n_plugin ) {
						$urls[] = wp_parse_url( qtrans_convertURL( $url, $lang, true ), PHP_URL_PATH ) . $regex;
					} elseif ( 'qtranslate-x' === $i18n_plugin ) {
						$urls[] = wp_parse_url( qtranxf_convertURL( $url, $lang, true ), PHP_URL_PATH ) . $regex;
					}
				}
			}
			break;
		// Polylang.
		case 'polylang':
			if ( function_exists( 'PLL' ) && is_object( PLL()->model ) ) {
				$translations = pll_get_post_translations( $post_id );
			} elseif ( ! empty( $GLOBALS['polylang']->model ) && is_object( $GLOBALS['polylang']->model ) ) {
				$translations = $GLOBALS['polylang']->model->get_translations( 'page', $post_id );
			}
			if ( ! empty( $translations ) ) {
				foreach ( $translations as $translation_post_id ) {
					$urls[] = wp_parse_url( get_permalink( $translation_post_id ), PHP_URL_PATH ) . $regex;
				}
			}
			break;
		default:
			/**
			 * Filters the list of translated URLs for a post ID
			 *
			 * @param array  $urls Array of translated URLs.
			 * @param string $url URL to use.
			 * @param string $post_type Post type.
			 * @param string $regex Pattern to include at the end.
			 */
			$urls = apply_filters( 'rocket_i18n_translated_post_urls', $urls, $url, $post_type, $regex );
			if ( ! is_array( $urls ) ) {
				$urls = $default;
			}
	}
	if ( trim( $path, '/' ) !== '' ) {
		$urls[] = $path . $regex;
	}
	return array_unique( $urls );
}
/**
 * Returns the home URL, without WPML filters if the plugin is active
 *
 * @since 3.2.4
 *
 * @param string $path Path to add to the home URL.
 * @return string
 */
function rocket_get_home_url( $path = '' ) {
	global $wpml_url_filters;
	static $home_url = [];
	static $has_wpml;
	if ( isset( $home_url[ $path ] ) ) {
		return $home_url[ $path ];
	}
	if ( ! isset( $has_wpml ) ) {
		$has_wpml = $wpml_url_filters && is_object( $wpml_url_filters ) && method_exists( $wpml_url_filters, 'home_url_filter' );
	}
	if ( $has_wpml ) {
		remove_filter( 'home_url', [ $wpml_url_filters, 'home_url_filter' ], -10 );
	}
	$home_url[ $path ] = home_url( $path );
	if ( $has_wpml ) {
		add_filter( 'home_url', [ $wpml_url_filters, 'home_url_filter' ], -10, 4 );
	}
	return $home_url[ $path ];
}
/**
 * Gets the current language
 *
 * @since 3.3.3
 *
 * @return string
 */
function rocket_get_current_language() {
	$i18n_plugin = rocket_has_i18n();
	if ( ! $i18n_plugin ) {
		return '';
	}
	$current_language = '';
	$default          = $current_language;
	if ( 'polylang' === $i18n_plugin && function_exists( 'pll_current_language' ) ) {
		return pll_current_language();
	} elseif ( 'wpml' === $i18n_plugin ) {
		return apply_filters( 'wpml_current_language', null ); // phpcs:ignore WordPress.NamingConventions.PrefixAllGlobals
	}
	/**
	 * Filters the current language value
	 *
	 * @param string $current_language Current language.
	 */
	$current_language = apply_filters( 'rocket_i18n_current_language', $current_language );
	if ( ! is_string( $current_language ) ) {
		$current_language = $default;
	}
	return $current_language;
}