Use array storage for plugins list.
git-svn-id: https://develop.svn.wordpress.org/trunk@1522 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
parent
95febc82bf
commit
82e38938fa
@ -7,20 +7,17 @@ if (isset($_GET['action'])) {
|
|||||||
check_admin_referer();
|
check_admin_referer();
|
||||||
|
|
||||||
if ('activate' == $_GET['action']) {
|
if ('activate' == $_GET['action']) {
|
||||||
$current = "\n" . get_settings('active_plugins') . "\n";
|
$current = get_settings('active_plugins');
|
||||||
$current = preg_replace("|(\n)+\s*|", "\n", $current);
|
$current[] = trim( $_GET['plugin'] );
|
||||||
$current = trim($current) . "\n " . trim($_GET['plugin']);
|
sort($current);
|
||||||
$current = trim($current);
|
|
||||||
$current = preg_replace("|\n\s*|", "\n", $current); // I don't know where this is coming from
|
|
||||||
update_option('active_plugins', $current);
|
update_option('active_plugins', $current);
|
||||||
header('Location: plugins.php?activate=true');
|
header('Location: plugins.php?activate=true');
|
||||||
}
|
}
|
||||||
|
|
||||||
if ('deactivate' == $_GET['action']) {
|
if ('deactivate' == $_GET['action']) {
|
||||||
$current = "\n" . get_settings('active_plugins') . "\n";
|
$current = get_settings('active_plugins');
|
||||||
$current = str_replace("\n" . $_GET['plugin'], '', $current);
|
array_splice($current, array_search( $_GET['plugin'], $current), 1 ); // Array-fu!
|
||||||
$current = preg_replace("|(\n)+\s*|", "\n", $current);
|
update_option('active_plugins', $current);
|
||||||
update_option('active_plugins', trim($current));
|
|
||||||
header('Location: plugins.php?deactivate=true');
|
header('Location: plugins.php?deactivate=true');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -30,23 +27,19 @@ $title = __('Manage Plugins');
|
|||||||
require_once('admin-header.php');
|
require_once('admin-header.php');
|
||||||
|
|
||||||
if ($user_level < 9) // Must be at least level 9
|
if ($user_level < 9) // Must be at least level 9
|
||||||
die (__("Sorry, you must be at least a level 8 user to modify plugins."));
|
die (__('Sorry, you must be at least a level 8 user to modify plugins.'));
|
||||||
|
|
||||||
// Clean up options
|
// Clean up options
|
||||||
// if any files are in the option that don't exist, axe 'em
|
// If any plugins don't exist, axe 'em
|
||||||
|
|
||||||
$check_plugins = explode("\n", (get_settings('active_plugins')));
|
$check_plugins = get_settings('active_plugins');
|
||||||
foreach ($check_plugins as $check_plugin) {
|
foreach ($check_plugins as $check_plugin) {
|
||||||
if (!file_exists(ABSPATH . 'wp-content/plugins/' . $check_plugin)) {
|
if (!file_exists(ABSPATH . 'wp-content/plugins/' . $check_plugin)) {
|
||||||
$current = get_settings('active_plugins') . "\n";
|
$current = get_settings('active_plugins');
|
||||||
$current = str_replace($check_plugin . "\n", '', $current);
|
unset($current[$_GET['plugin']]);
|
||||||
$current = preg_replace("|\n+|", "\n", $current);
|
update_option('active_plugins', $current);
|
||||||
update_option('active_plugins', trim($current));
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
?>
|
?>
|
||||||
|
|
||||||
<?php if (isset($_GET['activate'])) : ?>
|
<?php if (isset($_GET['activate'])) : ?>
|
||||||
@ -60,7 +53,7 @@ foreach ($check_plugins as $check_plugin) {
|
|||||||
|
|
||||||
<div class="wrap">
|
<div class="wrap">
|
||||||
<h2><?php _e('Plugin Management'); ?></h2>
|
<h2><?php _e('Plugin Management'); ?></h2>
|
||||||
<p><?php _e('Plugins are files you usually download separately from WordPress that add functionality. To install a plugin you generally just need to put the plugin file into your <code>wp-content/plugins</code> directory. Once a plugin is installed, you may activate it or deactivate it here.'); ?></p>
|
<p><?php _e('Plugins are files you usually download separately from WordPress that add functionality. To install a plugin you generally just need to put the plugin file into your <code>wp-content/plugins</code> directory. Once a plugin is installed, you may activate it or deactivate it here. If something goes wrong with a plugin and you can’t use WordPress, delete that plugin from the <code>wp-content/plugins</code> directory and it will be automatically deactivated.'); ?></p>
|
||||||
<?php
|
<?php
|
||||||
// Files in wp-content/plugins directory
|
// Files in wp-content/plugins directory
|
||||||
$plugins_dir = @ dir(ABSPATH . 'wp-content/plugins');
|
$plugins_dir = @ dir(ABSPATH . 'wp-content/plugins');
|
||||||
@ -71,9 +64,8 @@ if ($plugins_dir) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if ('' != trim(get_settings('active_plugins'))) {
|
if ( get_settings('active_plugins') )
|
||||||
$current_plugins = explode("\n", (get_settings('active_plugins')));
|
$current_plugins = get_settings('active_plugins');
|
||||||
}
|
|
||||||
|
|
||||||
if (!$plugins_dir || !$plugin_files) {
|
if (!$plugins_dir || !$plugin_files) {
|
||||||
_e("<p>Couldn't open plugins directory or there are no plugins available.</p>"); // TODO: make more helpful
|
_e("<p>Couldn't open plugins directory or there are no plugins available.</p>"); // TODO: make more helpful
|
||||||
|
@ -923,6 +923,11 @@ function upgrade_130() {
|
|||||||
if ($wpdb->get_var("SELECT option_value FROM $wpdb->options WHERE option_name = 'what_to_show'") == 'paged') {
|
if ($wpdb->get_var("SELECT option_value FROM $wpdb->options WHERE option_name = 'what_to_show'") == 'paged') {
|
||||||
$wpdb->query("UPDATE $wpdb->options SET option_value = 'posts' WHERE option_name = 'what_to_show'");
|
$wpdb->query("UPDATE $wpdb->options SET option_value = 'posts' WHERE option_name = 'what_to_show'");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if ( !is_array( get_settings('active_plugins') ) ) {
|
||||||
|
$plugins = explode("\n", get_settings('active_plugins') );
|
||||||
|
update_option('active_plugins', $plugins);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
?>
|
?>
|
@ -81,7 +81,7 @@ if (get_settings('hack_file')) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if ( get_settings('active_plugins') ) {
|
if ( get_settings('active_plugins') ) {
|
||||||
$current_plugins = explode("\n", get_settings('active_plugins') );
|
$current_plugins = get_settings('active_plugins');
|
||||||
foreach ($current_plugins as $plugin) {
|
foreach ($current_plugins as $plugin) {
|
||||||
if (file_exists(ABSPATH . 'wp-content/plugins/' . $plugin))
|
if (file_exists(ABSPATH . 'wp-content/plugins/' . $plugin))
|
||||||
include(ABSPATH . 'wp-content/plugins/' . $plugin);
|
include(ABSPATH . 'wp-content/plugins/' . $plugin);
|
||||||
|
Loading…
Reference in New Issue
Block a user