* @copyright Copyright (c) 2014, Derek Herman */ if ( ! class_exists( 'OT_Cleanup' ) ) { class OT_Cleanup { /** * PHP5 constructor method. * * This method adds other methods of the class to specific hooks within WordPress. * * @uses add_action() * * @return void * * @access public * @since 2.4.6 */ function __construct() { if ( ! is_admin() ) return; // Load styles add_action( 'admin_head', array( $this, 'styles' ), 1 ); // Maybe Clean up OptionTree add_action( 'admin_menu', array( $this, 'maybe_cleanup' ), 100 ); // Increase timeout if allowed add_action( 'ot_pre_consolidate_posts', array( $this, 'increase_timeout' ) ); } /** * Adds the cleanup styles to the admin head * * @return string * * @access public * @since 2.5.0 */ function styles() { echo ''; } /** * Check if OptionTree needs to be cleaned up from a previous install. * * @return void * * @access public * @since 2.4.6 */ public function maybe_cleanup() { global $wpdb, $table_prefix, $ot_maybe_cleanup_posts, $ot_maybe_cleanup_table; $posts = $wpdb->get_results( "SELECT * FROM $wpdb->posts WHERE post_type = 'option-tree' LIMIT 2" ); $table = $wpdb->get_results( "SHOW TABLES LIKE '{$table_prefix}option_tree'" ); $ot_maybe_cleanup_posts = count( $posts ) > 1; $ot_maybe_cleanup_table = count( $table ) == 1; $page = isset( $_GET['page'] ) ? $_GET['page'] : ''; if ( ! $ot_maybe_cleanup_posts && ! $ot_maybe_cleanup_table && $page == 'ot-cleanup' ) { wp_redirect( apply_filters( 'ot_theme_options_parent_slug', 'themes.php' ) . '?page=' . apply_filters( 'ot_theme_options_menu_slug', 'ot-theme-options' ) ); exit; } if ( $ot_maybe_cleanup_posts || $ot_maybe_cleanup_table ) { if ( $page != 'ot-cleanup' ) add_action( 'admin_notices', array( $this, 'cleanup_notice' ) ); $theme_check_bs = 'add_menu_page'; $theme_check_bs( apply_filters( 'ot_cleanup_page_title', __( 'OptionTree Cleanup', 'option-tree' ) ), apply_filters( 'ot_cleanup_menu_title', __( 'OptionTree Cleanup', 'option-tree' ) ), 'edit_theme_options', 'ot-cleanup', array( $this, 'options_page' ) ); } } /** * Adds an admin nag. * * @return string * * @access public * @since 2.4.6 */ public function cleanup_notice() { if ( get_current_screen()->id != 'appearance_page_ot-cleanup' ) echo '
' . sprintf( __( 'There are currently %s OptionTree media posts in your database. At some point in the past, a version of OptionTree added multiple %s media post objects cluttering up your %s table. There is no associated risk or harm that these posts have caused other than to add size to your overall database. Thankfully, there is a way to remove all these orphaned media posts and get your database cleaned up.', 'option-tree' ), '' . number_format( count( $posts ) ) . '', 'option-tree', '' . $wpdb->posts . '' ) . '
' . sprintf( __( 'By clicking the button below, OptionTree will delete %s records and consolidate them into one single OptionTree media post for uploading attachments to. Additionally, the attachments will have their parent ID updated to the correct media post.', 'option-tree' ), '' . number_format( count( $posts ) - 1 ) . '' ) . '
' . __( 'This could take a while to fully process depending on how many records you have in your database, so please be patient and wait for the script to finish.', 'option-tree' ) . '
'; echo $safe_mode ? '' . sprintf( __( '%s Your server is running in safe mode. Which means this page will automatically reload after deleting %s posts, you can filter this number using %s if your server is having trouble processing that many at one time.', 'option-tree' ), 'Note:', apply_filters( 'ot_consolidate_posts_reload', 500 ), 'ot_consolidate_posts_reload' ) . '
' : ''; echo '' . __( 'Consolidate Posts', 'option-tree' ) . '
'; if ( isset( $_GET['_wpnonce'] ) && wp_verify_nonce( $_GET['_wpnonce'], 'consolidate-posts' ) ) { if ( $post_ID === false || empty( $post_ID ) ) { $post_ID = isset( $posts[0]->ID ) ? $posts[0]->ID : null; // Add to the DB if ( $post_ID !== null ) update_option( $option_id, $post_ID ); } // Do pre consolidation action to increase timeout. do_action( 'ot_pre_consolidate_posts' ); // Loop over posts foreach( $posts as $post ) { // Don't destroy the correct post. if ( $post_ID == $post->ID ) continue; // Update count $count++; // Reload script in safe mode if ( $safe_mode && $count > apply_filters( 'ot_consolidate_posts_reload', 500 ) ) { echo '' . sprintf( __( 'If you have upgraded from an old 1.x version of OptionTree at some point, you have an extra %s table in your database that can be removed. It\'s not hurting anything, but does not need to be there. If you want to remove it. Click the button below.', 'option-tree' ), '' . $table_name . '' ) . '
'; echo '' . __( 'Drop Table', 'option-tree' ) . '
'; if ( isset( $_GET['_wpnonce'] ) && wp_verify_nonce( $_GET['_wpnonce'], 'drop-table' ) ) { echo '' . sprintf( __( 'Deleting the outdated and unused %s table...', 'option-tree' ), '' . $table_name . '' ) . '
'; $wpdb->query( "DROP TABLE IF EXISTS $table_name" ); if ( count( $wpdb->get_results( "SHOW TABLES LIKE '{$table_prefix}option_tree'" ) ) == 0 ) { echo '' . sprintf( __( 'The %s table has been successfully deleted. The page will now reload...', 'option-tree' ), '' . $table_name . '' ) . '
'; echo ' '; } else { echo '' . sprintf( __( 'Something went wrong. The %s table was not deleted.', 'option-tree' ), '' . $table_name . '' ) . '
'; } } } echo '