Support network-wide plugin re-activation in upgrades and edits. props PeteMall, fixes #13216

git-svn-id: http://svn.automattic.com/wordpress/trunk@14348 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
nacin 2010-05-02 22:57:44 +00:00
parent 91354eefee
commit ec38ce48e9
3 changed files with 10 additions and 6 deletions

View File

@ -986,6 +986,7 @@ class WP_Upgrader_Skin {
class Plugin_Upgrader_Skin extends WP_Upgrader_Skin { class Plugin_Upgrader_Skin extends WP_Upgrader_Skin {
var $plugin = ''; var $plugin = '';
var $plugin_active = false; var $plugin_active = false;
var $plugin_network_active = false;
function Plugin_Upgrader_Skin($args = array()) { function Plugin_Upgrader_Skin($args = array()) {
return $this->__construct($args); return $this->__construct($args);
@ -997,7 +998,8 @@ class Plugin_Upgrader_Skin extends WP_Upgrader_Skin {
$this->plugin = $args['plugin']; $this->plugin = $args['plugin'];
$this->plugin_active = is_plugin_active($this->plugin); $this->plugin_active = is_plugin_active( $this->plugin );
$this->plugin_network_active = is_plugin_active_for_network( $this->plugin );
parent::__construct($args); parent::__construct($args);
} }
@ -1006,7 +1008,7 @@ class Plugin_Upgrader_Skin extends WP_Upgrader_Skin {
$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…'));
echo '<iframe style="border:0;overflow:hidden" width="100%" height="170px" src="' . wp_nonce_url('update.php?action=activate-plugin&plugin=' . $this->plugin, 'activate-plugin_' . $this->plugin) .'"></iframe>'; echo '<iframe style="border:0;overflow:hidden" width="100%" height="170px" src="' . wp_nonce_url('update.php?action=activate-plugin&networkwide=' . $this->plugin_network_active . '&plugin=' . $this->plugin, 'activate-plugin_' . $this->plugin) .'"></iframe>';
} }
$update_actions = array( $update_actions = array(

View File

@ -55,6 +55,8 @@ case 'update':
fwrite($f, $newcontent); fwrite($f, $newcontent);
fclose($f); fclose($f);
$network_wide = is_plugin_active_for_network( $file );
// Deactivate so we can test it. // Deactivate so we can test it.
if ( is_plugin_active($file) || isset($_POST['phperror']) ) { if ( is_plugin_active($file) || isset($_POST['phperror']) ) {
if ( is_plugin_active($file) ) if ( is_plugin_active($file) )
@ -62,7 +64,7 @@ case 'update':
update_option('recently_activated', array($file => time()) + (array)get_option('recently_activated')); update_option('recently_activated', array($file => time()) + (array)get_option('recently_activated'));
wp_redirect(add_query_arg('_wpnonce', wp_create_nonce('edit-plugin-test_' . $file), "plugin-editor.php?file=$file&liveupdate=1&scrollto=$scrollto")); wp_redirect(add_query_arg('_wpnonce', wp_create_nonce('edit-plugin-test_' . $file), "plugin-editor.php?file=$file&liveupdate=1&scrollto=$scrollto&networkwide=" . $network_wide));
exit; exit;
} }
wp_redirect("plugin-editor.php?file=$file&a=te&scrollto=$scrollto"); wp_redirect("plugin-editor.php?file=$file&a=te&scrollto=$scrollto");
@ -83,7 +85,7 @@ default:
wp_die( $error ); wp_die( $error );
if ( ! is_plugin_active($file) ) if ( ! is_plugin_active($file) )
activate_plugin($file, "plugin-editor.php?file=$file&phperror=1"); // we'll override this later if the plugin can be included without fatal error activate_plugin($file, "plugin-editor.php?file=$file&phperror=1", ! empty( $_GET['networkwide'] ) ); // we'll override this later if the plugin can be included without fatal error
wp_redirect("plugin-editor.php?file=$file&a=te&scrollto=$scrollto"); wp_redirect("plugin-editor.php?file=$file&a=te&scrollto=$scrollto");
exit; exit;

View File

@ -69,7 +69,7 @@ if ( isset($_GET['action']) ) {
check_admin_referer('activate-plugin_' . $plugin); check_admin_referer('activate-plugin_' . $plugin);
if ( ! isset($_GET['failure']) && ! isset($_GET['success']) ) { if ( ! isset($_GET['failure']) && ! isset($_GET['success']) ) {
wp_redirect( 'update.php?action=activate-plugin&failure=true&plugin=' . $plugin . '&_wpnonce=' . $_GET['_wpnonce'] ); wp_redirect( 'update.php?action=activate-plugin&failure=true&plugin=' . $plugin . '&_wpnonce=' . $_GET['_wpnonce'] );
activate_plugin($plugin); activate_plugin( $plugin, '', ! empty( $_GET['networkwide'] ) );
wp_redirect( 'update.php?action=activate-plugin&success=true&plugin=' . $plugin . '&_wpnonce=' . $_GET['_wpnonce'] ); wp_redirect( 'update.php?action=activate-plugin&success=true&plugin=' . $plugin . '&_wpnonce=' . $_GET['_wpnonce'] );
die(); die();
} }