site-users.php 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366
  1. <?php
  2. /**
  3. * Edit Site Users Administration Screen
  4. *
  5. * @package WordPress
  6. * @subpackage Multisite
  7. * @since 3.1.0
  8. */
  9. /** Load WordPress Administration Bootstrap */
  10. require_once( dirname( __FILE__ ) . '/admin.php' );
  11. if ( ! current_user_can( 'manage_sites' ) ) {
  12. wp_die( __( 'Sorry, you are not allowed to edit this site.' ), 403 );
  13. }
  14. $wp_list_table = _get_list_table( 'WP_Users_List_Table' );
  15. $wp_list_table->prepare_items();
  16. get_current_screen()->add_help_tab( get_site_screen_help_tab_args() );
  17. get_current_screen()->set_help_sidebar( get_site_screen_help_sidebar_content() );
  18. get_current_screen()->set_screen_reader_content(
  19. array(
  20. 'heading_views' => __( 'Filter site users list' ),
  21. 'heading_pagination' => __( 'Site users list navigation' ),
  22. 'heading_list' => __( 'Site users list' ),
  23. )
  24. );
  25. $_SERVER['REQUEST_URI'] = remove_query_arg( 'update', $_SERVER['REQUEST_URI'] );
  26. $referer = remove_query_arg( 'update', wp_get_referer() );
  27. if ( ! empty( $_REQUEST['paged'] ) ) {
  28. $referer = add_query_arg( 'paged', (int) $_REQUEST['paged'], $referer );
  29. }
  30. $id = isset( $_REQUEST['id'] ) ? intval( $_REQUEST['id'] ) : 0;
  31. if ( ! $id ) {
  32. wp_die( __( 'Invalid site ID.' ) );
  33. }
  34. $details = get_site( $id );
  35. if ( ! $details ) {
  36. wp_die( __( 'The requested site does not exist.' ) );
  37. }
  38. if ( ! can_edit_network( $details->site_id ) ) {
  39. wp_die( __( 'Sorry, you are not allowed to access this page.' ), 403 );
  40. }
  41. $is_main_site = is_main_site( $id );
  42. switch_to_blog( $id );
  43. $action = $wp_list_table->current_action();
  44. if ( $action ) {
  45. switch ( $action ) {
  46. case 'newuser':
  47. check_admin_referer( 'add-user', '_wpnonce_add-new-user' );
  48. $user = $_POST['user'];
  49. if ( ! is_array( $_POST['user'] ) || empty( $user['username'] ) || empty( $user['email'] ) ) {
  50. $update = 'err_new';
  51. } else {
  52. $password = wp_generate_password( 12, false );
  53. $user_id = wpmu_create_user( esc_html( strtolower( $user['username'] ) ), $password, esc_html( $user['email'] ) );
  54. if ( false === $user_id ) {
  55. $update = 'err_new_dup';
  56. } else {
  57. $result = add_user_to_blog( $id, $user_id, $_POST['new_role'] );
  58. if ( is_wp_error( $result ) ) {
  59. $update = 'err_add_fail';
  60. } else {
  61. $update = 'newuser';
  62. /**
  63. * Fires after a user has been created via the network site-users.php page.
  64. *
  65. * @since 4.4.0
  66. *
  67. * @param int $user_id ID of the newly created user.
  68. */
  69. do_action( 'network_site_users_created_user', $user_id );
  70. }
  71. }
  72. }
  73. break;
  74. case 'adduser':
  75. check_admin_referer( 'add-user', '_wpnonce_add-user' );
  76. if ( ! empty( $_POST['newuser'] ) ) {
  77. $update = 'adduser';
  78. $newuser = $_POST['newuser'];
  79. $user = get_user_by( 'login', $newuser );
  80. if ( $user && $user->exists() ) {
  81. if ( ! is_user_member_of_blog( $user->ID, $id ) ) {
  82. $result = add_user_to_blog( $id, $user->ID, $_POST['new_role'] );
  83. if ( is_wp_error( $result ) ) {
  84. $update = 'err_add_fail';
  85. }
  86. } else {
  87. $update = 'err_add_member';
  88. }
  89. } else {
  90. $update = 'err_add_notfound';
  91. }
  92. } else {
  93. $update = 'err_add_notfound';
  94. }
  95. break;
  96. case 'remove':
  97. if ( ! current_user_can( 'remove_users' ) ) {
  98. wp_die( __( 'Sorry, you are not allowed to remove users.' ), 403 );
  99. }
  100. check_admin_referer( 'bulk-users' );
  101. $update = 'remove';
  102. if ( isset( $_REQUEST['users'] ) ) {
  103. $userids = $_REQUEST['users'];
  104. foreach ( $userids as $user_id ) {
  105. $user_id = (int) $user_id;
  106. remove_user_from_blog( $user_id, $id );
  107. }
  108. } elseif ( isset( $_GET['user'] ) ) {
  109. remove_user_from_blog( $_GET['user'] );
  110. } else {
  111. $update = 'err_remove';
  112. }
  113. break;
  114. case 'promote':
  115. check_admin_referer( 'bulk-users' );
  116. $editable_roles = get_editable_roles();
  117. $role = false;
  118. if ( ! empty( $_REQUEST['new_role2'] ) ) {
  119. $role = $_REQUEST['new_role2'];
  120. } elseif ( ! empty( $_REQUEST['new_role'] ) ) {
  121. $role = $_REQUEST['new_role'];
  122. }
  123. if ( empty( $editable_roles[ $role ] ) ) {
  124. wp_die( __( 'Sorry, you are not allowed to give users that role.' ), 403 );
  125. }
  126. if ( isset( $_REQUEST['users'] ) ) {
  127. $userids = $_REQUEST['users'];
  128. $update = 'promote';
  129. foreach ( $userids as $user_id ) {
  130. $user_id = (int) $user_id;
  131. // If the user doesn't already belong to the blog, bail.
  132. if ( ! is_user_member_of_blog( $user_id ) ) {
  133. wp_die(
  134. '<h1>' . __( 'Something went wrong.' ) . '</h1>' .
  135. '<p>' . __( 'One of the selected users is not a member of this site.' ) . '</p>',
  136. 403
  137. );
  138. }
  139. $user = get_userdata( $user_id );
  140. $user->set_role( $role );
  141. }
  142. } else {
  143. $update = 'err_promote';
  144. }
  145. break;
  146. default:
  147. if ( ! isset( $_REQUEST['users'] ) ) {
  148. break;
  149. }
  150. check_admin_referer( 'bulk-users' );
  151. $userids = $_REQUEST['users'];
  152. /** This action is documented in wp-admin/network/site-themes.php */
  153. $referer = apply_filters( 'handle_network_bulk_actions-' . get_current_screen()->id, $referer, $action, $userids, $id ); // phpcs:ignore WordPress.NamingConventions.ValidHookName.UseUnderscores
  154. $update = $action;
  155. break;
  156. }
  157. wp_safe_redirect( add_query_arg( 'update', $update, $referer ) );
  158. exit();
  159. }
  160. restore_current_blog();
  161. if ( isset( $_GET['action'] ) && 'update-site' == $_GET['action'] ) {
  162. wp_safe_redirect( $referer );
  163. exit();
  164. }
  165. add_screen_option( 'per_page' );
  166. /* translators: %s: Site title. */
  167. $title = sprintf( __( 'Edit Site: %s' ), esc_html( $details->blogname ) );
  168. $parent_file = 'sites.php';
  169. $submenu_file = 'sites.php';
  170. /**
  171. * Filters whether to show the Add Existing User form on the Multisite Users screen.
  172. *
  173. * @since 3.1.0
  174. *
  175. * @param bool $bool Whether to show the Add Existing User form. Default true.
  176. */
  177. if ( ! wp_is_large_network( 'users' ) && apply_filters( 'show_network_site_users_add_existing_form', true ) ) {
  178. wp_enqueue_script( 'user-suggest' );
  179. }
  180. require( ABSPATH . 'wp-admin/admin-header.php' ); ?>
  181. <script type="text/javascript">
  182. var current_site_id = <?php echo $id; ?>;
  183. </script>
  184. <div class="wrap">
  185. <h1 id="edit-site"><?php echo $title; ?></h1>
  186. <p class="edit-site-actions"><a href="<?php echo esc_url( get_home_url( $id, '/' ) ); ?>"><?php _e( 'Visit' ); ?></a> | <a href="<?php echo esc_url( get_admin_url( $id ) ); ?>"><?php _e( 'Dashboard' ); ?></a></p>
  187. <?php
  188. network_edit_site_nav(
  189. array(
  190. 'blog_id' => $id,
  191. 'selected' => 'site-users',
  192. )
  193. );
  194. if ( isset( $_GET['update'] ) ) :
  195. switch ( $_GET['update'] ) {
  196. case 'adduser':
  197. echo '<div id="message" class="updated notice is-dismissible"><p>' . __( 'User added.' ) . '</p></div>';
  198. break;
  199. case 'err_add_member':
  200. echo '<div id="message" class="error notice is-dismissible"><p>' . __( 'User is already a member of this site.' ) . '</p></div>';
  201. break;
  202. case 'err_add_fail':
  203. echo '<div id="message" class="error notice is-dismissible"><p>' . __( 'User could not be added to this site.' ) . '</p></div>';
  204. break;
  205. case 'err_add_notfound':
  206. echo '<div id="message" class="error notice is-dismissible"><p>' . __( 'Enter the username of an existing user.' ) . '</p></div>';
  207. break;
  208. case 'promote':
  209. echo '<div id="message" class="updated notice is-dismissible"><p>' . __( 'Changed roles.' ) . '</p></div>';
  210. break;
  211. case 'err_promote':
  212. echo '<div id="message" class="error notice is-dismissible"><p>' . __( 'Select a user to change role.' ) . '</p></div>';
  213. break;
  214. case 'remove':
  215. echo '<div id="message" class="updated notice is-dismissible"><p>' . __( 'User removed from this site.' ) . '</p></div>';
  216. break;
  217. case 'err_remove':
  218. echo '<div id="message" class="error notice is-dismissible"><p>' . __( 'Select a user to remove.' ) . '</p></div>';
  219. break;
  220. case 'newuser':
  221. echo '<div id="message" class="updated notice is-dismissible"><p>' . __( 'User created.' ) . '</p></div>';
  222. break;
  223. case 'err_new':
  224. echo '<div id="message" class="error notice is-dismissible"><p>' . __( 'Enter the username and email.' ) . '</p></div>';
  225. break;
  226. case 'err_new_dup':
  227. echo '<div id="message" class="error notice is-dismissible"><p>' . __( 'Duplicated username or email address.' ) . '</p></div>';
  228. break;
  229. }
  230. endif;
  231. ?>
  232. <form class="search-form" method="get">
  233. <?php $wp_list_table->search_box( __( 'Search Users' ), 'user' ); ?>
  234. <input type="hidden" name="id" value="<?php echo esc_attr( $id ); ?>" />
  235. </form>
  236. <?php $wp_list_table->views(); ?>
  237. <form method="post" action="site-users.php?action=update-site">
  238. <input type="hidden" name="id" value="<?php echo esc_attr( $id ); ?>" />
  239. <?php $wp_list_table->display(); ?>
  240. </form>
  241. <?php
  242. /**
  243. * Fires after the list table on the Users screen in the Multisite Network Admin.
  244. *
  245. * @since 3.1.0
  246. */
  247. do_action( 'network_site_users_after_list_table' );
  248. /** This filter is documented in wp-admin/network/site-users.php */
  249. if ( current_user_can( 'promote_users' ) && apply_filters( 'show_network_site_users_add_existing_form', true ) ) :
  250. ?>
  251. <h2 id="add-existing-user"><?php _e( 'Add Existing User' ); ?></h2>
  252. <form action="site-users.php?action=adduser" id="adduser" method="post">
  253. <input type="hidden" name="id" value="<?php echo esc_attr( $id ); ?>" />
  254. <table class="form-table" role="presentation">
  255. <tr>
  256. <th scope="row"><label for="newuser"><?php _e( 'Username' ); ?></label></th>
  257. <td><input type="text" class="regular-text wp-suggest-user" name="newuser" id="newuser" /></td>
  258. </tr>
  259. <tr>
  260. <th scope="row"><label for="new_role_adduser"><?php _e( 'Role' ); ?></label></th>
  261. <td><select name="new_role" id="new_role_adduser">
  262. <?php
  263. switch_to_blog( $id );
  264. wp_dropdown_roles( get_option( 'default_role' ) );
  265. restore_current_blog();
  266. ?>
  267. </select></td>
  268. </tr>
  269. </table>
  270. <?php wp_nonce_field( 'add-user', '_wpnonce_add-user' ); ?>
  271. <?php submit_button( __( 'Add User' ), 'primary', 'add-user', true, array( 'id' => 'submit-add-existing-user' ) ); ?>
  272. </form>
  273. <?php endif; ?>
  274. <?php
  275. /**
  276. * Filters whether to show the Add New User form on the Multisite Users screen.
  277. *
  278. * @since 3.1.0
  279. *
  280. * @param bool $bool Whether to show the Add New User form. Default true.
  281. */
  282. if ( current_user_can( 'create_users' ) && apply_filters( 'show_network_site_users_add_new_form', true ) ) :
  283. ?>
  284. <h2 id="add-new-user"><?php _e( 'Add New User' ); ?></h2>
  285. <form action="<?php echo network_admin_url( 'site-users.php?action=newuser' ); ?>" id="newuser" method="post">
  286. <input type="hidden" name="id" value="<?php echo esc_attr( $id ); ?>" />
  287. <table class="form-table" role="presentation">
  288. <tr>
  289. <th scope="row"><label for="user_username"><?php _e( 'Username' ); ?></label></th>
  290. <td><input type="text" class="regular-text" name="user[username]" id="user_username" /></td>
  291. </tr>
  292. <tr>
  293. <th scope="row"><label for="user_email"><?php _e( 'Email' ); ?></label></th>
  294. <td><input type="text" class="regular-text" name="user[email]" id="user_email" /></td>
  295. </tr>
  296. <tr>
  297. <th scope="row"><label for="new_role_newuser"><?php _e( 'Role' ); ?></label></th>
  298. <td><select name="new_role" id="new_role_newuser">
  299. <?php
  300. switch_to_blog( $id );
  301. wp_dropdown_roles( get_option( 'default_role' ) );
  302. restore_current_blog();
  303. ?>
  304. </select></td>
  305. </tr>
  306. <tr class="form-field">
  307. <td colspan="2" class="td-full"><?php _e( 'A password reset link will be sent to the user via email.' ); ?></td>
  308. </tr>
  309. </table>
  310. <?php wp_nonce_field( 'add-user', '_wpnonce_add-new-user' ); ?>
  311. <?php submit_button( __( 'Add New User' ), 'primary', 'add-user', true, array( 'id' => 'submit-add-user' ) ); ?>
  312. </form>
  313. <?php endif; ?>
  314. </div>
  315. <?php
  316. require( ABSPATH . 'wp-admin/admin-footer.php' );