Deactivate plugins during plugin update. Props DD32. see #6262
git-svn-id: https://develop.svn.wordpress.org/trunk@7465 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
parent
8c0ae81b06
commit
db66d57993
@ -31,7 +31,7 @@ function get_plugin_data( $plugin_file ) {
|
|||||||
return array('Name' => $name, 'Title' => $plugin, 'Description' => $description, 'Author' => $author, 'Version' => $version);
|
return array('Name' => $name, 'Title' => $plugin, 'Description' => $description, 'Author' => $author, 'Version' => $version);
|
||||||
}
|
}
|
||||||
|
|
||||||
function get_plugins() {
|
function get_plugins($plugin_folder = '') {
|
||||||
global $wp_plugins;
|
global $wp_plugins;
|
||||||
|
|
||||||
if ( isset( $wp_plugins ) ) {
|
if ( isset( $wp_plugins ) ) {
|
||||||
@ -40,6 +40,8 @@ function get_plugins() {
|
|||||||
|
|
||||||
$wp_plugins = array ();
|
$wp_plugins = array ();
|
||||||
$plugin_root = ABSPATH . PLUGINDIR;
|
$plugin_root = ABSPATH . PLUGINDIR;
|
||||||
|
if( !empty($plugin_folder) )
|
||||||
|
$plugin_root .= $plugin_folder;
|
||||||
|
|
||||||
// Files in wp-content/plugins directory
|
// Files in wp-content/plugins directory
|
||||||
$plugins_dir = @ opendir( $plugin_root);
|
$plugins_dir = @ opendir( $plugin_root);
|
||||||
@ -86,6 +88,10 @@ function get_plugins() {
|
|||||||
return $wp_plugins;
|
return $wp_plugins;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function is_plugin_active($plugin){
|
||||||
|
return in_array($plugin, get_option('active_plugins'));
|
||||||
|
}
|
||||||
|
|
||||||
function activate_plugin($plugin, $redirect = '') {
|
function activate_plugin($plugin, $redirect = '') {
|
||||||
$current = get_option('active_plugins');
|
$current = get_option('active_plugins');
|
||||||
$plugin = trim($plugin);
|
$plugin = trim($plugin);
|
||||||
@ -109,7 +115,7 @@ function activate_plugin($plugin, $redirect = '') {
|
|||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
function deactivate_plugins($plugins) {
|
function deactivate_plugins($plugins, $silent= false) {
|
||||||
$current = get_option('active_plugins');
|
$current = get_option('active_plugins');
|
||||||
|
|
||||||
if ( !is_array($plugins) )
|
if ( !is_array($plugins) )
|
||||||
@ -121,7 +127,8 @@ function deactivate_plugins($plugins) {
|
|||||||
continue;
|
continue;
|
||||||
if ( ( $key = array_search( $plugin, $current) ) !== false )
|
if ( ( $key = array_search( $plugin, $current) ) !== false )
|
||||||
array_splice($current, $key, 1 ); // Fixed Array-fu!
|
array_splice($current, $key, 1 ); // Fixed Array-fu!
|
||||||
do_action('deactivate_' . trim( $plugin ));
|
if ( ! $silent )
|
||||||
|
do_action('deactivate_' . trim( $plugin ));
|
||||||
}
|
}
|
||||||
|
|
||||||
update_option('active_plugins', $current);
|
update_option('active_plugins', $current);
|
||||||
|
@ -197,13 +197,19 @@ function wp_update_plugin($plugin, $feedback = '') {
|
|||||||
// Once installed, delete the package
|
// Once installed, delete the package
|
||||||
unlink($file);
|
unlink($file);
|
||||||
|
|
||||||
|
if ( is_plugin_active($plugin) ) {
|
||||||
|
//Deactivate the plugin
|
||||||
|
apply_filters('update_feedback', __('Deactivating the plugin'));
|
||||||
|
deactivate_plugins($plugin, true);
|
||||||
|
}
|
||||||
|
|
||||||
// Remove the existing plugin.
|
// Remove the existing plugin.
|
||||||
apply_filters('update_feedback', __('Removing the old version of the plugin'));
|
apply_filters('update_feedback', __('Removing the old version of the plugin'));
|
||||||
$plugin_dir = dirname($base . PLUGINDIR . "/$plugin");
|
$plugin_dir = dirname($base . PLUGINDIR . "/$plugin");
|
||||||
$plugin_dir = trailingslashit($plugin_dir);
|
$plugin_dir = trailingslashit($plugin_dir);
|
||||||
|
|
||||||
// If plugin is in its own directory, recursively delete the directory.
|
// If plugin is in its own directory, recursively delete the directory.
|
||||||
if( strpos($plugin, '/') && $plugin_dir != $base . PLUGINDIR . '/' )
|
if ( strpos($plugin, '/') && $plugin_dir != $base . PLUGINDIR . '/' )
|
||||||
$deleted = $wp_filesystem->delete($plugin_dir, true);
|
$deleted = $wp_filesystem->delete($plugin_dir, true);
|
||||||
else
|
else
|
||||||
$deleted = $wp_filesystem->delete($base . PLUGINDIR . "/$plugin");
|
$deleted = $wp_filesystem->delete($base . PLUGINDIR . "/$plugin");
|
||||||
@ -225,6 +231,13 @@ function wp_update_plugin($plugin, $feedback = '') {
|
|||||||
|
|
||||||
// Force refresh of plugin update information
|
// Force refresh of plugin update information
|
||||||
delete_option('update_plugins');
|
delete_option('update_plugins');
|
||||||
|
|
||||||
|
//Return the new plugin file.
|
||||||
|
if ( ! preg_match('!/([a-z0-9\-]+)/?$!i', $working_dir, $mat) )
|
||||||
|
return false;
|
||||||
|
$plugin = get_plugins('/' . $mat[1]); //Pass it with a leading slash
|
||||||
|
$list = array_keys($plugin);
|
||||||
|
return $mat[1] . '/' . $list[0]; //Pass it without a leading slash.
|
||||||
}
|
}
|
||||||
|
|
||||||
?>
|
?>
|
||||||
|
@ -86,7 +86,7 @@ function show_message($message) {
|
|||||||
else
|
else
|
||||||
$message = $message->get_error_message();
|
$message = $message->get_error_message();
|
||||||
}
|
}
|
||||||
echo "<p>$message</p>";
|
echo "<p>$message</p>\n";
|
||||||
}
|
}
|
||||||
|
|
||||||
function do_plugin_upgrade($plugin) {
|
function do_plugin_upgrade($plugin) {
|
||||||
@ -95,12 +95,12 @@ function do_plugin_upgrade($plugin) {
|
|||||||
$url = wp_nonce_url("update.php?action=upgrade-plugin&plugin=$plugin", "upgrade-plugin_$plugin");
|
$url = wp_nonce_url("update.php?action=upgrade-plugin&plugin=$plugin", "upgrade-plugin_$plugin");
|
||||||
if ( false === ($credentials = request_filesystem_credentials($url)) )
|
if ( false === ($credentials = request_filesystem_credentials($url)) )
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if( ! WP_Filesystem($credentials) ){
|
if ( ! WP_Filesystem($credentials) ) {
|
||||||
request_filesystem_credentials($url, '', true); //Failed to connect, Error and request again
|
request_filesystem_credentials($url, '', true); //Failed to connect, Error and request again
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
echo '<div class="wrap">';
|
echo '<div class="wrap">';
|
||||||
echo '<h2>' . __('Upgrade Plugin') . '</h2>';
|
echo '<h2>' . __('Upgrade Plugin') . '</h2>';
|
||||||
if ( $wp_filesystem->errors->get_error_code() ) {
|
if ( $wp_filesystem->errors->get_error_code() ) {
|
||||||
@ -110,18 +110,25 @@ function do_plugin_upgrade($plugin) {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$was_activated = is_plugin_active($plugin); //Check now, It'll be deactivated by the next line if it is,
|
||||||
|
|
||||||
$result = wp_update_plugin($plugin, 'show_message');
|
$result = wp_update_plugin($plugin, 'show_message');
|
||||||
|
|
||||||
if ( is_wp_error($result) )
|
if ( is_wp_error($result) ) {
|
||||||
show_message($result);
|
show_message($result);
|
||||||
else
|
} else {
|
||||||
echo __('Plugin upgraded successfully');
|
//Result is the new plugin file relative to PLUGINDIR
|
||||||
|
show_message(__('Plugin upgraded successfully'));
|
||||||
|
if( $result && $was_activated ){
|
||||||
|
show_message(__('Attempting reactivation of the plugin'));
|
||||||
|
echo '<iframe style="border:0" width="100%" height="170px" src="' . wp_nonce_url('update.php?action=activate-plugin&plugin=' . $result, 'activate-plugin_' . $result) .'"></iframe>';
|
||||||
|
}
|
||||||
|
}
|
||||||
echo '</div>';
|
echo '</div>';
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( isset($_GET['action']) ) {
|
if ( isset($_GET['action']) ) {
|
||||||
if ( isset($_GET['plugin']) )
|
$plugin = isset($_GET['plugin']) ? trim($_GET['plugin']) : '';
|
||||||
$plugin = trim($_GET['plugin']);
|
|
||||||
|
|
||||||
if ( 'upgrade-plugin' == $_GET['action'] ) {
|
if ( 'upgrade-plugin' == $_GET['action'] ) {
|
||||||
check_admin_referer('upgrade-plugin_' . $plugin);
|
check_admin_referer('upgrade-plugin_' . $plugin);
|
||||||
@ -130,6 +137,36 @@ if ( isset($_GET['action']) ) {
|
|||||||
require_once('admin-header.php');
|
require_once('admin-header.php');
|
||||||
do_plugin_upgrade($plugin);
|
do_plugin_upgrade($plugin);
|
||||||
include('admin-footer.php');
|
include('admin-footer.php');
|
||||||
|
} elseif ('activate-plugin' == $_GET['action'] ) {
|
||||||
|
check_admin_referer('activate-plugin_' . $plugin);
|
||||||
|
if( ! isset($_GET['failure']) && ! isset($_GET['success']) ) {
|
||||||
|
wp_redirect( 'update.php?action=activate-plugin&failure=true&plugin=' . $plugin . '&_wpnonce=' . $_GET['_wpnonce'] );
|
||||||
|
activate_plugin($plugin);
|
||||||
|
wp_redirect( 'update.php?action=activate-plugin&success=true&plugin=' . $plugin . '&_wpnonce=' . $_GET['_wpnonce'] );
|
||||||
|
die();
|
||||||
|
}
|
||||||
|
?><!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
|
||||||
|
<html xmlns="http://www.w3.org/1999/xhtml" <?php do_action('admin_xml_ns'); ?> <?php language_attributes(); ?>>
|
||||||
|
<head>
|
||||||
|
<meta http-equiv="Content-Type" content="<?php bloginfo('html_type'); ?>; charset=<?php echo get_option('blog_charset'); ?>" />
|
||||||
|
<title><?php bloginfo('name') ?> › <?php _e('Plugin Reactivation'); ?> — <?php _e('WordPress'); ?></title>
|
||||||
|
<?php
|
||||||
|
wp_admin_css( 'css/global' );
|
||||||
|
wp_admin_css( 'css/colors' );
|
||||||
|
?>
|
||||||
|
</head>
|
||||||
|
<body>
|
||||||
|
<?php
|
||||||
|
if( isset($_GET['success']) )
|
||||||
|
echo '<p>' . __('Plugin reactivated successfully.') . '</p>';
|
||||||
|
|
||||||
|
if( isset($_GET['failure']) ){
|
||||||
|
echo '<p>' . __('Plugin failed to reactivate due to a fatal error.') . '</p>';
|
||||||
|
error_reporting( E_ALL ^ E_NOTICE );
|
||||||
|
@ini_set('display_errors', true); //Ensure that Fatal errors are displayed.
|
||||||
|
include(ABSPATH . PLUGINDIR . '/' . $plugin);
|
||||||
|
}
|
||||||
|
echo "</body></html>";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user