2010-10-21 09:49:49 -04:00
< ? php
/**
* Add Site Administration Screen
*
* @ package WordPress
2010-11-10 09:27:15 -05:00
* @ subpackage Multisite
2010-10-21 11:38:50 -04:00
* @ since 3.1 . 0
2010-10-21 09:49:49 -04:00
*/
/** Load WordPress Administration Bootstrap */
2013-09-24 20:18:11 -04:00
require_once ( dirname ( __FILE__ ) . '/admin.php' );
2010-10-21 09:49:49 -04:00
if ( ! is_multisite () )
wp_die ( __ ( 'Multisite support is not enabled.' ) );
2010-12-16 02:41:38 -05:00
if ( ! current_user_can ( 'manage_sites' ) )
wp_die ( __ ( 'You do not have sufficient permissions to add sites to this network.' ) );
2010-10-21 09:49:49 -04:00
2011-11-30 21:22:07 -05:00
get_current_screen () -> add_help_tab ( array (
'id' => 'overview' ,
'title' => __ ( 'Overview' ),
'content' =>
'<p>' . __ ( 'This screen is for Super Admins to add new sites to the network. This is not affected by the registration settings.' ) . '</p>' .
'<p>' . __ ( 'If the admin email for the new site does not exist in the database, a new user will also be created.' ) . '</p>'
) );
2011-11-02 01:33:53 -04:00
2011-11-02 17:32:16 -04:00
get_current_screen () -> set_help_sidebar (
2010-12-16 01:52:47 -05:00
'<p><strong>' . __ ( 'For more information:' ) . '</strong></p>' .
2015-04-12 17:29:32 -04:00
'<p>' . __ ( '<a href="https://codex.wordpress.org/Network_Admin_Sites_Screen" target="_blank">Documentation on Site Management</a>' ) . '</p>' .
2014-03-07 23:14:15 -05:00
'<p>' . __ ( '<a href="https://wordpress.org/support/forum/multisite/" target="_blank">Support Forums</a>' ) . '</p>'
2010-12-16 01:52:47 -05:00
);
2010-10-21 09:49:49 -04:00
if ( isset ( $_REQUEST [ 'action' ]) && 'add-site' == $_REQUEST [ 'action' ] ) {
check_admin_referer ( 'add-blog' , '_wpnonce_add-blog' );
2010-12-16 02:41:38 -05:00
if ( ! is_array ( $_POST [ 'blog' ] ) )
2010-11-11 11:57:22 -05:00
wp_die ( __ ( 'Can’t create an empty site.' ) );
2013-11-16 12:38:11 -05:00
2013-03-01 11:28:40 -05:00
$blog = $_POST [ 'blog' ];
2010-10-21 09:49:49 -04:00
$domain = '' ;
2011-07-26 17:35:39 -04:00
if ( preg_match ( '|^([a-zA-Z0-9-])+$|' , $blog [ 'domain' ] ) )
2010-10-21 09:49:49 -04:00
$domain = strtolower ( $blog [ 'domain' ] );
// If not a subdomain install, make sure the domain isn't a reserved word
if ( ! is_subdomain_install () ) {
2013-10-30 10:39:10 -04:00
/** This filter is documented in wp-includes/ms-functions.php */
2010-10-21 09:49:49 -04:00
$subdirectory_reserved_names = apply_filters ( 'subdirectory_reserved_names' , array ( 'page' , 'comments' , 'blog' , 'files' , 'feed' ) );
if ( in_array ( $domain , $subdirectory_reserved_names ) )
wp_die ( sprintf ( __ ( 'The following words are reserved for use by WordPress functions and cannot be used as blog names: <code>%s</code>' ), implode ( '</code>, <code>' , $subdirectory_reserved_names ) ) );
}
$title = $blog [ 'title' ];
if ( empty ( $domain ) )
wp_die ( __ ( 'Missing or invalid site address.' ) );
2014-10-11 20:22:18 -04:00
if ( isset ( $blog [ 'email' ] ) && '' === trim ( $blog [ 'email' ] ) ) {
2010-10-21 09:49:49 -04:00
wp_die ( __ ( 'Missing email address.' ) );
2014-10-11 20:22:18 -04:00
}
$email = sanitize_email ( $blog [ 'email' ] );
if ( ! is_email ( $email ) ) {
2010-10-21 09:49:49 -04:00
wp_die ( __ ( 'Invalid email address.' ) );
2014-10-11 20:22:18 -04:00
}
2010-10-21 09:49:49 -04:00
if ( is_subdomain_install () ) {
$newdomain = $domain . '.' . preg_replace ( '|^www\.|' , '' , $current_site -> domain );
2012-09-27 02:07:21 -04:00
$path = $current_site -> path ;
2010-10-21 09:49:49 -04:00
} else {
$newdomain = $current_site -> domain ;
2012-09-27 02:07:21 -04:00
$path = $current_site -> path . $domain . '/' ;
2010-10-21 09:49:49 -04:00
}
$password = 'N/A' ;
$user_id = email_exists ( $email );
if ( ! $user_id ) { // Create a new user with a random password
2010-11-10 18:31:54 -05:00
$password = wp_generate_password ( 12 , false );
2010-10-21 09:49:49 -04:00
$user_id = wpmu_create_user ( $domain , $password , $email );
2015-06-12 13:19:27 -04:00
if ( false === $user_id )
2010-10-21 09:49:49 -04:00
wp_die ( __ ( 'There was an error creating the user.' ) );
else
wp_new_user_notification ( $user_id , $password );
}
$wpdb -> hide_errors ();
$id = wpmu_create_blog ( $newdomain , $path , $title , $user_id , array ( 'public' => 1 ), $current_site -> id );
$wpdb -> show_errors ();
2015-04-01 09:26:28 -04:00
if ( ! is_wp_error ( $id ) ) {
if ( ! is_super_admin ( $user_id ) && ! get_user_option ( 'primary_blog' , $user_id ) ) {
2010-10-21 09:49:49 -04:00
update_user_option ( $user_id , 'primary_blog' , $id , true );
2015-04-01 09:26:28 -04:00
}
$content_mail = sprintf (
/* translators: 1: user login, 2: site url, 3: site name/title */
__ ( ' New site created by % 1 $s
2012-11-19 01:11:42 -05:00
Address : % 2 $s
2015-04-01 09:26:28 -04:00
Name : % 3 $s ' ),
$current_user -> user_login ,
get_site_url ( $id ),
wp_unslash ( $title )
);
2010-11-11 11:57:22 -05:00
wp_mail ( get_site_option ( 'admin_email' ), sprintf ( __ ( '[%s] New Site Created' ), $current_site -> site_name ), $content_mail , 'From: "Site Admin" <' . get_site_option ( 'admin_email' ) . '>' );
2010-10-21 09:49:49 -04:00
wpmu_welcome_notification ( $id , $user_id , $password , $title , array ( 'public' => 1 ) );
2011-09-22 03:17:27 -04:00
wp_redirect ( add_query_arg ( array ( 'update' => 'added' , 'id' => $id ), 'site-new.php' ) );
2010-10-21 09:49:49 -04:00
exit ;
} else {
wp_die ( $id -> get_error_message () );
}
}
if ( isset ( $_GET [ 'update' ]) ) {
$messages = array ();
if ( 'added' == $_GET [ 'update' ] )
2015-04-01 09:26:28 -04:00
$messages [] = sprintf (
/* translators: 1: dashboard url, 2: network admin edit url */
__ ( 'Site added. <a href="%1$s">Visit Dashboard</a> or <a href="%2$s">Edit Site</a>' ),
esc_url ( get_admin_url ( absint ( $_GET [ 'id' ] ) ) ),
network_admin_url ( 'site-info.php?id=' . absint ( $_GET [ 'id' ] ) )
);
2010-10-21 09:49:49 -04:00
}
$title = __ ( 'Add New Site' );
$parent_file = 'sites.php' ;
2014-01-27 18:10:12 -05:00
wp_enqueue_script ( 'user-suggest' );
2013-09-24 20:18:11 -04:00
require ( ABSPATH . 'wp-admin/admin-header.php' );
2010-10-21 09:49:49 -04:00
?>
< div class = " wrap " >
< h2 id = " add-new-site " >< ? php _e ( 'Add New Site' ) ?> </h2>
< ? php
if ( ! empty ( $messages ) ) {
foreach ( $messages as $msg )
2015-04-01 18:06:28 -04:00
echo '<div id="message" class="updated notice is-dismissible"><p>' . $msg . '</p></div>' ;
2010-10-21 09:49:49 -04:00
} ?>
2014-07-08 13:52:14 -04:00
< form method = " post " action = " <?php echo network_admin_url( 'site-new.php?action=add-site' ); ?> " novalidate = " novalidate " >
2010-10-21 09:49:49 -04:00
< ? php wp_nonce_field ( 'add-blog' , '_wpnonce_add-blog' ) ?>
< table class = " form-table " >
< tr class = " form-field form-required " >
2015-02-22 21:29:26 -05:00
< th scope = " row " >< label for = " site-address " >< ? php _e ( 'Site Address' ) ?> </label></th>
2010-10-21 09:49:49 -04:00
< td >
< ? php if ( is_subdomain_install () ) { ?>
2015-02-22 21:29:26 -05:00
< input name = " blog[domain] " type = " text " class = " regular-text " id = " site-address " aria - describedby = " site-address-desc " />< span class = " no-break " >.< ? php echo preg_replace ( '|^www\.|' , '' , $current_site -> domain ); ?> </span>
2010-10-21 09:49:49 -04:00
< ? php } else {
2015-02-22 21:29:26 -05:00
echo $current_site -> domain . $current_site -> path ?> <input name="blog[domain]" type="text" class="regular-text" id="site-address" aria-describedby="site-address-desc" />
2010-10-21 09:49:49 -04:00
< ? php }
2015-02-22 21:29:26 -05:00
echo '<p id="site-address-desc">' . __ ( 'Only lowercase letters (a-z) and numbers are allowed.' ) . '</p>' ;
2010-10-21 09:49:49 -04:00
?>
</ td >
</ tr >
< tr class = " form-field form-required " >
2015-02-22 21:29:26 -05:00
< th scope = " row " >< label for = " site-title " >< ? php _e ( 'Site Title' ) ?> </label></th>
< td >< input name = " blog[title] " type = " text " class = " regular-text " id = " site-title " /></ td >
2010-10-21 09:49:49 -04:00
</ tr >
< tr class = " form-field form-required " >
2015-04-30 10:30:25 -04:00
< th scope = " row " >< label for = " admin-email " >< ? php _e ( 'Admin Email' ) ?> </label></th>
2015-02-22 21:29:26 -05:00
< td >< input name = " blog[email] " type = " email " class = " regular-text wp-suggest-user " id = " admin-email " data - autocomplete - type = " search " data - autocomplete - field = " user_email " /></ td >
2010-10-21 09:49:49 -04:00
</ tr >
< tr class = " form-field " >
< td colspan = " 2 " >< ? php _e ( 'A new user will be created if the above email address is not in the database.' ) ?> <br /><?php _e( 'The username and password will be mailed to this email address.' ) ?></td>
</ tr >
</ table >
< ? php submit_button ( __ ( 'Add Site' ), 'primary' , 'add-site' ); ?>
</ form >
</ div >
< ? php
2013-09-24 20:18:11 -04:00
require ( ABSPATH . 'wp-admin/admin-footer.php' );