From a415c29efee45520ae252d2aa28f1083a521cd7b Mon Sep 17 00:00:00 2001
From: Daniel Baumann
Date: Wed, 17 Apr 2024 09:56:49 +0200
Subject: Adding upstream version 6.4.3+dfsg1.
Signed-off-by: Daniel Baumann
---
wp-admin/network/about.php | 13 +
wp-admin/network/admin.php | 36 +++
wp-admin/network/contribute.php | 13 +
wp-admin/network/credits.php | 13 +
wp-admin/network/edit.php | 41 +++
wp-admin/network/freedoms.php | 13 +
wp-admin/network/index.php | 84 ++++++
wp-admin/network/menu.php | 118 ++++++++
wp-admin/network/plugin-editor.php | 13 +
wp-admin/network/plugin-install.php | 17 ++
wp-admin/network/plugins.php | 13 +
wp-admin/network/privacy.php | 13 +
wp-admin/network/profile.php | 13 +
wp-admin/network/settings.php | 547 ++++++++++++++++++++++++++++++++++++
wp-admin/network/setup.php | 13 +
wp-admin/network/site-info.php | 234 +++++++++++++++
wp-admin/network/site-new.php | 304 ++++++++++++++++++++
wp-admin/network/site-settings.php | 188 +++++++++++++
wp-admin/network/site-themes.php | 254 +++++++++++++++++
wp-admin/network/site-users.php | 382 +++++++++++++++++++++++++
wp-admin/network/sites.php | 413 +++++++++++++++++++++++++++
wp-admin/network/theme-editor.php | 13 +
wp-admin/network/theme-install.php | 17 ++
wp-admin/network/themes.php | 488 ++++++++++++++++++++++++++++++++
wp-admin/network/update-core.php | 13 +
wp-admin/network/update.php | 17 ++
wp-admin/network/upgrade.php | 158 +++++++++++
wp-admin/network/user-edit.php | 13 +
wp-admin/network/user-new.php | 166 +++++++++++
wp-admin/network/users.php | 320 +++++++++++++++++++++
30 files changed, 3940 insertions(+)
create mode 100644 wp-admin/network/about.php
create mode 100644 wp-admin/network/admin.php
create mode 100644 wp-admin/network/contribute.php
create mode 100644 wp-admin/network/credits.php
create mode 100644 wp-admin/network/edit.php
create mode 100644 wp-admin/network/freedoms.php
create mode 100644 wp-admin/network/index.php
create mode 100644 wp-admin/network/menu.php
create mode 100644 wp-admin/network/plugin-editor.php
create mode 100644 wp-admin/network/plugin-install.php
create mode 100644 wp-admin/network/plugins.php
create mode 100644 wp-admin/network/privacy.php
create mode 100644 wp-admin/network/profile.php
create mode 100644 wp-admin/network/settings.php
create mode 100644 wp-admin/network/setup.php
create mode 100644 wp-admin/network/site-info.php
create mode 100644 wp-admin/network/site-new.php
create mode 100644 wp-admin/network/site-settings.php
create mode 100644 wp-admin/network/site-themes.php
create mode 100644 wp-admin/network/site-users.php
create mode 100644 wp-admin/network/sites.php
create mode 100644 wp-admin/network/theme-editor.php
create mode 100644 wp-admin/network/theme-install.php
create mode 100644 wp-admin/network/themes.php
create mode 100644 wp-admin/network/update-core.php
create mode 100644 wp-admin/network/update.php
create mode 100644 wp-admin/network/upgrade.php
create mode 100644 wp-admin/network/user-edit.php
create mode 100644 wp-admin/network/user-new.php
create mode 100644 wp-admin/network/users.php
(limited to 'wp-admin/network')
diff --git a/wp-admin/network/about.php b/wp-admin/network/about.php
new file mode 100644
index 0000000..35fde68
--- /dev/null
+++ b/wp-admin/network/about.php
@@ -0,0 +1,13 @@
+domain, $current_site->domain ) || 0 !== strcasecmp( $current_blog->path, $current_site->path ) );
+
+/**
+ * Filters whether to redirect the request to the Network Admin.
+ *
+ * @since 3.2.0
+ *
+ * @param bool $redirect_network_admin_request Whether the request should be redirected.
+ */
+$redirect_network_admin_request = apply_filters( 'redirect_network_admin_request', $redirect_network_admin_request );
+
+if ( $redirect_network_admin_request ) {
+ wp_redirect( network_admin_url() );
+ exit;
+}
+
+unset( $redirect_network_admin_request );
diff --git a/wp-admin/network/contribute.php b/wp-admin/network/contribute.php
new file mode 100644
index 0000000..45e6f65
--- /dev/null
+++ b/wp-admin/network/contribute.php
@@ -0,0 +1,13 @@
+' . __( 'Welcome to your Network Admin. This area of the Administration Screens is used for managing all aspects of your Multisite Network.' ) . '
';
+$overview .= '' . __( 'From here you can:' ) . '
';
+$overview .= '' . __( 'Add and manage sites or users' ) . ' ';
+$overview .= '' . __( 'Install and activate themes or plugins' ) . ' ';
+$overview .= '' . __( 'Update your network' ) . ' ';
+$overview .= '' . __( 'Modify global network settings' ) . ' ';
+
+get_current_screen()->add_help_tab(
+ array(
+ 'id' => 'overview',
+ 'title' => __( 'Overview' ),
+ 'content' => $overview,
+ )
+);
+
+$quick_tasks = '' . __( 'The Right Now widget on this screen provides current user and site counts on your network.' ) . '
';
+$quick_tasks .= '' . __( 'To add a new user, click Create a New User .' ) . ' ';
+$quick_tasks .= '' . __( 'To add a new site, click Create a New Site .' ) . ' ';
+$quick_tasks .= '' . __( 'To search for a user or site, use the search boxes.' ) . '
';
+$quick_tasks .= '' . __( 'To search for a user, enter an email address or username . Use a wildcard to search for a partial username, such as user*.' ) . ' ';
+$quick_tasks .= '' . __( 'To search for a site, enter the path or domain .' ) . ' ';
+
+get_current_screen()->add_help_tab(
+ array(
+ 'id' => 'quick-tasks',
+ 'title' => __( 'Quick Tasks' ),
+ 'content' => $quick_tasks,
+ )
+);
+
+get_current_screen()->set_help_sidebar(
+ '' . __( 'For more information:' ) . '
' .
+ '' . __( 'Documentation on the Network Admin ' ) . '
' .
+ '' . __( 'Support forums ' ) . '
'
+);
+
+wp_dashboard_setup();
+
+wp_enqueue_script( 'dashboard' );
+wp_enqueue_script( 'plugin-install' );
+add_thickbox();
+
+require_once ABSPATH . 'wp-admin/admin-header.php';
+
+?>
+
+
+
+%s ',
+ $update_data['counts']['total'],
+ number_format_i18n( $update_data['counts']['total'] )
+ )
+ ),
+ $cap,
+ 'update-core.php',
+ );
+} else {
+ $submenu['index.php'][10] = array( __( 'Updates' ), $cap, 'update-core.php' );
+}
+
+unset( $cap );
+
+$submenu['index.php'][15] = array( __( 'Upgrade Network' ), 'upgrade_network', 'upgrade.php' );
+
+$menu[4] = array( '', 'read', 'separator1', '', 'wp-menu-separator' );
+
+/* translators: Sites menu item. */
+$menu[5] = array( __( 'Sites' ), 'manage_sites', 'sites.php', '', 'menu-top menu-icon-site', 'menu-site', 'dashicons-admin-multisite' );
+$submenu['sites.php'][5] = array( __( 'All Sites' ), 'manage_sites', 'sites.php' );
+$submenu['sites.php'][10] = array( __( 'Add New Site' ), 'create_sites', 'site-new.php' );
+
+$menu[10] = array( __( 'Users' ), 'manage_network_users', 'users.php', '', 'menu-top menu-icon-users', 'menu-users', 'dashicons-admin-users' );
+$submenu['users.php'][5] = array( __( 'All Users' ), 'manage_network_users', 'users.php' );
+$submenu['users.php'][10] = array( __( 'Add New User' ), 'create_users', 'user-new.php' );
+
+if ( current_user_can( 'update_themes' ) && $update_data['counts']['themes'] ) {
+ $menu[15] = array(
+ sprintf(
+ /* translators: %s: Number of available theme updates. */
+ __( 'Themes %s' ),
+ sprintf(
+ '%s ',
+ $update_data['counts']['themes'],
+ number_format_i18n( $update_data['counts']['themes'] )
+ )
+ ),
+ 'manage_network_themes',
+ 'themes.php',
+ '',
+ 'menu-top menu-icon-appearance',
+ 'menu-appearance',
+ 'dashicons-admin-appearance',
+ );
+} else {
+ $menu[15] = array( __( 'Themes' ), 'manage_network_themes', 'themes.php', '', 'menu-top menu-icon-appearance', 'menu-appearance', 'dashicons-admin-appearance' );
+}
+$submenu['themes.php'][5] = array( __( 'Installed Themes' ), 'manage_network_themes', 'themes.php' );
+$submenu['themes.php'][10] = array( __( 'Add New Theme' ), 'install_themes', 'theme-install.php' );
+$submenu['themes.php'][15] = array( __( 'Theme File Editor' ), 'edit_themes', 'theme-editor.php' );
+
+if ( current_user_can( 'update_plugins' ) && $update_data['counts']['plugins'] ) {
+ $menu[20] = array(
+ sprintf(
+ /* translators: %s: Number of available plugin updates. */
+ __( 'Plugins %s' ),
+ sprintf(
+ '%s ',
+ $update_data['counts']['plugins'],
+ number_format_i18n( $update_data['counts']['plugins'] )
+ )
+ ),
+ 'manage_network_plugins',
+ 'plugins.php',
+ '',
+ 'menu-top menu-icon-plugins',
+ 'menu-plugins',
+ 'dashicons-admin-plugins',
+ );
+} else {
+ $menu[20] = array( __( 'Plugins' ), 'manage_network_plugins', 'plugins.php', '', 'menu-top menu-icon-plugins', 'menu-plugins', 'dashicons-admin-plugins' );
+}
+$submenu['plugins.php'][5] = array( __( 'Installed Plugins' ), 'manage_network_plugins', 'plugins.php' );
+$submenu['plugins.php'][10] = array( __( 'Add New Plugin' ), 'install_plugins', 'plugin-install.php' );
+$submenu['plugins.php'][15] = array( __( 'Plugin File Editor' ), 'edit_plugins', 'plugin-editor.php' );
+
+$menu[25] = array( __( 'Settings' ), 'manage_network_options', 'settings.php', '', 'menu-top menu-icon-settings', 'menu-settings', 'dashicons-admin-settings' );
+if ( defined( 'MULTISITE' ) && defined( 'WP_ALLOW_MULTISITE' ) && WP_ALLOW_MULTISITE ) {
+ $submenu['settings.php'][5] = array( __( 'Network Settings' ), 'manage_network_options', 'settings.php' );
+ $submenu['settings.php'][10] = array( __( 'Network Setup' ), 'setup_network', 'setup.php' );
+}
+unset( $update_data );
+
+$menu[99] = array( '', 'exist', 'separator-last', '', 'wp-menu-separator' );
+
+require_once ABSPATH . 'wp-admin/includes/menu.php';
diff --git a/wp-admin/network/plugin-editor.php b/wp-admin/network/plugin-editor.php
new file mode 100644
index 0000000..32cb1e7
--- /dev/null
+++ b/wp-admin/network/plugin-editor.php
@@ -0,0 +1,13 @@
+add_help_tab(
+ array(
+ 'id' => 'overview',
+ 'title' => __( 'Overview' ),
+ 'content' =>
+ '' . __( 'This screen sets and changes options for the network as a whole. The first site is the main site in the network and network options are pulled from that original site’s options.' ) . '
' .
+ '' . __( 'Operational settings has fields for the network’s name and admin email.' ) . '
' .
+ '' . __( 'Registration settings can disable/enable public signups. If you let others sign up for a site, install spam plugins. Spaces, not commas, should separate names banned as sites for this network.' ) . '
' .
+ '' . __( 'New site settings are defaults applied when a new site is created in the network. These include welcome email for when a new site or user account is registered, and what᾿s put in the first post, page, comment, comment author, and comment URL.' ) . '
' .
+ '' . __( 'Upload settings control the size of the uploaded files and the amount of available upload space for each site. You can change the default value for specific sites when you edit a particular site. Allowed file types are also listed (space separated only).' ) . '
' .
+ '' . __( 'You can set the language, and WordPress will automatically download and install the translation files (available if your filesystem is writable).' ) . '
' .
+ '' . __( 'Menu setting enables/disables the plugin menus from appearing for non super admins, so that only super admins, not site admins, have access to activate plugins.' ) . '
' .
+ '' . __( 'Super admins can no longer be added on the Options screen. You must now go to the list of existing users on Network Admin > Users and click on Username or the Edit action link below that name. This goes to an Edit User page where you can check a box to grant super admin privileges.' ) . '
',
+ )
+);
+
+get_current_screen()->set_help_sidebar(
+ '' . __( 'For more information:' ) . '
' .
+ '' . __( 'Documentation on Network Settings ' ) . '
' .
+ '' . __( 'Support forums ' ) . '
'
+);
+
+if ( $_POST ) {
+ /** This action is documented in wp-admin/network/edit.php */
+ do_action( 'wpmuadminedit' );
+
+ check_admin_referer( 'siteoptions' );
+
+ $checked_options = array(
+ 'menu_items' => array(),
+ 'registrationnotification' => 'no',
+ 'upload_space_check_disabled' => 1,
+ 'add_new_users' => 0,
+ );
+ foreach ( $checked_options as $option_name => $option_unchecked_value ) {
+ if ( ! isset( $_POST[ $option_name ] ) ) {
+ $_POST[ $option_name ] = $option_unchecked_value;
+ }
+ }
+
+ $options = array(
+ 'registrationnotification',
+ 'registration',
+ 'add_new_users',
+ 'menu_items',
+ 'upload_space_check_disabled',
+ 'blog_upload_space',
+ 'upload_filetypes',
+ 'site_name',
+ 'first_post',
+ 'first_page',
+ 'first_comment',
+ 'first_comment_url',
+ 'first_comment_author',
+ 'welcome_email',
+ 'welcome_user_email',
+ 'fileupload_maxk',
+ 'illegal_names',
+ 'limited_email_domains',
+ 'banned_email_domains',
+ 'WPLANG',
+ 'new_admin_email',
+ 'first_comment_email',
+ );
+
+ // Handle translation installation.
+ if ( ! empty( $_POST['WPLANG'] ) && current_user_can( 'install_languages' ) && wp_can_install_language_pack() ) {
+ $language = wp_download_language_pack( $_POST['WPLANG'] );
+ if ( $language ) {
+ $_POST['WPLANG'] = $language;
+ }
+ }
+
+ foreach ( $options as $option_name ) {
+ if ( ! isset( $_POST[ $option_name ] ) ) {
+ continue;
+ }
+ $value = wp_unslash( $_POST[ $option_name ] );
+ update_site_option( $option_name, $value );
+ }
+
+ /**
+ * Fires after the network options are updated.
+ *
+ * @since MU (3.0.0)
+ */
+ do_action( 'update_wpmu_options' );
+
+ wp_redirect( add_query_arg( 'updated', 'true', network_admin_url( 'settings.php' ) ) );
+ exit;
+}
+
+require_once ABSPATH . 'wp-admin/admin-header.php';
+
+if ( isset( $_GET['updated'] ) ) {
+ wp_admin_notice(
+ __( 'Settings saved.' ),
+ array(
+ 'type' => 'success',
+ 'dismissible' => true,
+ 'id' => 'message',
+ )
+ );
+}
+?>
+
+
+
+
diff --git a/wp-admin/network/setup.php b/wp-admin/network/setup.php
new file mode 100644
index 0000000..4b1f5b1
--- /dev/null
+++ b/wp-admin/network/setup.php
@@ -0,0 +1,13 @@
+add_help_tab( get_site_screen_help_tab_args() );
+get_current_screen()->set_help_sidebar( get_site_screen_help_sidebar_content() );
+
+$id = isset( $_REQUEST['id'] ) ? (int) $_REQUEST['id'] : 0;
+
+if ( ! $id ) {
+ wp_die( __( 'Invalid site ID.' ) );
+}
+
+$details = get_site( $id );
+if ( ! $details ) {
+ wp_die( __( 'The requested site does not exist.' ) );
+}
+
+if ( ! can_edit_network( $details->site_id ) ) {
+ wp_die( __( 'Sorry, you are not allowed to access this page.' ), 403 );
+}
+
+$parsed_scheme = parse_url( $details->siteurl, PHP_URL_SCHEME );
+$is_main_site = is_main_site( $id );
+
+if ( isset( $_REQUEST['action'] ) && 'update-site' === $_REQUEST['action'] ) {
+ check_admin_referer( 'edit-site' );
+
+ switch_to_blog( $id );
+
+ // Rewrite rules can't be flushed during switch to blog.
+ delete_option( 'rewrite_rules' );
+
+ $blog_data = wp_unslash( $_POST['blog'] );
+ $blog_data['scheme'] = $parsed_scheme;
+
+ if ( $is_main_site ) {
+ // On the network's main site, don't allow the domain or path to change.
+ $blog_data['domain'] = $details->domain;
+ $blog_data['path'] = $details->path;
+ } else {
+ // For any other site, the scheme, domain, and path can all be changed. We first
+ // need to ensure a scheme has been provided, otherwise fallback to the existing.
+ $new_url_scheme = parse_url( $blog_data['url'], PHP_URL_SCHEME );
+
+ if ( ! $new_url_scheme ) {
+ $blog_data['url'] = esc_url( $parsed_scheme . '://' . $blog_data['url'] );
+ }
+ $update_parsed_url = parse_url( $blog_data['url'] );
+
+ // If a path is not provided, use the default of `/`.
+ if ( ! isset( $update_parsed_url['path'] ) ) {
+ $update_parsed_url['path'] = '/';
+ }
+
+ $blog_data['scheme'] = $update_parsed_url['scheme'];
+ $blog_data['domain'] = $update_parsed_url['host'];
+ $blog_data['path'] = $update_parsed_url['path'];
+ }
+
+ $existing_details = get_site( $id );
+ $blog_data_checkboxes = array( 'public', 'archived', 'spam', 'mature', 'deleted' );
+
+ foreach ( $blog_data_checkboxes as $c ) {
+ if ( ! in_array( (int) $existing_details->$c, array( 0, 1 ), true ) ) {
+ $blog_data[ $c ] = $existing_details->$c;
+ } else {
+ $blog_data[ $c ] = isset( $_POST['blog'][ $c ] ) ? 1 : 0;
+ }
+ }
+
+ update_blog_details( $id, $blog_data );
+
+ // Maybe update home and siteurl options.
+ $new_details = get_site( $id );
+
+ $old_home_url = trailingslashit( esc_url( get_option( 'home' ) ) );
+ $old_home_parsed = parse_url( $old_home_url );
+
+ if ( $old_home_parsed['host'] === $existing_details->domain && $old_home_parsed['path'] === $existing_details->path ) {
+ $new_home_url = untrailingslashit( sanitize_url( $blog_data['scheme'] . '://' . $new_details->domain . $new_details->path ) );
+ update_option( 'home', $new_home_url );
+ }
+
+ $old_site_url = trailingslashit( esc_url( get_option( 'siteurl' ) ) );
+ $old_site_parsed = parse_url( $old_site_url );
+
+ if ( $old_site_parsed['host'] === $existing_details->domain && $old_site_parsed['path'] === $existing_details->path ) {
+ $new_site_url = untrailingslashit( sanitize_url( $blog_data['scheme'] . '://' . $new_details->domain . $new_details->path ) );
+ update_option( 'siteurl', $new_site_url );
+ }
+
+ restore_current_blog();
+ wp_redirect(
+ add_query_arg(
+ array(
+ 'update' => 'updated',
+ 'id' => $id,
+ ),
+ 'site-info.php'
+ )
+ );
+ exit;
+}
+
+if ( isset( $_GET['update'] ) ) {
+ $messages = array();
+ if ( 'updated' === $_GET['update'] ) {
+ $messages[] = __( 'Site info updated.' );
+ }
+}
+
+// Used in the HTML title tag.
+/* translators: %s: Site title. */
+$title = sprintf( __( 'Edit Site: %s' ), esc_html( $details->blogname ) );
+
+$parent_file = 'sites.php';
+$submenu_file = 'sites.php';
+
+require_once ABSPATH . 'wp-admin/admin-header.php';
+
+?>
+
+
+
+
|
+ $id,
+ 'selected' => 'site-info',
+ )
+);
+
+if ( ! empty( $messages ) ) {
+ $notice_args = array(
+ 'type' => 'success',
+ 'dismissible' => true,
+ 'id' => 'message',
+ );
+
+ foreach ( $messages as $msg ) {
+ wp_admin_notice( $msg, $notice_args );
+ }
+}
+?>
+
+
+
+
+
+
+
+
+
+add_help_tab(
+ array(
+ 'id' => 'overview',
+ 'title' => __( 'Overview' ),
+ 'content' =>
+ '' . __( 'This screen is for Super Admins to add new sites to the network. This is not affected by the registration settings.' ) . '
' .
+ '' . __( 'If the admin email for the new site does not exist in the database, a new user will also be created.' ) . '
',
+ )
+);
+
+get_current_screen()->set_help_sidebar(
+ '' . __( 'For more information:' ) . '
' .
+ '' . __( 'Documentation on Site Management ' ) . '
' .
+ '' . __( 'Support forums ' ) . '
'
+);
+
+if ( isset( $_REQUEST['action'] ) && 'add-site' === $_REQUEST['action'] ) {
+ check_admin_referer( 'add-blog', '_wpnonce_add-blog' );
+
+ if ( ! is_array( $_POST['blog'] ) ) {
+ wp_die( __( 'Cannot create an empty site.' ) );
+ }
+
+ $blog = $_POST['blog'];
+ $domain = '';
+
+ $blog['domain'] = trim( $blog['domain'] );
+ if ( preg_match( '|^([a-zA-Z0-9-])+$|', $blog['domain'] ) ) {
+ $domain = strtolower( $blog['domain'] );
+ }
+
+ // If not a subdomain installation, make sure the domain isn't a reserved word.
+ if ( ! is_subdomain_install() ) {
+ $subdirectory_reserved_names = get_subdirectory_reserved_names();
+
+ if ( in_array( $domain, $subdirectory_reserved_names, true ) ) {
+ wp_die(
+ sprintf(
+ /* translators: %s: Reserved names list. */
+ __( 'The following words are reserved for use by WordPress functions and cannot be used as site names: %s' ),
+ '' . implode( '
, ', $subdirectory_reserved_names ) . '
'
+ )
+ );
+ }
+ }
+
+ $title = $blog['title'];
+
+ $meta = array(
+ 'public' => 1,
+ );
+
+ // Handle translation installation for the new site.
+ if ( isset( $_POST['WPLANG'] ) ) {
+ if ( '' === $_POST['WPLANG'] ) {
+ $meta['WPLANG'] = ''; // en_US
+ } elseif ( in_array( $_POST['WPLANG'], get_available_languages(), true ) ) {
+ $meta['WPLANG'] = $_POST['WPLANG'];
+ } elseif ( current_user_can( 'install_languages' ) && wp_can_install_language_pack() ) {
+ $language = wp_download_language_pack( wp_unslash( $_POST['WPLANG'] ) );
+ if ( $language ) {
+ $meta['WPLANG'] = $language;
+ }
+ }
+ }
+
+ if ( empty( $title ) ) {
+ wp_die( __( 'Missing site title.' ) );
+ }
+
+ if ( empty( $domain ) ) {
+ wp_die( __( 'Missing or invalid site address.' ) );
+ }
+
+ if ( isset( $blog['email'] ) && '' === trim( $blog['email'] ) ) {
+ wp_die( __( 'Missing email address.' ) );
+ }
+
+ $email = sanitize_email( $blog['email'] );
+ if ( ! is_email( $email ) ) {
+ wp_die( __( 'Invalid email address.' ) );
+ }
+
+ if ( is_subdomain_install() ) {
+ $newdomain = $domain . '.' . preg_replace( '|^www\.|', '', get_network()->domain );
+ $path = get_network()->path;
+ } else {
+ $newdomain = get_network()->domain;
+ $path = get_network()->path . $domain . '/';
+ }
+
+ $password = 'N/A';
+ $user_id = email_exists( $email );
+ if ( ! $user_id ) { // Create a new user with a random password.
+ /**
+ * Fires immediately before a new user is created via the network site-new.php page.
+ *
+ * @since 4.5.0
+ *
+ * @param string $email Email of the non-existent user.
+ */
+ do_action( 'pre_network_site_new_created_user', $email );
+
+ $user_id = username_exists( $domain );
+ if ( $user_id ) {
+ wp_die( __( 'The domain or path entered conflicts with an existing username.' ) );
+ }
+ $password = wp_generate_password( 12, false );
+ $user_id = wpmu_create_user( $domain, $password, $email );
+ if ( false === $user_id ) {
+ wp_die( __( 'There was an error creating the user.' ) );
+ }
+
+ /**
+ * Fires after a new user has been created via the network site-new.php page.
+ *
+ * @since 4.4.0
+ *
+ * @param int $user_id ID of the newly created user.
+ */
+ do_action( 'network_site_new_created_user', $user_id );
+ }
+
+ $wpdb->hide_errors();
+ $id = wpmu_create_blog( $newdomain, $path, $title, $user_id, $meta, get_current_network_id() );
+ $wpdb->show_errors();
+
+ if ( ! is_wp_error( $id ) ) {
+ if ( ! is_super_admin( $user_id ) && ! get_user_option( 'primary_blog', $user_id ) ) {
+ update_user_option( $user_id, 'primary_blog', $id, true );
+ }
+
+ wpmu_new_site_admin_notification( $id, $user_id );
+ wpmu_welcome_notification( $id, $user_id, $password, $title, array( 'public' => 1 ) );
+ wp_redirect(
+ add_query_arg(
+ array(
+ 'update' => 'added',
+ 'id' => $id,
+ ),
+ 'site-new.php'
+ )
+ );
+ exit;
+ } else {
+ wp_die( $id->get_error_message() );
+ }
+}
+
+if ( isset( $_GET['update'] ) ) {
+ $messages = array();
+ if ( 'added' === $_GET['update'] ) {
+ $messages[] = sprintf(
+ /* translators: 1: Dashboard URL, 2: Network admin edit URL. */
+ __( 'Site added. Visit Dashboard or Edit Site ' ),
+ esc_url( get_admin_url( absint( $_GET['id'] ) ) ),
+ network_admin_url( 'site-info.php?id=' . absint( $_GET['id'] ) )
+ );
+ }
+}
+
+// Used in the HTML title tag.
+$title = __( 'Add New Site' );
+$parent_file = 'sites.php';
+
+wp_enqueue_script( 'user-suggest' );
+
+require_once ABSPATH . 'wp-admin/admin-header.php';
+
+?>
+
+
+
+ 'success',
+ 'dismissible' => true,
+ 'id' => 'message',
+ );
+
+ foreach ( $messages as $msg ) {
+ wp_admin_notice( $msg, $notice_args );
+ }
+}
+?>
+
+
+
+
+
+
+
+
+add_help_tab( get_site_screen_help_tab_args() );
+get_current_screen()->set_help_sidebar( get_site_screen_help_sidebar_content() );
+
+$id = isset( $_REQUEST['id'] ) ? (int) $_REQUEST['id'] : 0;
+
+if ( ! $id ) {
+ wp_die( __( 'Invalid site ID.' ) );
+}
+
+$details = get_site( $id );
+if ( ! $details ) {
+ wp_die( __( 'The requested site does not exist.' ) );
+}
+
+if ( ! can_edit_network( $details->site_id ) ) {
+ wp_die( __( 'Sorry, you are not allowed to access this page.' ), 403 );
+}
+
+$is_main_site = is_main_site( $id );
+
+if ( isset( $_REQUEST['action'] ) && 'update-site' === $_REQUEST['action'] && is_array( $_POST['option'] ) ) {
+ check_admin_referer( 'edit-site' );
+
+ switch_to_blog( $id );
+
+ $skip_options = array( 'allowedthemes' ); // Don't update these options since they are handled elsewhere in the form.
+ foreach ( (array) $_POST['option'] as $key => $val ) {
+ $key = wp_unslash( $key );
+ $val = wp_unslash( $val );
+ if ( 0 === $key || is_array( $val ) || in_array( $key, $skip_options, true ) ) {
+ continue; // Avoids "0 is a protected WP option and may not be modified" error when editing blog options.
+ }
+ update_option( $key, $val );
+ }
+
+ /**
+ * Fires after the site options are updated.
+ *
+ * @since 3.0.0
+ * @since 4.4.0 Added `$id` parameter.
+ *
+ * @param int $id The ID of the site being updated.
+ */
+ do_action( 'wpmu_update_blog_options', $id );
+
+ restore_current_blog();
+ wp_redirect(
+ add_query_arg(
+ array(
+ 'update' => 'updated',
+ 'id' => $id,
+ ),
+ 'site-settings.php'
+ )
+ );
+ exit;
+}
+
+if ( isset( $_GET['update'] ) ) {
+ $messages = array();
+ if ( 'updated' === $_GET['update'] ) {
+ $messages[] = __( 'Site options updated.' );
+ }
+}
+
+// Used in the HTML title tag.
+/* translators: %s: Site title. */
+$title = sprintf( __( 'Edit Site: %s' ), esc_html( $details->blogname ) );
+
+$parent_file = 'sites.php';
+$submenu_file = 'sites.php';
+
+require_once ABSPATH . 'wp-admin/admin-header.php';
+
+?>
+
+
+
+
|
+
+ $id,
+ 'selected' => 'site-settings',
+ )
+);
+
+if ( ! empty( $messages ) ) {
+ $notice_args = array(
+ 'type' => 'success',
+ 'dismissible' => true,
+ 'id' => 'message',
+ );
+
+ foreach ( $messages as $msg ) {
+ wp_admin_notice( $msg, $notice_args );
+ }
+}
+?>
+
+
+
+
+
+
+
+
+add_help_tab( get_site_screen_help_tab_args() );
+get_current_screen()->set_help_sidebar( get_site_screen_help_sidebar_content() );
+
+get_current_screen()->set_screen_reader_content(
+ array(
+ 'heading_views' => __( 'Filter site themes list' ),
+ 'heading_pagination' => __( 'Site themes list navigation' ),
+ 'heading_list' => __( 'Site themes list' ),
+ )
+);
+
+$wp_list_table = _get_list_table( 'WP_MS_Themes_List_Table' );
+
+$action = $wp_list_table->current_action();
+
+$s = isset( $_REQUEST['s'] ) ? $_REQUEST['s'] : '';
+
+// Clean up request URI from temporary args for screen options/paging uri's to work as expected.
+$temp_args = array( 'enabled', 'disabled', 'error' );
+$_SERVER['REQUEST_URI'] = remove_query_arg( $temp_args, $_SERVER['REQUEST_URI'] );
+$referer = remove_query_arg( $temp_args, wp_get_referer() );
+
+if ( ! empty( $_REQUEST['paged'] ) ) {
+ $referer = add_query_arg( 'paged', (int) $_REQUEST['paged'], $referer );
+}
+
+$id = isset( $_REQUEST['id'] ) ? (int) $_REQUEST['id'] : 0;
+
+if ( ! $id ) {
+ wp_die( __( 'Invalid site ID.' ) );
+}
+
+$wp_list_table->prepare_items();
+
+$details = get_site( $id );
+if ( ! $details ) {
+ wp_die( __( 'The requested site does not exist.' ) );
+}
+
+if ( ! can_edit_network( $details->site_id ) ) {
+ wp_die( __( 'Sorry, you are not allowed to access this page.' ), 403 );
+}
+
+$is_main_site = is_main_site( $id );
+
+if ( $action ) {
+ switch_to_blog( $id );
+ $allowed_themes = get_option( 'allowedthemes' );
+
+ switch ( $action ) {
+ case 'enable':
+ check_admin_referer( 'enable-theme_' . $_GET['theme'] );
+ $theme = $_GET['theme'];
+ $action = 'enabled';
+ $n = 1;
+ if ( ! $allowed_themes ) {
+ $allowed_themes = array( $theme => true );
+ } else {
+ $allowed_themes[ $theme ] = true;
+ }
+ break;
+ case 'disable':
+ check_admin_referer( 'disable-theme_' . $_GET['theme'] );
+ $theme = $_GET['theme'];
+ $action = 'disabled';
+ $n = 1;
+ if ( ! $allowed_themes ) {
+ $allowed_themes = array();
+ } else {
+ unset( $allowed_themes[ $theme ] );
+ }
+ break;
+ case 'enable-selected':
+ check_admin_referer( 'bulk-themes' );
+ if ( isset( $_POST['checked'] ) ) {
+ $themes = (array) $_POST['checked'];
+ $action = 'enabled';
+ $n = count( $themes );
+ foreach ( (array) $themes as $theme ) {
+ $allowed_themes[ $theme ] = true;
+ }
+ } else {
+ $action = 'error';
+ $n = 'none';
+ }
+ break;
+ case 'disable-selected':
+ check_admin_referer( 'bulk-themes' );
+ if ( isset( $_POST['checked'] ) ) {
+ $themes = (array) $_POST['checked'];
+ $action = 'disabled';
+ $n = count( $themes );
+ foreach ( (array) $themes as $theme ) {
+ unset( $allowed_themes[ $theme ] );
+ }
+ } else {
+ $action = 'error';
+ $n = 'none';
+ }
+ break;
+ default:
+ if ( isset( $_POST['checked'] ) ) {
+ check_admin_referer( 'bulk-themes' );
+ $themes = (array) $_POST['checked'];
+ $n = count( $themes );
+ $screen = get_current_screen()->id;
+
+ /**
+ * Fires when a custom bulk action should be handled.
+ *
+ * The redirect link should be modified with success or failure feedback
+ * from the action to be used to display feedback to the user.
+ *
+ * The dynamic portion of the hook name, `$screen`, refers to the current screen ID.
+ *
+ * @since 4.7.0
+ *
+ * @param string $redirect_url The redirect URL.
+ * @param string $action The action being taken.
+ * @param array $items The items to take the action on.
+ * @param int $site_id The site ID.
+ */
+ $referer = apply_filters( "handle_network_bulk_actions-{$screen}", $referer, $action, $themes, $id ); // phpcs:ignore WordPress.NamingConventions.ValidHookName.UseUnderscores
+ } else {
+ $action = 'error';
+ $n = 'none';
+ }
+ }
+
+ update_option( 'allowedthemes', $allowed_themes );
+ restore_current_blog();
+
+ wp_safe_redirect(
+ add_query_arg(
+ array(
+ 'id' => $id,
+ $action => $n,
+ ),
+ $referer
+ )
+ );
+ exit;
+}
+
+if ( isset( $_GET['action'] ) && 'update-site' === $_GET['action'] ) {
+ wp_safe_redirect( $referer );
+ exit;
+}
+
+add_thickbox();
+add_screen_option( 'per_page' );
+
+// Used in the HTML title tag.
+/* translators: %s: Site title. */
+$title = sprintf( __( 'Edit Site: %s' ), esc_html( $details->blogname ) );
+
+$parent_file = 'sites.php';
+$submenu_file = 'sites.php';
+
+require_once ABSPATH . 'wp-admin/admin-header.php';
+?>
+
+
+
+
|
+ $id,
+ 'selected' => 'site-themes',
+ )
+);
+
+if ( isset( $_GET['enabled'] ) ) {
+ $enabled = absint( $_GET['enabled'] );
+ if ( 1 === $enabled ) {
+ $message = __( 'Theme enabled.' );
+ } else {
+ /* translators: %s: Number of themes. */
+ $message = _n( '%s theme enabled.', '%s themes enabled.', $enabled );
+ }
+
+ wp_admin_notice(
+ sprintf( $message, number_format_i18n( $enabled ) ),
+ array(
+ 'type' => 'success',
+ 'dismissible' => true,
+ 'id' => 'message',
+ )
+ );
+} elseif ( isset( $_GET['disabled'] ) ) {
+ $disabled = absint( $_GET['disabled'] );
+ if ( 1 === $disabled ) {
+ $message = __( 'Theme disabled.' );
+ } else {
+ /* translators: %s: Number of themes. */
+ $message = _n( '%s theme disabled.', '%s themes disabled.', $disabled );
+ }
+
+ wp_admin_notice(
+ sprintf( $message, number_format_i18n( $disabled ) ),
+ array(
+ 'type' => 'success',
+ 'dismissible' => true,
+ 'id' => 'message',
+ )
+ );
+} elseif ( isset( $_GET['error'] ) && 'none' === $_GET['error'] ) {
+ wp_admin_notice(
+ __( 'No theme selected.' ),
+ array(
+ 'type' => 'error',
+ 'dismissible' => true,
+ 'id' => 'message',
+ )
+ );
+}
+?>
+
+
+
+
+search_box( __( 'Search Installed Themes' ), 'theme' ); ?>
+
+
+
+views(); ?>
+
+
+
+
+display(); ?>
+
+
+
+
+
diff --git a/wp-admin/network/site-users.php b/wp-admin/network/site-users.php
new file mode 100644
index 0000000..78af65b
--- /dev/null
+++ b/wp-admin/network/site-users.php
@@ -0,0 +1,382 @@
+prepare_items();
+
+get_current_screen()->add_help_tab( get_site_screen_help_tab_args() );
+get_current_screen()->set_help_sidebar( get_site_screen_help_sidebar_content() );
+
+get_current_screen()->set_screen_reader_content(
+ array(
+ 'heading_views' => __( 'Filter site users list' ),
+ 'heading_pagination' => __( 'Site users list navigation' ),
+ 'heading_list' => __( 'Site users list' ),
+ )
+);
+
+$_SERVER['REQUEST_URI'] = remove_query_arg( 'update', $_SERVER['REQUEST_URI'] );
+$referer = remove_query_arg( 'update', wp_get_referer() );
+
+if ( ! empty( $_REQUEST['paged'] ) ) {
+ $referer = add_query_arg( 'paged', (int) $_REQUEST['paged'], $referer );
+}
+
+$id = isset( $_REQUEST['id'] ) ? (int) $_REQUEST['id'] : 0;
+
+if ( ! $id ) {
+ wp_die( __( 'Invalid site ID.' ) );
+}
+
+$details = get_site( $id );
+if ( ! $details ) {
+ wp_die( __( 'The requested site does not exist.' ) );
+}
+
+if ( ! can_edit_network( $details->site_id ) ) {
+ wp_die( __( 'Sorry, you are not allowed to access this page.' ), 403 );
+}
+
+$is_main_site = is_main_site( $id );
+
+switch_to_blog( $id );
+
+$action = $wp_list_table->current_action();
+
+if ( $action ) {
+
+ switch ( $action ) {
+ case 'newuser':
+ check_admin_referer( 'add-user', '_wpnonce_add-new-user' );
+ $user = $_POST['user'];
+ if ( ! is_array( $_POST['user'] ) || empty( $user['username'] ) || empty( $user['email'] ) ) {
+ $update = 'err_new';
+ } else {
+ $password = wp_generate_password( 12, false );
+ $user_id = wpmu_create_user( esc_html( strtolower( $user['username'] ) ), $password, esc_html( $user['email'] ) );
+
+ if ( false === $user_id ) {
+ $update = 'err_new_dup';
+ } else {
+ $result = add_user_to_blog( $id, $user_id, $_POST['new_role'] );
+
+ if ( is_wp_error( $result ) ) {
+ $update = 'err_add_fail';
+ } else {
+ $update = 'newuser';
+
+ /**
+ * Fires after a user has been created via the network site-users.php page.
+ *
+ * @since 4.4.0
+ *
+ * @param int $user_id ID of the newly created user.
+ */
+ do_action( 'network_site_users_created_user', $user_id );
+ }
+ }
+ }
+ break;
+
+ case 'adduser':
+ check_admin_referer( 'add-user', '_wpnonce_add-user' );
+ if ( ! empty( $_POST['newuser'] ) ) {
+ $update = 'adduser';
+ $newuser = $_POST['newuser'];
+ $user = get_user_by( 'login', $newuser );
+ if ( $user && $user->exists() ) {
+ if ( ! is_user_member_of_blog( $user->ID, $id ) ) {
+ $result = add_user_to_blog( $id, $user->ID, $_POST['new_role'] );
+
+ if ( is_wp_error( $result ) ) {
+ $update = 'err_add_fail';
+ }
+ } else {
+ $update = 'err_add_member';
+ }
+ } else {
+ $update = 'err_add_notfound';
+ }
+ } else {
+ $update = 'err_add_notfound';
+ }
+ break;
+
+ case 'remove':
+ if ( ! current_user_can( 'remove_users' ) ) {
+ wp_die( __( 'Sorry, you are not allowed to remove users.' ), 403 );
+ }
+
+ check_admin_referer( 'bulk-users' );
+
+ $update = 'remove';
+ if ( isset( $_REQUEST['users'] ) ) {
+ $userids = $_REQUEST['users'];
+
+ foreach ( $userids as $user_id ) {
+ $user_id = (int) $user_id;
+ remove_user_from_blog( $user_id, $id );
+ }
+ } elseif ( isset( $_GET['user'] ) ) {
+ remove_user_from_blog( $_GET['user'] );
+ } else {
+ $update = 'err_remove';
+ }
+ break;
+
+ case 'promote':
+ check_admin_referer( 'bulk-users' );
+ $editable_roles = get_editable_roles();
+ $role = $_REQUEST['new_role'];
+
+ if ( empty( $editable_roles[ $role ] ) ) {
+ wp_die( __( 'Sorry, you are not allowed to give users that role.' ), 403 );
+ }
+
+ if ( isset( $_REQUEST['users'] ) ) {
+ $userids = $_REQUEST['users'];
+ $update = 'promote';
+ foreach ( $userids as $user_id ) {
+ $user_id = (int) $user_id;
+
+ // If the user doesn't already belong to the blog, bail.
+ if ( ! is_user_member_of_blog( $user_id ) ) {
+ wp_die(
+ '' . __( 'Something went wrong.' ) . ' ' .
+ '' . __( 'One of the selected users is not a member of this site.' ) . '
',
+ 403
+ );
+ }
+
+ $user = get_userdata( $user_id );
+ $user->set_role( $role );
+ }
+ } else {
+ $update = 'err_promote';
+ }
+ break;
+ default:
+ if ( ! isset( $_REQUEST['users'] ) ) {
+ break;
+ }
+ check_admin_referer( 'bulk-users' );
+ $userids = $_REQUEST['users'];
+
+ /** This action is documented in wp-admin/network/site-themes.php */
+ $referer = apply_filters( 'handle_network_bulk_actions-' . get_current_screen()->id, $referer, $action, $userids, $id ); // phpcs:ignore WordPress.NamingConventions.ValidHookName.UseUnderscores
+
+ $update = $action;
+ break;
+ }
+
+ wp_safe_redirect( add_query_arg( 'update', $update, $referer ) );
+ exit;
+}
+
+restore_current_blog();
+
+if ( isset( $_GET['action'] ) && 'update-site' === $_GET['action'] ) {
+ wp_safe_redirect( $referer );
+ exit;
+}
+
+add_screen_option( 'per_page' );
+
+// Used in the HTML title tag.
+/* translators: %s: Site title. */
+$title = sprintf( __( 'Edit Site: %s' ), esc_html( $details->blogname ) );
+
+$parent_file = 'sites.php';
+$submenu_file = 'sites.php';
+
+/**
+ * Filters whether to show the Add Existing User form on the Multisite Users screen.
+ *
+ * @since 3.1.0
+ *
+ * @param bool $bool Whether to show the Add Existing User form. Default true.
+ */
+if ( ! wp_is_large_network( 'users' ) && apply_filters( 'show_network_site_users_add_existing_form', true ) ) {
+ wp_enqueue_script( 'user-suggest' );
+}
+
+require_once ABSPATH . 'wp-admin/admin-header.php';
+?>
+
+
+
+
+
+
+
|
+ $id,
+ 'selected' => 'site-users',
+ )
+);
+
+if ( isset( $_GET['update'] ) ) :
+ $message = '';
+ $type = 'error';
+
+ switch ( $_GET['update'] ) {
+ case 'adduser':
+ $type = 'success';
+ $message = __( 'User added.' );
+ break;
+ case 'err_add_member':
+ $message = __( 'User is already a member of this site.' );
+ break;
+ case 'err_add_fail':
+ $message = __( 'User could not be added to this site.' );
+ break;
+ case 'err_add_notfound':
+ $message = __( 'Enter the username of an existing user.' );
+ break;
+ case 'promote':
+ $type = 'success';
+ $message = __( 'Changed roles.' );
+ break;
+ case 'err_promote':
+ $message = __( 'Select a user to change role.' );
+ break;
+ case 'remove':
+ $type = 'success';
+ $message = __( 'User removed from this site.' );
+ break;
+ case 'err_remove':
+ $message = __( 'Select a user to remove.' );
+ break;
+ case 'newuser':
+ $type = 'success';
+ $message = __( 'User created.' );
+ break;
+ case 'err_new':
+ $message = __( 'Enter the username and email.' );
+ break;
+ case 'err_new_dup':
+ $message = __( 'Duplicated username or email address.' );
+ break;
+ }
+
+ wp_admin_notice(
+ $message,
+ array(
+ 'type' => $type,
+ 'dismissible' => true,
+ 'id' => 'message',
+ )
+ );
+endif;
+?>
+
+
+search_box( __( 'Search Users' ), 'user' ); ?>
+
+
+
+views(); ?>
+
+
+
+
+display(); ?>
+
+
+
+
+
+
+
+
+
+ 'submit-add-existing-user' ) ); ?>
+
+
+
+
+
+
+
+
+
+ 'submit-add-user' ) ); ?>
+
+
+
+get_pagenum();
+
+// Used in the HTML title tag.
+$title = __( 'Sites' );
+$parent_file = 'sites.php';
+
+add_screen_option( 'per_page' );
+
+get_current_screen()->add_help_tab(
+ array(
+ 'id' => 'overview',
+ 'title' => __( 'Overview' ),
+ 'content' =>
+ '' . __( '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.' ) . '
' .
+ '' . __( '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.' ) . '
' .
+ '' . __( 'Hovering over each site reveals seven options (three for the primary site):' ) . '
' .
+ '' . __( 'An Edit link to a separate Edit Site screen.' ) . ' ' .
+ '' . __( 'Dashboard leads to the Dashboard for that site.' ) . ' ' .
+ '' . __( 'Deactivate, Archive, and Spam which lead to confirmation screens. These actions can be reversed later.' ) . ' ' .
+ '' . __( 'Delete which is a permanent action after the confirmation screens.' ) . ' ' .
+ '' . __( 'Visit to go to the front-end site live.' ) . ' ' .
+ '' . __( 'The site ID is used internally, and is not shown on the front end of the site or to users/viewers.' ) . '
' .
+ '' . __( 'Clicking on bold headings can re-sort this table.' ) . '
',
+ )
+);
+
+get_current_screen()->set_help_sidebar(
+ '' . __( 'For more information:' ) . '
' .
+ '' . __( 'Documentation on Site Management ' ) . '
' .
+ '' . __( 'Support forums ' ) . '
'
+);
+
+get_current_screen()->set_screen_reader_content(
+ array(
+ 'heading_pagination' => __( 'Sites list navigation' ),
+ 'heading_list' => __( 'Sites list' ),
+ )
+);
+
+$id = isset( $_REQUEST['id'] ) ? (int) $_REQUEST['id'] : 0;
+
+if ( isset( $_GET['action'] ) ) {
+ /** This action is documented in wp-admin/network/edit.php */
+ do_action( 'wpmuadminedit' );
+
+ // A list of valid actions and their associated messaging for confirmation output.
+ $manage_actions = array(
+ /* translators: %s: Site URL. */
+ 'activateblog' => __( 'You are about to activate the site %s.' ),
+ /* translators: %s: Site URL. */
+ 'deactivateblog' => __( 'You are about to deactivate the site %s.' ),
+ /* translators: %s: Site URL. */
+ 'unarchiveblog' => __( 'You are about to unarchive the site %s.' ),
+ /* translators: %s: Site URL. */
+ 'archiveblog' => __( 'You are about to archive the site %s.' ),
+ /* translators: %s: Site URL. */
+ 'unspamblog' => __( 'You are about to unspam the site %s.' ),
+ /* translators: %s: Site URL. */
+ 'spamblog' => __( 'You are about to mark the site %s as spam.' ),
+ /* translators: %s: Site URL. */
+ 'deleteblog' => __( 'You are about to delete the site %s.' ),
+ /* translators: %s: Site URL. */
+ 'unmatureblog' => __( 'You are about to mark the site %s as mature.' ),
+ /* translators: %s: Site URL. */
+ 'matureblog' => __( 'You are about to mark the site %s as not mature.' ),
+ );
+
+ if ( 'confirm' === $_GET['action'] ) {
+ // The action2 parameter contains the action being taken on the site.
+ $site_action = $_GET['action2'];
+
+ if ( ! array_key_exists( $site_action, $manage_actions ) ) {
+ wp_die( __( 'The requested action is not valid.' ) );
+ }
+
+ // The mature/unmature UI exists only as external code. Check the "confirm" nonce for backward compatibility.
+ if ( 'matureblog' === $site_action || 'unmatureblog' === $site_action ) {
+ check_admin_referer( 'confirm' );
+ } else {
+ check_admin_referer( $site_action . '_' . $id );
+ }
+
+ if ( ! headers_sent() ) {
+ nocache_headers();
+ header( 'Content-Type: text/html; charset=utf-8' );
+ }
+
+ if ( is_main_site( $id ) ) {
+ wp_die( __( 'Sorry, you are not allowed to change the current site.' ) );
+ }
+
+ $site_details = get_site( $id );
+ $site_address = untrailingslashit( $site_details->domain . $site_details->path );
+
+ require_once ABSPATH . 'wp-admin/admin-header.php';
+ ?>
+
+ 403 ) );
+ }
+
+ $updated_action = 'not_deleted';
+ if ( 0 !== $id && ! is_main_site( $id ) && current_user_can( 'delete_site', $id ) ) {
+ wpmu_delete_blog( $id, true );
+ $updated_action = 'delete';
+ }
+ break;
+
+ case 'delete_sites':
+ check_admin_referer( 'ms-delete-sites' );
+
+ foreach ( (array) $_POST['site_ids'] as $site_id ) {
+ $site_id = (int) $site_id;
+
+ if ( is_main_site( $site_id ) ) {
+ continue;
+ }
+
+ if ( ! current_user_can( 'delete_site', $site_id ) ) {
+ $site = get_site( $site_id );
+ $site_address = untrailingslashit( $site->domain . $site->path );
+
+ wp_die(
+ sprintf(
+ /* translators: %s: Site URL. */
+ __( 'Sorry, you are not allowed to delete the site %s.' ),
+ $site_address
+ ),
+ 403
+ );
+ }
+
+ $updated_action = 'all_delete';
+ wpmu_delete_blog( $site_id, true );
+ }
+ break;
+
+ case 'allblogs':
+ if ( isset( $_POST['action'] ) && isset( $_POST['allblogs'] ) ) {
+ $doaction = $_POST['action'];
+
+ foreach ( (array) $_POST['allblogs'] as $site_id ) {
+ $site_id = (int) $site_id;
+
+ if ( 0 !== $site_id && ! is_main_site( $site_id ) ) {
+ switch ( $doaction ) {
+ case 'delete':
+ require_once ABSPATH . 'wp-admin/admin-header.php';
+ ?>
+
+
+
+
+
+
+
+
+ domain . $site->path );
+ ?>
+
+
+
+
+
+
+
+
+
+ id, $redirect_to, $doaction, $blogs, $id ); // phpcs:ignore WordPress.NamingConventions.ValidHookName.UseUnderscores
+
+ wp_safe_redirect( $redirect_to );
+ exit;
+ }
+ } else {
+ // Process query defined by WP_MS_Site_List_Table::extra_table_nav().
+ $location = remove_query_arg(
+ array( '_wp_http_referer', '_wpnonce' ),
+ add_query_arg( $_POST, network_admin_url( 'sites.php' ) )
+ );
+
+ wp_redirect( $location );
+ exit;
+ }
+
+ break;
+
+ case 'archiveblog':
+ case 'unarchiveblog':
+ update_blog_status( $id, 'archived', ( 'archiveblog' === $_GET['action'] ) ? '1' : '0' );
+ break;
+
+ case 'activateblog':
+ update_blog_status( $id, 'deleted', '0' );
+
+ /**
+ * Fires after a network site is activated.
+ *
+ * @since MU (3.0.0)
+ *
+ * @param int $id The ID of the activated site.
+ */
+ do_action( 'activate_blog', $id );
+ break;
+
+ case 'deactivateblog':
+ /**
+ * Fires before a network site is deactivated.
+ *
+ * @since MU (3.0.0)
+ *
+ * @param int $id The ID of the site being deactivated.
+ */
+ do_action( 'deactivate_blog', $id );
+
+ update_blog_status( $id, 'deleted', '1' );
+ break;
+
+ case 'unspamblog':
+ case 'spamblog':
+ update_blog_status( $id, 'spam', ( 'spamblog' === $_GET['action'] ) ? '1' : '0' );
+ break;
+
+ case 'unmatureblog':
+ case 'matureblog':
+ update_blog_status( $id, 'mature', ( 'matureblog' === $_GET['action'] ) ? '1' : '0' );
+ break;
+ }
+
+ if ( empty( $updated_action ) && array_key_exists( $_GET['action'], $manage_actions ) ) {
+ $updated_action = $_GET['action'];
+ }
+
+ if ( ! empty( $updated_action ) ) {
+ wp_safe_redirect( add_query_arg( array( 'updated' => $updated_action ), wp_get_referer() ) );
+ exit;
+ }
+}
+
+$msg = '';
+if ( isset( $_GET['updated'] ) ) {
+ $action = $_GET['updated'];
+
+ switch ( $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.' );
+ break;
+ case 'not_deleted':
+ $msg = __( 'Sorry, you are not allowed to delete that site.' );
+ break;
+ case 'archiveblog':
+ $msg = __( 'Site archived.' );
+ break;
+ case 'unarchiveblog':
+ $msg = __( 'Site unarchived.' );
+ break;
+ case 'activateblog':
+ $msg = __( 'Site activated.' );
+ break;
+ case 'deactivateblog':
+ $msg = __( 'Site deactivated.' );
+ break;
+ case 'unspamblog':
+ $msg = __( 'Site removed from spam.' );
+ break;
+ case 'spamblog':
+ $msg = __( 'Site marked as spam.' );
+ break;
+ default:
+ /**
+ * Filters a specific, non-default, site-updated message in the Network admin.
+ *
+ * The dynamic portion of the hook name, `$action`, refers to the non-default
+ * site update action.
+ *
+ * @since 3.1.0
+ *
+ * @param string $msg The update message. Default 'Settings saved'.
+ */
+ $msg = apply_filters( "network_sites_updated_message_{$action}", __( 'Settings saved.' ) );
+ break;
+ }
+
+ if ( ! empty( $msg ) ) {
+ $msg = wp_get_admin_notice(
+ $msg,
+ array(
+ 'type' => 'success',
+ 'dismissible' => true,
+ 'id' => 'message',
+ )
+ );
+ }
+}
+
+$wp_list_table->prepare_items();
+
+require_once ABSPATH . 'wp-admin/admin-header.php';
+?>
+
+
+
+
+
+
+
+
+';
+ printf(
+ /* translators: %s: Search query. */
+ __( 'Search results for: %s' ),
+ '
' . esc_html( $s ) . ' '
+ );
+ echo '';
+}
+?>
+
+
+
+views(); ?>
+
+
+
+
+search_box( __( 'Search Sites' ), 'site' ); ?>
+
+
+
+
+ display(); ?>
+
+
+
diff --git a/wp-admin/network/theme-editor.php b/wp-admin/network/theme-editor.php
new file mode 100644
index 0000000..e8599f8
--- /dev/null
+++ b/wp-admin/network/theme-editor.php
@@ -0,0 +1,13 @@
+get_pagenum();
+
+$action = $wp_list_table->current_action();
+
+$s = isset( $_REQUEST['s'] ) ? $_REQUEST['s'] : '';
+
+// Clean up request URI from temporary args for screen options/paging uri's to work as expected.
+$temp_args = array(
+ 'enabled',
+ 'disabled',
+ 'deleted',
+ 'error',
+ 'enabled-auto-update',
+ 'disabled-auto-update',
+);
+
+$_SERVER['REQUEST_URI'] = remove_query_arg( $temp_args, $_SERVER['REQUEST_URI'] );
+$referer = remove_query_arg( $temp_args, wp_get_referer() );
+
+if ( $action ) {
+ switch ( $action ) {
+ case 'enable':
+ check_admin_referer( 'enable-theme_' . $_GET['theme'] );
+ WP_Theme::network_enable_theme( $_GET['theme'] );
+ if ( ! str_contains( $referer, '/network/themes.php' ) ) {
+ wp_redirect( network_admin_url( 'themes.php?enabled=1' ) );
+ } else {
+ wp_safe_redirect( add_query_arg( 'enabled', 1, $referer ) );
+ }
+ exit;
+ case 'disable':
+ check_admin_referer( 'disable-theme_' . $_GET['theme'] );
+ WP_Theme::network_disable_theme( $_GET['theme'] );
+ wp_safe_redirect( add_query_arg( 'disabled', '1', $referer ) );
+ exit;
+ case 'enable-selected':
+ check_admin_referer( 'bulk-themes' );
+ $themes = isset( $_POST['checked'] ) ? (array) $_POST['checked'] : array();
+ if ( empty( $themes ) ) {
+ wp_safe_redirect( add_query_arg( 'error', 'none', $referer ) );
+ exit;
+ }
+ WP_Theme::network_enable_theme( (array) $themes );
+ wp_safe_redirect( add_query_arg( 'enabled', count( $themes ), $referer ) );
+ exit;
+ case 'disable-selected':
+ check_admin_referer( 'bulk-themes' );
+ $themes = isset( $_POST['checked'] ) ? (array) $_POST['checked'] : array();
+ if ( empty( $themes ) ) {
+ wp_safe_redirect( add_query_arg( 'error', 'none', $referer ) );
+ exit;
+ }
+ WP_Theme::network_disable_theme( (array) $themes );
+ wp_safe_redirect( add_query_arg( 'disabled', count( $themes ), $referer ) );
+ exit;
+ case 'update-selected':
+ check_admin_referer( 'bulk-themes' );
+
+ if ( isset( $_GET['themes'] ) ) {
+ $themes = explode( ',', $_GET['themes'] );
+ } elseif ( isset( $_POST['checked'] ) ) {
+ $themes = (array) $_POST['checked'];
+ } else {
+ $themes = array();
+ }
+
+ // Used in the HTML title tag.
+ $title = __( 'Update Themes' );
+ $parent_file = 'themes.php';
+
+ require_once ABSPATH . 'wp-admin/admin-header.php';
+
+ echo '';
+ echo '
' . esc_html( $title ) . ' ';
+
+ $url = self_admin_url( 'update.php?action=update-selected-themes&themes=' . urlencode( implode( ',', $themes ) ) );
+ $url = wp_nonce_url( $url, 'bulk-update-themes' );
+
+ echo "";
+ echo '';
+ require_once ABSPATH . 'wp-admin/admin-footer.php';
+ exit;
+ case 'delete-selected':
+ if ( ! current_user_can( 'delete_themes' ) ) {
+ wp_die( __( 'Sorry, you are not allowed to delete themes for this site.' ) );
+ }
+
+ check_admin_referer( 'bulk-themes' );
+
+ $themes = isset( $_REQUEST['checked'] ) ? (array) $_REQUEST['checked'] : array();
+
+ if ( empty( $themes ) ) {
+ wp_safe_redirect( add_query_arg( 'error', 'none', $referer ) );
+ exit;
+ }
+
+ $themes = array_diff( $themes, array( get_option( 'stylesheet' ), get_option( 'template' ) ) );
+
+ if ( empty( $themes ) ) {
+ wp_safe_redirect( add_query_arg( 'error', 'main', $referer ) );
+ exit;
+ }
+
+ $theme_info = array();
+ foreach ( $themes as $key => $theme ) {
+ $theme_info[ $theme ] = wp_get_theme( $theme );
+ }
+
+ require ABSPATH . 'wp-admin/update.php';
+
+ $parent_file = 'themes.php';
+
+ if ( ! isset( $_REQUEST['verify-delete'] ) ) {
+ wp_enqueue_script( 'jquery' );
+ require_once ABSPATH . 'wp-admin/admin-header.php';
+ $themes_to_delete = count( $themes );
+ ?>
+
+
+
+ ' . __( 'Caution:' ) . ' ' . __( 'This theme may be active on other sites in the network.' ),
+ array(
+ 'additional_classes' => array( 'error' ),
+ )
+ );
+ ?>
+
+
+
+ ' . __( 'Caution:' ) . ' ' . __( 'These themes may be active on other sites in the network.' ),
+ array(
+ 'additional_classes' => array( 'error' ),
+ )
+ );
+ ?>
+
+
+
+ ' . sprintf(
+ /* translators: 1: Theme name, 2: Theme author. */
+ _x( '%1$s by %2$s', 'theme' ),
+ '' . $theme->display( 'Name' ) . ' ',
+ '' . $theme->display( 'Author' ) . ' '
+ ) . '';
+ }
+ ?>
+
+
+
+
+
+
+
+
+
+ ';
+ }
+
+ wp_nonce_field( 'bulk-themes' );
+
+ if ( 1 === $themes_to_delete ) {
+ submit_button( __( 'Yes, delete this theme' ), '', 'submit', false );
+ } else {
+ submit_button( __( 'Yes, delete these themes' ), '', 'submit', false );
+ }
+
+ ?>
+
+
+
+
+
+
+ 1,
+ 'action' => 'delete-selected',
+ 'checked' => $_REQUEST['checked'],
+ '_wpnonce' => $_REQUEST['_wpnonce'],
+ ),
+ network_admin_url( 'themes.php' )
+ )
+ )
+ );
+ }
+
+ $paged = ( $_REQUEST['paged'] ) ? $_REQUEST['paged'] : 1;
+ wp_redirect(
+ add_query_arg(
+ array(
+ 'deleted' => count( $themes ),
+ 'paged' => $paged,
+ 's' => $s,
+ ),
+ network_admin_url( 'themes.php' )
+ )
+ );
+ exit;
+ case 'enable-auto-update':
+ case 'disable-auto-update':
+ case 'enable-auto-update-selected':
+ case 'disable-auto-update-selected':
+ if ( ! ( current_user_can( 'update_themes' ) && wp_is_auto_update_enabled_for_type( 'theme' ) ) ) {
+ wp_die( __( 'Sorry, you are not allowed to change themes automatic update settings.' ) );
+ }
+
+ if ( 'enable-auto-update' === $action || 'disable-auto-update' === $action ) {
+ check_admin_referer( 'updates' );
+ } else {
+ if ( empty( $_POST['checked'] ) ) {
+ // Nothing to do.
+ wp_safe_redirect( add_query_arg( 'error', 'none', $referer ) );
+ exit;
+ }
+
+ check_admin_referer( 'bulk-themes' );
+ }
+
+ $auto_updates = (array) get_site_option( 'auto_update_themes', array() );
+
+ if ( 'enable-auto-update' === $action ) {
+ $auto_updates[] = $_GET['theme'];
+ $auto_updates = array_unique( $auto_updates );
+ $referer = add_query_arg( 'enabled-auto-update', 1, $referer );
+ } elseif ( 'disable-auto-update' === $action ) {
+ $auto_updates = array_diff( $auto_updates, array( $_GET['theme'] ) );
+ $referer = add_query_arg( 'disabled-auto-update', 1, $referer );
+ } else {
+ // Bulk enable/disable.
+ $themes = (array) wp_unslash( $_POST['checked'] );
+
+ if ( 'enable-auto-update-selected' === $action ) {
+ $auto_updates = array_merge( $auto_updates, $themes );
+ $auto_updates = array_unique( $auto_updates );
+ $referer = add_query_arg( 'enabled-auto-update', count( $themes ), $referer );
+ } else {
+ $auto_updates = array_diff( $auto_updates, $themes );
+ $referer = add_query_arg( 'disabled-auto-update', count( $themes ), $referer );
+ }
+ }
+
+ $all_items = wp_get_themes();
+
+ // Remove themes that don't exist or have been deleted since the option was last updated.
+ $auto_updates = array_intersect( $auto_updates, array_keys( $all_items ) );
+
+ update_site_option( 'auto_update_themes', $auto_updates );
+
+ wp_safe_redirect( $referer );
+ exit;
+ default:
+ $themes = isset( $_POST['checked'] ) ? (array) $_POST['checked'] : array();
+ if ( empty( $themes ) ) {
+ wp_safe_redirect( add_query_arg( 'error', 'none', $referer ) );
+ exit;
+ }
+ check_admin_referer( 'bulk-themes' );
+
+ /** This action is documented in wp-admin/network/site-themes.php */
+ $referer = apply_filters( 'handle_network_bulk_actions-' . get_current_screen()->id, $referer, $action, $themes ); // phpcs:ignore WordPress.NamingConventions.ValidHookName.UseUnderscores
+
+ wp_safe_redirect( $referer );
+ exit;
+ }
+}
+
+$wp_list_table->prepare_items();
+
+add_thickbox();
+
+add_screen_option( 'per_page' );
+
+get_current_screen()->add_help_tab(
+ array(
+ 'id' => 'overview',
+ 'title' => __( 'Overview' ),
+ 'content' =>
+ '' . __( 'This screen enables and disables the inclusion of themes available to choose in the Appearance menu for each site. It does not activate or deactivate which theme a site is currently using.' ) . '
' .
+ '' . __( 'If the network admin disables a theme that is in use, it can still remain selected on that site. If another theme is chosen, the disabled theme will not appear in the site’s Appearance > Themes screen.' ) . '
' .
+ '' . __( 'Themes can be enabled on a site by site basis by the network admin on the Edit Site screen (which has a Themes tab); get there via the Edit action link on the All Sites screen. Only network admins are able to install or edit themes.' ) . '
',
+ )
+);
+
+$help_sidebar_autoupdates = '';
+
+if ( current_user_can( 'update_themes' ) && wp_is_auto_update_enabled_for_type( 'theme' ) ) {
+ get_current_screen()->add_help_tab(
+ array(
+ 'id' => 'plugins-themes-auto-updates',
+ 'title' => __( 'Auto-updates' ),
+ 'content' =>
+ '' . __( 'Auto-updates can be enabled or disabled for each individual theme. Themes with auto-updates enabled will display the estimated date of the next auto-update. Auto-updates depends on the WP-Cron task scheduling system.' ) . '
' .
+ '' . __( 'Please note: Third-party themes and plugins, or custom code, may override WordPress scheduling.' ) . '
',
+ )
+ );
+
+ $help_sidebar_autoupdates = '' . __( 'Documentation on Auto-updates ' ) . '
';
+}
+
+get_current_screen()->set_help_sidebar(
+ '' . __( 'For more information:' ) . '
' .
+ '' . __( 'Documentation on Network Themes ' ) . '
' .
+ $help_sidebar_autoupdates .
+ '' . __( 'Support forums ' ) . '
'
+);
+
+get_current_screen()->set_screen_reader_content(
+ array(
+ 'heading_views' => __( 'Filter themes list' ),
+ 'heading_pagination' => __( 'Themes list navigation' ),
+ 'heading_list' => __( 'Themes list' ),
+ )
+);
+
+// Used in the HTML title tag.
+$title = __( 'Themes' );
+$parent_file = 'themes.php';
+
+wp_enqueue_script( 'updates' );
+wp_enqueue_script( 'theme-preview' );
+
+require_once ABSPATH . 'wp-admin/admin-header.php';
+
+?>
+
+
+
+
+
+
+
+
+';
+ printf(
+ /* translators: %s: Search query. */
+ __( 'Search results for: %s' ),
+ '
' . esc_html( $s ) . ' '
+ );
+ echo '';
+}
+?>
+
+
+
+ $type,
+ 'dismissible' => true,
+ 'id' => 'message',
+ )
+ );
+}
+?>
+
+
+search_box( __( 'Search Installed Themes' ), 'theme' ); ?>
+
+
+views();
+
+if ( 'broken' === $status ) {
+ echo '
' . __( 'The following themes are installed but incomplete.' ) . '
';
+}
+?>
+
+
+
+
+
+display(); ?>
+
+
+
+
+add_help_tab(
+ array(
+ 'id' => 'overview',
+ 'title' => __( 'Overview' ),
+ 'content' =>
+ '' . __( 'Only use this screen once you have updated to a new version of WordPress through Updates/Available Updates (via the Network Administration navigation menu or the Toolbar). Clicking the Upgrade Network button will step through each site in the network, five at a time, and make sure any database updates are applied.' ) . '
' .
+ '' . __( 'If a version update to core has not happened, clicking this button will not affect anything.' ) . '
' .
+ '' . __( 'If this process fails for any reason, users logging in to their sites will force the same update.' ) . '
',
+ )
+);
+
+get_current_screen()->set_help_sidebar(
+ '' . __( 'For more information:' ) . '
' .
+ '' . __( 'Documentation on Upgrade Network ' ) . '
' .
+ '' . __( 'Support forums ' ) . '
'
+);
+
+require_once ABSPATH . 'wp-admin/admin-header.php';
+
+if ( ! current_user_can( 'upgrade_network' ) ) {
+ wp_die( __( 'Sorry, you are not allowed to access this page.' ), 403 );
+}
+
+echo '';
+echo '
' . __( 'Upgrade Network' ) . ' ';
+
+$action = isset( $_GET['action'] ) ? $_GET['action'] : 'show';
+
+switch ( $action ) {
+ case 'upgrade':
+ $n = ( isset( $_GET['n'] ) ) ? (int) $_GET['n'] : 0;
+
+ if ( $n < 5 ) {
+ /**
+ * @global int $wp_db_version WordPress database version.
+ */
+ global $wp_db_version;
+ update_site_option( 'wpmu_upgrade_site', $wp_db_version );
+ }
+
+ $site_ids = get_sites(
+ array(
+ 'spam' => 0,
+ 'deleted' => 0,
+ 'archived' => 0,
+ 'network_id' => get_current_network_id(),
+ 'number' => 5,
+ 'offset' => $n,
+ 'fields' => 'ids',
+ 'order' => 'DESC',
+ 'orderby' => 'id',
+ 'update_site_meta_cache' => false,
+ )
+ );
+ if ( empty( $site_ids ) ) {
+ echo '
' . __( 'All done!' ) . '
';
+ break;
+ }
+ echo '
';
+ foreach ( (array) $site_ids as $site_id ) {
+ switch_to_blog( $site_id );
+ $siteurl = site_url();
+ $upgrade_url = admin_url( 'upgrade.php?step=upgrade_db' );
+ restore_current_blog();
+
+ echo "$siteurl ";
+
+ $response = wp_remote_get(
+ $upgrade_url,
+ array(
+ 'timeout' => 120,
+ 'httpversion' => '1.1',
+ 'sslverify' => false,
+ )
+ );
+
+ if ( is_wp_error( $response ) ) {
+ wp_die(
+ sprintf(
+ /* translators: 1: Site URL, 2: Server error message. */
+ __( 'Warning! Problem updating %1$s. Your server may not be able to connect to sites running on it. Error message: %2$s' ),
+ $siteurl,
+ '' . $response->get_error_message() . ' '
+ )
+ );
+ }
+
+ /**
+ * Fires after the Multisite DB upgrade for each site is complete.
+ *
+ * @since MU (3.0.0)
+ *
+ * @param array $response The upgrade response array.
+ */
+ do_action( 'after_mu_upgrade', $response );
+
+ /**
+ * Fires after each site has been upgraded.
+ *
+ * @since MU (3.0.0)
+ *
+ * @param int $site_id The Site ID.
+ */
+ do_action( 'wpmu_upgrade_site', $site_id );
+ }
+ echo ' ';
+ ?>
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/wp-admin/network/user-edit.php b/wp-admin/network/user-edit.php
new file mode 100644
index 0000000..7b908fd
--- /dev/null
+++ b/wp-admin/network/user-edit.php
@@ -0,0 +1,13 @@
+add_help_tab(
+ array(
+ 'id' => 'overview',
+ 'title' => __( 'Overview' ),
+ 'content' =>
+ '' . __( 'Add User will set up a new user account on the network and send that person an email with username and password.' ) . '
' .
+ '' . __( 'Users who are signed up to the network without a site are added as subscribers to the main or primary dashboard site, giving them profile pages to manage their accounts. These users will only see Dashboard and My Sites in the main navigation until a site is created for them.' ) . '
',
+ )
+);
+
+get_current_screen()->set_help_sidebar(
+ '' . __( 'For more information:' ) . '
' .
+ '' . __( 'Documentation on Network Users ' ) . '
' .
+ '' . __( 'Support forums ' ) . '
'
+);
+
+if ( isset( $_REQUEST['action'] ) && 'add-user' === $_REQUEST['action'] ) {
+ check_admin_referer( 'add-user', '_wpnonce_add-user' );
+
+ if ( ! current_user_can( 'manage_network_users' ) ) {
+ wp_die( __( 'Sorry, you are not allowed to access this page.' ), 403 );
+ }
+
+ if ( ! is_array( $_POST['user'] ) ) {
+ wp_die( __( 'Cannot create an empty user.' ) );
+ }
+
+ $user = wp_unslash( $_POST['user'] );
+
+ $user_details = wpmu_validate_user_signup( $user['username'], $user['email'] );
+
+ if ( is_wp_error( $user_details['errors'] ) && $user_details['errors']->has_errors() ) {
+ $add_user_errors = $user_details['errors'];
+ } else {
+ $password = wp_generate_password( 12, false );
+ $user_id = wpmu_create_user( esc_html( strtolower( $user['username'] ) ), $password, sanitize_email( $user['email'] ) );
+
+ if ( ! $user_id ) {
+ $add_user_errors = new WP_Error( 'add_user_fail', __( 'Cannot add user.' ) );
+ } else {
+ /**
+ * Fires after a new user has been created via the network user-new.php page.
+ *
+ * @since 4.4.0
+ *
+ * @param int $user_id ID of the newly created user.
+ */
+ do_action( 'network_user_new_created_user', $user_id );
+
+ wp_redirect(
+ add_query_arg(
+ array(
+ 'update' => 'added',
+ 'user_id' => $user_id,
+ ),
+ 'user-new.php'
+ )
+ );
+ exit;
+ }
+ }
+}
+
+$message = '';
+if ( isset( $_GET['update'] ) ) {
+ if ( 'added' === $_GET['update'] ) {
+ $edit_link = '';
+ if ( isset( $_GET['user_id'] ) ) {
+ $user_id_new = absint( $_GET['user_id'] );
+ if ( $user_id_new ) {
+ $edit_link = esc_url( add_query_arg( 'wp_http_referer', urlencode( wp_unslash( $_SERVER['REQUEST_URI'] ) ), get_edit_user_link( $user_id_new ) ) );
+ }
+ }
+
+ $message = __( 'User added.' );
+
+ if ( $edit_link ) {
+ $message .= sprintf( ' %s ', $edit_link, __( 'Edit user' ) );
+ }
+ }
+}
+
+// Used in the HTML title tag.
+$title = __( 'Add New User' );
+$parent_file = 'users.php';
+
+require_once ABSPATH . 'wp-admin/admin-header.php';
+?>
+
+
+
+ 'success',
+ 'dismissible' => true,
+ 'id' => 'message',
+ )
+ );
+}
+
+if ( isset( $add_user_errors ) && is_wp_error( $add_user_errors ) ) {
+ $error_messages = '';
+ foreach ( $add_user_errors->get_error_messages() as $error ) {
+ $error_messages .= "
$error
";
+ }
+
+ wp_admin_notice(
+ $error_messages,
+ array(
+ 'type' => 'error',
+ 'dismissible' => true,
+ 'id' => 'message',
+ 'paragraph_wrap' => false,
+ )
+ );
+}
+?>
+
+
+
+
+
+
+ 1 ) {
+ $_POST['allusers'] = array( $id ); // confirm_delete_users() can only handle arrays.
+
+ // Used in the HTML title tag.
+ $title = __( 'Users' );
+ $parent_file = 'users.php';
+
+ require_once ABSPATH . 'wp-admin/admin-header.php';
+
+ echo '';
+ confirm_delete_users( $_POST['allusers'] );
+ echo '
';
+
+ require_once ABSPATH . 'wp-admin/admin-footer.php';
+ } else {
+ wp_redirect( network_admin_url( 'users.php' ) );
+ }
+ exit;
+
+ case 'allusers':
+ if ( ! current_user_can( 'manage_network_users' ) ) {
+ wp_die( __( 'Sorry, you are not allowed to access this page.' ), 403 );
+ }
+
+ if ( isset( $_POST['action'] ) && isset( $_POST['allusers'] ) ) {
+ check_admin_referer( 'bulk-users-network' );
+
+ $doaction = $_POST['action'];
+ $userfunction = '';
+
+ foreach ( (array) $_POST['allusers'] as $user_id ) {
+ if ( ! empty( $user_id ) ) {
+ switch ( $doaction ) {
+ case 'delete':
+ if ( ! current_user_can( 'delete_users' ) ) {
+ wp_die( __( 'Sorry, you are not allowed to access this page.' ), 403 );
+ }
+
+ // Used in the HTML title tag.
+ $title = __( 'Users' );
+ $parent_file = 'users.php';
+
+ require_once ABSPATH . 'wp-admin/admin-header.php';
+
+ echo '';
+ confirm_delete_users( $_POST['allusers'] );
+ echo '
';
+
+ require_once ABSPATH . 'wp-admin/admin-footer.php';
+ exit;
+
+ case 'spam':
+ $user = get_userdata( $user_id );
+ if ( is_super_admin( $user->ID ) ) {
+ wp_die(
+ sprintf(
+ /* translators: %s: User login. */
+ __( 'Warning! User cannot be modified. The user %s is a network administrator.' ),
+ esc_html( $user->user_login )
+ )
+ );
+ }
+
+ $userfunction = 'all_spam';
+ $blogs = get_blogs_of_user( $user_id, true );
+
+ foreach ( (array) $blogs as $details ) {
+ if ( ! is_main_site( $details->userblog_id ) ) { // Main site is not a spam!
+ update_blog_status( $details->userblog_id, 'spam', '1' );
+ }
+ }
+
+ $user_data = $user->to_array();
+ $user_data['spam'] = '1';
+
+ wp_update_user( $user_data );
+ break;
+
+ case 'notspam':
+ $user = get_userdata( $user_id );
+
+ $userfunction = 'all_notspam';
+ $blogs = get_blogs_of_user( $user_id, true );
+
+ foreach ( (array) $blogs as $details ) {
+ update_blog_status( $details->userblog_id, 'spam', '0' );
+ }
+
+ $user_data = $user->to_array();
+ $user_data['spam'] = '0';
+
+ wp_update_user( $user_data );
+ break;
+ }
+ }
+ }
+
+ if ( ! in_array( $doaction, array( 'delete', 'spam', 'notspam' ), true ) ) {
+ $sendback = wp_get_referer();
+ $user_ids = (array) $_POST['allusers'];
+
+ /** This action is documented in wp-admin/network/site-themes.php */
+ $sendback = apply_filters( 'handle_network_bulk_actions-' . get_current_screen()->id, $sendback, $doaction, $user_ids ); // phpcs:ignore WordPress.NamingConventions.ValidHookName.UseUnderscores
+
+ wp_safe_redirect( $sendback );
+ exit;
+ }
+
+ wp_safe_redirect(
+ add_query_arg(
+ array(
+ 'updated' => 'true',
+ 'action' => $userfunction,
+ ),
+ wp_get_referer()
+ )
+ );
+ } else {
+ $location = network_admin_url( 'users.php' );
+
+ if ( ! empty( $_REQUEST['paged'] ) ) {
+ $location = add_query_arg( 'paged', (int) $_REQUEST['paged'], $location );
+ }
+ wp_redirect( $location );
+ }
+ exit;
+
+ case 'dodelete':
+ check_admin_referer( 'ms-users-delete' );
+ if ( ! ( current_user_can( 'manage_network_users' ) && current_user_can( 'delete_users' ) ) ) {
+ wp_die( __( 'Sorry, you are not allowed to access this page.' ), 403 );
+ }
+
+ if ( ! empty( $_POST['blog'] ) && is_array( $_POST['blog'] ) ) {
+ foreach ( $_POST['blog'] as $id => $users ) {
+ foreach ( $users as $blogid => $user_id ) {
+ if ( ! current_user_can( 'delete_user', $id ) ) {
+ continue;
+ }
+
+ if ( ! empty( $_POST['delete'] ) && 'reassign' === $_POST['delete'][ $blogid ][ $id ] ) {
+ remove_user_from_blog( $id, $blogid, (int) $user_id );
+ } else {
+ remove_user_from_blog( $id, $blogid );
+ }
+ }
+ }
+ }
+
+ $i = 0;
+
+ if ( is_array( $_POST['user'] ) && ! empty( $_POST['user'] ) ) {
+ foreach ( $_POST['user'] as $id ) {
+ if ( ! current_user_can( 'delete_user', $id ) ) {
+ continue;
+ }
+ wpmu_delete_user( $id );
+ ++$i;
+ }
+ }
+
+ if ( 1 === $i ) {
+ $deletefunction = 'delete';
+ } else {
+ $deletefunction = 'all_delete';
+ }
+
+ wp_redirect(
+ add_query_arg(
+ array(
+ 'updated' => 'true',
+ 'action' => $deletefunction,
+ ),
+ network_admin_url( 'users.php' )
+ )
+ );
+ exit;
+ }
+}
+
+$wp_list_table = _get_list_table( 'WP_MS_Users_List_Table' );
+$pagenum = $wp_list_table->get_pagenum();
+$wp_list_table->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;
+}
+
+// Used in the HTML title tag.
+$title = __( 'Users' );
+$parent_file = 'users.php';
+
+add_screen_option( 'per_page' );
+
+get_current_screen()->add_help_tab(
+ array(
+ 'id' => 'overview',
+ 'title' => __( 'Overview' ),
+ 'content' =>
+ '' . __( 'This table shows all users across the network and the sites to which they are assigned.' ) . '
' .
+ '' . __( 'Hover over any user on the list to make the edit links appear. The Edit link on the left will take you to their Edit User profile page; the Edit link on the right by any site name goes to an Edit Site screen for that site.' ) . '
' .
+ '' . __( 'You can also go to the user’s profile page by clicking on the individual username.' ) . '
' .
+ '' . __( 'You can sort the table by clicking on any of the table headings and switch between list and excerpt views by using the icons above the users list.' ) . '
' .
+ '' . __( 'The bulk action will permanently delete selected users, or mark/unmark those selected as spam. Spam users will have posts removed and will be unable to sign up again with the same email addresses.' ) . '
' .
+ '' . __( 'You can make an existing user an additional super admin by going to the Edit User profile page and checking the box to grant that privilege.' ) . '
',
+ )
+);
+
+get_current_screen()->set_help_sidebar(
+ '' . __( 'For more information:' ) . '
' .
+ '' . __( 'Documentation on Network Users ' ) . '
' .
+ '' . __( 'Support forums ' ) . '
'
+);
+
+get_current_screen()->set_screen_reader_content(
+ array(
+ 'heading_views' => __( 'Filter users list' ),
+ 'heading_pagination' => __( 'Users list navigation' ),
+ 'heading_list' => __( 'Users list' ),
+ )
+);
+
+require_once ABSPATH . 'wp-admin/admin-header.php';
+
+if ( isset( $_REQUEST['updated'] ) && 'true' === $_REQUEST['updated'] && ! empty( $_REQUEST['action'] ) ) {
+ $message = '';
+ switch ( $_REQUEST['action'] ) {
+ case 'delete':
+ $message = __( 'User deleted.' );
+ break;
+ case 'all_spam':
+ $message = __( 'Users marked as spam.' );
+ break;
+ case 'all_notspam':
+ $message = __( 'Users removed from spam.' );
+ break;
+ case 'all_delete':
+ $message = __( 'Users deleted.' );
+ break;
+ case 'add':
+ $message = __( 'User added.' );
+ break;
+ }
+
+ wp_admin_notice(
+ $message,
+ array(
+ 'type' => 'success',
+ 'dismissible' => true,
+ 'id' => 'message',
+ )
+ );
+}
+?>
+
+
+
+
+
+ ';
+ printf(
+ /* translators: %s: Search query. */
+ __( 'Search results for: %s' ),
+ '
' . esc_html( $usersearch ) . ' '
+ );
+ echo '';
+ }
+ ?>
+
+
+
+ views(); ?>
+
+
+ search_box( __( 'Search Users' ), 'all-user' ); ?>
+
+
+
+ display(); ?>
+
+
+
+
--
cgit v1.2.3