X-Git-Url: https://scripts.mit.edu/gitweb/autoinstalls/wordpress.git/blobdiff_plain/58f607a1de715c9bca69340a4d6fb9e1b9c2bed2..fef8173b8c3bad08f495551e43cfdeac1cae6021:/wp-admin/plugins.php
diff --git a/wp-admin/plugins.php b/wp-admin/plugins.php
index bed5d5f6..0c36bbd1 100644
--- a/wp-admin/plugins.php
+++ b/wp-admin/plugins.php
@@ -8,44 +8,29 @@
/** WordPress Administration Bootstrap */
require_once('./admin.php');
+
if ( is_multisite() ) {
$menu_perms = get_site_option( 'menu_items', array() );
- if ( empty($menu_perms['plugins']) && ! is_super_admin() )
+ if ( empty( $menu_perms['plugins'] ) && ! is_super_admin() )
wp_die( __( 'Cheatin’ uh?' ) );
- else if ( $menu_perms['plugins'] != 1 && is_super_admin() )
- add_action( 'admin_notices', '_admin_notice_multisite_activate_plugins_page' );
}
-if ( ! current_user_can( 'activate_plugins' ) )
+if ( !current_user_can('activate_plugins') )
wp_die( __( 'You do not have sufficient permissions to manage plugins for this site.' ) );
-if ( isset($_POST['clear-recent-list']) )
- $action = 'clear-recent-list';
-elseif ( !empty($_REQUEST['action']) )
- $action = $_REQUEST['action'];
-elseif ( !empty($_REQUEST['action2']) )
- $action = $_REQUEST['action2'];
-else
- $action = false;
-
-$plugin = isset($_REQUEST['plugin']) ? $_REQUEST['plugin'] : '';
+$wp_list_table = _get_list_table('WP_Plugins_List_Table');
+$pagenum = $wp_list_table->get_pagenum();
-$default_status = get_user_option('plugins_last_view');
-if ( empty($default_status) )
- $default_status = 'all';
-$status = isset($_REQUEST['plugin_status']) ? $_REQUEST['plugin_status'] : $default_status;
-if ( !in_array($status, array('all', 'active', 'inactive', 'recent', 'upgrade', 'network', 'mustuse', 'dropins', 'search')) )
- $status = 'all';
-if ( $status != $default_status && 'search' != $status )
- update_user_meta($current_user->ID, 'plugins_last_view', $status);
+$action = $wp_list_table->current_action();
-$page = isset($_REQUEST['paged']) ? $_REQUEST['paged'] : 1;
+$plugin = isset($_REQUEST['plugin']) ? $_REQUEST['plugin'] : '';
+$s = isset($_REQUEST['s']) ? $_REQUEST['s'] : '';
-//Clean up request URI from temporary args for screen options/paging uri's to work as expected.
+// Clean up request URI from temporary args for screen options/paging uri's to work as expected.
$_SERVER['REQUEST_URI'] = remove_query_arg(array('error', 'deleted', 'activate', 'activate-multi', 'deactivate', 'deactivate-multi', '_error_nonce'), $_SERVER['REQUEST_URI']);
-if ( !empty($action) ) {
+if ( $action ) {
$network_wide = false;
if ( ( isset( $_GET['networkwide'] ) || 'network-activate-selected' == $action ) && is_multisite() && current_user_can( 'manage_network_plugins' ) )
$network_wide = true;
@@ -57,10 +42,10 @@ if ( !empty($action) ) {
check_admin_referer('activate-plugin_' . $plugin);
- $result = activate_plugin($plugin, 'plugins.php?error=true&plugin=' . $plugin, $network_wide);
+ $result = activate_plugin($plugin, self_admin_url('plugins.php?error=true&plugin=' . $plugin), $network_wide);
if ( is_wp_error( $result ) ) {
if ( 'unexpected_output' == $result->get_error_code() ) {
- $redirect = 'plugins.php?error=true&charsout=' . strlen($result->get_error_data()) . '&plugin=' . $plugin;
+ $redirect = self_admin_url('plugins.php?error=true&charsout=' . strlen($result->get_error_data()) . '&plugin=' . $plugin . "&plugin_status=$status&paged=$page&s=$s");
wp_redirect(add_query_arg('_error_nonce', wp_create_nonce('plugin-activation-error_' . $plugin), $redirect));
exit;
} else {
@@ -74,9 +59,9 @@ if ( !empty($action) ) {
update_option('recently_activated', $recent);
}
if ( isset($_GET['from']) && 'import' == $_GET['from'] ) {
- wp_redirect("import.php?import=" . str_replace('-importer', '', dirname($plugin)) ); // overrides the ?error=true one above and redirects to the Imports page, striping the -importer suffix
+ wp_redirect( self_admin_url("import.php?import=" . str_replace('-importer', '', dirname($plugin))) ); // overrides the ?error=true one above and redirects to the Imports page, striping the -importer suffix
} else {
- wp_redirect("plugins.php?activate=true&plugin_status=$status&paged=$page"); // overrides the ?error=true one above
+ wp_redirect( self_admin_url("plugins.php?activate=true&plugin_status=$status&paged=$page&s=$s") ); // overrides the ?error=true one above
}
exit;
break;
@@ -85,16 +70,22 @@ if ( !empty($action) ) {
if ( ! current_user_can('activate_plugins') )
wp_die(__('You do not have sufficient permissions to activate plugins for this site.'));
- check_admin_referer('bulk-manage-plugins');
+ check_admin_referer('bulk-plugins');
$plugins = isset( $_POST['checked'] ) ? (array) $_POST['checked'] : array();
- $plugins = array_filter($plugins, create_function('$plugin', 'return !is_plugin_active($plugin);') ); // Only activate plugins which are not already active.
+
+ // Only activate plugins which are not already active.
+ $check = $network_wide ? 'is_plugin_active_for_network' : 'is_plugin_active';
+ foreach ( $plugins as $i => $plugin )
+ if ( $check( $plugin ) )
+ unset( $plugins[ $i ] );
+
if ( empty($plugins) ) {
- wp_redirect("plugins.php?plugin_status=$status&paged=$page");
+ wp_redirect( self_admin_url("plugins.php?plugin_status=$status&paged=$page&s=$s") );
exit;
}
- activate_plugins($plugins, 'plugins.php?error=true', $network_wide);
+ activate_plugins($plugins, self_admin_url('plugins.php?error=true'), $network_wide);
$recent = (array)get_option('recently_activated');
foreach ( $plugins as $plugin => $time)
@@ -103,12 +94,12 @@ if ( !empty($action) ) {
update_option('recently_activated', $recent);
- wp_redirect("plugins.php?activate-multi=true&plugin_status=$status&paged=$page");
+ wp_redirect( self_admin_url("plugins.php?activate-multi=true&plugin_status=$status&paged=$page&s=$s") );
exit;
break;
case 'update-selected' :
- check_admin_referer( 'bulk-manage-plugins' );
+ check_admin_referer( 'bulk-plugins' );
if ( isset( $_GET['plugins'] ) )
$plugins = explode( ',', $_GET['plugins'] );
@@ -117,22 +108,22 @@ if ( !empty($action) ) {
else
$plugins = array();
- $title = __( 'Upgrade Plugins' );
+ $title = __( 'Update Plugins' );
$parent_file = 'plugins.php';
- require_once( './admin-header.php' );
+ require_once(ABSPATH . 'wp-admin/admin-header.php');
echo '
';
screen_icon();
echo '
' . esc_html( $title ) . ' ';
- $url = 'update.php?action=update-selected&plugins=' . urlencode( join(',', $plugins) );
+ $url = self_admin_url('update.php?action=update-selected&plugins=' . urlencode( join(',', $plugins) ));
$url = wp_nonce_url($url, 'bulk-update-plugins');
echo "";
echo '';
- require_once( './admin-footer.php' );
+ require_once(ABSPATH . 'wp-admin/admin-footer.php');
exit;
break;
case 'error_scrape':
@@ -168,22 +159,22 @@ if ( !empty($action) ) {
check_admin_referer('deactivate-plugin_' . $plugin);
deactivate_plugins($plugin);
update_option('recently_activated', array($plugin => time()) + (array)get_option('recently_activated'));
- if (headers_sent())
- echo " ";
+ if ( headers_sent() )
+ echo " ";
else
- wp_redirect("plugins.php?deactivate=true&plugin_status=$status&paged=$page");
+ wp_redirect( self_admin_url("plugins.php?deactivate=true&plugin_status=$status&paged=$page&s=$s") );
exit;
break;
case 'deactivate-selected':
if ( ! current_user_can('activate_plugins') )
wp_die(__('You do not have sufficient permissions to deactivate plugins for this site.'));
- check_admin_referer('bulk-manage-plugins');
+ check_admin_referer('bulk-plugins');
$plugins = isset( $_POST['checked'] ) ? (array) $_POST['checked'] : array();
$plugins = array_filter($plugins, 'is_plugin_active'); //Do not deactivate plugins which are already deactivated.
if ( empty($plugins) ) {
- wp_redirect("plugins.php?plugin_status=$status&paged=$page");
+ wp_redirect( self_admin_url("plugins.php?plugin_status=$status&paged=$page&s=$s") );
exit;
}
@@ -194,20 +185,25 @@ if ( !empty($action) ) {
$deactivated[ $plugin ] = time();
update_option('recently_activated', $deactivated + (array)get_option('recently_activated'));
- wp_redirect("plugins.php?deactivate-multi=true&plugin_status=$status&paged=$page");
+ wp_redirect( self_admin_url("plugins.php?deactivate-multi=true&plugin_status=$status&paged=$page&s=$s") );
exit;
break;
case 'delete-selected':
if ( ! current_user_can('delete_plugins') )
wp_die(__('You do not have sufficient permissions to delete plugins for this site.'));
- check_admin_referer('bulk-manage-plugins');
+ check_admin_referer('bulk-plugins');
//$_POST = from the plugin form; $_GET = from the FTP details screen.
$plugins = isset( $_REQUEST['checked'] ) ? (array) $_REQUEST['checked'] : array();
- $plugins = array_filter($plugins, create_function('$plugin', 'return !is_plugin_active($plugin);') ); //Do not allow to delete Activated plugins.
- if ( empty($plugins) ) {
- wp_redirect("plugins.php?plugin_status=$status&paged=$page");
+ if ( empty( $plugins ) ) {
+ wp_redirect( self_admin_url("plugins.php?plugin_status=$status&paged=$page&s=$s") );
+ exit;
+ }
+
+ $plugins = array_filter($plugins, 'is_plugin_inactive'); // Do not allow to delete Activated plugins.
+ if ( empty( $plugins ) ) {
+ wp_redirect( self_admin_url( "plugins.php?error=true&main=true&plugin_status=$status&paged=$page&s=$s" ) );
exit;
}
@@ -217,17 +213,20 @@ if ( !empty($action) ) {
if ( ! isset($_REQUEST['verify-delete']) ) {
wp_enqueue_script('jquery');
- require_once('./admin-header.php');
+ require_once(ABSPATH . 'wp-admin/admin-header.php');
?>
$data ) {
- $plugin_info[ $plugin_file ] = $data;
+ $plugin_info[ $plugin_file ] = _get_plugin_data_markup_translate( $plugin_file, $data );
$plugin_info[ $plugin_file ]['is_uninstallable'] = is_uninstallable_plugin( $plugin );
+ if ( ! $plugin_info[ $plugin_file ]['Network'] )
+ $have_non_network_plugins = true;
}
}
}
@@ -248,6 +249,9 @@ if ( !empty($action) ) {
$plugins_to_delete = count( $plugin_info );
echo '
' . _n( 'Delete Plugin', 'Delete Plugins', $plugins_to_delete ) . ' ';
?>
+
+
+
', sprintf( __( '%1$s by %2$s (will also delete its data )' ), $plugin['Name'], $plugin['Author'] ), '';
+ echo '', sprintf( __( '%1$s by %2$s (will also delete its data )' ), esc_html($plugin['Name']), esc_html($plugin['AuthorName']) ), ' ';
$data_to_delete = true;
} else {
/* translators: 1: plugin name, 2: plugin author */
- echo '', sprintf( __('%1$s by %2$s ' ), $plugin['Name'], $plugin['Author'] ), ' ';
+ echo '', sprintf( __('%1$s by %2$s ' ), esc_html($plugin['Name']), esc_html($plugin['AuthorName']) ), ' ';
}
}
?>
@@ -274,14 +278,14 @@ if ( !empty($action) ) {
';
?>
-
-
+
+
@@ -289,19 +293,19 @@ if ( !empty($action) ) {
' . str_replace(WP_PLUGIN_DIR, '', $file) . '';
+ echo '' . esc_html(str_replace(WP_PLUGIN_DIR, '', $file)) . ' ';
?>
prepare_items();
+
+$total_pages = $wp_list_table->get_pagination_arg( 'total_pages' );
+if ( $pagenum > $total_pages && $total_pages > 0 ) {
+ wp_redirect( add_query_arg( 'paged', $total_pages ) );
+ exit;
+}
+
wp_enqueue_script('plugin-install');
add_thickbox();
+add_screen_option( 'per_page', array('label' => _x( 'Plugins', 'plugins per page (screen options)' )) );
+
add_contextual_help($current_screen,
'' . __('Plugins extend and expand the functionality of WordPress. Once a plugin is installed, you may activate it or deactivate it here.') . '
' .
'' . sprintf(__('You can find additional plugins for your site by using the Plugin Browser/Installer functionality or by browsing the WordPress Plugin Directory directly and installing new plugins manually. To manually install a plugin you generally just need to upload the plugin file into your /wp-content/plugins
directory. Once a plugin has been installed, you can activate it here.'), 'plugin-install.php', 'http://wordpress.org/extend/plugins/') . '
' .
@@ -324,8 +338,9 @@ add_contextual_help($current_screen,
);
$title = __('Plugins');
+$parent_file = 'plugins.php';
-require_once('./admin-header.php');
+require_once(ABSPATH . 'wp-admin/admin-header.php');
$invalid = validate_active_plugins();
if ( !empty($invalid) )
@@ -335,15 +350,17 @@ if ( !empty($invalid) )
unexpected output during activation. If you notice “headers already sent” messages, problems with syndication feeds or other issues, try deactivating or removing this plugin.'), $_GET['charsout']);
else
$errmsg = __('Plugin could not be activated because it triggered a fatal error .');
?>
-
+ if ( !isset( $_GET['main'] ) && !isset($_GET['charsout']) && wp_verify_nonce($_GET['_error_nonce'], 'plugin-activation-error_' . $plugin) ) { ?>
+
@@ -371,415 +388,36 @@ if ( !empty($invalid) )
-
-
-
+
+' . __('Search results for “%s”') . '', esc_html( $s ) ); ?>
+
-$all_plugins = apply_filters( 'all_plugins', get_plugins() );
-$search_plugins = array();
-$active_plugins = array();
-$inactive_plugins = array();
-$recent_plugins = array();
-$recently_activated = get_option('recently_activated', array());
-$upgrade_plugins = array();
-$network_plugins = array();
-$mustuse_plugins = $dropins_plugins = array();
-if ( ! is_multisite() || current_user_can('manage_network_plugins') ) {
- if ( apply_filters( 'show_advanced_plugins', true, 'mustuse' ) )
- $mustuse_plugins = get_mu_plugins();
- if ( apply_filters( 'show_advanced_plugins', true, 'dropins' ) )
- $dropins_plugins = get_dropins();
-}
+
-set_transient( 'plugin_slugs', array_keys($all_plugins), 86400 );
-
-// Clean out any plugins which were deactivated over a week ago.
-foreach ( $recently_activated as $key => $time )
- if ( $time + (7*24*60*60) < time() ) //1 week
- unset($recently_activated[ $key ]);
-if ( $recently_activated != get_option('recently_activated') ) //If array changed, update it.
- update_option('recently_activated', $recently_activated);
-$current = get_site_transient( 'update_plugins' );
-
-foreach ( array( 'all_plugins', 'mustuse_plugins', 'dropins_plugins' ) as $plugin_array_name) {
- foreach ( (array) $$plugin_array_name as $plugin_file => $plugin_data ) {
- // Translate, Apply Markup, Sanitize HTML
- $plugin_data = _get_plugin_data_markup_translate($plugin_file, $plugin_data, false, true);
- ${$plugin_array_name}[ $plugin_file ] = $plugin_data;
- }
-}
-unset( $plugin_array_name );
-
-foreach ( (array) $all_plugins as $plugin_file => $plugin_data) {
- // Filter into individual sections
- if ( is_multisite() && is_network_only_plugin( $plugin_file ) && !current_user_can( 'manage_network_plugins' ) ) {
- unset( $all_plugins[ $plugin_file ] );
- continue;
- } elseif ( is_plugin_active_for_network($plugin_file) ) {
- $network_plugins[ $plugin_file ] = $plugin_data;
- } elseif ( is_plugin_active($plugin_file) ) {
- $active_plugins[ $plugin_file ] = $plugin_data;
- } else {
- if ( isset( $recently_activated[ $plugin_file ] ) ) // Was the plugin recently activated?
- $recent_plugins[ $plugin_file ] = $plugin_data;
- $inactive_plugins[ $plugin_file ] = $plugin_data;
- }
+views(); ?>
- if ( isset( $current->response[ $plugin_file ] ) )
- $upgrade_plugins[ $plugin_file ] = $plugin_data;
-}
+
-
-
-
-
' . __( 'Files in the /wp-content/mu-plugins
directory are executed automatically.' ) . '
';
+ echo '
' . __( 'Files in the /wp-content/mu-plugins
directory are executed automatically.' ) . '
';
elseif ( 'dropins' == $status )
- echo '
' . __( 'Drop-ins are advanced plugins in the /wp-content
directory that replace WordPress functionality when present.' ) . '
';
-
-if ( !empty( $plugins ) && ( ! in_array( $status, array( 'mustuse', 'dropins' ) ) || $page_links ) ) :
+ echo '
' . __( 'Drop-ins are advanced plugins in the /wp-content
directory that replace WordPress functionality when present.' ) . '
';
?>
-
-', $page_links_text, '
';
-print_plugin_actions($status);
-?>
-
-
- $plugins_per_page )
- $plugins = array_slice($plugins, $start, $plugins_per_page);
-
-print_plugins_table($plugins, $status);
-
-if ( !empty( $plugins ) && ! in_array( $status, array( 'mustuse', 'dropins' ) ) || $page_links ) {
-?>
-
-$page_links_text
";
-
-print_plugin_actions($status, "action2");
-?>
-
-
+display(); ?>
-
-
-
-
-
+include(ABSPATH . 'wp-admin/admin-footer.php');