Skip to content

Commit

Permalink
Merge pull request #154 from humanmade/backport-150-to-v8-branch
Browse files Browse the repository at this point in the history
[Backport v8-branch] Improvements to migrate command
  • Loading branch information
roborourke authored Nov 19, 2021
2 parents 59af2d2 + 5abb58d commit cdf4f1d
Showing 1 changed file with 64 additions and 58 deletions.
122 changes: 64 additions & 58 deletions inc/namespace.php
Original file line number Diff line number Diff line change
Expand Up @@ -80,7 +80,10 @@ function bootstrap( Module $module ) {
add_filter( 'wpseo_should_save_indexable', '__return_true' );

// Migrations.
add_action( 'altis.migrate', __NAMESPACE__ . '\\do_migrations' );
add_action( 'altis.migrate', __NAMESPACE__ . '\\suggest_migrations' );
if ( defined( 'WP_CLI' ) && WP_CLI ) {
WP_CLI::add_command( 'altis migrate-seo', __NAMESPACE__ . '\\do_migrations' );
}
}

/**
Expand Down Expand Up @@ -449,6 +452,15 @@ function hide_yoast_premium_social_previews() {
echo "<style>$styles</style>"; // phpcs:ignore HM.Security.EscapeOutput.OutputNotEscaped
}

/**
* Suggestion migration command.
*
* @return void
*/
function suggest_migrations() : void {
WP_CLI::line( WP_CLI::colorize( '%yTo migrate SEO data for Altis v7 or earlier to Yoast SEO run `wp altis migrate-seo`%n' ) );
}

/**
* Run migration functions.
*
Expand Down Expand Up @@ -574,71 +586,65 @@ function migrate_wpseo_to_yoast() : void {
delete_option( 'wp-seo' );
}

// Ensure queries are not modified and go via the db, prevents ElasticPress integration etc...
remove_all_actions( 'pre_get_posts' );

// Handle post meta.
$posts_query_args = [
// Get all post types, even those with exclude_from_search (so "any" is not appropriate https://core.trac.wordpress.org/ticket/17592).
'post_type' => get_post_types(),
'post_status' => 'any',
'posts_per_page' => 0,
'fields' => 'ids',
// Ignore filters that may exclude certain post types from queries.
'suppress_filters' => true,
// phpcs:disable HM.Performance.SlowMetaQuery.dynamic_query -- check required for all of this meta. Performance here isn't a major issue, as this is only run manually on upgrade.
'meta_query' => [
'relation' => 'OR',
[
'meta_key' => '_meta_title',
'meta_compare' => 'EXISTS',
],
[
'meta_key' => '_meta_description',
'meta_compare' => 'EXISTS',
],
[
'meta_key' => '_meta_keywords',
'meta_compare' => 'EXISTS',
foreach ( array_keys( $meta_mapping ) as $meta_key ) {
$posts_query_args = [
// Get all public post types, even those with exclude_from_search (so "any" is not appropriate https://core.trac.wordpress.org/ticket/17592).
'post_type' => get_post_types( [ 'public' => true ] ),
'post_status' => 'any',
'posts_per_page' => 1,
'fields' => 'ids',
'suppress_filters' => true,
'meta_query' => [
[
'key' => $meta_key,
'compare' => 'EXISTS',
],
],
],
// phpcs:enable HM.Performance.SlowMetaQuery.dynamic_query
];
$posts = new WP_Query( $posts_query_args );

if ( $posts->found_posts > 0 ) {
$posts_query_args['posts_per_page'] = 100;
$posts_query_args['paged'] = 1;

$progress = WP_CLI\Utils\make_progress_bar( 'Copying post meta data', $posts->found_posts );

while ( $posts_query_args['paged'] <= $posts->max_num_pages ) {

$posts = new WP_Query( $posts_query_args );
$posts_query_args['paged']++;

foreach ( $posts->posts as $post_id ) {
foreach ( $meta_mapping as $old => $new ) {
// Copy post meta data over.
$value = get_post_meta( $post_id, $old, true );
// Handle keywords, Yoast only accepts 1 focus keyword by default so use the 1st.
if ( $old === '_meta_keywords' ) {
$value = explode( ',', $value );
$value = array_map( 'trim', $value );
$value = array_shift( $value );
];
$posts = new WP_Query( $posts_query_args );

if ( $posts->found_posts > 0 ) {
$posts_query_args['posts_per_page'] = 100;
$posts_query_args['paged'] = 1;

$progress = WP_CLI\Utils\make_progress_bar( sprintf( 'Copying %s data', $meta_key ), $posts->found_posts );

while ( $posts_query_args['paged'] <= $posts->max_num_pages ) {

$posts = new WP_Query( $posts_query_args );
$posts_query_args['paged']++;

foreach ( $posts->posts as $post_id ) {
foreach ( $meta_mapping as $old => $new ) {
// Copy post meta data over.
$value = get_post_meta( $post_id, $old, true );
// Handle keywords, Yoast only accepts 1 focus keyword by default so use the 1st.
if ( $old === '_meta_keywords' ) {
$value = explode( ',', $value );
$value = array_map( 'trim', $value );
$value = array_shift( $value );
}
// Update meta data if Yoast data not present.
if ( ! empty( $value ) && empty( get_post_meta( $post_id, $new, true ) ) ) {
update_post_meta( $post_id, $new, $value );
}
// Remove old meta data to prevent reprocessing.
delete_post_meta( $post_id, $old );
}
if ( ! empty( $value ) ) {
update_post_meta( $post_id, $new, $value );
}
// Remove old meta data to prevent reprocessing.
delete_post_meta( $post_id, $old );

$progress->tick();
}

$progress->tick();
// Prevent object cache consuming too much memory.
WP_CLI\Utils\wp_clear_object_cache();
}

// Prevent object cache consuming too much memory.
WP_CLI\Utils\wp_clear_object_cache();
$progress->finish();
}

$progress->finish();
}

restore_current_blog();
Expand Down

0 comments on commit cdf4f1d

Please sign in to comment.