From 25a558f83f0dc55ffe4a849b1c652f227bef3e33 Mon Sep 17 00:00:00 2001 From: donncha Date: Thu, 14 Jul 2005 07:09:38 +0000 Subject: Merged changes from WP SVN. git-svn-id: http://svn.automattic.com/wordpress-mu/trunk@22 7be80a69-a1ef-0310-a953-fb0f7c49ff36 --- wp-inst/wp-admin/users.php | 367 ++++++++++++++++++++++++++------------------- 1 file changed, 212 insertions(+), 155 deletions(-) (limited to 'wp-inst/wp-admin/users.php') diff --git a/wp-inst/wp-admin/users.php b/wp-inst/wp-admin/users.php index 296c6a8..7e91124 100644 --- a/wp-inst/wp-admin/users.php +++ b/wp-inst/wp-admin/users.php @@ -8,140 +8,242 @@ $parent_file = 'profile.php'; $action = $_REQUEST['action']; switch ($action) { -case 'adduser': + +case 'promote': check_admin_referer(); - $user_login = wp_specialchars(trim($_POST['user_login'])); - $pass1 = $_POST['pass1']; - $pass2 = $_POST['pass2']; - $user_email = wp_specialchars(trim($_POST['email'])); - $user_firstname = wp_specialchars(trim($_POST['firstname'])); - $user_lastname = wp_specialchars(trim($_POST['lastname'])); - $user_uri = wp_specialchars(trim($_POST['uri'])); - - /* checking that username has been typed */ - if ($user_login == '') - die (__('ERROR: Please enter a username.')); + if (empty($_POST['users'])) { + header('Location: users.php'); + } - /* checking the password has been typed twice */ - do_action('check_passwords', array($user_login, &$pass1, &$pass2)); - if ($pass1 == '' || $pass2 == '') - die (__('ERROR: Please enter your password twice.')); + if ( !current_user_can('edit_users') ) + die(__('You can’t edit users.')); - /* checking the password has been typed twice the same */ - if ($pass1 != $pass2) - die (__('ERROR: Please type the same password in the two password fields.')); + $userids = $_POST['users']; + foreach($userids as $id) { + $user = new WP_User($id); + $user->set_role($_POST['new_role']); + } + + header('Location: users.php?update=promote'); - $user_nickname = $user_login; +break; - if ( username_exists( $user_login ) ) - die (__('ERROR: This username is already registered, please choose another one.')); +case 'dodelete': - /* checking e-mail address */ - if (empty($user_email)) { - die (__("ERROR: please type an e-mail address")); - return false; - } else if (!is_email($user_email)) { - die (__("ERROR: the email address isn't correct")); - return false; + check_admin_referer(); + + if (empty($_POST['users'])) { + header('Location: users.php'); } - $user_ID = create_user( $user_login, $pass1, $user_email, 0 ); + if ( !current_user_can('edit_users') ) + die(__('You can’t delete users.')); - update_usermeta( $user_ID, 'first_name', $user_firstname); - update_usermeta( $user_ID, 'last_name', $user_lastname); - update_usermeta( $user_ID, 'first_name', $user_firstname); + $userids = $_POST['users']; - $stars = ''; - for ($i = 0; $i < strlen($pass1); $i = $i + 1) - $stars .= '*'; + foreach($userids as $id) { + switch($_POST['delete_option']) { + case 'delete': + wp_delete_user($id); + break; + case 'reassign': + wp_delete_user($id, $_POST['reassign_user']); + break; + } + } - $user_login = stripslashes($user_login); - $message = sprintf(__('New user registration on your blog %s:'), get_settings('blogname')) . "\r\n\r\n"; - $message .= sprintf(__('Username: %s'), $user_login) . "\r\n\r\n"; - $message .= sprintf(__('E-mail: %s'), $user_email) . "\r\n"; + header('Location: users.php?update=del'); - @wp_mail(get_settings('admin_email'), sprintf(__('[%s] New User Registration'), get_settings('blogname')), $message); - header('Location: users.php'); break; -case 'promote': +case 'delete': + check_admin_referer(); - if (empty($_GET['prom'])) { + if (empty($_POST['users'])) { header('Location: users.php'); } - $id = (int) $_GET['id']; - $prom = $_GET['prom']; + if ( !current_user_can('edit_users') ) + $error['edit_users'] = __('You can’t delete users.'); - $user_data = get_userdata($id); + $userids = $_POST['users']; - $usertopromote_level = $user_data->user_level; - - if ( $user_level <= $usertopromote_level ) - die(__('Can’t change the level of a user whose level is higher than yours.')); - - if ('up' == $prom) { - $new_level = $usertopromote_level + 1; - } elseif ('down' == $prom) { - $new_level = $usertopromote_level - 1; + include ('admin-header.php'); +?> +
+
+

+

+
    + "; + echo "{$id}: {$user->data->user_login}\n"; } - update_usermeta( $id, $wpdb->prefix . 'user_level', $new_level); - - header('Location: users.php'); + $all_logins = $wpdb->get_results("SELECT ID, user_login FROM $wpdb->users ORDER BY user_login"); + $user_dropdown = ''; + ?> +
+

+
    +
  • +
  • + Attribute all posts and links to: %s'), $user_dropdown); ?>
  • +
+ +

+
+
+ERROR: Please enter a username.'); - if (!$id) { - header('Location: users.php'); - } + /* checking the password has been typed twice */ + do_action('check_passwords', array($new_user_login, &$new_pass1, &$new_pass2)); + if ($new_pass1 == '' || $new_pass2 == '') + $errors['pass'] = __('ERROR: Please enter your password twice.'); - $user_data = get_userdata($id); - $usertodelete_level = $user_data->user_level; + /* checking the password has been typed twice the same */ + if ($new_pass1 != $new_pass2) + $errors['pass'] = __('ERROR: Please type the same password in the two password fields.'); - if ($user_level <= $usertodelete_level) - die(__('Can’t delete a user whose level is higher than yours.')); + $new_user_nickname = $new_user_login; - wp_delete_user($id); + if ( username_exists( $new_user_login ) ) + $errors['pass'] = __('ERROR: This username is already registered, please choose another one.'); - header('Location: users.php?deleted=true'); + /* checking e-mail address */ + if (empty($new_user_email)) { + $errors['user_email'] = __("ERROR: please type an e-mail address"); + } else if (!is_email($new_user_email)) { + $errors['user_email'] = __("ERROR: the email address isn't correct"); + } -break; + if(count($errors) == 0) { + $user_ID = create_user( $new_user_login, $new_pass1, $new_user_email, 0 ); + + update_usermeta( $user_ID, 'first_name', $new_user_firstname); + update_usermeta( $user_ID, 'last_name', $new_user_lastname); + update_usermeta( $user_ID, 'first_name', $new_user_firstname); + + $user = new WP_User($user_ID); + $user->set_role(get_settings('default_role')); + + $stars = ''; + for ($i = 0; $i < strlen($pass1); $i = $i + 1) + $stars .= '*'; + + $user_login = stripslashes($new_user_login); + $message = sprintf(__('New user registration on your blog %s:'), get_settings('blogname')) . "\r\n\r\n"; + $message .= sprintf(__('Username: %s'), $new_user_login) . "\r\n\r\n"; + $message .= sprintf(__('E-mail: %s'), $new_user_email) . "\r\n"; + + @wp_mail(get_settings('admin_email'), sprintf(__('[%s] New User Registration'), get_settings('blogname')), $message); + header('Location: users.php?update=add'); + die(); + } default: include ('admin-header.php'); + + $userids = $wpdb->get_col("SELECT ID FROM $wpdb->users;"); + + foreach($userids as $userid) { + $tmp_user = new WP_User($userid); + $roles = array_keys($tmp_user->roles); + $role = $roles[0]; + $roleclasses[$role][$tmp_user->data->user_login] = $tmp_user; + } + ?> - -

- + +

+ +

+ +

+ +
+ +
+ + +
-

+

+ $roleclass) { + ksort($roleclass); + ?> + + + + - + - data; $email = $user_data->user_email; $url = $user_data->user_url; $short_url = str_replace('http://', '', $url); @@ -151,24 +253,18 @@ default: if (strlen($short_url) > 35) $short_url = substr($short_url, 0, 32).'...'; $style = ('class="alternate"' == $style) ? '' : 'class="alternate"'; - $numposts = $wpdb->get_var("SELECT COUNT(*) FROM $wpdb->posts WHERE post_author = '$user' and post_status = 'publish'"); + $numposts = $wpdb->get_var("SELECT COUNT(*) FROM $wpdb->posts WHERE post_author = '$user_data->ID' and post_status = 'publish'"); if (0 < $numposts) $numposts = "$numposts"; echo " - - - + + + - - "; + "; + echo ""; echo ''; echo ''; @@ -176,68 +272,29 @@ default: ?> -
+

role_names[$role]; ?>

+
 
$user_data->ID$user_data->user_login$user_data->first_name $user_data->last_name $email$short_url"; - if (($user_level >= 2) and ($user_level > $user_data->user_level) and ($user_data->user_level > 0)) - echo " ID."&prom=down\">- "; - echo $user_data->user_level; - if (($user_level >= 2) and ($user_level > ($user_data->user_level + 1))) - echo " ID."&prom=up\">+ "; - echo "$numposts$short_url$numposts'; - if (($user_level >= 2) and ($user_level > $user_data->user_level)) + if (current_user_can('edit_users')) echo "".__('Edit').""; echo '
-
-
-

- - - - - - - - - - - -user_email; - $url = $user_data->user_url; - $short_url = str_replace('http://', '', $url); - $short_url = str_replace('www.', '', $short_url); - if ('/' == substr($short_url, -1)) - $short_url = substr($short_url, 0, -1); - if (strlen($short_url) > 35) - $short_url = substr($short_url, 0, 32).'...'; - $style = ('class="alternate"' == $style) ? '' : 'class="alternate"'; -echo "\n - - - - - -\n"; - echo ''; +
$user_data->ID$user_data->user_login$user_data->first_name $user_data->last_name$email$short_url"; - - if ($user_level >= 6) - echo "". __('Promote') . ''; - echo "'; - if (($user_level >= 6) and ($user_level > $user_data->user_level)) - echo "".__('Edit').""; - echo ''; - if ($user_level >= 6) - echo "" . __('Delete'). ''; - echo '
-} -?> - - -

+

+'; +foreach($wp_roles->role_names as $role => $name) { + $role_select .= ""; +} +$role_select .= ''; +?> +
    +
  • +
  • Set the Role of checked users to: %s'), $role_select); ?>
  • +
+

+
-

Users can register themselves or you can manually create users here.

'), get_settings('siteurl')); ?> @@ -246,23 +303,23 @@ echo "\n - + - + - + - + - +