mirror of
https://github.com/WordPress/WordPress.git
synced 2024-12-23 01:27:36 +01:00
First scrape at new UI for Bulk plugin upgrades. See #11232
git-svn-id: http://svn.automattic.com/wordpress/trunk@13602 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
parent
a9642826f3
commit
f3af366e3d
@ -297,6 +297,7 @@ class WP_Upgrader {
|
|||||||
$download = $this->download_package( $package );
|
$download = $this->download_package( $package );
|
||||||
if ( is_wp_error($download) ) {
|
if ( is_wp_error($download) ) {
|
||||||
$this->skin->error($download);
|
$this->skin->error($download);
|
||||||
|
$this->skin->after();
|
||||||
return $download;
|
return $download;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -304,6 +305,7 @@ class WP_Upgrader {
|
|||||||
$working_dir = $this->unpack_package( $download );
|
$working_dir = $this->unpack_package( $download );
|
||||||
if ( is_wp_error($working_dir) ) {
|
if ( is_wp_error($working_dir) ) {
|
||||||
$this->skin->error($working_dir);
|
$this->skin->error($working_dir);
|
||||||
|
$this->skin->after();
|
||||||
return $working_dir;
|
return $working_dir;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -409,6 +411,7 @@ class Plugin_Upgrader extends WP_Upgrader {
|
|||||||
|
|
||||||
$current = get_site_transient( 'update_plugins' );
|
$current = get_site_transient( 'update_plugins' );
|
||||||
if ( !isset( $current->response[ $plugin ] ) ) {
|
if ( !isset( $current->response[ $plugin ] ) ) {
|
||||||
|
$this->skin->before();
|
||||||
$this->skin->set_result(false);
|
$this->skin->set_result(false);
|
||||||
$this->skin->error('up_to_date');
|
$this->skin->error('up_to_date');
|
||||||
$this->skin->after();
|
$this->skin->after();
|
||||||
@ -466,15 +469,15 @@ class Plugin_Upgrader extends WP_Upgrader {
|
|||||||
|
|
||||||
$results = array();
|
$results = array();
|
||||||
|
|
||||||
$all = count($plugins);
|
$this->plugin_count = count($plugins);
|
||||||
$i = 1;
|
$this->plugin_current = 0;
|
||||||
foreach ( $plugins as $plugin ) {
|
foreach ( $plugins as $plugin ) {
|
||||||
|
$this->plugin_current++;
|
||||||
$this->show_before = sprintf( '<h4>' . __('Updating plugin %1$d of %2$d…') . '</h4>', $i, $all );
|
$this->skin->plugin_info = get_plugin_data( WP_PLUGIN_DIR . '/' . $plugin, false, true);
|
||||||
$i++;
|
|
||||||
|
|
||||||
if ( !isset( $current->response[ $plugin ] ) ) {
|
if ( !isset( $current->response[ $plugin ] ) ) {
|
||||||
$this->skin->set_result(false);
|
$this->skin->set_result(false);
|
||||||
|
$this->skin->before();
|
||||||
$this->skin->error('up_to_date');
|
$this->skin->error('up_to_date');
|
||||||
$this->skin->after();
|
$this->skin->after();
|
||||||
$results[$plugin] = false;
|
$results[$plugin] = false;
|
||||||
@ -502,7 +505,7 @@ class Plugin_Upgrader extends WP_Upgrader {
|
|||||||
// Prevent credentials auth screen from displaying multiple times
|
// Prevent credentials auth screen from displaying multiple times
|
||||||
if ( false === $result )
|
if ( false === $result )
|
||||||
break;
|
break;
|
||||||
}
|
} //end foreach $plugins
|
||||||
$this->maintenance_mode(false);
|
$this->maintenance_mode(false);
|
||||||
$this->skin->footer();
|
$this->skin->footer();
|
||||||
|
|
||||||
@ -645,6 +648,7 @@ class Theme_Upgrader extends WP_Upgrader {
|
|||||||
// Is an update available?
|
// Is an update available?
|
||||||
$current = get_site_transient( 'update_themes' );
|
$current = get_site_transient( 'update_themes' );
|
||||||
if ( !isset( $current->response[ $theme ] ) ) {
|
if ( !isset( $current->response[ $theme ] ) ) {
|
||||||
|
$this->skin->before();
|
||||||
$this->skin->set_result(false);
|
$this->skin->set_result(false);
|
||||||
$this->skin->error('up_to_date');
|
$this->skin->error('up_to_date');
|
||||||
$this->skin->after();
|
$this->skin->after();
|
||||||
@ -910,9 +914,6 @@ class Plugin_Upgrader_Skin extends WP_Upgrader_Skin {
|
|||||||
}
|
}
|
||||||
|
|
||||||
function after() {
|
function after() {
|
||||||
if ( $this->upgrader->bulk )
|
|
||||||
return;
|
|
||||||
|
|
||||||
$this->plugin = $this->upgrader->plugin_info();
|
$this->plugin = $this->upgrader->plugin_info();
|
||||||
if ( !empty($this->plugin) && !is_wp_error($this->result) && $this->plugin_active ){
|
if ( !empty($this->plugin) && !is_wp_error($this->result) && $this->plugin_active ){
|
||||||
show_message(__('Reactivating the plugin…'));
|
show_message(__('Reactivating the plugin…'));
|
||||||
@ -941,6 +942,103 @@ class Plugin_Upgrader_Skin extends WP_Upgrader_Skin {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Plugin Upgrader Skin for WordPress Plugin Upgrades.
|
||||||
|
*
|
||||||
|
* @package WordPress
|
||||||
|
* @subpackage Upgrader
|
||||||
|
* @since 3.0
|
||||||
|
*/
|
||||||
|
class Bulk_Plugin_Upgrader_Skin extends WP_Upgrader_Skin {
|
||||||
|
var $in_loop = false;
|
||||||
|
var $error = false;
|
||||||
|
|
||||||
|
function Plugin_Upgrader_Skin($args = array()) {
|
||||||
|
return $this->__construct($args);
|
||||||
|
}
|
||||||
|
|
||||||
|
function __construct($args = array()) {
|
||||||
|
$defaults = array( 'url' => '', 'nonce' => '' );
|
||||||
|
$args = wp_parse_args($args, $defaults);
|
||||||
|
|
||||||
|
parent::__construct($args);
|
||||||
|
}
|
||||||
|
|
||||||
|
function feedback($string) {
|
||||||
|
if ( isset( $this->upgrader->strings[$string] ) )
|
||||||
|
$string = $this->upgrader->strings[$string];
|
||||||
|
|
||||||
|
if ( strpos($string, '%') !== false ) {
|
||||||
|
$args = func_get_args();
|
||||||
|
$args = array_splice($args, 1);
|
||||||
|
if ( !empty($args) )
|
||||||
|
$string = vsprintf($string, $args);
|
||||||
|
}
|
||||||
|
if ( empty($string) )
|
||||||
|
return;
|
||||||
|
if ( $this->in_loop )
|
||||||
|
echo "$string<br />\n";
|
||||||
|
else
|
||||||
|
echo "<p>$string</p>\n";
|
||||||
|
}
|
||||||
|
|
||||||
|
function header() {
|
||||||
|
// Nothing, This will be displayed within a iframe.
|
||||||
|
}
|
||||||
|
|
||||||
|
function footer() {
|
||||||
|
// Nothing, This will be displayed within a iframe.
|
||||||
|
}
|
||||||
|
function error($error) {
|
||||||
|
if ( is_string($error) && isset( $this->upgrader->strings[$error] ) )
|
||||||
|
$this->error = $this->upgrader->strings[$error];
|
||||||
|
|
||||||
|
if ( is_wp_error($error) && $error->get_error_code() ) {
|
||||||
|
foreach ( $error->get_error_messages() as $emessage ) {
|
||||||
|
if ( $error->get_error_data() )
|
||||||
|
$messages[] = $emessage . ' ' . $error->get_error_data();
|
||||||
|
else
|
||||||
|
$messages[] = $emessage;
|
||||||
|
}
|
||||||
|
$this->error = implode(', ', $messages);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function before() {
|
||||||
|
$this->in_loop = true;
|
||||||
|
printf( '<h4>' . __('Updating Plugin %1$s (%2$d/%3$d)') . '</h4>', $this->plugin_info['Title'], $this->upgrader->plugin_current, $this->upgrader->plugin_count);
|
||||||
|
echo '<div class="update-messages" style="display:none" id="progress-' . esc_attr($this->upgrader->plugin_current) . '"><p>';
|
||||||
|
$this->flush_output();
|
||||||
|
}
|
||||||
|
|
||||||
|
function after() {
|
||||||
|
echo '</p></div>';
|
||||||
|
if ( $this->error || ! $this->result ) {
|
||||||
|
if ( $this->error )
|
||||||
|
echo '<div class="error"><p>' . sprintf(__('An error occured while updating %1$s: <strong>%2$s</strong>.'), $this->plugin_info['Title'], $this->error) . '</p></div>';
|
||||||
|
else
|
||||||
|
echo '<div class="error"><p>' . sprintf(__('The update of %1$s failed.'), $this->plugin_info['Title']) . '</p></div>';
|
||||||
|
echo '<script type="text/javascript">jQuery(\'#progress-' . esc_js($this->upgrader->plugin_current) . '\').show();</script>';
|
||||||
|
}
|
||||||
|
if ( !empty($this->result) && !is_wp_error($this->result) ) {
|
||||||
|
echo '<div class="updated"><p>' . sprintf(__('%1$s updated successfully. <a onclick="%2$s" href="#">See Details</a>.'), $this->plugin_info['Title'], 'jQuery(\'#progress-' . esc_js($this->upgrader->plugin_current) . '\').toggle(); return false;') . '</p></div>';
|
||||||
|
}
|
||||||
|
$this->reset();
|
||||||
|
$this->flush_output();
|
||||||
|
}
|
||||||
|
|
||||||
|
function reset() {
|
||||||
|
$this->in_loop = false;
|
||||||
|
$this->error = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
function flush_output() {
|
||||||
|
wp_ob_end_flush_all();
|
||||||
|
flush();
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Plugin Installer Skin for WordPress Plugin Installer.
|
* Plugin Installer Skin for WordPress Plugin Installer.
|
||||||
*
|
*
|
||||||
|
@ -271,6 +271,8 @@ function show_message($message) {
|
|||||||
$message = $message->get_error_message();
|
$message = $message->get_error_message();
|
||||||
}
|
}
|
||||||
echo "<p>$message</p>\n";
|
echo "<p>$message</p>\n";
|
||||||
|
wp_ob_end_flush_all();
|
||||||
|
flush();
|
||||||
}
|
}
|
||||||
|
|
||||||
function wp_doc_link_parse( $content ) {
|
function wp_doc_link_parse( $content ) {
|
||||||
|
@ -96,8 +96,6 @@ if ( !empty($action) ) {
|
|||||||
exit;
|
exit;
|
||||||
break;
|
break;
|
||||||
case 'update-selected' :
|
case 'update-selected' :
|
||||||
if ( ! current_user_can( 'update_plugins' ) )
|
|
||||||
wp_die( __( 'You do not have sufficient permissions to update plugins for this blog.' ) );
|
|
||||||
|
|
||||||
check_admin_referer( 'bulk-manage-plugins' );
|
check_admin_referer( 'bulk-manage-plugins' );
|
||||||
|
|
||||||
@ -106,34 +104,23 @@ if ( !empty($action) ) {
|
|||||||
elseif ( isset( $_POST['checked'] ) )
|
elseif ( isset( $_POST['checked'] ) )
|
||||||
$plugins = (array) $_POST['checked'];
|
$plugins = (array) $_POST['checked'];
|
||||||
else
|
else
|
||||||
break;
|
$plugins = array();
|
||||||
|
|
||||||
if ( empty( $plugins ) )
|
|
||||||
break;
|
|
||||||
|
|
||||||
// We'll be passing all checked plugins as long as at least one is out of date.
|
|
||||||
$_plugins = $plugins;
|
|
||||||
$current = get_site_transient( 'update_plugins' );
|
|
||||||
foreach ( $_plugins as $k => $v ) {
|
|
||||||
if ( ! isset( $current->response[ $v ] ) )
|
|
||||||
unset( $_plugins[ $k ] );
|
|
||||||
}
|
|
||||||
unset( $current );
|
|
||||||
// If all checked plugins are up to date
|
|
||||||
if ( empty( $_plugins ) )
|
|
||||||
break;
|
|
||||||
|
|
||||||
require_once( ABSPATH . 'wp-admin/includes/class-wp-upgrader.php' );
|
|
||||||
require_once( 'admin-header.php' );
|
|
||||||
|
|
||||||
$url = 'plugins.php?action=upgrade-selected&plugins=' . urlencode( join( ',', $plugins ) );
|
|
||||||
$title = __( 'Upgrade Plugins' );
|
$title = __( 'Upgrade Plugins' );
|
||||||
$nonce = 'bulk-manage-plugins';
|
|
||||||
$parent_file = 'plugins.php';
|
$parent_file = 'plugins.php';
|
||||||
|
|
||||||
$upgrader = new Plugin_Upgrader( new Plugin_Upgrader_Skin( compact( 'title', 'nonce', 'url' ) ) );
|
require_once( 'admin-header.php' );
|
||||||
$upgrader->bulk_upgrade( $plugins );
|
|
||||||
|
|
||||||
|
echo '<div class="wrap">';
|
||||||
|
screen_icon();
|
||||||
|
echo '<h2>' . esc_html( $title ) . '</h2>';
|
||||||
|
|
||||||
|
|
||||||
|
$url = 'update.php?action=update-selected&plugins=' . urlencode( join(',', $plugins) );
|
||||||
|
$url = wp_nonce_url($url, 'bulk-update-plugins');
|
||||||
|
|
||||||
|
echo "<iframe src='$url' style='width: 100%; height:100%; min-height:850px;'></iframe>";
|
||||||
|
echo '</div>';
|
||||||
require_once( 'admin-footer.php' );
|
require_once( 'admin-footer.php' );
|
||||||
exit;
|
exit;
|
||||||
break;
|
break;
|
||||||
|
@ -351,24 +351,6 @@ function no_update_actions($actions) {
|
|||||||
return '';
|
return '';
|
||||||
}
|
}
|
||||||
|
|
||||||
function do_plugin_upgrade() {
|
|
||||||
if ( isset( $_GET['plugins'] ) ) {
|
|
||||||
$plugins = explode( ',', $_GET['plugins'] );
|
|
||||||
} elseif ( isset( $_POST['checked'] ) ) {
|
|
||||||
$plugins = (array) $_POST['checked'];
|
|
||||||
} else {
|
|
||||||
// Nothing to do.
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
include_once ABSPATH . 'wp-admin/includes/class-wp-upgrader.php';
|
|
||||||
$url = 'update-core.php?action=do-plugin-upgrade&plugins=' . urlencode( implode( ',', $plugins ) );
|
|
||||||
$title = __( 'Upgrade Plugins' );
|
|
||||||
$nonce = 'upgrade-core';
|
|
||||||
$upgrader = new Plugin_Upgrader( new Plugin_Upgrader_Skin( compact( 'title', 'nonce', 'url' ) ) );
|
|
||||||
$upgrader->bulk_upgrade( $plugins );
|
|
||||||
}
|
|
||||||
|
|
||||||
$action = isset($_GET['action']) ? $_GET['action'] : 'upgrade-core';
|
$action = isset($_GET['action']) ? $_GET['action'] : 'upgrade-core';
|
||||||
|
|
||||||
$upgrade_error = false;
|
$upgrade_error = false;
|
||||||
@ -386,23 +368,46 @@ if ( 'upgrade-core' == $action ) {
|
|||||||
core_upgrade_preamble();
|
core_upgrade_preamble();
|
||||||
} elseif ( 'do-core-upgrade' == $action || 'do-core-reinstall' == $action ) {
|
} elseif ( 'do-core-upgrade' == $action || 'do-core-reinstall' == $action ) {
|
||||||
check_admin_referer('upgrade-core');
|
check_admin_referer('upgrade-core');
|
||||||
|
|
||||||
// do the (un)dismiss actions before headers,
|
// do the (un)dismiss actions before headers,
|
||||||
// so that they can redirect
|
// so that they can redirect
|
||||||
if ( isset( $_POST['dismiss'] ) )
|
if ( isset( $_POST['dismiss'] ) )
|
||||||
do_dismiss_core_update();
|
do_dismiss_core_update();
|
||||||
elseif ( isset( $_POST['undismiss'] ) )
|
elseif ( isset( $_POST['undismiss'] ) )
|
||||||
do_undismiss_core_update();
|
do_undismiss_core_update();
|
||||||
|
|
||||||
require_once('admin-header.php');
|
require_once('admin-header.php');
|
||||||
if ( 'do-core-reinstall' == $action )
|
if ( 'do-core-reinstall' == $action )
|
||||||
$reinstall = true;
|
$reinstall = true;
|
||||||
else
|
else
|
||||||
$reinstall = false;
|
$reinstall = false;
|
||||||
|
|
||||||
if ( isset( $_POST['upgrade'] ) )
|
if ( isset( $_POST['upgrade'] ) )
|
||||||
do_core_upgrade($reinstall);
|
do_core_upgrade($reinstall);
|
||||||
|
|
||||||
} elseif ( 'do-plugin-upgrade' == $action ) {
|
} elseif ( 'do-plugin-upgrade' == $action ) {
|
||||||
check_admin_referer('upgrade-core');
|
check_admin_referer('upgrade-core');
|
||||||
|
|
||||||
|
if ( isset( $_GET['plugins'] ) ) {
|
||||||
|
$plugins = explode( ',', $_GET['plugins'] );
|
||||||
|
} elseif ( isset( $_POST['checked'] ) ) {
|
||||||
|
$plugins = (array) $_POST['checked'];
|
||||||
|
} else {
|
||||||
|
wp_redirect('plugins.php');
|
||||||
|
exit;
|
||||||
|
}
|
||||||
|
|
||||||
|
$url = 'update.php?action=update-selected&plugins=' . urlencode(implode(',', $plugins));
|
||||||
|
$url = wp_nonce_url($url, 'bulk-update-plugins');
|
||||||
|
|
||||||
|
$title = __('Update Plugins');
|
||||||
|
|
||||||
require_once('admin-header.php');
|
require_once('admin-header.php');
|
||||||
do_plugin_upgrade();
|
echo '<div class="wrap">';
|
||||||
|
screen_icon('plugins');
|
||||||
|
echo '<h2>' . esc_html__('Update Plugins') . '</h2>';
|
||||||
|
echo "<iframe src='$url' style='width: 100%; height:100%; min-height:850px;'></iframe>";
|
||||||
|
echo '</div>';
|
||||||
}
|
}
|
||||||
|
|
||||||
include('admin-footer.php');
|
include('admin-footer.php');
|
||||||
|
@ -16,7 +16,35 @@ if ( isset($_GET['action']) ) {
|
|||||||
$theme = isset($_REQUEST['theme']) ? urldecode($_REQUEST['theme']) : '';
|
$theme = isset($_REQUEST['theme']) ? urldecode($_REQUEST['theme']) : '';
|
||||||
$action = isset($_REQUEST['action']) ? $_REQUEST['action'] : '';
|
$action = isset($_REQUEST['action']) ? $_REQUEST['action'] : '';
|
||||||
|
|
||||||
if ( 'upgrade-plugin' == $action ) {
|
if ( 'update-selected' == $action ) {
|
||||||
|
if ( ! current_user_can( 'update_plugins' ) )
|
||||||
|
wp_die( __( 'You do not have sufficient permissions to update plugins for this blog.' ) );
|
||||||
|
|
||||||
|
check_admin_referer( 'bulk-update-plugins' );
|
||||||
|
|
||||||
|
if ( isset( $_GET['plugins'] ) )
|
||||||
|
$plugins = explode( ',', stripslashes($_GET['plugins']) );
|
||||||
|
elseif ( isset( $_POST['checked'] ) )
|
||||||
|
$plugins = (array) $_POST['checked'];
|
||||||
|
else
|
||||||
|
$plugins = array();
|
||||||
|
|
||||||
|
$plugins = array_map('urldecode', $plugins);
|
||||||
|
|
||||||
|
$url = 'update.php?action=update-selected&plugins=' . urlencode(implode(',', $plugins));
|
||||||
|
$nonce = 'bulk-update-plugins';
|
||||||
|
|
||||||
|
require_once( ABSPATH . 'wp-admin/includes/class-wp-upgrader.php' );
|
||||||
|
wp_enqueue_script('jquery');
|
||||||
|
iframe_header();
|
||||||
|
|
||||||
|
$upgrader = new Plugin_Upgrader( new Bulk_Plugin_Upgrader_Skin( compact( 'nonce', 'url' ) ) );
|
||||||
|
$upgrader->bulk_upgrade( $plugins );
|
||||||
|
|
||||||
|
iframe_footer();
|
||||||
|
exit;
|
||||||
|
|
||||||
|
} elseif ( 'upgrade-plugin' == $action ) {
|
||||||
if ( ! current_user_can('update_plugins') )
|
if ( ! current_user_can('update_plugins') )
|
||||||
wp_die(__('You do not have sufficient permissions to update plugins for this blog.'));
|
wp_die(__('You do not have sufficient permissions to update plugins for this blog.'));
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user