wp/wp-content/plugins/option-tree/includes/class-ot-cleanup.php
author ymh <ymh.work@gmail.com>
Mon, 14 Oct 2019 18:35:50 +0200
changeset 11 bf1778c34b9a
permissions -rw-r--r--
upgrade optiontree
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
11
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
     1
<?php
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
     2
/**
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
     3
 * OptionTree Cleanup.
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
     4
 *
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
     5
 * @package OptionTree
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
     6
 */
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
     7
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
     8
if ( ! defined( 'OT_VERSION' ) ) {
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
     9
	exit( 'No direct script access allowed' );
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    10
}
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    11
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    12
if ( ! class_exists( 'OT_Cleanup' ) ) {
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    13
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    14
	/**
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    15
	 * OptionTree Cleanup class.
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    16
	 *
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    17
	 * This class loads all the OptionTree Cleanup methods and helpers.
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    18
	 */
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    19
	class OT_Cleanup {
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    20
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    21
		/**
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    22
		 * Class constructor.
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    23
		 *
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    24
		 * This method adds other methods of the class to specific hooks within WordPress.
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    25
		 *
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    26
		 * @uses add_action()
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    27
		 *
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    28
		 * @access public
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    29
		 * @since  2.4.6
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    30
		 */
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    31
		public function __construct() {
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    32
			if ( ! is_admin() ) {
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    33
				return;
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    34
			}
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    35
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    36
			// Load styles.
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    37
			add_action( 'admin_head', array( $this, 'styles' ), 1 );
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    38
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    39
			// Maybe Clean up OptionTree.
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    40
			add_action( 'admin_menu', array( $this, 'maybe_cleanup' ), 100 );
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    41
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    42
			// Increase timeout if allowed.
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    43
			add_action( 'ot_pre_consolidate_posts', array( $this, 'increase_timeout' ) );
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    44
		}
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    45
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    46
		/**
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    47
		 * Adds the cleanup styles to the admin head
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    48
		 *
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    49
		 * @access public
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    50
		 * @since  2.5.0
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    51
		 */
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    52
		public function styles() {
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    53
			echo '<style>#toplevel_page_ot-cleanup{display:none;}</style>';
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    54
		}
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    55
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    56
		/**
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    57
		 * Check if OptionTree needs to be cleaned up from a previous install.
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    58
		 *
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    59
		 * @access public
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    60
		 * @since  2.4.6
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    61
		 */
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    62
		public function maybe_cleanup() {
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    63
			global $wpdb, $ot_maybe_cleanup_posts, $ot_maybe_cleanup_table;
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    64
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    65
			$table_name             = $wpdb->prefix . 'option_tree';
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    66
			$page                   = isset( $_GET['page'] ) ? sanitize_text_field( wp_unslash( $_GET['page'] ) ) : ''; // phpcs:ignore
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    67
			$ot_maybe_cleanup_posts = count( $wpdb->get_results( "SELECT * FROM $wpdb->posts WHERE post_type = 'option-tree' LIMIT 2" ) ) > 1; // phpcs:ignore
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    68
			$ot_maybe_cleanup_table = $wpdb->get_var( $wpdb->prepare( 'SHOW TABLES LIKE %s', $table_name ) ) == $table_name; // phpcs:ignore
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    69
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    70
			if ( ! $ot_maybe_cleanup_posts && ! $ot_maybe_cleanup_table && 'ot-cleanup' === $page ) {
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    71
				wp_safe_redirect( apply_filters( 'ot_theme_options_parent_slug', 'themes.php' ) . '?page=' . apply_filters( 'ot_theme_options_menu_slug', 'ot-theme-options' ) );
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    72
				exit;
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    73
			}
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    74
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    75
			if ( $ot_maybe_cleanup_posts || $ot_maybe_cleanup_table ) {
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    76
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    77
				if ( 'ot-cleanup' !== $page ) {
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    78
					add_action( 'admin_notices', array( $this, 'cleanup_notice' ) );
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    79
				}
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    80
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    81
				$theme_check_bs = 'add_menu_' . 'page'; // phpcs:ignore
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    82
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    83
				$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' ) );
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    84
			}
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    85
		}
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    86
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    87
		/**
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    88
		 * Adds an admin nag.
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    89
		 *
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    90
		 * @access public
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    91
		 * @since  2.4.6
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    92
		 */
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    93
		public function cleanup_notice() {
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    94
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    95
			if ( 'appearance_page_ot-cleanup' !== get_current_screen()->id ) {
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    96
				$link = sprintf( '<a href="%s">%s</a>', admin_url( 'themes.php?page=ot-cleanup' ), apply_filters( 'ot_cleanup_menu_title', esc_html__( 'OptionTree Cleanup', 'option-tree' ) ) );
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    97
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    98
				/* translators: %s: internal admin page URL */
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
    99
				echo '<div class="update-nag">' . sprintf( esc_html__( 'OptionTree has outdated data that should be removed. Please go to %s for more information.', 'option-tree' ), $link ) . '</div>'; // phpcs:ignore
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   100
			}
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   101
		}
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   102
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   103
		/**
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   104
		 * Adds a Tools sub page to clean up the database with.
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   105
		 *
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   106
		 * @access public
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   107
		 * @since  2.4.6
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   108
		 */
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   109
		public function options_page() {
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   110
			global $wpdb, $ot_maybe_cleanup_posts, $ot_maybe_cleanup_table;
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   111
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   112
			// Option ID.
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   113
			$option_id = 'ot_media_post_ID';
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   114
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   115
			// Get the media post ID.
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   116
			$post_ID = get_option( $option_id, false );
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   117
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   118
			// Zero loop count.
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   119
			$count = 0;
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   120
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   121
			// Check for safe mode.
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   122
			$safe_mode = ini_get( 'safe_mode' ); // phpcs:ignore
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   123
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   124
			echo '<div class="wrap">';
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   125
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   126
			echo '<h2>' . apply_filters( 'ot_cleanup_page_title', esc_html__( 'OptionTree Cleanup', 'option-tree' ) ) . '</h2>'; // phpcs:ignore
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   127
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   128
			if ( $ot_maybe_cleanup_posts ) {
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   129
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   130
				$posts = $wpdb->get_results( "SELECT * FROM $wpdb->posts WHERE post_type = 'option-tree'" ); // phpcs:ignore
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   131
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   132
				echo '<h3>' . esc_html__( 'Multiple Media Posts', 'option-tree' ) . '</h3>';
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   133
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   134
				/* translators: %1$s: number of media posts, %2$s: media post type, %3$s: table name */
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   135
				$string = esc_html__( 'There are currently %1$s OptionTree media posts in your database. At some point in the past, a version of OptionTree added multiple %2$s media post objects cluttering up your %3$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' );
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   136
				echo '<p>' . sprintf( $string, '<code>' . number_format( count( $posts ) ) . '</code>', '<tt>option-tree</tt>', '<tt>' . $wpdb->posts . '</tt>' ) . '</p>'; // phpcs:ignore
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   137
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   138
				/* translators: %s: number of media posts being deleted  */
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   139
				echo '<p>' . sprintf( esc_html__( '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' ), '<code>' . number_format( count( $posts ) - 1 ) . '</code>' ) . '</p>';
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   140
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   141
				echo '<p><strong>' . esc_html__( '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' ) . '</strong></p>';
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   142
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   143
				/* translators: %1$s: the word Note wrapped in a strong attribute, %2$s: number of posts being deleted */
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   144
				$string = __( '%1$s: Your server is running in safe mode. Which means this page will automatically reload after deleting %2$s posts, you can filter this number using %3$s if your server is having trouble processing that many at one time.', 'option-tree' );
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   145
				echo $safe_mode ? '<p>' . sprintf( $string, '<strong>' . esc_html__( 'Note', 'option-tree' ) . '</strong>:', apply_filters( 'ot_consolidate_posts_reload', 500 ), '<tt>ot_consolidate_posts_reload</tt>' ) . '</p>' : ''; // phpcs:ignore
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   146
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   147
				echo '<p><a class="button button-primary" href="' . wp_nonce_url( admin_url( 'themes.php?page=ot-cleanup' ), 'consolidate-posts' ) . '">' . esc_html__( 'Consolidate Posts', 'option-tree' ) . '</a></p>'; // phpcs:ignore
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   148
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   149
				if ( isset( $_GET['_wpnonce'] ) && wp_verify_nonce( $_GET['_wpnonce'], 'consolidate-posts' ) ) { // phpcs:ignore
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   150
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   151
					if ( false === $post_ID || empty( $post_ID ) ) {
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   152
						$post_ID = isset( $posts[0]->ID ) ? $posts[0]->ID : null;
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   153
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   154
						// Add to the DB.
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   155
						if ( null !== $post_ID ) {
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   156
							update_option( $option_id, $post_ID );
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   157
						}
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   158
					}
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   159
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   160
					// Do pre consolidation action to increase timeout.
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   161
					do_action( 'ot_pre_consolidate_posts' );
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   162
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   163
					// Loop over posts.
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   164
					foreach ( $posts as $post ) {
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   165
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   166
						// Don't destroy the correct post.
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   167
						if ( $post_ID === $post->ID ) {
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   168
							continue;
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   169
						}
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   170
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   171
						// Update count.
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   172
						$count++;
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   173
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   174
						// Reload script in safe mode.
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   175
						if ( $safe_mode && $count > absint( apply_filters( 'ot_consolidate_posts_reload', 500 ) ) ) {
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   176
							echo '<br />' . esc_html__( 'Reloading...', 'option-tree' );
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   177
							echo '
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   178
                <script>
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   179
                  setTimeout( ot_script_reload, 3000 )
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   180
                  function ot_script_reload() {
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   181
                    window.location = "' . esc_url_raw( self_admin_url( 'themes.php?page=ot-cleanup&_wpnonce=' . wp_create_nonce( 'consolidate-posts' ) ) ) . '"
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   182
                  }
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   183
                </script>';
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   184
							break;
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   185
						}
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   186
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   187
						// Get the attachments.
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   188
						$attachments = get_children( 'post_type=attachment&post_parent=' . $post->ID );
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   189
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   190
						// Update the attachments parent ID.
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   191
						if ( ! empty( $attachments ) ) {
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   192
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   193
							/* translators: %1$s: the post type, %2$s: the post ID  */
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   194
							$string = esc_html__( 'Updating Attachments parent ID for %1$s post %2$s.', 'option-tree' );
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   195
							echo sprintf( $string . '<br />', '<tt>option-tree</tt>', '<tt>#' . $post->ID . '</tt>' ); // phpcs:ignore
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   196
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   197
							foreach ( $attachments as $attachment_id => $attachment ) {
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   198
								wp_update_post(
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   199
									array(
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   200
										'ID'          => $attachment_id,
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   201
										'post_parent' => $post_ID,
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   202
									)
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   203
								);
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   204
							}
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   205
						}
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   206
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   207
						/* translators: %1$s: the post type, %2$s: the post ID  */
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   208
						$string = esc_html__( 'Deleting %1$s post %2$s.', 'option-tree' );
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   209
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   210
						// Delete post.
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   211
						echo sprintf( $string . '<br />', '<tt>option-tree</tt>', '<tt>#' . $post->ID . '</tt>' ); // phpcs:ignore
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   212
						wp_delete_post( $post->ID, true );
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   213
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   214
					}
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   215
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   216
					echo '<br />' . esc_html__( 'Clean up script has completed, the page will now reload...', 'option-tree' );
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   217
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   218
					echo '
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   219
            <script>
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   220
              setTimeout( ot_script_reload, 3000 )
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   221
              function ot_script_reload() {
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   222
                window.location = "' . esc_url_raw( self_admin_url( 'themes.php?page=ot-cleanup' ) ) . '"
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   223
              }
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   224
            </script>';
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   225
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   226
				}
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   227
			}
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   228
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   229
			if ( $ot_maybe_cleanup_table ) {
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   230
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   231
				$table_name = $wpdb->prefix . 'option_tree';
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   232
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   233
				echo $ot_maybe_cleanup_posts ? '<hr />' : '';
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   234
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   235
				echo '<h3>' . esc_html__( 'Outdated Table', 'option-tree' ) . '</h3>';
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   236
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   237
				/* translators: %s: table name  */
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   238
				$string = esc_html__( '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' );
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   239
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   240
				echo '<p>' . sprintf( $string, '<tt>' . $table_name . '</tt>' ) . '</p>'; // phpcs:ignore
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   241
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   242
				echo '<p><a class="button button-primary" href="' . esc_url_raw( wp_nonce_url( admin_url( 'themes.php?page=ot-cleanup' ), 'drop-table' ) ) . '">' . esc_html__( 'Drop Table', 'option-tree' ) . '</a></p>';
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   243
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   244
				if ( isset( $_GET['_wpnonce'] ) && wp_verify_nonce( $_GET['_wpnonce'], 'drop-table' ) ) { // phpcs:ignore
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   245
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   246
					/* translators: %s: table name  */
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   247
					$string = esc_html__( 'Deleting the outdated and unused %s table...', 'option-tree' );
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   248
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   249
					echo '<p>' . sprintf( $string, '<tt>' . $table_name . '</tt>' ) . '</p>'; // phpcs:ignore
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   250
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   251
					$wpdb->query( "DROP TABLE IF EXISTS $table_name" ); // phpcs:ignore
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   252
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   253
					if ( $wpdb->get_var( $wpdb->prepare( 'SHOW TABLES LIKE %s', $table_name ) ) != $table_name ) { // phpcs:ignore
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   254
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   255
						/* translators: %s: table name  */
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   256
						$string = esc_html__( 'The %s table has been successfully deleted. The page will now reload...', 'option-tree' );
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   257
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   258
						echo '<p>' . sprintf( $string, '<tt>' . $table_name . '</tt>' ) . '</p>'; // phpcs:ignore
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   259
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   260
						echo '
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   261
              <script>
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   262
                setTimeout( ot_script_reload, 3000 )
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   263
                function ot_script_reload() {
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   264
                  window.location = "' . esc_url_raw( self_admin_url( 'themes.php?page=ot-cleanup' ) ) . '"
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   265
                }
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   266
              </script>';
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   267
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   268
					} else {
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   269
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   270
						/* translators: %s: table name  */
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   271
						$string = esc_html__( 'Something went wrong. The %s table was not deleted.', 'option-tree' );
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   272
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   273
						echo '<p>' . sprintf( $string, '<tt>' . $table_name . '</tt>' ) . '</p>'; // phpcs:ignore
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   274
					}
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   275
				}
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   276
			}
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   277
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   278
			echo '</div>';
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   279
		}
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   280
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   281
		/**
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   282
		 * Increase PHP timeout.
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   283
		 *
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   284
		 * This is to prevent bulk operations from timing out
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   285
		 *
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   286
		 * @access public
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   287
		 * @since  2.4.6
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   288
		 */
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   289
		public function increase_timeout() {
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   290
			if ( ! ini_get( 'safe_mode' ) ) { // phpcs:ignore
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   291
				@set_time_limit( 0 ); // phpcs:ignore
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   292
			}
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   293
		}
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   294
	}
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   295
}
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   296
bf1778c34b9a upgrade optiontree
ymh <ymh.work@gmail.com>
parents:
diff changeset
   297
new OT_Cleanup();