first commit
This commit is contained in:
288
wp-content/plugins/polylang-pro/vendor/wpsyntex/polylang/install/upgrade.php
vendored
Normal file
288
wp-content/plugins/polylang-pro/vendor/wpsyntex/polylang/install/upgrade.php
vendored
Normal file
@@ -0,0 +1,288 @@
|
||||
<?php
|
||||
/**
|
||||
* @package Polylang
|
||||
*/
|
||||
|
||||
/**
|
||||
* Manages Polylang upgrades
|
||||
*
|
||||
* @since 1.2
|
||||
*/
|
||||
class PLL_Upgrade {
|
||||
/**
|
||||
* Stores the plugin options.
|
||||
*
|
||||
* @var array
|
||||
*/
|
||||
public $options;
|
||||
|
||||
/**
|
||||
* Constructor
|
||||
*
|
||||
* @since 1.2
|
||||
*
|
||||
* @param array $options Polylang options
|
||||
*/
|
||||
public function __construct( &$options ) {
|
||||
$this->options = &$options;
|
||||
}
|
||||
|
||||
/**
|
||||
* Check if upgrade is possible otherwise die to avoid activation
|
||||
*
|
||||
* @since 1.2
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
public function can_activate() {
|
||||
if ( ! $this->can_upgrade() ) {
|
||||
ob_start();
|
||||
$this->admin_notices(); // FIXME the error message is displayed two times
|
||||
die( ob_get_contents() ); // phpcs:ignore WordPress.Security.EscapeOutput
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Upgrades if possible otherwise returns false to stop Polylang loading
|
||||
*
|
||||
* @since 1.2
|
||||
*
|
||||
* @return bool true if upgrade is possible, false otherwise
|
||||
*/
|
||||
public function upgrade() {
|
||||
if ( ! $this->can_upgrade() ) {
|
||||
add_action( 'all_admin_notices', array( $this, 'admin_notices' ) );
|
||||
return false;
|
||||
}
|
||||
|
||||
delete_transient( 'pll_languages_list' );
|
||||
add_action( 'admin_init', array( $this, '_upgrade' ) );
|
||||
return true;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Check if we the previous version is not too old
|
||||
* Upgrades if OK
|
||||
* /!\ never start any upgrade before admin_init as it is likely to conflict with some other plugins
|
||||
*
|
||||
* @since 1.2
|
||||
*
|
||||
* @return bool true if upgrade is possible, false otherwise
|
||||
*/
|
||||
public function can_upgrade() {
|
||||
// Don't manage upgrade from version < 1.8
|
||||
return version_compare( $this->options['version'], '1.8', '>=' );
|
||||
}
|
||||
|
||||
/**
|
||||
* Displays a notice when ugrading from a too old version
|
||||
*
|
||||
* @since 1.0
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
public function admin_notices() {
|
||||
load_plugin_textdomain( 'polylang' );
|
||||
printf(
|
||||
'<div class="error"><p>%s</p><p>%s</p></div>',
|
||||
esc_html__( 'Polylang has been deactivated because you upgraded from a too old version.', 'polylang' ),
|
||||
sprintf(
|
||||
/* translators: %1$s and %2$s are Polylang version numbers */
|
||||
esc_html__( 'Before upgrading to %2$s, please upgrade to %1$s.', 'polylang' ),
|
||||
'<strong>2.9</strong>',
|
||||
POLYLANG_VERSION // phpcs:ignore WordPress.Security.EscapeOutput
|
||||
)
|
||||
);
|
||||
}
|
||||
|
||||
/**
|
||||
* Upgrades the plugin depending on the previous version
|
||||
*
|
||||
* @since 1.2
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
public function _upgrade() {
|
||||
foreach ( array( '2.0.8', '2.1', '2.7', '3.4' ) as $version ) {
|
||||
if ( version_compare( $this->options['version'], $version, '<' ) ) {
|
||||
$method_to_call = array( $this, 'upgrade_' . str_replace( '.', '_', $version ) );
|
||||
if ( is_callable( $method_to_call ) ) {
|
||||
call_user_func( $method_to_call );
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
$this->options['previous_version'] = $this->options['version']; // Remember the previous version of Polylang since v1.7.7
|
||||
$this->options['version'] = POLYLANG_VERSION;
|
||||
update_option( 'polylang', $this->options );
|
||||
}
|
||||
|
||||
/**
|
||||
* Upgrades if the previous version is < 2.0.8
|
||||
* Changes the user meta 'user_lang' to 'locale' to match WP 4.7 choice
|
||||
*
|
||||
* @since 2.0.8
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
protected function upgrade_2_0_8() {
|
||||
global $wpdb;
|
||||
$wpdb->update( $wpdb->usermeta, array( 'meta_key' => 'locale' ), array( 'meta_key' => 'user_lang' ) );
|
||||
}
|
||||
|
||||
/**
|
||||
* Upgrades if the previous version is < 2.1.
|
||||
* Moves strings translations from polylang_mo post_content to post meta _pll_strings_translations.
|
||||
*
|
||||
* @since 2.1
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
protected function upgrade_2_1() {
|
||||
$posts = get_posts(
|
||||
array(
|
||||
'post_type' => 'polylang_mo',
|
||||
'post_status' => 'any',
|
||||
'numberposts' => -1,
|
||||
'nopaging' => true,
|
||||
)
|
||||
);
|
||||
|
||||
if ( is_array( $posts ) ) {
|
||||
foreach ( $posts as $post ) {
|
||||
$meta = get_post_meta( $post->ID, '_pll_strings_translations', true );
|
||||
|
||||
if ( empty( $meta ) ) {
|
||||
$strings = maybe_unserialize( $post->post_content );
|
||||
if ( is_array( $strings ) ) {
|
||||
update_post_meta( $post->ID, '_pll_strings_translations', $strings );
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Upgrades if the previous version is < 2.7
|
||||
* Replace numeric keys by hashes in WPML registered strings
|
||||
* Dismiss the wizard notice for existing sites
|
||||
*
|
||||
* @since 2.7
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
protected function upgrade_2_7() {
|
||||
$strings = get_option( 'polylang_wpml_strings' );
|
||||
if ( is_array( $strings ) ) {
|
||||
$new_strings = array();
|
||||
|
||||
foreach ( $strings as $string ) {
|
||||
$context = $string['context'];
|
||||
$name = $string['name'];
|
||||
|
||||
$key = md5( "$context | $name" );
|
||||
$new_strings[ $key ] = $string;
|
||||
}
|
||||
update_option( 'polylang_wpml_strings', $new_strings );
|
||||
}
|
||||
|
||||
PLL_Admin_Notices::dismiss( 'wizard' );
|
||||
}
|
||||
|
||||
/**
|
||||
* Upgrades if the previous version is < 3.4.0.
|
||||
*
|
||||
* @since 3.4
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
protected function upgrade_3_4() {
|
||||
$this->migrate_locale_fallback_to_language_description();
|
||||
|
||||
$this->migrate_strings_translations();
|
||||
}
|
||||
|
||||
/**
|
||||
* Moves strings translations from post meta to term meta _pll_strings_translations.
|
||||
*
|
||||
* @since 3.4
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
protected function migrate_strings_translations() {
|
||||
$posts = get_posts(
|
||||
array(
|
||||
'post_type' => 'polylang_mo',
|
||||
'post_status' => 'any',
|
||||
'numberposts' => -1,
|
||||
'nopaging' => true,
|
||||
)
|
||||
);
|
||||
|
||||
if ( ! is_array( $posts ) ) {
|
||||
return;
|
||||
}
|
||||
|
||||
foreach ( $posts as $post ) {
|
||||
$meta = get_post_meta( $post->ID, '_pll_strings_translations', true );
|
||||
|
||||
$term_id = (int) substr( $post->post_title, 12 );
|
||||
|
||||
// Do not delete post metas in case a user needs to rollback to Polylang < 3.4.
|
||||
|
||||
if ( empty( $meta ) || ! is_array( $meta ) ) {
|
||||
continue;
|
||||
}
|
||||
|
||||
update_term_meta( $term_id, '_pll_strings_translations', wp_slash( $meta ) );
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Migrate locale fallback to language term description.
|
||||
*
|
||||
* @since 3.4
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
protected function migrate_locale_fallback_to_language_description() {
|
||||
// Migrate locale fallbacks from term metas to language term description.
|
||||
$terms = get_terms(
|
||||
array(
|
||||
'taxonomy' => 'language',
|
||||
'hide_empty' => false,
|
||||
'meta_query' => array( // phpcs:ignore WordPress.DB.SlowDBQuery.slow_db_query_meta_query
|
||||
array(
|
||||
'key' => 'fallback',
|
||||
'compare_key' => 'EXISTS',
|
||||
),
|
||||
),
|
||||
)
|
||||
);
|
||||
|
||||
if ( ! is_array( $terms ) ) {
|
||||
return;
|
||||
}
|
||||
|
||||
foreach ( $terms as $term ) {
|
||||
$fallbacks = get_term_meta( $term->term_id, 'fallback', true );
|
||||
|
||||
delete_term_meta( $term->term_id, 'fallback' );
|
||||
|
||||
if ( empty( $fallbacks ) || ! is_array( $fallbacks ) ) {
|
||||
// Empty or invalid value, should not happen.
|
||||
continue;
|
||||
}
|
||||
|
||||
$description = maybe_unserialize( $term->description );
|
||||
$description = is_array( $description ) ? $description : array();
|
||||
|
||||
$description['fallbacks'] = $fallbacks;
|
||||
/** @var string */
|
||||
$description = maybe_serialize( $description );
|
||||
|
||||
wp_update_term( $term->term_id, 'language', array( 'description' => $description ) );
|
||||
}
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user