2010-07-30 16:34:54 -04:00
< ? php
/**
* Multisite sites administration panel .
*
* @ package WordPress
* @ subpackage Multisite
* @ since 3.0 . 0
*/
2010-11-10 09:27:15 -05:00
/** Load WordPress Administration Bootstrap */
2010-07-30 16:34:54 -04:00
require_once ( './admin.php' );
if ( ! is_multisite () )
wp_die ( __ ( 'Multisite support is not enabled.' ) );
2010-12-16 03:43:22 -05:00
if ( ! current_user_can ( 'manage_sites' ) )
wp_die ( __ ( 'You do not have permission to access this page.' ) );
2011-01-16 16:47:24 -05:00
$wp_list_table = _get_list_table ( 'WP_MS_Sites_List_Table' );
2011-01-12 19:03:38 -05:00
$pagenum = $wp_list_table -> get_pagenum ();
2010-07-30 16:34:54 -04:00
$title = __ ( 'Sites' );
$parent_file = 'sites.php' ;
2011-10-07 00:57:12 -04:00
add_screen_option ( 'per_page' , array ( 'label' => _x ( 'Sites' , 'sites per page (screen options)' )) );
2011-10-02 02:59:36 -04:00
2010-10-21 14:35:52 -04:00
add_contextual_help ( $current_screen ,
'<p>' . __ ( 'Add New takes you to the Add New Site screen. You can search for a site by Name, ID number, or IP address. Screen Options allows you to choose how many sites to display on one page.' ) . '</p>' .
'<p>' . __ ( 'This is the main table of all sites on this network. Switch between list and excerpt views by using the icons above the right side of the table.' ) . '</p>' .
'<p>' . __ ( 'Hovering over each site reveals seven options (three for the primary site):' ) . '</p>' .
'<ul><li>' . __ ( 'An Edit link to a separate Edit Site screen.' ) . '</li>' .
2010-10-27 04:14:48 -04:00
'<li>' . __ ( 'Dashboard leads to the Dashboard for that site.' ) . '</li>' .
2010-10-21 14:35:52 -04:00
'<li>' . __ ( 'Deactivate, Archive, and Spam which lead to confirmation screens. These actions can be reversed later.' ) . '</li>' .
2010-10-27 04:14:48 -04:00
'<li>' . __ ( 'Delete which is a permanent action after the confirmation screens.' ) . '</li>' .
2010-10-21 14:35:52 -04:00
'<li>' . __ ( 'Visit to go to the frontend site live.' ) . '</li></ul>' .
'<p>' . __ ( 'The site ID is used internally, and is not shown on the front end of the site or to users/viewers.' ) . '</p>' .
2011-11-02 01:33:53 -04:00
'<p>' . __ ( 'Clicking on bold headings can re-sort this table.' ) . '</p>'
);
2011-11-02 17:32:16 -04:00
get_current_screen () -> set_help_sidebar (
2010-10-21 14:35:52 -04:00
'<p><strong>' . __ ( 'For more information:' ) . '</strong></p>' .
2010-12-18 13:27:12 -05:00
'<p>' . __ ( '<a href="http://codex.wordpress.org/Network_Admin_Sites_Screens" target="_blank">Documentation on Site Management</a>' ) . '</p>' .
2010-12-25 14:21:00 -05:00
'<p>' . __ ( '<a href="http://wordpress.org/support/forum/multisite/" target="_blank">Support Forums</a>' ) . '</p>'
2010-10-21 14:35:52 -04:00
);
2010-07-30 16:34:54 -04:00
2010-08-11 17:54:51 -04:00
$id = isset ( $_REQUEST [ 'id' ] ) ? intval ( $_REQUEST [ 'id' ] ) : 0 ;
2010-07-30 16:34:54 -04:00
2011-08-17 22:29:06 -04:00
if ( isset ( $_GET [ 'action' ] ) ) {
do_action ( 'wpmuadminedit' , '' );
switch ( $_GET [ 'action' ] ) {
case 'updateblog' :
// No longer used.
break ;
case 'deleteblog' :
check_admin_referer ( 'deleteblog' );
if ( ! ( current_user_can ( 'manage_sites' ) && current_user_can ( 'delete_sites' ) ) )
wp_die ( __ ( 'You do not have permission to access this page.' ) );
if ( $id != '0' && $id != $current_site -> blog_id && current_user_can ( 'delete_site' , $id ) ) {
wpmu_delete_blog ( $id , true );
wp_redirect ( add_query_arg ( array ( 'updated' => 'true' , 'action' => 'delete' ), wp_get_referer () ) );
} else {
wp_redirect ( add_query_arg ( array ( 'updated' => 'true' , 'action' => 'not_deleted' ), wp_get_referer () ) );
}
exit ();
break ;
case 'allblogs' :
if ( ( isset ( $_POST [ 'action' ] ) || isset ( $_POST [ 'action2' ] ) ) && isset ( $_POST [ 'allblogs' ] ) ) {
check_admin_referer ( 'bulk-sites' );
if ( ! current_user_can ( 'manage_sites' ) )
wp_die ( __ ( 'You do not have permission to access this page.' ) );
if ( $_GET [ 'action' ] != - 1 || $_POST [ 'action2' ] != - 1 )
$doaction = $_POST [ 'action' ] != - 1 ? $_POST [ 'action' ] : $_POST [ 'action2' ];
$blogfunction = '' ;
foreach ( ( array ) $_POST [ 'allblogs' ] as $key => $val ) {
if ( $val != '0' && $val != $current_site -> blog_id ) {
switch ( $doaction ) {
case 'delete' :
if ( ! current_user_can ( 'delete_site' , $val ) )
wp_die ( __ ( 'You are not allowed to delete the site.' ) );
$blogfunction = 'all_delete' ;
wpmu_delete_blog ( $val , true );
break ;
case 'spam' :
$blogfunction = 'all_spam' ;
update_blog_status ( $val , 'spam' , '1' );
set_time_limit ( 60 );
break ;
case 'notspam' :
$blogfunction = 'all_notspam' ;
update_blog_status ( $val , 'spam' , '0' );
set_time_limit ( 60 );
break ;
}
} else {
wp_die ( __ ( 'You are not allowed to change the current site.' ) );
}
}
wp_redirect ( add_query_arg ( array ( 'updated' => 'true' , 'action' => $blogfunction ), wp_get_referer () ) );
} else {
wp_redirect ( network_admin_url ( 'sites.php' ) );
}
exit ();
break ;
case 'archiveblog' :
check_admin_referer ( 'archiveblog' );
if ( ! current_user_can ( 'manage_sites' ) )
wp_die ( __ ( 'You do not have permission to access this page.' ) );
update_blog_status ( $id , 'archived' , '1' );
wp_redirect ( add_query_arg ( array ( 'updated' => 'true' , 'action' => 'archive' ), wp_get_referer () ) );
exit ();
break ;
case 'unarchiveblog' :
check_admin_referer ( 'unarchiveblog' );
if ( ! current_user_can ( 'manage_sites' ) )
wp_die ( __ ( 'You do not have permission to access this page.' ) );
update_blog_status ( $id , 'archived' , '0' );
wp_redirect ( add_query_arg ( array ( 'updated' => 'true' , 'action' => 'unarchive' ), wp_get_referer () ) );
exit ();
break ;
case 'activateblog' :
check_admin_referer ( 'activateblog' );
if ( ! current_user_can ( 'manage_sites' ) )
wp_die ( __ ( 'You do not have permission to access this page.' ) );
update_blog_status ( $id , 'deleted' , '0' );
do_action ( 'activate_blog' , $id );
wp_redirect ( add_query_arg ( array ( 'updated' => 'true' , 'action' => 'activate' ), wp_get_referer () ) );
exit ();
break ;
case 'deactivateblog' :
check_admin_referer ( 'deactivateblog' );
if ( ! current_user_can ( 'manage_sites' ) )
wp_die ( __ ( 'You do not have permission to access this page.' ) );
do_action ( 'deactivate_blog' , $id );
update_blog_status ( $id , 'deleted' , '1' );
wp_redirect ( add_query_arg ( array ( 'updated' => 'true' , 'action' => 'deactivate' ), wp_get_referer () ) );
exit ();
break ;
case 'unspamblog' :
check_admin_referer ( 'unspamblog' );
if ( ! current_user_can ( 'manage_sites' ) )
wp_die ( __ ( 'You do not have permission to access this page.' ) );
update_blog_status ( $id , 'spam' , '0' );
wp_redirect ( add_query_arg ( array ( 'updated' => 'true' , 'action' => 'unspam' ), wp_get_referer () ) );
exit ();
break ;
case 'spamblog' :
check_admin_referer ( 'spamblog' );
if ( ! current_user_can ( 'manage_sites' ) )
wp_die ( __ ( 'You do not have permission to access this page.' ) );
update_blog_status ( $id , 'spam' , '1' );
wp_redirect ( add_query_arg ( array ( 'updated' => 'true' , 'action' => 'spam' ), wp_get_referer () ) );
exit ();
break ;
case 'unmatureblog' :
check_admin_referer ( 'unmatureblog' );
if ( ! current_user_can ( 'manage_sites' ) )
wp_die ( __ ( 'You do not have permission to access this page.' ) );
update_blog_status ( $id , 'mature' , '0' );
wp_redirect ( add_query_arg ( array ( 'updated' => 'true' , 'action' => 'unmature' ), wp_get_referer () ) );
exit ();
break ;
case 'matureblog' :
check_admin_referer ( 'matureblog' );
if ( ! current_user_can ( 'manage_sites' ) )
wp_die ( __ ( 'You do not have permission to access this page.' ) );
update_blog_status ( $id , 'mature' , '1' );
wp_redirect ( add_query_arg ( array ( 'updated' => 'true' , 'action' => 'mature' ), wp_get_referer () ) );
exit ();
break ;
// Common
case 'confirm' :
check_admin_referer ( 'confirm' );
if ( ! headers_sent () ) {
nocache_headers ();
header ( 'Content-Type: text/html; charset=utf-8' );
}
if ( $current_site -> blog_id == $id )
wp_die ( __ ( 'You are not allowed to change the current site.' ) );
?>
<! DOCTYPE html >
< html xmlns = " http://www.w3.org/1999/xhtml " < ? php if ( function_exists ( 'language_attributes' ) ) language_attributes (); ?> >
< head >
< title >< ? php _e ( 'WordPress › Confirm your action' ); ?> </title>
< meta http - equiv = " Content-Type " content = " text/html; charset=utf-8 " />
< ? php
wp_admin_css ( 'install' , true );
wp_admin_css ( 'ie' , true );
?>
</ head >
< body >
< h1 id = " logo " >< img alt = " WordPress " src = " <?php echo esc_attr( admin_url( 'images/wordpress-logo.png' ) ); ?> " /></ h1 >
< form action = " sites.php?action=<?php echo esc_attr( $_GET['action2'] ) ?> " method = " post " >
< input type = " hidden " name = " action " value = " <?php echo esc_attr( $_GET['action2'] ) ?> " />
< input type = " hidden " name = " id " value = " <?php echo esc_attr( $id ); ?> " />
< input type = " hidden " name = " _wp_http_referer " value = " <?php echo esc_attr( wp_get_referer() ); ?> " />
< ? php wp_nonce_field ( $_GET [ 'action2' ], '_wpnonce' , false ); ?>
< p >< ? php echo esc_html ( stripslashes ( $_GET [ 'msg' ] ) ); ?> </p>
< ? php submit_button ( __ ( 'Confirm' ), 'button' ); ?>
</ form >
</ body >
</ html >
< ? php
exit ();
break ;
}
}
2010-09-28 14:21:46 -04:00
$msg = '' ;
2010-08-11 17:54:51 -04:00
if ( isset ( $_REQUEST [ 'updated' ] ) && $_REQUEST [ 'updated' ] == 'true' && ! empty ( $_REQUEST [ 'action' ] ) ) {
2010-09-28 14:21:46 -04:00
switch ( $_REQUEST [ 'action' ] ) {
case 'all_notspam' :
$msg = __ ( 'Sites removed from spam.' );
break ;
case 'all_spam' :
$msg = __ ( 'Sites marked as spam.' );
break ;
case 'all_delete' :
$msg = __ ( 'Sites deleted.' );
break ;
case 'delete' :
$msg = __ ( 'Site deleted.' );
2010-12-13 16:03:34 -05:00
break ;
2010-11-12 11:35:28 -05:00
case 'not_deleted' :
$msg = __ ( 'You do not have permission to delete that site.' );
2010-09-28 14:21:46 -04:00
break ;
case 'archive' :
$msg = __ ( 'Site archived.' );
break ;
case 'unarchive' :
$msg = __ ( 'Site unarchived.' );
break ;
case 'activate' :
$msg = __ ( 'Site activated.' );
break ;
case 'deactivate' :
$msg = __ ( 'Site deactivated.' );
break ;
case 'unspam' :
$msg = __ ( 'Site removed from spam.' );
break ;
case 'spam' :
$msg = __ ( 'Site marked as spam.' );
break ;
default :
2010-12-03 07:12:44 -05:00
$msg = apply_filters ( 'network_sites_updated_message_' . $_REQUEST [ 'action' ] , __ ( 'Settings saved.' ) );
2010-09-28 14:21:46 -04:00
break ;
}
if ( $msg )
$msg = '<div class="updated" id="message"><p>' . $msg . '</p></div>' ;
2010-07-30 16:34:54 -04:00
}
2010-10-27 12:06:40 -04:00
$wp_list_table -> prepare_items ();
require_once ( '../admin-header.php' );
?>
< div class = " wrap " >
< ? php screen_icon ( 'ms-admin' ); ?>
2011-05-10 15:18:16 -04:00
< h2 >< ? php _e ( 'Sites' ) ?>
< ? php echo $msg ; ?>
< ? php if ( current_user_can ( 'create_sites' ) ) : ?>
2011-05-11 20:22:22 -04:00
< a href = " <?php echo network_admin_url('site-new.php'); ?> " class = " add-new-h2 " >< ? php echo esc_html_x ( 'Add New' , 'site' ); ?> </a>
2011-05-10 15:18:16 -04:00
< ? php endif ; ?>
< ? php if ( isset ( $_REQUEST [ 's' ] ) && $_REQUEST [ 's' ] ) {
2010-10-27 12:06:40 -04:00
printf ( '<span class="subtitle">' . __ ( 'Search results for “%s”' ) . '</span>' , esc_html ( $s ) );
} ?>
</ h2 >
< form action = " " method = " get " id = " ms-search " >
2010-12-16 15:45:10 -05:00
< ? php $wp_list_table -> search_box ( __ ( 'Search Sites' ), 'site' ); ?>
2010-10-27 12:06:40 -04:00
< input type = " hidden " name = " action " value = " blogs " />
</ form >
2011-08-17 22:29:06 -04:00
< form id = " form-site-list " action = " sites.php?action=allblogs " method = " post " >
2010-10-27 12:06:40 -04:00
< ? php $wp_list_table -> display (); ?>
</ form >
</ div >
< ? php
2010-07-30 16:34:54 -04:00
2010-08-11 20:38:46 -04:00
require_once ( '../admin-footer.php' ); ?>