2003-12-08 02:28:41 +01:00
< ? php
2004-10-19 05:03:06 +02:00
require_once ( 'admin.php' );
2005-07-09 03:27:46 +02:00
require_once ( ABSPATH . WPINC . '/registration-functions.php' );
2004-04-25 06:24:06 +02:00
$title = __ ( 'Users' );
2004-12-24 21:55:36 +01:00
$parent_file = 'profile.php' ;
2003-12-08 02:28:41 +01:00
2005-07-09 03:27:46 +02:00
$action = $_REQUEST [ 'action' ];
2005-11-13 05:40:18 +01:00
$update = '' ;
2003-12-08 02:28:41 +01:00
switch ( $action ) {
2005-07-12 17:53:13 +02:00
case 'promote' :
2006-05-12 01:05:45 +02:00
check_admin_referer ( 'bulk-users' );
2004-05-17 22:34:05 +02:00
2005-07-12 17:53:13 +02:00
if ( empty ( $_POST [ 'users' ])) {
2006-06-28 01:10:02 +02:00
wp_redirect ( 'users.php' );
2006-11-15 23:23:43 +01:00
exit ();
2005-07-12 17:53:13 +02:00
}
2003-12-23 21:21:29 +01:00
2005-07-12 17:53:13 +02:00
if ( ! current_user_can ( 'edit_users' ) )
die ( __ ( 'You can’t edit users.' ));
2003-12-23 21:21:29 +01:00
2005-11-13 05:40:18 +01:00
$userids = $_POST [ 'users' ];
$update = 'promote' ;
foreach ( $userids as $id ) {
// The new role of the current user must also have edit_users caps
if ( $id == $current_user -> id && ! $wp_roles -> role_objects [ $_POST [ 'new_role' ]] -> has_cap ( 'edit_users' )) {
$update = 'err_admin_role' ;
continue ;
}
$user = new WP_User ( $id );
$user -> set_role ( $_POST [ 'new_role' ]);
}
2005-07-12 17:53:13 +02:00
2006-06-28 01:10:02 +02:00
wp_redirect ( 'users.php?update=' . $update );
2006-11-15 23:23:43 +01:00
exit ();
2005-03-09 23:49:42 +01:00
2005-07-12 17:53:13 +02:00
break ;
2003-12-23 21:21:29 +01:00
2005-07-12 17:53:13 +02:00
case 'dodelete' :
2003-12-23 21:21:29 +01:00
2006-05-12 01:05:45 +02:00
check_admin_referer ( 'delete-users' );
2005-07-12 17:53:13 +02:00
2005-11-13 05:40:18 +01:00
if ( empty ( $_POST [ 'users' ]) ) {
2006-06-28 01:10:02 +02:00
wp_redirect ( 'users.php' );
2006-11-15 23:23:43 +01:00
exit ();
2004-05-17 14:38:19 +02:00
}
2003-12-23 21:21:29 +01:00
2005-07-12 17:53:13 +02:00
if ( ! current_user_can ( 'edit_users' ) )
die ( __ ( 'You can’t delete users.' ));
2003-12-23 21:21:29 +01:00
2005-07-12 17:53:13 +02:00
$userids = $_POST [ 'users' ];
2003-12-08 02:28:41 +01:00
2005-11-13 05:40:18 +01:00
$update = 'del' ;
foreach ( $userids as $id ) {
if ( $id == $current_user -> id ) {
$update = 'err_admin_del' ;
continue ;
}
switch ( $_POST [ 'delete_option' ]) {
2005-07-12 17:53:13 +02:00
case 'delete' :
wp_delete_user ( $id );
break ;
case 'reassign' :
wp_delete_user ( $id , $_POST [ 'reassign_user' ]);
break ;
}
}
2003-12-23 21:21:29 +01:00
2006-06-28 01:10:02 +02:00
wp_redirect ( 'users.php?update=' . $update );
2006-11-15 23:23:43 +01:00
exit ();
2003-12-23 21:21:29 +01:00
break ;
2005-07-12 17:53:13 +02:00
case 'delete' :
2006-05-12 01:05:45 +02:00
check_admin_referer ( 'bulk-users' );
2004-05-17 22:34:05 +02:00
2006-11-15 23:23:43 +01:00
if ( empty ( $_POST [ 'users' ]) ) {
2006-06-28 01:10:02 +02:00
wp_redirect ( 'users.php' );
2006-11-15 23:23:43 +01:00
exit ();
}
2003-12-08 02:28:41 +01:00
2005-07-12 17:53:13 +02:00
if ( ! current_user_can ( 'edit_users' ) )
$error [ 'edit_users' ] = __ ( 'You can’t delete users.' );
2003-12-08 02:28:41 +01:00
2005-07-12 17:53:13 +02:00
$userids = $_POST [ 'users' ];
2005-07-09 03:27:46 +02:00
2005-07-12 17:53:13 +02:00
include ( 'admin-header.php' );
?>
< form action = " " method = " post " name = " updateusers " id = " updateusers " >
2006-05-12 01:05:45 +02:00
< ? php wp_nonce_field ( 'delete-users' ) ?>
2005-07-12 17:53:13 +02:00
< div class = " wrap " >
2005-11-13 05:40:18 +01:00
< h2 >< ? php _e ( 'Delete Users' ); ?> </h2>
< p >< ? php _e ( 'You have specified these users for deletion:' ); ?> </p>
< ul >
< ? php
$go_delete = false ;
foreach ( $userids as $id ) {
$user = new WP_User ( $id );
if ( $id == $current_user -> id ) {
2005-12-12 23:48:30 +01:00
echo " <li> " . sprintf ( __ ( 'ID #%1s: %2s <strong>The current user will not be deleted.</strong>' ), $id , $user -> user_login ) . " </li> \n " ;
2005-11-13 05:40:18 +01:00
} else {
2005-12-12 23:48:30 +01:00
echo " <li><input type= \" hidden \" name= \" users[] \" value= \" { $id } \" /> " . sprintf ( __ ( 'ID #%1s: %2s' ), $id , $user -> user_login ) . " </li> \n " ;
2005-11-13 05:40:18 +01:00
$go_delete = true ;
2005-07-12 17:53:13 +02:00
}
2005-11-13 05:40:18 +01:00
}
$all_logins = $wpdb -> get_results ( " SELECT ID, user_login FROM $wpdb->users ORDER BY user_login " );
$user_dropdown = '<select name="reassign_user">' ;
foreach ( $all_logins as $login ) {
if ( $login -> ID == $current_user -> id || ! in_array ( $login -> ID , $userids ) ) {
$user_dropdown .= " <option value= \" { $login -> ID } \" > { $login -> user_login } </option> " ;
}
}
$user_dropdown .= '</select>' ;
?>
</ ul >
< ? php if ( $go_delete ) : ?>
< p >< ? php _e ( 'What should be done with posts and links owned by this user?' ); ?> </p>
2005-07-12 17:53:13 +02:00
< ul style = " list-style:none; " >
< li >< label >< input type = " radio " id = " delete_option0 " name = " delete_option " value = " delete " checked = " checked " />
< ? php _e ( 'Delete all posts and links.' ); ?> </label></li>
< li >< input type = " radio " id = " delete_option1 " name = " delete_option " value = " reassign " />
2005-12-02 23:37:02 +01:00
< ? php echo '<label for="delete_option1">' . __ ( 'Attribute all posts and links to:' ) . " </label> $user_dropdown " ; ?> </li>
2005-07-12 17:53:13 +02:00
</ ul >
< input type = " hidden " name = " action " value = " dodelete " />
< p class = " submit " >< input type = " submit " name = " submit " value = " <?php _e('Confirm Deletion'); ?> " /></ p >
2005-11-13 05:40:18 +01:00
< ? php else : ?>
< p >< ? php _e ( 'There are no valid users selected for deletion.' ); ?> </p>
< ? php endif ; ?>
2005-07-12 17:53:13 +02:00
</ div >
</ form >
< ? php
2003-12-08 02:28:41 +01:00
break ;
2005-07-12 17:53:13 +02:00
case 'adduser' :
2006-05-12 01:05:45 +02:00
check_admin_referer ( 'add-user' );
2005-07-12 17:53:13 +02:00
2005-09-14 02:03:02 +02:00
$errors = add_user ();
2005-07-12 17:53:13 +02:00
2006-11-15 23:23:43 +01:00
if ( count ( $errors ) == 0 ) {
2006-06-28 01:10:02 +02:00
wp_redirect ( 'users.php?update=add' );
2006-11-15 23:23:43 +01:00
exit ();
2005-07-12 17:53:13 +02:00
}
2003-12-08 02:28:41 +01:00
default :
2003-12-11 01:22:36 +01:00
include ( 'admin-header.php' );
2005-07-12 17:53:13 +02:00
$userids = $wpdb -> get_col ( " SELECT ID FROM $wpdb->users ; " );
foreach ( $userids as $userid ) {
$tmp_user = new WP_User ( $userid );
2005-09-07 05:16:08 +02:00
$roles = $tmp_user -> roles ;
2006-01-25 04:44:35 +01:00
$role = array_shift ( $roles );
2005-11-16 03:54:23 +01:00
$roleclasses [ $role ][ $tmp_user -> user_login ] = $tmp_user ;
2005-07-12 17:53:13 +02:00
}
2003-12-08 02:28:41 +01:00
?>
2004-07-21 09:23:45 +02:00
2005-07-12 17:53:13 +02:00
< ? php
if ( isset ( $_GET [ 'update' ])) :
switch ( $_GET [ 'update' ]) {
case 'del' :
?>
2005-08-08 03:13:22 +02:00
< div id = " message " class = " updated fade " >< p >< ? php _e ( 'User deleted.' ); ?> </p></div>
2005-07-12 17:53:13 +02:00
< ? php
break ;
case 'add' :
?>
2005-08-08 03:13:22 +02:00
< div id = " message " class = " updated fade " >< p >< ? php _e ( 'New user created.' ); ?> </p></div>
2005-07-12 17:53:13 +02:00
< ? php
break ;
case 'promote' :
?>
2005-08-08 03:13:22 +02:00
< div id = " message " class = " updated fade " >< p >< ? php _e ( 'Changed roles.' ); ?> </p></div>
2005-07-12 17:53:13 +02:00
< ? php
break ;
2005-11-13 05:40:18 +01:00
case 'err_admin_role' :
?>
< div id = " message " class = " error " >< p >< ? php _e ( " The current user's role must have user editing capabilities. " ); ?> </p></div>
< div id = " message " class = " updated fade " >< p >< ? php _e ( 'Other user roles have been changed.' ); ?> </p></div>
< ? php
break ;
case 'err_admin_del' :
?>
< div id = " message " class = " error " >< p >< ? php _e ( " You can't delete the current user. " ); ?> </p></div>
< div id = " message " class = " updated fade " >< p >< ? php _e ( 'Other users have been deleted.' ); ?> </p></div>
< ? php
break ;
2005-07-12 17:53:13 +02:00
}
endif ;
if ( isset ( $errors ) ) : ?>
< div class = " error " >
< ul >
< ? php
foreach ( $errors as $error ) echo " <li> $error </li> " ;
?>
</ ul >
</ div >
< ? php
endif ;
?>
< form action = " " method = " post " name = " updateusers " id = " updateusers " >
2006-05-12 01:05:45 +02:00
< ? php wp_nonce_field ( 'bulk-users' ) ?>
2003-12-08 02:28:41 +01:00
< div class = " wrap " >
2005-07-12 17:53:13 +02:00
< h2 >< ? php _e ( 'User List by Role' ); ?> </h2>
2003-12-08 09:12:09 +01:00
< table cellpadding = " 3 " cellspacing = " 3 " width = " 100% " >
2005-07-12 17:53:13 +02:00
< ? php
foreach ( $roleclasses as $role => $roleclass ) {
2006-10-04 05:50:14 +02:00
uksort ( $roleclass , " strnatcasecmp " );
2005-07-12 17:53:13 +02:00
?>
< tr >
< th colspan = " 8 " align = " left " >
< h3 >< ? php echo $wp_roles -> role_names [ $role ]; ?> </h3>
2005-08-20 03:49:24 +02:00
</ th ></ tr >
2005-07-12 17:53:13 +02:00
2003-12-08 02:28:41 +01:00
< tr >
2004-04-25 06:24:06 +02:00
< th >< ? php _e ( 'ID' ) ?> </th>
2005-07-12 17:53:13 +02:00
< th >< ? php _e ( 'Username' ) ?> </th>
2004-04-25 06:24:06 +02:00
< th >< ? php _e ( 'Name' ) ?> </th>
< th >< ? php _e ( 'E-mail' ) ?> </th>
2004-05-05 10:27:43 +02:00
< th >< ? php _e ( 'Website' ) ?> </th>
2004-04-25 06:24:06 +02:00
< th >< ? php _e ( 'Posts' ) ?> </th>
2004-08-01 11:13:50 +02:00
< th >& nbsp ; </ th >
2003-12-08 02:28:41 +01:00
</ tr >
< ? php
2004-05-08 01:56:33 +02:00
$style = '' ;
2005-07-12 17:53:13 +02:00
foreach ( $roleclass as $user_object ) {
2005-11-16 03:54:23 +01:00
$email = $user_object -> user_email ;
$url = $user_object -> user_url ;
2004-06-18 02:22:09 +02:00
$short_url = str_replace ( 'http://' , '' , $url );
2003-12-08 02:28:41 +01:00
$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 ) . '...' ;
2003-12-08 09:12:09 +01:00
$style = ( 'class="alternate"' == $style ) ? '' : 'class="alternate"' ;
2005-11-16 03:54:23 +01:00
$numposts = $wpdb -> get_var ( " SELECT COUNT(*) FROM $wpdb->posts WHERE post_author = ' $user_object->ID ' and post_status = 'publish' " );
if ( 0 < $numposts ) $numposts = " <a href='edit.php?author= $user_object->ID ' title=' " . __ ( 'View posts' ) . " '> $numposts </a> " ;
2003-12-08 02:28:41 +01:00
echo "
2003-12-08 09:12:09 +01:00
< tr $style >
2005-11-16 03:54:23 +01:00
< td >< input type = 'checkbox' name = 'users[]' id = 'user_{$user_object->ID}' value = '{$user_object->ID}' /> < label for = 'user_{$user_object->ID}' > { $user_object -> ID } </ label ></ td >
< td >< label for = 'user_{$user_object->ID}' >< strong > $user_object -> user_login </ strong ></ label ></ td >
< td >< label for = 'user_{$user_object->ID}' > $user_object -> first_name $user_object -> last_name </ label ></ td >
2004-04-25 06:24:06 +02:00
< td >< a href = 'mailto:$email' title = '" . sprintf(__(' e - mail : % s '), $email) . "' > $email </ a ></ td >
2005-07-12 17:53:13 +02:00
< td >< a href = '$url' title = 'website: $url' > $short_url </ a ></ td > " ;
echo " <td align='right'> $numposts </td> " ;
2004-08-01 11:13:50 +02:00
echo '<td>' ;
2005-07-12 17:53:13 +02:00
if ( current_user_can ( 'edit_users' ))
2005-11-16 03:54:23 +01:00
echo " <a href='user-edit.php?user_id= $user_object->ID ' class='edit'> " . __ ( 'Edit' ) . " </a> " ;
2004-08-01 11:13:50 +02:00
echo '</td>' ;
2003-12-08 02:28:41 +01:00
echo '</tr>' ;
}
?>
< ? php
2005-07-12 17:53:13 +02:00
}
2003-12-08 02:28:41 +01:00
?>
2005-07-12 17:53:13 +02:00
</ table >
2004-09-22 01:36:27 +02:00
2005-07-12 17:53:13 +02:00
< h2 >< ? php _e ( 'Update Users' ); ?> </h2>
< ? php
$role_select = '<select name="new_role">' ;
foreach ( $wp_roles -> role_names as $role => $name ) {
$role_select .= " <option value= \" { $role } \" > { $name } </option> " ;
}
$role_select .= '</select>' ;
?>
< ul style = " list-style:none; " >
2005-08-20 03:49:24 +02:00
< li >< input type = " radio " name = " action " id = " action0 " value = " delete " /> < label for = " action0 " >< ? php _e ( 'Delete checked users.' ); ?> </label></li>
2005-12-02 23:37:02 +01:00
< li >< input type = " radio " name = " action " id = " action1 " value = " promote " /> < ? php echo '<label for="action1">' . __ ( 'Set the Role of checked users to:' ) . " </label> $role_select " ; ?> </li>
2005-07-12 17:53:13 +02:00
</ ul >
2005-08-20 03:49:24 +02:00
< p class = " submit " >< input type = " submit " value = " <?php _e('Update »'); ?> " /></ p >
2003-12-08 02:28:41 +01:00
</ div >
2005-07-12 17:53:13 +02:00
</ form >
2003-12-08 02:28:41 +01:00
< div class = " wrap " >
2004-07-21 09:44:55 +02:00
< h2 >< ? php _e ( 'Add New User' ) ?> </h2>
2005-12-02 23:37:02 +01:00
< ? php echo '<p>' . sprintf ( __ ( 'Users can <a href="%1$s">register themselves</a> or you can manually create users here.' ), get_settings ( 'siteurl' ) . '/wp-register.php' ) . '</p>' ; ?>
2003-12-23 21:21:29 +01:00
< form action = " " method = " post " name = " adduser " id = " adduser " >
2006-05-12 01:05:45 +02:00
< ? php wp_nonce_field ( 'add-user' ) ?>
2004-05-05 10:27:43 +02:00
< table class = " editform " width = " 100% " cellspacing = " 2 " cellpadding = " 5 " >
2003-12-23 21:21:29 +01:00
< tr >
2004-05-05 10:27:43 +02:00
< th scope = " row " width = " 33% " >< ? php _e ( 'Nickname' ) ?>
2003-12-23 21:21:29 +01:00
< input name = " action " type = " hidden " id = " action " value = " adduser " /></ th >
2005-07-12 17:53:13 +02:00
< td width = " 66% " >< input name = " user_login " type = " text " id = " user_login " value = " <?php echo $new_user_login ; ?> " /></ td >
2003-12-23 21:21:29 +01:00
</ tr >
< tr >
2004-04-25 06:24:06 +02:00
< th scope = " row " >< ? php _e ( 'First Name' ) ?> </th>
2005-09-14 02:03:02 +02:00
< td >< input name = " first_name " type = " text " id = " first_name " value = " <?php echo $new_user_firstname ; ?> " /></ td >
2003-12-23 21:21:29 +01:00
</ tr >
< tr >
2004-04-25 06:24:06 +02:00
< th scope = " row " >< ? php _e ( 'Last Name' ) ?> </th>
2005-09-14 02:03:02 +02:00
< td >< input name = " last_name " type = " text " id = " last_name " value = " <?php echo $new_user_lastname ; ?> " /></ td >
2003-12-23 21:21:29 +01:00
</ tr >
< tr >
2004-05-05 10:27:43 +02:00
< th scope = " row " >< ? php _e ( 'E-mail' ) ?> </th>
2005-07-12 17:53:13 +02:00
< td >< input name = " email " type = " text " id = " email " value = " <?php echo $new_user_email ; ?> " /></ td >
2003-12-23 21:21:29 +01:00
</ tr >
< tr >
2004-05-05 10:27:43 +02:00
< th scope = " row " >< ? php _e ( 'Website' ) ?> </th>
2005-09-14 02:03:02 +02:00
< td >< input name = " url " type = " text " id = " url " value = " <?php echo $new_user_uri ; ?> " /></ td >
2003-12-23 21:21:29 +01:00
</ tr >
2005-03-09 23:49:42 +01:00
< ? php
$show_password_fields = apply_filters ( 'show_password_fields' , true );
if ( $show_password_fields ) :
?>
2003-12-23 21:21:29 +01:00
< tr >
2004-04-25 06:24:06 +02:00
< th scope = " row " >< ? php _e ( 'Password (twice)' ) ?> </th>
2004-01-21 23:44:28 +01:00
< td >< input name = " pass1 " type = " password " id = " pass1 " />
2003-12-23 21:21:29 +01:00
< br />
2004-01-21 23:44:28 +01:00
< input name = " pass2 " type = " password " id = " pass2 " /></ td >
2003-12-23 21:21:29 +01:00
</ tr >
2005-03-09 23:49:42 +01:00
< ? php endif ; ?>
2003-12-23 21:21:29 +01:00
</ table >
2004-04-28 06:59:54 +02:00
< p class = " submit " >
2004-06-11 20:23:12 +02:00
< input name = " adduser " type = " submit " id = " adduser " value = " <?php _e('Add User') ?> » " />
2003-12-23 21:21:29 +01:00
</ p >
</ form >
2003-12-08 02:28:41 +01:00
</ div >
< ? php
break ;
}
2004-08-23 01:24:50 +02:00
2003-12-11 01:22:36 +01:00
include ( 'admin-footer.php' );
2004-12-24 21:55:36 +01:00
?>