From 7086111ad4dd997e12a3220e1ee60c9b9bcf0bb8 Mon Sep 17 00:00:00 2001 From: Charles Date: Tue, 7 Jan 2020 13:06:14 +0100 Subject: Added wordpress --- srcs/wordpress/wp-admin/network/site-users.php | 366 +++++++++++++++++++++++++ 1 file changed, 366 insertions(+) create mode 100644 srcs/wordpress/wp-admin/network/site-users.php (limited to 'srcs/wordpress/wp-admin/network/site-users.php') diff --git a/srcs/wordpress/wp-admin/network/site-users.php b/srcs/wordpress/wp-admin/network/site-users.php new file mode 100644 index 0000000..5113025 --- /dev/null +++ b/srcs/wordpress/wp-admin/network/site-users.php @@ -0,0 +1,366 @@ +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'] ) ? intval( $_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 = false; + if ( ! empty( $_REQUEST['new_role2'] ) ) { + $role = $_REQUEST['new_role2']; + } elseif ( ! empty( $_REQUEST['new_role'] ) ) { + $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' ); + +/* 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( ABSPATH . 'wp-admin/admin-header.php' ); ?> + + + + +
+

+

|

+ $id, + 'selected' => 'site-users', + ) +); + +if ( isset( $_GET['update'] ) ) : + switch ( $_GET['update'] ) { + case 'adduser': + echo '

' . __( 'User added.' ) . '

'; + break; + case 'err_add_member': + echo '

' . __( 'User is already a member of this site.' ) . '

'; + break; + case 'err_add_fail': + echo '

' . __( 'User could not be added to this site.' ) . '

'; + break; + case 'err_add_notfound': + echo '

' . __( 'Enter the username of an existing user.' ) . '

'; + break; + case 'promote': + echo '

' . __( 'Changed roles.' ) . '

'; + break; + case 'err_promote': + echo '

' . __( 'Select a user to change role.' ) . '

'; + break; + case 'remove': + echo '

' . __( 'User removed from this site.' ) . '

'; + break; + case 'err_remove': + echo '

' . __( 'Select a user to remove.' ) . '

'; + break; + case 'newuser': + echo '

' . __( 'User created.' ) . '

'; + break; + case 'err_new': + echo '

' . __( 'Enter the username and email.' ) . '

'; + break; + case 'err_new_dup': + echo '

' . __( 'Duplicated username or email address.' ) . '

'; + break; + } +endif; +?> + +
+search_box( __( 'Search Users' ), 'user' ); ?> + +
+ +views(); ?> + +
+ + +display(); ?> + +
+ + +

+
+ + + + + + + + + + + + + 'submit-add-existing-user' ) ); ?> +
+ + + +

+
+ + + + + + + + + + + + + + + + + + + + 'submit-add-user' ) ); ?> +
+ +
+