diff --git a/newspack-custom-content-migrator.php b/newspack-custom-content-migrator.php index 310f97803..7939f8fd1 100644 --- a/newspack-custom-content-migrator.php +++ b/newspack-custom-content-migrator.php @@ -84,6 +84,7 @@ // Publisher specific, remove when launched. Command\PublisherSpecific\CarsonNowMigrator::class, Command\PublisherSpecific\ArkansasTimesMigrator::class, + Command\PublisherSpecific\DallasVoiceMigrator::class, Command\PublisherSpecific\ZocaloMigrator::class, ) ); diff --git a/src/Command/PublisherSpecific/DallasVoiceMigrator.php b/src/Command/PublisherSpecific/DallasVoiceMigrator.php new file mode 100644 index 000000000..4dac5b0dc --- /dev/null +++ b/src/Command/PublisherSpecific/DallasVoiceMigrator.php @@ -0,0 +1,602 @@ +logger = new Logger(); + $this->block_generator = new GutenbergBlockGenerator(); + } + + /** + * Singleton. + * + * @return DallasVoiceMigrator + */ + public static function get_instance(): self { + static $instance = null; + if ( null === $instance ) { + $instance = new self(); + } + + return $instance; + } + + /** + * Register WP CLI commands. + */ + public function register_commands(): void { + WP_CLI::add_command( + 'newspack-content-migrator dallasvoice-hide-featured-image-if-used-in-post-content', + [ $this, 'cmd_hide_featured_image_if_used_in_post_content' ], + [ + 'shortdesc' => 'Hides the Featured Image if it\'s being used in post content', + ] + ); + + WP_CLI::add_command( + 'newspack-content-migrator dallasvoice-migrate-galleries', + [ $this, 'cmd_migrate_galleries_from_bwg_to_wp_gallery' ], + [ + 'shortdesc' => 'Migrates the Galleries from Best WordPress Gallery (Photo Gallery plugin) to WordPress Gallery block', + ] + ); + + WP_CLI::add_command( + 'newspack-content-migrator dallasvoice-fix-image-blocks-wrong-attachment-id-reference', + [ $this, 'cmd_fix_image_blocks_wrong_attachment_id_reference' ], + [ + 'shortdesc' => 'Fix wrong attachment ID reference in Image Blocks', + ] + ); + + WP_CLI::add_command( + 'newspack-content-migrator dallasvoice-fix-gallery-blocks-wrong-attachment-id-reference', + [ $this, 'cmd_fix_gallery_blocks_wrong_attachment_id_reference' ], + [ + 'shortdesc' => 'Fix wrong attachment ID reference in Gallery Blocks', + ] + ); + } + + /** + * Hides the Featured Image if it\'s being used in post content. + * + * Alias for `newspack-content-migrator hide-featured-image-if-used-in-post-content --anywhere-in-post-content` + */ + public function cmd_hide_featured_image_if_used_in_post_content(): void { + WP_CLI::runcommand( + 'newspack-content-migrator hide-featured-image-if-used-in-post-content --anywhere-in-post-content', + [ + 'launch' => false, + ] + ); + } + + /** + * Migrates the Galleries from Best WordPress Gallery (Photo Gallery plugin) to WordPress Gallery block. + */ + public function cmd_migrate_galleries_from_bwg_to_wp_gallery(): void { + global $wpdb; + + require_once ABSPATH . 'wp-admin/includes/media.php'; + require_once ABSPATH . 'wp-admin/includes/file.php'; + require_once ABSPATH . 'wp-admin/includes/image.php'; + + $default_author = get_user_by( 'login', self::DEFAULT_USERNAME ); + + $uploads_dir = wp_upload_dir(); + + $migration_datetime = date( 'Y-m-d H-i-s' ); + $migration_name = 'dallasvoice-migrate-galleries'; + + // Logs. + $log = $migration_datetime . '-' . $migration_name . '.log'; + + // CSV. + $csv = $migration_datetime . '-' . $migration_name . '.csv'; + $csv_file_pointer = fopen( $csv, 'w' ); + fputcsv( + $csv_file_pointer, + [ + '#', + 'Post ID', + 'Old Content', + 'New Content', + 'Gallery', + 'Local URL', + 'Staging URL', + 'Live URL', + ] + ); + + $posts = $wpdb->get_col( + $wpdb->prepare( + "SELECT `ID` FROM `$wpdb->posts` WHERE `post_type` IN ('post', 'page') AND `post_content` LIKE '%Best_Wordpress_Gallery%'" + ) + ); + + $progress_bar = WP_CLI\Utils\make_progress_bar( 'Migrating Galleries', count( $posts ), 1 ); + + foreach ( $posts as $post_index => $post_id ) { + $old_content = get_post_field( 'post_content', $post_id ); + $new_content = $old_content; + + $count_matches = preg_match_all( '~' . get_shortcode_regex( [ 'Best_Wordpress_Gallery' ] ) . '~', $old_content, $matches ); + + for ( $i = 0; $i < $count_matches; $i++ ) { + $shortcode_atts = shortcode_parse_atts( $matches[0][ $i ] ); + $gallery_settings = $this->bwg_get_gallery_settings( $shortcode_atts['id'] ); + + $bwg_gallery_id = $gallery_settings['gallery_id']; + + $gallery_images_ids = $wpdb->get_results( + $wpdb->prepare( + "SELECT * + FROM `{$wpdb->prefix}bwg_image` + WHERE `gallery_id` = %d + ORDER BY `order` ASC", + $bwg_gallery_id + ) + ); + + $gallery_attachments_ids = []; + + foreach ( $gallery_images_ids as $gallery_image_data ) { + copy( + trailingslashit( $uploads_dir['basedir'] ) . 'photo-gallery' . $gallery_image_data->image_url, + getcwd() . '/' . $gallery_image_data->image_url, + ); + + $attachment_id = $wpdb->get_var( + $wpdb->prepare( + "SELECT `post_id` + FROM `$wpdb->postmeta` + WHERE `meta_key` = 'newspack_bwg_image_id' + AND `meta_value` = %d", + $gallery_image_data->id + ) + ); + + $filename = pathinfo( str_replace( '/', '', $gallery_image_data->image_url ) ); + $filename = substr( $filename['filename'], 0, 150 ) . '.' . $filename['extension']; + + if ( ! $attachment_id ) { + $attachment_id = media_handle_sideload( + [ + 'name' => $filename, + 'tmp_name' => getcwd() . '/' . $gallery_image_data->image_url, + ], + 0, + $gallery_image_data->alt ?? $gallery_image_data->filename, + [ + 'post_author' => $default_author->ID, + 'post_content' => $gallery_image_data->description, + 'post_excerpt' => $gallery_image_data->description, + ] + ); + } + + if ( is_wp_error( $attachment_id ) ) { + echo 'Post ID: ' . $post_id . "\r\n"; + echo 'Gallery Image ID: ' . $gallery_image_data->id . "\r\n"; + var_dump( 'WP Error', $attachment_id ); + exit; + } + + update_post_meta( $attachment_id, '_wp_attachment_image_alt', $gallery_image_data->alt ); + update_post_meta( $attachment_id, 'newspack_bwg_image_id', $gallery_image_data->id ); + update_post_meta( $attachment_id, 'newspack_bwg_gallery_id', $bwg_gallery_id ); + + $gallery_attachments_ids[] = $attachment_id; + } + + $gallery_shortcode = '[gallery ids="' . implode( ',', $gallery_attachments_ids ) . '" columns="3" size="large" link="file"]'; + + $new_content = str_replace( $matches[0][ $i ], $gallery_shortcode, $new_content ); + } + + wp_update_post( + [ + 'ID' => $post_id, + 'post_content' => $new_content, + ] + ); + + update_post_meta( $post_id, 'newspack_bwg_migration_post_updated', $migration_datetime ); + + fputcsv( + $csv_file_pointer, + [ + $post_index + 1, // #. + $post_id, // Post ID. + $old_content, // Old Content. + $new_content, // New Content. + implode( ' ', $matches[0] ), // Shortcodes. + get_permalink( $post_id ), // Local URL. + str_replace( home_url( '/' ), 'https://dallasvoice-newspack.newspackstaging.com/', get_permalink( $post_id ) ), // Staging URL. + str_replace( home_url( '/' ), 'https://dallasvoice.com/', get_permalink( $post_id ) ), // Live URL. + ] + ); + + $progress_bar->tick( 1, sprintf( '[Memory: %s]', size_format( memory_get_usage( true ) ) ) ); + } + + $progress_bar->finish(); + + // Close CSV. + fclose( $csv_file_pointer ); + + WP_CLI::success( sprintf( 'Done. See %s', $log ) ); + } + + /** + * Migrates the Galleries from Best WordPress Gallery (Photo Gallery plugin) to WordPress Gallery block. + */ + public function cmd_fix_image_blocks_wrong_attachment_id_reference( array $args, array $assoc_args ): void { + $dry_run = ! empty( $assoc_args['dry-run'] ) ? (bool) $assoc_args['dry-run'] : false; + $post_id_from = ! empty( $assoc_args['post-id-from'] ) ? (int) $assoc_args['post-id-from'] : 0; + + $migration_datetime = date( 'Y-m-d H-i-s' ); + $migration_name = 'dallasvoice-fix-image-blocks' . ( $dry_run ? '-dry-run' : '' ); + + // Logs. + $log = $migration_datetime . '-' . $migration_name . '.log'; + + // CSV. + $csv = $migration_datetime . '-' . $migration_name . '.csv'; + $csv_file_pointer = fopen( $csv, 'w' ); + fputcsv( + $csv_file_pointer, + [ + '#', + 'Post ID', + 'Post Title', + 'Old Content', + 'New Content', + 'Local URL', + 'Staging URL', + 'Live URL', + ] + ); + + global $wpdb; + + $post_ids = $wpdb->get_col( + $wpdb->prepare( + "SELECT `ID` FROM `$wpdb->posts` WHERE `post_type` IN ('post', 'page') AND `ID` > $post_id_from AND `post_content` LIKE '%