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.' ) );
2012-09-27 13:11:07 -04: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' ;
2012-09-27 13:11:07 -04:00
add_screen_option ( 'per_page' , array ( 'label' => _x ( 'Sites' , 'sites per page (screen options)' ) ) );
2011-10-02 02:59:36 -04:00
2011-11-30 21:22:07 -05:00
get_current_screen () -> add_help_tab ( array (
'id' => 'overview' ,
'title' => __ ( 'Overview' ),
'content' =>
'<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>' .
'<li>' . __ ( 'Dashboard leads to the Dashboard for that site.' ) . '</li>' .
'<li>' . __ ( 'Deactivate, Archive, and Spam which lead to confirmation screens. These actions can be reversed later.' ) . '</li>' .
'<li>' . __ ( 'Delete which is a permanent action after the confirmation screens.' ) . '</li>' .
'<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>' .
'<p>' . __ ( 'Clicking on bold headings can re-sort this table.' ) . '</p>'
) );
2011-11-02 01:33:53 -04:00
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>' .
2012-05-03 09:34:33 -04:00
'<p>' . __ ( '<a href="http://codex.wordpress.org/Network_Admin_Sites_Screen" 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' , '' );
2012-09-27 13:11:07 -04:00
if ( 'confirm' === $_GET [ 'action' ] ) {
check_admin_referer ( 'confirm' );
2012-11-30 08:40:59 -05:00
2012-09-27 13:11:07 -04:00
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 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 >
2012-11-30 08:40:59 -05:00
< body class = " wp-core-ui " >
2013-02-14 00:52:23 -05:00
< h1 id = " logo " >< a href = " <?php echo esc_url( __( 'http://wordpress.org/' ) ); ?> " >< ? php _e ( 'WordPress' ); ?> </a></h1>
2012-09-27 13:11:07 -04:00
< 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 ); ?>
2013-03-01 12:14:09 -05:00
< p >< ? php echo esc_html ( wp_unslash ( $_GET [ 'msg' ] ) ); ?> </p>
2012-09-27 13:11:07 -04:00
< ? php submit_button ( __ ( 'Confirm' ), 'button' ); ?>
</ form >
</ body >
</ html >
< ? php
2012-11-30 08:40:59 -05:00
exit ();
2012-09-27 13:11:07 -04:00
}
2012-11-30 08:40:59 -05:00
2012-09-27 13:11:07 -04:00
$updated_action = '' ;
2012-11-30 08:40:59 -05:00
2012-09-27 13:11:07 -04:00
$manage_actions = array ( 'deleteblog' , 'allblogs' , 'archiveblog' , 'unarchiveblog' , 'activateblog' , 'deactivateblog' , 'unspamblog' , 'spamblog' , 'unmatureblog' , 'matureblog' );
2012-11-30 08:40:59 -05:00
if ( in_array ( $_GET [ 'action' ], $manage_actions ) ) {
2012-09-27 13:11:07 -04:00
$action = $_GET [ 'action' ];
if ( 'allblogs' === $action )
$action = 'bulk-sites' ;
check_admin_referer ( $action );
2012-11-30 08:40:59 -05:00
}
2011-08-17 22:29:06 -04:00
switch ( $_GET [ 'action' ] ) {
case 'deleteblog' :
2012-09-27 13:11:07 -04:00
if ( ! current_user_can ( 'delete_sites' ) )
2011-08-17 22:29:06 -04:00
wp_die ( __ ( 'You do not have permission to access this page.' ) );
2012-09-27 13:11:07 -04:00
$updated_action = 'not_deleted' ;
2011-08-17 22:29:06 -04:00
if ( $id != '0' && $id != $current_site -> blog_id && current_user_can ( 'delete_site' , $id ) ) {
wpmu_delete_blog ( $id , true );
2012-11-30 08:40:59 -05:00
$updated_action = 'delete' ;
2011-08-17 22:29:06 -04:00
}
break ;
case 'allblogs' :
if ( ( isset ( $_POST [ 'action' ] ) || isset ( $_POST [ 'action2' ] ) ) && isset ( $_POST [ 'allblogs' ] ) ) {
2012-03-02 17:01:41 -05:00
$doaction = $_POST [ 'action' ] != - 1 ? $_POST [ 'action' ] : $_POST [ 'action2' ];
2012-11-30 08:40:59 -05:00
2011-08-17 22:29:06 -04:00
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.' ) );
2012-11-30 08:40:59 -05:00
2012-09-27 13:11:07 -04:00
$updated_action = 'all_delete' ;
2011-08-17 22:29:06 -04:00
wpmu_delete_blog ( $val , true );
break ;
case 'spam' :
case 'notspam' :
2012-09-27 13:11:07 -04:00
$updated_action = ( 'spam' === $doaction ) ? 'all_spam' : 'all_notspam' ;
update_blog_status ( $val , 'spam' , ( 'spam' === $doaction ) ? '1' : '0' );
2011-08-17 22:29:06 -04:00
break ;
}
} else {
wp_die ( __ ( 'You are not allowed to change the current site.' ) );
}
}
} else {
wp_redirect ( network_admin_url ( 'sites.php' ) );
2012-09-27 13:11:07 -04:00
exit ();
2011-08-17 22:29:06 -04:00
}
break ;
case 'archiveblog' :
case 'unarchiveblog' :
2012-09-27 13:11:07 -04:00
update_blog_status ( $id , 'archived' , ( 'archiveblog' === $_GET [ 'action' ] ) ? '1' : '0' );
2011-08-17 22:29:06 -04:00
break ;
case 'activateblog' :
update_blog_status ( $id , 'deleted' , '0' );
do_action ( 'activate_blog' , $id );
break ;
case 'deactivateblog' :
do_action ( 'deactivate_blog' , $id );
update_blog_status ( $id , 'deleted' , '1' );
break ;
case 'unspamblog' :
case 'spamblog' :
2012-09-27 13:11:07 -04:00
update_blog_status ( $id , 'spam' , ( 'spamblog' === $_GET [ 'action' ] ) ? '1' : '0' );
2011-08-17 22:29:06 -04:00
break ;
2012-11-30 08:40:59 -05:00
2011-08-17 22:29:06 -04:00
case 'unmatureblog' :
case 'matureblog' :
2012-09-27 13:11:07 -04:00
update_blog_status ( $id , 'mature' , ( 'matureblog' === $_GET [ 'action' ] ) ? '1' : '0' );
2011-08-17 22:29:06 -04:00
break ;
}
2012-11-30 08:40:59 -05:00
2012-09-27 13:11:07 -04:00
if ( empty ( $updated_action ) && in_array ( $_GET [ 'action' ], $manage_actions ) )
$updated_action = $_GET [ 'action' ];
2012-11-30 08:40:59 -05:00
2012-09-27 13:11:07 -04:00
if ( ! empty ( $updated_action ) ) {
wp_safe_redirect ( add_query_arg ( array ( 'updated' => $updated_action ), wp_get_referer () ) );
exit ();
}
2011-08-17 22:29:06 -04:00
}
2010-09-28 14:21:46 -04:00
$msg = '' ;
2012-09-27 13:11:07 -04:00
if ( isset ( $_GET [ 'updated' ] ) ) {
switch ( $_GET [ 'updated' ] ) {
2010-09-28 14:21:46 -04:00
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 ;
2012-09-27 13:11:07 -04:00
case 'archiveblog' :
2010-09-28 14:21:46 -04:00
$msg = __ ( 'Site archived.' );
break ;
2012-09-27 13:11:07 -04:00
case 'unarchiveblog' :
2010-09-28 14:21:46 -04:00
$msg = __ ( 'Site unarchived.' );
break ;
2012-09-27 13:11:07 -04:00
case 'activateblog' :
2010-09-28 14:21:46 -04:00
$msg = __ ( 'Site activated.' );
break ;
2012-09-27 13:11:07 -04:00
case 'deactivateblog' :
2010-09-28 14:21:46 -04:00
$msg = __ ( 'Site deactivated.' );
break ;
2012-09-27 13:11:07 -04:00
case 'unspamblog' :
2010-09-28 14:21:46 -04:00
$msg = __ ( 'Site removed from spam.' );
break ;
2012-09-27 13:11:07 -04:00
case 'spamblog' :
2010-09-28 14:21:46 -04:00
$msg = __ ( 'Site marked as spam.' );
break ;
default :
2012-09-27 13:11:07 -04:00
$msg = apply_filters ( 'network_sites_updated_message_' . $_GET [ 'updated' ], __ ( 'Settings saved.' ) );
2010-09-28 14:21:46 -04:00
break ;
}
2012-11-30 08:40:59 -05:00
2012-09-27 13:11:07 -04:00
if ( ! empty ( $msg ) )
2010-09-28 14:21:46 -04:00
$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 " >
2012-09-27 13:11:07 -04:00
< ? php screen_icon ( 'ms-admin' ); ?>
< h2 >< ? php _e ( 'Sites' ) ?>
2012-11-30 08:40:59 -05:00
2011-05-10 15:18:16 -04:00
< ? php if ( current_user_can ( 'create_sites' ) ) : ?>
2012-09-27 13:11:07 -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 >
2012-11-30 08:40:59 -05:00
< ? php echo $msg ; ?>
2010-10-27 12:06:40 -04:00
< 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' ); ?>