2007-05-25 09:16:21 +02:00
< ? php
2008-10-02 03:03:26 +02:00
/**
* WordPress user administration API .
*
* @ package WordPress
* @ subpackage Administration
*/
/**
* Creates a new user from the " Users " form using $_POST information .
*
2013-12-24 19:57:12 +01:00
* @ since 2.0 . 0
2008-10-02 03:03:26 +02:00
*
2015-05-29 22:17:26 +02:00
* @ return int | WP_Error WP_Error or User ID .
2008-10-02 03:03:26 +02:00
*/
2007-05-25 09:16:21 +02:00
function add_user () {
2012-01-05 21:38:40 +01:00
return edit_user ();
2007-05-25 09:16:21 +02:00
}
2008-10-02 03:03:26 +02:00
/**
2009-01-06 23:00:05 +01:00
* Edit user settings based on contents of $_POST
2008-10-02 03:03:26 +02:00
*
2009-01-06 23:00:05 +01:00
* Used on user - edit . php and profile . php to manage and process user options , passwords etc .
2008-10-02 03:03:26 +02:00
*
2013-12-24 19:57:12 +01:00
* @ since 2.0 . 0
2008-10-02 03:03:26 +02:00
*
* @ param int $user_id Optional . User ID .
2019-01-18 02:03:50 +01:00
* @ return int | WP_Error user id of the updated user .
2008-10-02 03:03:26 +02:00
*/
2007-05-25 09:16:21 +02:00
function edit_user ( $user_id = 0 ) {
2015-05-28 23:41:30 +02:00
$wp_roles = wp_roles ();
2017-12-01 00:11:00 +01:00
$user = new stdClass ;
2018-03-19 21:29:34 +01:00
$user_id = ( int ) $user_id ;
2010-11-15 07:38:10 +01:00
if ( $user_id ) {
2017-12-01 00:11:00 +01:00
$update = true ;
2018-03-19 21:29:34 +01:00
$user -> ID = $user_id ;
2017-12-01 00:11:00 +01:00
$userdata = get_userdata ( $user_id );
2013-03-01 18:14:09 +01:00
$user -> user_login = wp_slash ( $userdata -> user_login );
2007-05-25 09:16:21 +02:00
} else {
$update = false ;
}
2017-12-01 00:11:00 +01:00
if ( ! $update && isset ( $_POST [ 'user_login' ] ) ) {
2019-11-03 21:12:02 +01:00
$user -> user_login = sanitize_user ( wp_unslash ( $_POST [ 'user_login' ] ), true );
2017-12-01 00:11:00 +01:00
}
2007-05-25 09:16:21 +02:00
2019-07-01 14:52:01 +02:00
$pass1 = '' ;
$pass2 = '' ;
2017-12-01 00:11:00 +01:00
if ( isset ( $_POST [ 'pass1' ] ) ) {
2013-06-25 13:14:50 +02:00
$pass1 = $_POST [ 'pass1' ];
2017-12-01 00:11:00 +01:00
}
if ( isset ( $_POST [ 'pass2' ] ) ) {
2013-06-25 13:14:50 +02:00
$pass2 = $_POST [ 'pass2' ];
2017-12-01 00:11:00 +01:00
}
2007-05-25 09:16:21 +02:00
2018-03-19 21:29:34 +01:00
if ( isset ( $_POST [ 'role' ] ) && current_user_can ( 'promote_users' ) && ( ! $user_id || current_user_can ( 'promote_user' , $user_id ) ) ) {
$new_role = sanitize_text_field ( $_POST [ 'role' ] );
2009-01-06 23:00:05 +01:00
2018-03-19 21:29:34 +01:00
// If the new role isn't editable by the logged-in user die with error.
2009-01-06 23:00:05 +01:00
$editable_roles = get_editable_roles ();
2017-12-01 00:11:00 +01:00
if ( ! empty ( $new_role ) && empty ( $editable_roles [ $new_role ] ) ) {
2017-06-25 20:46:44 +02:00
wp_die ( __ ( 'Sorry, you are not allowed to give users that role.' ), 403 );
2017-12-01 00:11:00 +01:00
}
2018-03-19 21:29:34 +01:00
$potential_role = isset ( $wp_roles -> role_objects [ $new_role ] ) ? $wp_roles -> role_objects [ $new_role ] : false ;
/*
* Don 't let anyone with ' promote_users ' edit their own role to something without it .
* Multisite super admins can freely edit their roles , they possess all caps .
*/
if (
( is_multisite () && current_user_can ( 'manage_network_users' ) ) ||
2020-02-09 17:55:09 +01:00
get_current_user_id () !== $user_id ||
2018-03-19 21:29:34 +01:00
( $potential_role && $potential_role -> has_cap ( 'promote_users' ) )
) {
$user -> role = $new_role ;
}
2007-05-25 09:16:21 +02:00
}
2017-12-01 00:11:00 +01:00
if ( isset ( $_POST [ 'email' ] ) ) {
2014-10-19 22:30:19 +02:00
$user -> user_email = sanitize_text_field ( wp_unslash ( $_POST [ 'email' ] ) );
2017-12-01 00:11:00 +01:00
}
2013-03-01 17:28:40 +01:00
if ( isset ( $_POST [ 'url' ] ) ) {
2020-02-09 17:55:09 +01:00
if ( empty ( $_POST [ 'url' ] ) || 'http://' === $_POST [ 'url' ] ) {
2009-05-14 00:41:05 +02:00
$user -> user_url = '' ;
} else {
2013-03-01 17:28:40 +01:00
$user -> user_url = esc_url_raw ( $_POST [ 'url' ] );
2017-12-01 00:11:00 +01:00
$protocols = implode ( '|' , array_map ( 'preg_quote' , wp_allowed_protocols () ) );
$user -> user_url = preg_match ( '/^(' . $protocols . '):/is' , $user -> user_url ) ? $user -> user_url : 'http://' . $user -> user_url ;
2009-05-14 00:41:05 +02:00
}
2007-05-25 09:16:21 +02:00
}
2017-12-01 00:11:00 +01:00
if ( isset ( $_POST [ 'first_name' ] ) ) {
2013-03-01 17:28:40 +01:00
$user -> first_name = sanitize_text_field ( $_POST [ 'first_name' ] );
2017-12-01 00:11:00 +01:00
}
if ( isset ( $_POST [ 'last_name' ] ) ) {
2013-03-01 17:28:40 +01:00
$user -> last_name = sanitize_text_field ( $_POST [ 'last_name' ] );
2017-12-01 00:11:00 +01:00
}
if ( isset ( $_POST [ 'nickname' ] ) ) {
2013-03-01 17:28:40 +01:00
$user -> nickname = sanitize_text_field ( $_POST [ 'nickname' ] );
2017-12-01 00:11:00 +01:00
}
if ( isset ( $_POST [ 'display_name' ] ) ) {
2013-03-01 17:28:40 +01:00
$user -> display_name = sanitize_text_field ( $_POST [ 'display_name' ] );
2017-12-01 00:11:00 +01:00
}
2013-03-01 17:28:40 +01:00
2017-12-01 00:11:00 +01:00
if ( isset ( $_POST [ 'description' ] ) ) {
2013-03-01 17:28:40 +01:00
$user -> description = trim ( $_POST [ 'description' ] );
2017-12-01 00:11:00 +01:00
}
2009-09-14 15:57:48 +02:00
2013-09-24 20:14:09 +02:00
foreach ( wp_get_user_contact_methods ( $user ) as $method => $name ) {
2017-12-01 00:11:00 +01:00
if ( isset ( $_POST [ $method ] ) ) {
$user -> $method = sanitize_text_field ( $_POST [ $method ] );
}
2009-09-14 15:57:48 +02:00
}
2020-03-27 22:58:05 +01:00
if ( isset ( $_POST [ 'locale' ] ) ) {
$locale = sanitize_text_field ( $_POST [ 'locale' ] );
if ( 'site-default' === $locale ) {
$locale = '' ;
} elseif ( '' === $locale ) {
$locale = 'en_US' ;
} elseif ( ! in_array ( $locale , get_available_languages (), true ) ) {
$locale = '' ;
}
$user -> locale = $locale ;
}
2009-09-14 15:57:48 +02:00
if ( $update ) {
2017-12-01 00:11:00 +01:00
$user -> rich_editing = isset ( $_POST [ 'rich_editing' ] ) && 'false' === $_POST [ 'rich_editing' ] ? 'false' : 'true' ;
$user -> syntax_highlighting = isset ( $_POST [ 'syntax_highlighting' ] ) && 'false' === $_POST [ 'syntax_highlighting' ] ? 'false' : 'true' ;
$user -> admin_color = isset ( $_POST [ 'admin_color' ] ) ? sanitize_text_field ( $_POST [ 'admin_color' ] ) : 'fresh' ;
2013-03-01 17:28:40 +01:00
$user -> show_admin_bar_front = isset ( $_POST [ 'admin_bar_front' ] ) ? 'true' : 'false' ;
2009-08-06 23:59:52 +02:00
}
2007-05-25 09:16:21 +02:00
2020-05-16 20:42:12 +02:00
$user -> comment_shortcuts = isset ( $_POST [ 'comment_shortcuts' ] ) && 'true' === $_POST [ 'comment_shortcuts' ] ? 'true' : '' ;
2008-12-09 19:03:31 +01:00
2008-08-21 19:40:38 +02:00
$user -> use_ssl = 0 ;
2017-12-01 00:11:00 +01:00
if ( ! empty ( $_POST [ 'use_ssl' ] ) ) {
2008-08-21 19:40:38 +02:00
$user -> use_ssl = 1 ;
2017-12-01 00:11:00 +01:00
}
2008-08-21 19:40:38 +02:00
2007-05-25 09:16:21 +02:00
$errors = new WP_Error ();
/* checking that username has been typed */
2020-05-16 20:42:12 +02:00
if ( '' === $user -> user_login ) {
I18N: Remove the "Error:" prefix from error messages.
For a number of years, most of the WordPress error messages have been prefixed with "Error:". However, these messages appear in a context where it's already clear an error occurred. Whether it's an error, a warning, or any other classification, that's not so relevant for users. The content of the message is the relevant part. The "Error:" prefix doesn't add great value while it does add unnecessary complexity for the message readability.
Also, revises some of these messages to improve clarity and removes HTML from translatable strings.
Props garrett-eclipse, ramiy, SergeyBiryukov, afercia, sabernhardt, quadthemes, audrasjb.
See #47003, #43037, #42945, #15887.
Fixes #47656.
Built from https://develop.svn.wordpress.org/trunk@48059
git-svn-id: http://core.svn.wordpress.org/trunk@47826 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2020-06-16 17:35:13 +02:00
$errors -> add ( 'user_login' , __ ( 'Please enter a username.' ) );
2017-12-01 00:11:00 +01:00
}
2015-09-25 06:44:25 +02:00
2015-09-24 19:49:25 +02:00
/* checking that nickname has been typed */
2015-09-25 06:44:25 +02:00
if ( $update && empty ( $user -> nickname ) ) {
I18N: Remove the "Error:" prefix from error messages.
For a number of years, most of the WordPress error messages have been prefixed with "Error:". However, these messages appear in a context where it's already clear an error occurred. Whether it's an error, a warning, or any other classification, that's not so relevant for users. The content of the message is the relevant part. The "Error:" prefix doesn't add great value while it does add unnecessary complexity for the message readability.
Also, revises some of these messages to improve clarity and removes HTML from translatable strings.
Props garrett-eclipse, ramiy, SergeyBiryukov, afercia, sabernhardt, quadthemes, audrasjb.
See #47003, #43037, #42945, #15887.
Fixes #47656.
Built from https://develop.svn.wordpress.org/trunk@48059
git-svn-id: http://core.svn.wordpress.org/trunk@47826 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2020-06-16 17:35:13 +02:00
$errors -> add ( 'nickname' , __ ( 'Please enter a nickname.' ) );
2015-09-24 19:49:25 +02:00
}
2015-09-25 06:44:25 +02:00
2013-12-01 18:54:10 +01:00
/**
* Fires before the password and confirm password fields are checked for congruity .
*
* @ since 1.5 . 1
*
* @ param string $user_login The username .
2017-10-03 00:03:33 +02:00
* @ param string $pass1 The password ( passed by reference ) .
* @ param string $pass2 The confirmed password ( passed by reference ) .
2013-12-01 18:54:10 +01:00
*/
2013-03-07 07:00:16 +01:00
do_action_ref_array ( 'check_passwords' , array ( $user -> user_login , & $pass1 , & $pass2 ) );
2007-05-25 09:16:21 +02:00
2016-03-23 00:07:27 +01:00
// Check for blank password when adding a user.
if ( ! $update && empty ( $pass1 ) ) {
I18N: Remove the "Error:" prefix from error messages.
For a number of years, most of the WordPress error messages have been prefixed with "Error:". However, these messages appear in a context where it's already clear an error occurred. Whether it's an error, a warning, or any other classification, that's not so relevant for users. The content of the message is the relevant part. The "Error:" prefix doesn't add great value while it does add unnecessary complexity for the message readability.
Also, revises some of these messages to improve clarity and removes HTML from translatable strings.
Props garrett-eclipse, ramiy, SergeyBiryukov, afercia, sabernhardt, quadthemes, audrasjb.
See #47003, #43037, #42945, #15887.
Fixes #47656.
Built from https://develop.svn.wordpress.org/trunk@48059
git-svn-id: http://core.svn.wordpress.org/trunk@47826 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2020-06-16 17:35:13 +02:00
$errors -> add ( 'pass' , __ ( 'Please enter a password.' ), array ( 'form-field' => 'pass1' ) );
2016-03-23 00:07:27 +01:00
}
// Check for "\" in password.
2017-12-01 00:11:00 +01:00
if ( false !== strpos ( wp_unslash ( $pass1 ), '\\' ) ) {
I18N: Remove the "Error:" prefix from error messages.
For a number of years, most of the WordPress error messages have been prefixed with "Error:". However, these messages appear in a context where it's already clear an error occurred. Whether it's an error, a warning, or any other classification, that's not so relevant for users. The content of the message is the relevant part. The "Error:" prefix doesn't add great value while it does add unnecessary complexity for the message readability.
Also, revises some of these messages to improve clarity and removes HTML from translatable strings.
Props garrett-eclipse, ramiy, SergeyBiryukov, afercia, sabernhardt, quadthemes, audrasjb.
See #47003, #43037, #42945, #15887.
Fixes #47656.
Built from https://develop.svn.wordpress.org/trunk@48059
git-svn-id: http://core.svn.wordpress.org/trunk@47826 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2020-06-16 17:35:13 +02:00
$errors -> add ( 'pass' , __ ( 'Passwords may not contain the character "\\".' ), array ( 'form-field' => 'pass1' ) );
2016-03-23 00:07:27 +01:00
}
2007-05-25 09:16:21 +02:00
2016-03-23 00:07:27 +01:00
// Checking the password has been typed twice the same.
if ( ( $update || ! empty ( $pass1 ) ) && $pass1 != $pass2 ) {
I18N: Remove the "Error:" prefix from error messages.
For a number of years, most of the WordPress error messages have been prefixed with "Error:". However, these messages appear in a context where it's already clear an error occurred. Whether it's an error, a warning, or any other classification, that's not so relevant for users. The content of the message is the relevant part. The "Error:" prefix doesn't add great value while it does add unnecessary complexity for the message readability.
Also, revises some of these messages to improve clarity and removes HTML from translatable strings.
Props garrett-eclipse, ramiy, SergeyBiryukov, afercia, sabernhardt, quadthemes, audrasjb.
See #47003, #43037, #42945, #15887.
Fixes #47656.
Built from https://develop.svn.wordpress.org/trunk@48059
git-svn-id: http://core.svn.wordpress.org/trunk@47826 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2020-06-16 17:35:13 +02:00
$errors -> add ( 'pass' , __ ( 'Passwords don’t match. Please enter the same password in both password fields.' ), array ( 'form-field' => 'pass1' ) );
2016-03-23 00:07:27 +01:00
}
2007-05-25 09:16:21 +02:00
2017-12-01 00:11:00 +01:00
if ( ! empty ( $pass1 ) ) {
2007-05-25 09:16:21 +02:00
$user -> user_pass = $pass1 ;
2017-12-01 00:11:00 +01:00
}
2007-05-25 09:16:21 +02:00
2017-12-01 00:11:00 +01:00
if ( ! $update && isset ( $_POST [ 'user_login' ] ) && ! validate_username ( $_POST [ 'user_login' ] ) ) {
I18N: Remove the "Error:" prefix from error messages.
For a number of years, most of the WordPress error messages have been prefixed with "Error:". However, these messages appear in a context where it's already clear an error occurred. Whether it's an error, a warning, or any other classification, that's not so relevant for users. The content of the message is the relevant part. The "Error:" prefix doesn't add great value while it does add unnecessary complexity for the message readability.
Also, revises some of these messages to improve clarity and removes HTML from translatable strings.
Props garrett-eclipse, ramiy, SergeyBiryukov, afercia, sabernhardt, quadthemes, audrasjb.
See #47003, #43037, #42945, #15887.
Fixes #47656.
Built from https://develop.svn.wordpress.org/trunk@48059
git-svn-id: http://core.svn.wordpress.org/trunk@47826 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2020-06-16 17:35:13 +02:00
$errors -> add ( 'user_login' , __ ( 'This username is invalid because it uses illegal characters. Please enter a valid username.' ) );
2017-12-01 00:11:00 +01:00
}
2007-05-25 09:16:21 +02:00
2017-12-01 00:11:00 +01:00
if ( ! $update && username_exists ( $user -> user_login ) ) {
I18N: Remove the "Error:" prefix from error messages.
For a number of years, most of the WordPress error messages have been prefixed with "Error:". However, these messages appear in a context where it's already clear an error occurred. Whether it's an error, a warning, or any other classification, that's not so relevant for users. The content of the message is the relevant part. The "Error:" prefix doesn't add great value while it does add unnecessary complexity for the message readability.
Also, revises some of these messages to improve clarity and removes HTML from translatable strings.
Props garrett-eclipse, ramiy, SergeyBiryukov, afercia, sabernhardt, quadthemes, audrasjb.
See #47003, #43037, #42945, #15887.
Fixes #47656.
Built from https://develop.svn.wordpress.org/trunk@48059
git-svn-id: http://core.svn.wordpress.org/trunk@47826 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2020-06-16 17:35:13 +02:00
$errors -> add ( 'user_login' , __ ( 'This username is already registered. Please choose another one.' ) );
2017-12-01 00:11:00 +01:00
}
2007-05-25 09:16:21 +02:00
2015-11-22 04:51:28 +01:00
/** This filter is documented in wp-includes/user.php */
2015-11-12 17:34:27 +01:00
$illegal_logins = ( array ) apply_filters ( 'illegal_user_logins' , array () );
2015-11-12 17:30:28 +01:00
2019-11-29 23:04:02 +01:00
if ( in_array ( strtolower ( $user -> user_login ), array_map ( 'strtolower' , $illegal_logins ), true ) ) {
I18N: Remove the "Error:" prefix from error messages.
For a number of years, most of the WordPress error messages have been prefixed with "Error:". However, these messages appear in a context where it's already clear an error occurred. Whether it's an error, a warning, or any other classification, that's not so relevant for users. The content of the message is the relevant part. The "Error:" prefix doesn't add great value while it does add unnecessary complexity for the message readability.
Also, revises some of these messages to improve clarity and removes HTML from translatable strings.
Props garrett-eclipse, ramiy, SergeyBiryukov, afercia, sabernhardt, quadthemes, audrasjb.
See #47003, #43037, #42945, #15887.
Fixes #47656.
Built from https://develop.svn.wordpress.org/trunk@48059
git-svn-id: http://core.svn.wordpress.org/trunk@47826 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2020-06-16 17:35:13 +02:00
$errors -> add ( 'invalid_username' , __ ( 'Sorry, that username is not allowed.' ) );
2015-10-15 07:43:26 +02:00
}
2015-08-28 05:17:21 +02:00
/* checking email address */
2009-09-14 15:57:48 +02:00
if ( empty ( $user -> user_email ) ) {
I18N: Remove the "Error:" prefix from error messages.
For a number of years, most of the WordPress error messages have been prefixed with "Error:". However, these messages appear in a context where it's already clear an error occurred. Whether it's an error, a warning, or any other classification, that's not so relevant for users. The content of the message is the relevant part. The "Error:" prefix doesn't add great value while it does add unnecessary complexity for the message readability.
Also, revises some of these messages to improve clarity and removes HTML from translatable strings.
Props garrett-eclipse, ramiy, SergeyBiryukov, afercia, sabernhardt, quadthemes, audrasjb.
See #47003, #43037, #42945, #15887.
Fixes #47656.
Built from https://develop.svn.wordpress.org/trunk@48059
git-svn-id: http://core.svn.wordpress.org/trunk@47826 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2020-06-16 17:35:13 +02:00
$errors -> add ( 'empty_email' , __ ( 'Please enter an email address.' ), array ( 'form-field' => 'email' ) );
2017-12-01 00:11:00 +01:00
} elseif ( ! is_email ( $user -> user_email ) ) {
I18N: Remove the "Error:" prefix from error messages.
For a number of years, most of the WordPress error messages have been prefixed with "Error:". However, these messages appear in a context where it's already clear an error occurred. Whether it's an error, a warning, or any other classification, that's not so relevant for users. The content of the message is the relevant part. The "Error:" prefix doesn't add great value while it does add unnecessary complexity for the message readability.
Also, revises some of these messages to improve clarity and removes HTML from translatable strings.
Props garrett-eclipse, ramiy, SergeyBiryukov, afercia, sabernhardt, quadthemes, audrasjb.
See #47003, #43037, #42945, #15887.
Fixes #47656.
Built from https://develop.svn.wordpress.org/trunk@48059
git-svn-id: http://core.svn.wordpress.org/trunk@47826 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2020-06-16 17:35:13 +02:00
$errors -> add ( 'invalid_email' , __ ( 'The email address isn’t correct.' ), array ( 'form-field' => 'email' ) );
2019-07-01 14:52:01 +02:00
} else {
$owner_id = email_exists ( $user -> user_email );
if ( $owner_id && ( ! $update || ( $owner_id != $user -> ID ) ) ) {
I18N: Remove the "Error:" prefix from error messages.
For a number of years, most of the WordPress error messages have been prefixed with "Error:". However, these messages appear in a context where it's already clear an error occurred. Whether it's an error, a warning, or any other classification, that's not so relevant for users. The content of the message is the relevant part. The "Error:" prefix doesn't add great value while it does add unnecessary complexity for the message readability.
Also, revises some of these messages to improve clarity and removes HTML from translatable strings.
Props garrett-eclipse, ramiy, SergeyBiryukov, afercia, sabernhardt, quadthemes, audrasjb.
See #47003, #43037, #42945, #15887.
Fixes #47656.
Built from https://develop.svn.wordpress.org/trunk@48059
git-svn-id: http://core.svn.wordpress.org/trunk@47826 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2020-06-16 17:35:13 +02:00
$errors -> add ( 'email_exists' , __ ( 'This email is already registered. Please choose another one.' ), array ( 'form-field' => 'email' ) );
2019-07-01 14:52:01 +02:00
}
2009-04-17 20:43:40 +02:00
}
2007-05-25 09:16:21 +02:00
2013-12-01 18:54:10 +01:00
/**
* Fires before user profile update errors are returned .
*
* @ since 2.8 . 0
*
2017-10-03 00:03:33 +02:00
* @ param WP_Error $errors WP_Error object ( passed by reference ) .
2015-08-27 19:16:21 +02:00
* @ param bool $update Whether this is a user update .
2017-10-03 00:03:33 +02:00
* @ param stdClass $user User object ( passed by reference ) .
2013-12-01 18:54:10 +01:00
*/
2013-03-07 07:00:16 +01:00
do_action_ref_array ( 'user_profile_update_errors' , array ( & $errors , $update , & $user ) );
2009-05-25 01:47:49 +02:00
2018-02-27 03:31:31 +01:00
if ( $errors -> has_errors () ) {
2007-05-25 09:16:21 +02:00
return $errors ;
2017-12-01 00:11:00 +01:00
}
2007-05-25 09:16:21 +02:00
if ( $update ) {
2012-08-10 17:36:54 +02:00
$user_id = wp_update_user ( $user );
2007-05-25 09:16:21 +02:00
} else {
2012-08-10 17:36:54 +02:00
$user_id = wp_insert_user ( $user );
2015-11-25 23:38:29 +01:00
$notify = isset ( $_POST [ 'send_user_notification' ] ) ? 'both' : 'admin' ;
2015-09-17 00:19:24 +02:00
/**
2017-11-27 00:57:55 +01:00
* Fires after a new user has been created .
*
* @ since 4.4 . 0
*
* @ param int $user_id ID of the newly created user .
* @ param string $notify Type of notification that should happen . See wp_send_new_user_notifications ()
* for more information on possible values .
*/
2015-11-25 23:38:29 +01:00
do_action ( 'edit_user_created_user' , $user_id , $notify );
2007-05-25 09:16:21 +02:00
}
return $user_id ;
}
2009-01-06 23:00:05 +01:00
/**
2009-03-18 03:43:45 +01:00
* Fetch a filtered list of user roles that the current user is
* allowed to edit .
2009-01-06 23:00:05 +01:00
*
2018-10-02 18:23:25 +02:00
* Simple function whose main purpose is to allow filtering of the
2009-01-06 23:00:05 +01:00
* list of roles in the $wp_roles object so that plugins can remove
2011-09-03 16:18:10 +02:00
* inappropriate ones depending on the situation or user making edits .
2009-01-06 23:00:05 +01:00
* Specifically because without filtering anyone with the edit_users
* capability can edit others to be administrators , even if they are
* only editors or authors . This filter allows admins to delegate
2009-03-18 03:43:45 +01:00
* user management .
2009-01-06 23:00:05 +01:00
*
2013-12-24 19:57:12 +01:00
* @ since 2.8 . 0
2009-01-06 23:00:05 +01:00
*
2018-03-25 20:10:32 +02:00
* @ return array [] Array of arrays containing role information .
2009-01-06 23:00:05 +01:00
*/
function get_editable_roles () {
2015-05-28 23:41:30 +02:00
$all_roles = wp_roles () -> roles ;
2013-12-01 18:54:10 +01:00
/**
2016-05-22 20:01:30 +02:00
* Filters the list of editable roles .
2013-12-01 18:54:10 +01:00
*
* @ since 2.8 . 0
*
2018-03-25 20:10:32 +02:00
* @ param array [] $all_roles Array of arrays containing role information .
2013-12-01 18:54:10 +01:00
*/
$editable_roles = apply_filters ( 'editable_roles' , $all_roles );
2009-03-18 03:43:45 +01:00
2009-01-06 23:00:05 +01:00
return $editable_roles ;
}
2008-10-02 03:03:26 +02:00
/**
* Retrieve user data and filter it .
*
2010-12-01 20:24:38 +01:00
* @ since 2.0 . 5
2008-10-02 03:03:26 +02:00
*
* @ param int $user_id User ID .
2013-09-02 05:25:09 +02:00
* @ return WP_User | bool WP_User object on success , false on failure .
2008-10-02 03:03:26 +02:00
*/
2007-05-25 09:16:21 +02:00
function get_user_to_edit ( $user_id ) {
2012-08-03 03:06:05 +02:00
$user = get_userdata ( $user_id );
2009-08-06 23:59:52 +02:00
2017-12-01 00:11:00 +01:00
if ( $user ) {
2013-09-02 05:25:09 +02:00
$user -> filter = 'edit' ;
2017-12-01 00:11:00 +01:00
}
2007-05-25 09:16:21 +02:00
return $user ;
}
2008-10-02 03:03:26 +02:00
/**
* Retrieve the user ' s drafts .
*
2010-12-01 20:24:38 +01:00
* @ since 2.0 . 0
2008-10-02 03:03:26 +02:00
*
2015-10-15 01:44:25 +02:00
* @ global wpdb $wpdb WordPress database abstraction object .
2015-05-28 23:41:30 +02:00
*
2008-10-02 03:03:26 +02:00
* @ param int $user_id User ID .
* @ return array
*/
2007-05-25 09:16:21 +02:00
function get_users_drafts ( $user_id ) {
global $wpdb ;
2017-12-01 00:11:00 +01:00
$query = $wpdb -> prepare ( " SELECT ID, post_title FROM $wpdb->posts WHERE post_type = 'post' AND post_status = 'draft' AND post_author = %d ORDER BY post_modified DESC " , $user_id );
2013-12-01 18:54:10 +01:00
/**
2016-05-22 20:01:30 +02:00
* Filters the user ' s drafts query string .
2013-12-01 18:54:10 +01:00
*
* @ since 2.0 . 0
*
* @ param string $query The user ' s drafts query string .
*/
$query = apply_filters ( 'get_users_drafts' , $query );
2007-05-25 09:16:21 +02:00
return $wpdb -> get_results ( $query );
}
2008-10-02 03:03:26 +02:00
/**
* Remove user and optionally reassign posts and links to another user .
*
2015-04-05 16:44:27 +02:00
* If the $reassign parameter is not assigned to a User ID , then all posts will
2016-05-23 19:28:27 +02:00
* be deleted of that user . The action { @ see 'delete_user' } that is passed the User ID
2008-10-02 03:03:26 +02:00
* being deleted will be run after the posts are either reassigned or deleted .
* The user meta will also be deleted that are for that User ID .
*
2010-12-01 20:24:38 +01:00
* @ since 2.0 . 0
2008-10-02 03:03:26 +02:00
*
2015-10-15 01:44:25 +02:00
* @ global wpdb $wpdb WordPress database abstraction object .
2015-05-28 23:41:30 +02:00
*
2008-10-02 03:03:26 +02:00
* @ param int $id User ID .
* @ param int $reassign Optional . Reassign posts and links to new User ID .
* @ return bool True when finished .
*/
2014-03-08 04:16:14 +01:00
function wp_delete_user ( $id , $reassign = null ) {
2007-05-25 09:16:21 +02:00
global $wpdb ;
2015-09-11 04:25:23 +02:00
if ( ! is_numeric ( $id ) ) {
return false ;
}
2017-12-01 00:11:00 +01:00
$id = ( int ) $id ;
2012-04-18 23:07:31 +02:00
$user = new WP_User ( $id );
2009-04-17 04:13:00 +02:00
2017-12-01 00:11:00 +01:00
if ( ! $user -> exists () ) {
2013-02-02 05:41:02 +01:00
return false ;
2017-12-01 00:11:00 +01:00
}
2013-02-02 05:41:02 +01:00
2014-03-08 04:16:14 +01:00
// Normalize $reassign to null or a user ID. 'novalue' was an older default.
if ( 'novalue' === $reassign ) {
$reassign = null ;
} elseif ( null !== $reassign ) {
$reassign = ( int ) $reassign ;
}
2013-12-01 18:54:10 +01:00
/**
* Fires immediately before a user is deleted from the database .
*
* @ since 2.0 . 0
*
2014-03-08 04:16:14 +01:00
* @ param int $id ID of the user to delete .
* @ param int | null $reassign ID of the user to reassign posts and links to .
* Default null , for no reassignment .
2013-12-01 18:54:10 +01:00
*/
2014-03-08 02:23:15 +01:00
do_action ( 'delete_user' , $id , $reassign );
2007-05-25 09:16:21 +02:00
2014-03-08 04:16:14 +01:00
if ( null === $reassign ) {
2012-05-08 19:01:50 +02:00
$post_types_to_delete = array ();
foreach ( get_post_types ( array (), 'objects' ) as $post_type ) {
if ( $post_type -> delete_with_user ) {
$post_types_to_delete [] = $post_type -> name ;
} elseif ( null === $post_type -> delete_with_user && post_type_supports ( $post_type -> name , 'author' ) ) {
$post_types_to_delete [] = $post_type -> name ;
}
}
2007-05-25 09:16:21 +02:00
2013-12-01 18:54:10 +01:00
/**
2016-05-22 20:01:30 +02:00
* Filters the list of post types to delete with a user .
2013-12-01 18:54:10 +01:00
*
* @ since 3.4 . 0
*
2018-03-25 20:10:32 +02:00
* @ param string [] $post_types_to_delete Array of post types to delete .
* @ param int $id User ID .
2013-12-01 18:54:10 +01:00
*/
2012-05-08 19:01:50 +02:00
$post_types_to_delete = apply_filters ( 'post_types_to_delete_with_user' , $post_types_to_delete , $id );
$post_types_to_delete = implode ( " ', ' " , $post_types_to_delete );
2017-12-01 00:11:00 +01:00
$post_ids = $wpdb -> get_col ( $wpdb -> prepare ( " SELECT ID FROM $wpdb->posts WHERE post_author = %d AND post_type IN (' $post_types_to_delete ') " , $id ) );
2010-01-19 20:23:11 +01:00
if ( $post_ids ) {
2017-12-01 00:11:00 +01:00
foreach ( $post_ids as $post_id ) {
2012-05-08 19:01:50 +02:00
wp_delete_post ( $post_id );
2017-12-01 00:11:00 +01:00
}
2007-05-25 09:16:21 +02:00
}
2020-01-29 01:45:18 +01:00
// Clean links.
2017-12-01 00:11:00 +01:00
$link_ids = $wpdb -> get_col ( $wpdb -> prepare ( " SELECT link_id FROM $wpdb->links WHERE link_owner = %d " , $id ) );
2009-04-17 04:13:00 +02:00
if ( $link_ids ) {
2017-12-01 00:11:00 +01:00
foreach ( $link_ids as $link_id ) {
wp_delete_link ( $link_id );
}
2009-04-17 04:13:00 +02:00
}
2007-05-25 09:16:21 +02:00
} else {
2012-09-10 21:56:08 +02:00
$post_ids = $wpdb -> get_col ( $wpdb -> prepare ( " SELECT ID FROM $wpdb->posts WHERE post_author = %d " , $id ) );
2017-12-01 00:11:00 +01:00
$wpdb -> update ( $wpdb -> posts , array ( 'post_author' => $reassign ), array ( 'post_author' => $id ) );
2012-09-10 21:56:08 +02:00
if ( ! empty ( $post_ids ) ) {
2017-12-01 00:11:00 +01:00
foreach ( $post_ids as $post_id ) {
2012-09-10 21:56:08 +02:00
clean_post_cache ( $post_id );
2017-12-01 00:11:00 +01:00
}
2012-09-10 21:56:08 +02:00
}
2017-12-01 00:11:00 +01:00
$link_ids = $wpdb -> get_col ( $wpdb -> prepare ( " SELECT link_id FROM $wpdb->links WHERE link_owner = %d " , $id ) );
$wpdb -> update ( $wpdb -> links , array ( 'link_owner' => $reassign ), array ( 'link_owner' => $id ) );
2012-09-10 21:56:08 +02:00
if ( ! empty ( $link_ids ) ) {
2017-12-01 00:11:00 +01:00
foreach ( $link_ids as $link_id ) {
2012-09-10 21:56:08 +02:00
clean_bookmark_cache ( $link_id );
2017-12-01 00:11:00 +01:00
}
2012-09-10 21:56:08 +02:00
}
2007-05-25 09:16:21 +02:00
}
2020-01-29 01:45:18 +01:00
// FINALLY, delete user.
2012-04-25 00:13:47 +02:00
if ( is_multisite () ) {
remove_user_from_blog ( $id , get_current_blog_id () );
2010-01-15 01:21:13 +01:00
} else {
2012-04-25 00:13:47 +02:00
$meta = $wpdb -> get_col ( $wpdb -> prepare ( " SELECT umeta_id FROM $wpdb->usermeta WHERE user_id = %d " , $id ) );
2017-12-01 00:11:00 +01:00
foreach ( $meta as $mid ) {
2012-04-25 00:13:47 +02:00
delete_metadata_by_mid ( 'user' , $mid );
2017-12-01 00:11:00 +01:00
}
2012-04-25 00:13:47 +02:00
$wpdb -> delete ( $wpdb -> users , array ( 'ID' => $id ) );
2010-01-15 01:21:13 +01:00
}
2007-05-25 09:16:21 +02:00
2012-04-18 23:24:53 +02:00
clean_user_cache ( $user );
2013-12-01 18:54:10 +01:00
/**
* Fires immediately after a user is deleted from the database .
*
* @ since 2.9 . 0
*
2014-03-08 04:16:14 +01:00
* @ param int $id ID of the deleted user .
* @ param int | null $reassign ID of the user to reassign posts and links to .
* Default null , for no reassignment .
2013-12-01 18:54:10 +01:00
*/
2014-03-08 02:23:15 +01:00
do_action ( 'deleted_user' , $id , $reassign );
2007-05-25 09:16:21 +02:00
return true ;
}
2008-10-02 03:03:26 +02:00
/**
* Remove all capabilities from user .
*
2010-12-01 20:24:38 +01:00
* @ since 2.1 . 0
2008-10-02 03:03:26 +02:00
*
* @ param int $id User ID .
*/
2017-12-01 00:11:00 +01:00
function wp_revoke_user ( $id ) {
2007-05-25 09:16:21 +02:00
$id = ( int ) $id ;
2017-12-01 00:11:00 +01:00
$user = new WP_User ( $id );
2007-05-25 09:16:21 +02:00
$user -> remove_all_caps ();
}
2010-12-01 20:24:38 +01:00
/**
* @ since 2.8 . 0
2015-05-28 23:41:30 +02:00
*
* @ global int $user_ID
*
* @ param false $errors Deprecated .
*/
2017-12-01 00:11:00 +01:00
function default_password_nag_handler ( $errors = false ) {
2009-05-06 18:19:40 +02:00
global $user_ID ;
2014-07-17 11:14:16 +02:00
// Short-circuit it.
2017-12-01 00:11:00 +01:00
if ( ! get_user_option ( 'default_password_nag' ) ) {
2009-05-06 18:19:40 +02:00
return ;
2017-12-01 00:11:00 +01:00
}
2009-05-06 18:19:40 +02:00
2020-01-29 01:45:18 +01:00
// get_user_setting() = JS-saved UI setting. Else no-js-fallback code.
2020-05-16 20:42:12 +02:00
if ( 'hide' === get_user_setting ( 'default_password_nag' )
|| isset ( $_GET [ 'default_password_nag' ] ) && '0' == $_GET [ 'default_password_nag' ]
) {
2017-12-01 00:11:00 +01:00
delete_user_setting ( 'default_password_nag' );
update_user_option ( $user_ID , 'default_password_nag' , false , true );
2009-05-03 19:06:29 +02:00
}
}
2009-05-06 18:19:40 +02:00
2010-12-01 20:24:38 +01:00
/**
* @ since 2.8 . 0
2015-05-29 22:17:26 +02:00
*
* @ param int $user_ID
* @ param object $old_data
2010-12-01 20:24:38 +01:00
*/
2017-12-01 00:11:00 +01:00
function default_password_nag_edit_user ( $user_ID , $old_data ) {
2014-07-17 11:14:16 +02:00
// Short-circuit it.
2017-12-01 00:11:00 +01:00
if ( ! get_user_option ( 'default_password_nag' , $user_ID ) ) {
2009-05-06 18:19:40 +02:00
return ;
2017-12-01 00:11:00 +01:00
}
2009-05-06 18:19:40 +02:00
2017-12-01 00:11:00 +01:00
$new_data = get_userdata ( $user_ID );
2009-05-06 18:19:40 +02:00
2014-07-17 11:14:16 +02:00
// Remove the nag if the password has been changed.
if ( $new_data -> user_pass != $old_data -> user_pass ) {
2017-12-01 00:11:00 +01:00
delete_user_setting ( 'default_password_nag' );
update_user_option ( $user_ID , 'default_password_nag' , false , true );
2009-05-06 18:19:40 +02:00
}
}
2010-12-01 20:24:38 +01:00
/**
* @ since 2.8 . 0
2015-05-28 23:41:30 +02:00
*
* @ global string $pagenow
2010-12-01 20:24:38 +01:00
*/
2009-05-03 19:06:29 +02:00
function default_password_nag () {
2010-09-13 18:49:04 +02:00
global $pagenow ;
2014-07-17 11:14:16 +02:00
// Short-circuit it.
2020-05-16 20:42:12 +02:00
if ( 'profile.php' === $pagenow || ! get_user_option ( 'default_password_nag' ) ) {
2009-05-03 19:06:29 +02:00
return ;
2017-12-01 00:11:00 +01:00
}
2009-05-03 19:06:29 +02:00
2010-04-20 19:15:07 +02:00
echo '<div class="error default-password-nag">' ;
echo '<p>' ;
2017-12-01 00:11:00 +01:00
echo '<strong>' . __ ( 'Notice:' ) . '</strong> ' ;
_e ( 'You’re using the auto-generated password for your account. Would you like to change it?' );
2010-04-27 23:57:18 +02:00
echo '</p><p>' ;
2017-12-01 00:11:00 +01:00
printf ( '<a href="%s">' . __ ( 'Yes, take me to my profile page' ) . '</a> | ' , get_edit_profile_url () . '#password' );
printf ( '<a href="%s" id="default-password-nag-no">' . __ ( 'No thanks, do not remind me again' ) . '</a>' , '?default_password_nag=0' );
2009-05-03 19:06:29 +02:00
echo '</p></div>' ;
}
2015-09-10 18:47:24 +02:00
/**
* @ since 3.5 . 0
* @ access private
*/
2017-12-01 00:11:00 +01:00
function delete_users_add_js () {
?>
2015-09-10 18:47:24 +02:00
< script >
jQuery ( document ) . ready ( function ( $ ) {
var submit = $ ( '#submit' ) . prop ( 'disabled' , true );
$ ( 'input[name="delete_option"]' ) . one ( 'change' , function () {
submit . prop ( 'disabled' , false );
});
$ ( '#reassign_user' ) . focus ( function () {
$ ( '#delete_option1' ) . prop ( 'checked' , true ) . trigger ( 'change' );
});
});
</ script >
2018-08-17 03:51:36 +02:00
< ? php
2015-09-10 23:33:33 +02:00
}
/**
* Optional SSL preference that can be turned on by hooking to the 'personal_options' action .
*
2016-05-23 19:28:27 +02:00
* See the { @ see 'personal_options' } action .
*
2015-09-10 23:33:33 +02:00
* @ since 2.7 . 0
*
2019-12-07 14:23:01 +01:00
* @ param WP_User $user User data object .
2015-09-10 23:33:33 +02:00
*/
2017-12-01 00:11:00 +01:00
function use_ssl_preference ( $user ) {
2018-08-17 03:51:36 +02:00
?>
2015-09-10 23:33:33 +02:00
< tr class = " user-use-ssl-wrap " >
2017-12-01 00:11:00 +01:00
< th scope = " row " >< ? php _e ( 'Use https' ); ?> </th>
< td >< label for = " use_ssl " >< input name = " use_ssl " type = " checkbox " id = " use_ssl " value = " 1 " < ? php checked ( '1' , $user -> use_ssl ); ?> /> <?php _e( 'Always use https when visiting the admin' ); ?></label></td>
2015-09-10 23:33:33 +02:00
</ tr >
2018-08-17 03:51:36 +02:00
< ? php
2015-09-10 23:33:33 +02:00
}
/**
I18N: Improve translator comments.
* Add missing translator comments.
* Fix placement of some translator comments. Translator comments should be on the line directly above the line containing the translation function call for optimal compatibility with various `.pot` file generation tools. The CS auto-fixing, which changed some inconsistent function calls to multi-line function calls, is part of the reason why this was no longer the case for a select group of translator comments.
Includes minor code layout fixes.
Polyglots, rejoice! All WordPress core files now have translator comments for all strings with placeholders!
Props jrf, subrataemfluence, GaryJ, webdados, Dency, swissspidy, alvarogois, marcomartins, mihaiiceyro, vladwtz, niq1982, flipkeijzer, michielatyoast, chandrapatel, thrijith, joshuanoyce, FesoVik, tessak22, bhaktirajdev, cleancoded, dhavalkasvala, garrett-eclipse, bibliofille, socalchristina, priyankkpatel, 5hel2l2y, adamsilverstein, JeffPaul, pierlo, SergeyBiryukov.
Fixes #44360.
Built from https://develop.svn.wordpress.org/trunk@45926
git-svn-id: http://core.svn.wordpress.org/trunk@45737 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2019-09-01 19:13:59 +02:00
* @ since MU ( 3.0 . 0 )
*
2015-09-10 23:33:33 +02:00
* @ param string $text
* @ return string
*/
function admin_created_user_email ( $text ) {
$roles = get_editable_roles ();
2017-12-01 00:11:00 +01:00
$role = $roles [ $_REQUEST [ 'role' ] ];
I18N: Improve translator comments.
* Add missing translator comments.
* Fix placement of some translator comments. Translator comments should be on the line directly above the line containing the translation function call for optimal compatibility with various `.pot` file generation tools. The CS auto-fixing, which changed some inconsistent function calls to multi-line function calls, is part of the reason why this was no longer the case for a select group of translator comments.
Includes minor code layout fixes.
Polyglots, rejoice! All WordPress core files now have translator comments for all strings with placeholders!
Props jrf, subrataemfluence, GaryJ, webdados, Dency, swissspidy, alvarogois, marcomartins, mihaiiceyro, vladwtz, niq1982, flipkeijzer, michielatyoast, chandrapatel, thrijith, joshuanoyce, FesoVik, tessak22, bhaktirajdev, cleancoded, dhavalkasvala, garrett-eclipse, bibliofille, socalchristina, priyankkpatel, 5hel2l2y, adamsilverstein, JeffPaul, pierlo, SergeyBiryukov.
Fixes #44360.
Built from https://develop.svn.wordpress.org/trunk@45926
git-svn-id: http://core.svn.wordpress.org/trunk@45737 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2019-09-01 19:13:59 +02:00
2017-12-01 00:11:00 +01:00
return sprintf (
2019-09-03 02:41:05 +02:00
/* translators: 1: Site title, 2: Site URL, 3: User role. */
2017-12-01 00:11:00 +01:00
__ (
' Hi ,
2015-09-10 23:33:33 +02:00
You\ ' ve been invited to join \ ' % 1 $s\ ' at
% 2 $s with the role of % 3 $s .
If you do not want to join this site please ignore
this email . This invitation will expire in a few days .
Please click the following link to activate your user account :
2017-12-01 00:11:00 +01:00
%% s '
2018-08-17 03:51:36 +02:00
),
wp_specialchars_decode ( get_bloginfo ( 'name' ), ENT_QUOTES ),
home_url (),
wp_specialchars_decode ( translate_user_role ( $role [ 'name' ] ) )
2017-12-01 00:11:00 +01:00
);
2015-09-25 06:44:25 +02:00
}