Edit File by line

Deprecated: str_replace(): Passing null to parameter #2 ($replace) of type array|string is deprecated in /home/sportsfever/public_html/filemanger/function.php on line 93

Warning: Undefined array key "page_file_edit_line" in /home/sportsfever/public_html/filemanger/edit_text_line.php on line 32
/home/sportsfe.../httpdocs/clone/wp-inclu...
File: user.php
* @since 3.1.0
[3000] Fix | Delete
*
[3001] Fix | Delete
* @global PasswordHash $wp_hasher Portable PHP password hashing framework instance.
[3002] Fix | Delete
*
[3003] Fix | Delete
* @param string $key Hash to validate sending user's password.
[3004] Fix | Delete
* @param string $login The user login.
[3005] Fix | Delete
* @return WP_User|WP_Error WP_User object on success, WP_Error object for invalid or expired keys.
[3006] Fix | Delete
*/
[3007] Fix | Delete
function check_password_reset_key( $key, $login ) {
[3008] Fix | Delete
global $wp_hasher;
[3009] Fix | Delete
[3010] Fix | Delete
$key = preg_replace( '/[^a-z0-9]/i', '', $key );
[3011] Fix | Delete
[3012] Fix | Delete
if ( empty( $key ) || ! is_string( $key ) ) {
[3013] Fix | Delete
return new WP_Error( 'invalid_key', __( 'Invalid key.' ) );
[3014] Fix | Delete
}
[3015] Fix | Delete
[3016] Fix | Delete
if ( empty( $login ) || ! is_string( $login ) ) {
[3017] Fix | Delete
return new WP_Error( 'invalid_key', __( 'Invalid key.' ) );
[3018] Fix | Delete
}
[3019] Fix | Delete
[3020] Fix | Delete
$user = get_user_by( 'login', $login );
[3021] Fix | Delete
[3022] Fix | Delete
if ( ! $user ) {
[3023] Fix | Delete
return new WP_Error( 'invalid_key', __( 'Invalid key.' ) );
[3024] Fix | Delete
}
[3025] Fix | Delete
[3026] Fix | Delete
if ( empty( $wp_hasher ) ) {
[3027] Fix | Delete
require_once ABSPATH . WPINC . '/class-phpass.php';
[3028] Fix | Delete
$wp_hasher = new PasswordHash( 8, true );
[3029] Fix | Delete
}
[3030] Fix | Delete
[3031] Fix | Delete
/**
[3032] Fix | Delete
* Filters the expiration time of password reset keys.
[3033] Fix | Delete
*
[3034] Fix | Delete
* @since 4.3.0
[3035] Fix | Delete
*
[3036] Fix | Delete
* @param int $expiration The expiration time in seconds.
[3037] Fix | Delete
*/
[3038] Fix | Delete
$expiration_duration = apply_filters( 'password_reset_expiration', DAY_IN_SECONDS );
[3039] Fix | Delete
[3040] Fix | Delete
if ( str_contains( $user->user_activation_key, ':' ) ) {
[3041] Fix | Delete
list( $pass_request_time, $pass_key ) = explode( ':', $user->user_activation_key, 2 );
[3042] Fix | Delete
$expiration_time = $pass_request_time + $expiration_duration;
[3043] Fix | Delete
} else {
[3044] Fix | Delete
$pass_key = $user->user_activation_key;
[3045] Fix | Delete
$expiration_time = false;
[3046] Fix | Delete
}
[3047] Fix | Delete
[3048] Fix | Delete
if ( ! $pass_key ) {
[3049] Fix | Delete
return new WP_Error( 'invalid_key', __( 'Invalid key.' ) );
[3050] Fix | Delete
}
[3051] Fix | Delete
[3052] Fix | Delete
$hash_is_correct = $wp_hasher->CheckPassword( $key, $pass_key );
[3053] Fix | Delete
[3054] Fix | Delete
if ( $hash_is_correct && $expiration_time && time() < $expiration_time ) {
[3055] Fix | Delete
return $user;
[3056] Fix | Delete
} elseif ( $hash_is_correct && $expiration_time ) {
[3057] Fix | Delete
// Key has an expiration time that's passed.
[3058] Fix | Delete
return new WP_Error( 'expired_key', __( 'Invalid key.' ) );
[3059] Fix | Delete
}
[3060] Fix | Delete
[3061] Fix | Delete
if ( hash_equals( $user->user_activation_key, $key ) || ( $hash_is_correct && ! $expiration_time ) ) {
[3062] Fix | Delete
$return = new WP_Error( 'expired_key', __( 'Invalid key.' ) );
[3063] Fix | Delete
$user_id = $user->ID;
[3064] Fix | Delete
[3065] Fix | Delete
/**
[3066] Fix | Delete
* Filters the return value of check_password_reset_key() when an
[3067] Fix | Delete
* old-style key is used.
[3068] Fix | Delete
*
[3069] Fix | Delete
* @since 3.7.0 Previously plain-text keys were stored in the database.
[3070] Fix | Delete
* @since 4.3.0 Previously key hashes were stored without an expiration time.
[3071] Fix | Delete
*
[3072] Fix | Delete
* @param WP_Error $return A WP_Error object denoting an expired key.
[3073] Fix | Delete
* Return a WP_User object to validate the key.
[3074] Fix | Delete
* @param int $user_id The matched user ID.
[3075] Fix | Delete
*/
[3076] Fix | Delete
return apply_filters( 'password_reset_key_expired', $return, $user_id );
[3077] Fix | Delete
}
[3078] Fix | Delete
[3079] Fix | Delete
return new WP_Error( 'invalid_key', __( 'Invalid key.' ) );
[3080] Fix | Delete
}
[3081] Fix | Delete
[3082] Fix | Delete
/**
[3083] Fix | Delete
* Handles sending a password retrieval email to a user.
[3084] Fix | Delete
*
[3085] Fix | Delete
* @since 2.5.0
[3086] Fix | Delete
* @since 5.7.0 Added `$user_login` parameter.
[3087] Fix | Delete
*
[3088] Fix | Delete
* @global wpdb $wpdb WordPress database abstraction object.
[3089] Fix | Delete
* @global PasswordHash $wp_hasher Portable PHP password hashing framework instance.
[3090] Fix | Delete
*
[3091] Fix | Delete
* @param string $user_login Optional. Username to send a password retrieval email for.
[3092] Fix | Delete
* Defaults to `$_POST['user_login']` if not set.
[3093] Fix | Delete
* @return true|WP_Error True when finished, WP_Error object on error.
[3094] Fix | Delete
*/
[3095] Fix | Delete
function retrieve_password( $user_login = null ) {
[3096] Fix | Delete
$errors = new WP_Error();
[3097] Fix | Delete
$user_data = false;
[3098] Fix | Delete
[3099] Fix | Delete
// Use the passed $user_login if available, otherwise use $_POST['user_login'].
[3100] Fix | Delete
if ( ! $user_login && ! empty( $_POST['user_login'] ) ) {
[3101] Fix | Delete
$user_login = $_POST['user_login'];
[3102] Fix | Delete
}
[3103] Fix | Delete
[3104] Fix | Delete
$user_login = trim( wp_unslash( $user_login ) );
[3105] Fix | Delete
[3106] Fix | Delete
if ( empty( $user_login ) ) {
[3107] Fix | Delete
$errors->add( 'empty_username', __( '<strong>Error:</strong> Please enter a username or email address.' ) );
[3108] Fix | Delete
} elseif ( strpos( $user_login, '@' ) ) {
[3109] Fix | Delete
$user_data = get_user_by( 'email', $user_login );
[3110] Fix | Delete
[3111] Fix | Delete
if ( empty( $user_data ) ) {
[3112] Fix | Delete
$user_data = get_user_by( 'login', $user_login );
[3113] Fix | Delete
}
[3114] Fix | Delete
[3115] Fix | Delete
if ( empty( $user_data ) ) {
[3116] Fix | Delete
$errors->add( 'invalid_email', __( '<strong>Error:</strong> There is no account with that username or email address.' ) );
[3117] Fix | Delete
}
[3118] Fix | Delete
} else {
[3119] Fix | Delete
$user_data = get_user_by( 'login', $user_login );
[3120] Fix | Delete
}
[3121] Fix | Delete
[3122] Fix | Delete
/**
[3123] Fix | Delete
* Filters the user data during a password reset request.
[3124] Fix | Delete
*
[3125] Fix | Delete
* Allows, for example, custom validation using data other than username or email address.
[3126] Fix | Delete
*
[3127] Fix | Delete
* @since 5.7.0
[3128] Fix | Delete
*
[3129] Fix | Delete
* @param WP_User|false $user_data WP_User object if found, false if the user does not exist.
[3130] Fix | Delete
* @param WP_Error $errors A WP_Error object containing any errors generated
[3131] Fix | Delete
* by using invalid credentials.
[3132] Fix | Delete
*/
[3133] Fix | Delete
$user_data = apply_filters( 'lostpassword_user_data', $user_data, $errors );
[3134] Fix | Delete
[3135] Fix | Delete
/**
[3136] Fix | Delete
* Fires before errors are returned from a password reset request.
[3137] Fix | Delete
*
[3138] Fix | Delete
* @since 2.1.0
[3139] Fix | Delete
* @since 4.4.0 Added the `$errors` parameter.
[3140] Fix | Delete
* @since 5.4.0 Added the `$user_data` parameter.
[3141] Fix | Delete
*
[3142] Fix | Delete
* @param WP_Error $errors A WP_Error object containing any errors generated
[3143] Fix | Delete
* by using invalid credentials.
[3144] Fix | Delete
* @param WP_User|false $user_data WP_User object if found, false if the user does not exist.
[3145] Fix | Delete
*/
[3146] Fix | Delete
do_action( 'lostpassword_post', $errors, $user_data );
[3147] Fix | Delete
[3148] Fix | Delete
/**
[3149] Fix | Delete
* Filters the errors encountered on a password reset request.
[3150] Fix | Delete
*
[3151] Fix | Delete
* The filtered WP_Error object may, for example, contain errors for an invalid
[3152] Fix | Delete
* username or email address. A WP_Error object should always be returned,
[3153] Fix | Delete
* but may or may not contain errors.
[3154] Fix | Delete
*
[3155] Fix | Delete
* If any errors are present in $errors, this will abort the password reset request.
[3156] Fix | Delete
*
[3157] Fix | Delete
* @since 5.5.0
[3158] Fix | Delete
*
[3159] Fix | Delete
* @param WP_Error $errors A WP_Error object containing any errors generated
[3160] Fix | Delete
* by using invalid credentials.
[3161] Fix | Delete
* @param WP_User|false $user_data WP_User object if found, false if the user does not exist.
[3162] Fix | Delete
*/
[3163] Fix | Delete
$errors = apply_filters( 'lostpassword_errors', $errors, $user_data );
[3164] Fix | Delete
[3165] Fix | Delete
if ( $errors->has_errors() ) {
[3166] Fix | Delete
return $errors;
[3167] Fix | Delete
}
[3168] Fix | Delete
[3169] Fix | Delete
if ( ! $user_data ) {
[3170] Fix | Delete
$errors->add( 'invalidcombo', __( '<strong>Error:</strong> There is no account with that username or email address.' ) );
[3171] Fix | Delete
return $errors;
[3172] Fix | Delete
}
[3173] Fix | Delete
[3174] Fix | Delete
/**
[3175] Fix | Delete
* Filters whether to send the retrieve password email.
[3176] Fix | Delete
*
[3177] Fix | Delete
* Return false to disable sending the email.
[3178] Fix | Delete
*
[3179] Fix | Delete
* @since 6.0.0
[3180] Fix | Delete
*
[3181] Fix | Delete
* @param bool $send Whether to send the email.
[3182] Fix | Delete
* @param string $user_login The username for the user.
[3183] Fix | Delete
* @param WP_User $user_data WP_User object.
[3184] Fix | Delete
*/
[3185] Fix | Delete
if ( ! apply_filters( 'send_retrieve_password_email', true, $user_login, $user_data ) ) {
[3186] Fix | Delete
return true;
[3187] Fix | Delete
}
[3188] Fix | Delete
[3189] Fix | Delete
// Redefining user_login ensures we return the right case in the email.
[3190] Fix | Delete
$user_login = $user_data->user_login;
[3191] Fix | Delete
$user_email = $user_data->user_email;
[3192] Fix | Delete
$key = get_password_reset_key( $user_data );
[3193] Fix | Delete
[3194] Fix | Delete
if ( is_wp_error( $key ) ) {
[3195] Fix | Delete
return $key;
[3196] Fix | Delete
}
[3197] Fix | Delete
[3198] Fix | Delete
// Localize password reset message content for user.
[3199] Fix | Delete
$locale = get_user_locale( $user_data );
[3200] Fix | Delete
[3201] Fix | Delete
$switched_locale = switch_to_user_locale( $user_data->ID );
[3202] Fix | Delete
[3203] Fix | Delete
if ( is_multisite() ) {
[3204] Fix | Delete
$site_name = get_network()->site_name;
[3205] Fix | Delete
} else {
[3206] Fix | Delete
/*
[3207] Fix | Delete
* The blogname option is escaped with esc_html on the way into the database
[3208] Fix | Delete
* in sanitize_option. We want to reverse this for the plain text arena of emails.
[3209] Fix | Delete
*/
[3210] Fix | Delete
$site_name = wp_specialchars_decode( get_option( 'blogname' ), ENT_QUOTES );
[3211] Fix | Delete
}
[3212] Fix | Delete
[3213] Fix | Delete
$message = __( 'Someone has requested a password reset for the following account:' ) . "\r\n\r\n";
[3214] Fix | Delete
/* translators: %s: Site name. */
[3215] Fix | Delete
$message .= sprintf( __( 'Site Name: %s' ), $site_name ) . "\r\n\r\n";
[3216] Fix | Delete
/* translators: %s: User login. */
[3217] Fix | Delete
$message .= sprintf( __( 'Username: %s' ), $user_login ) . "\r\n\r\n";
[3218] Fix | Delete
$message .= __( 'If this was a mistake, ignore this email and nothing will happen.' ) . "\r\n\r\n";
[3219] Fix | Delete
$message .= __( 'To reset your password, visit the following address:' ) . "\r\n\r\n";
[3220] Fix | Delete
$message .= network_site_url( "wp-login.php?action=rp&key=$key&login=" . rawurlencode( $user_login ), 'login' ) . '&wp_lang=' . $locale . "\r\n\r\n";
[3221] Fix | Delete
[3222] Fix | Delete
if ( ! is_user_logged_in() ) {
[3223] Fix | Delete
$requester_ip = $_SERVER['REMOTE_ADDR'];
[3224] Fix | Delete
if ( $requester_ip ) {
[3225] Fix | Delete
$message .= sprintf(
[3226] Fix | Delete
/* translators: %s: IP address of password reset requester. */
[3227] Fix | Delete
__( 'This password reset request originated from the IP address %s.' ),
[3228] Fix | Delete
$requester_ip
[3229] Fix | Delete
) . "\r\n";
[3230] Fix | Delete
}
[3231] Fix | Delete
}
[3232] Fix | Delete
[3233] Fix | Delete
/* translators: Password reset notification email subject. %s: Site title. */
[3234] Fix | Delete
$title = sprintf( __( '[%s] Password Reset' ), $site_name );
[3235] Fix | Delete
[3236] Fix | Delete
/**
[3237] Fix | Delete
* Filters the subject of the password reset email.
[3238] Fix | Delete
*
[3239] Fix | Delete
* @since 2.8.0
[3240] Fix | Delete
* @since 4.4.0 Added the `$user_login` and `$user_data` parameters.
[3241] Fix | Delete
*
[3242] Fix | Delete
* @param string $title Email subject.
[3243] Fix | Delete
* @param string $user_login The username for the user.
[3244] Fix | Delete
* @param WP_User $user_data WP_User object.
[3245] Fix | Delete
*/
[3246] Fix | Delete
$title = apply_filters( 'retrieve_password_title', $title, $user_login, $user_data );
[3247] Fix | Delete
[3248] Fix | Delete
/**
[3249] Fix | Delete
* Filters the message body of the password reset mail.
[3250] Fix | Delete
*
[3251] Fix | Delete
* If the filtered message is empty, the password reset email will not be sent.
[3252] Fix | Delete
*
[3253] Fix | Delete
* @since 2.8.0
[3254] Fix | Delete
* @since 4.1.0 Added `$user_login` and `$user_data` parameters.
[3255] Fix | Delete
*
[3256] Fix | Delete
* @param string $message Email message.
[3257] Fix | Delete
* @param string $key The activation key.
[3258] Fix | Delete
* @param string $user_login The username for the user.
[3259] Fix | Delete
* @param WP_User $user_data WP_User object.
[3260] Fix | Delete
*/
[3261] Fix | Delete
$message = apply_filters( 'retrieve_password_message', $message, $key, $user_login, $user_data );
[3262] Fix | Delete
[3263] Fix | Delete
// Short-circuit on falsey $message value for backwards compatibility.
[3264] Fix | Delete
if ( ! $message ) {
[3265] Fix | Delete
return true;
[3266] Fix | Delete
}
[3267] Fix | Delete
[3268] Fix | Delete
/*
[3269] Fix | Delete
* Wrap the single notification email arguments in an array
[3270] Fix | Delete
* to pass them to the retrieve_password_notification_email filter.
[3271] Fix | Delete
*/
[3272] Fix | Delete
$defaults = array(
[3273] Fix | Delete
'to' => $user_email,
[3274] Fix | Delete
'subject' => $title,
[3275] Fix | Delete
'message' => $message,
[3276] Fix | Delete
'headers' => '',
[3277] Fix | Delete
);
[3278] Fix | Delete
[3279] Fix | Delete
/**
[3280] Fix | Delete
* Filters the contents of the reset password notification email sent to the user.
[3281] Fix | Delete
*
[3282] Fix | Delete
* @since 6.0.0
[3283] Fix | Delete
*
[3284] Fix | Delete
* @param array $defaults {
[3285] Fix | Delete
* The default notification email arguments. Used to build wp_mail().
[3286] Fix | Delete
*
[3287] Fix | Delete
* @type string $to The intended recipient - user email address.
[3288] Fix | Delete
* @type string $subject The subject of the email.
[3289] Fix | Delete
* @type string $message The body of the email.
[3290] Fix | Delete
* @type string $headers The headers of the email.
[3291] Fix | Delete
* }
[3292] Fix | Delete
* @param string $key The activation key.
[3293] Fix | Delete
* @param string $user_login The username for the user.
[3294] Fix | Delete
* @param WP_User $user_data WP_User object.
[3295] Fix | Delete
*/
[3296] Fix | Delete
$notification_email = apply_filters( 'retrieve_password_notification_email', $defaults, $key, $user_login, $user_data );
[3297] Fix | Delete
[3298] Fix | Delete
if ( $switched_locale ) {
[3299] Fix | Delete
restore_previous_locale();
[3300] Fix | Delete
}
[3301] Fix | Delete
[3302] Fix | Delete
if ( is_array( $notification_email ) ) {
[3303] Fix | Delete
// Force key order and merge defaults in case any value is missing in the filtered array.
[3304] Fix | Delete
$notification_email = array_merge( $defaults, $notification_email );
[3305] Fix | Delete
} else {
[3306] Fix | Delete
$notification_email = $defaults;
[3307] Fix | Delete
}
[3308] Fix | Delete
[3309] Fix | Delete
list( $to, $subject, $message, $headers ) = array_values( $notification_email );
[3310] Fix | Delete
[3311] Fix | Delete
$subject = wp_specialchars_decode( $subject );
[3312] Fix | Delete
[3313] Fix | Delete
if ( ! wp_mail( $to, $subject, $message, $headers ) ) {
[3314] Fix | Delete
$errors->add(
[3315] Fix | Delete
'retrieve_password_email_failure',
[3316] Fix | Delete
sprintf(
[3317] Fix | Delete
/* translators: %s: Documentation URL. */
[3318] Fix | Delete
__( '<strong>Error:</strong> The email could not be sent. Your site may not be correctly configured to send emails. <a href="%s">Get support for resetting your password</a>.' ),
[3319] Fix | Delete
esc_url( __( 'https://wordpress.org/documentation/article/reset-your-password/' ) )
[3320] Fix | Delete
)
[3321] Fix | Delete
);
[3322] Fix | Delete
return $errors;
[3323] Fix | Delete
}
[3324] Fix | Delete
[3325] Fix | Delete
return true;
[3326] Fix | Delete
}
[3327] Fix | Delete
[3328] Fix | Delete
/**
[3329] Fix | Delete
* Handles resetting the user's password.
[3330] Fix | Delete
*
[3331] Fix | Delete
* @since 2.5.0
[3332] Fix | Delete
*
[3333] Fix | Delete
* @param WP_User $user The user
[3334] Fix | Delete
* @param string $new_pass New password for the user in plaintext
[3335] Fix | Delete
*/
[3336] Fix | Delete
function reset_password( $user, $new_pass ) {
[3337] Fix | Delete
/**
[3338] Fix | Delete
* Fires before the user's password is reset.
[3339] Fix | Delete
*
[3340] Fix | Delete
* @since 1.5.0
[3341] Fix | Delete
*
[3342] Fix | Delete
* @param WP_User $user The user.
[3343] Fix | Delete
* @param string $new_pass New user password.
[3344] Fix | Delete
*/
[3345] Fix | Delete
do_action( 'password_reset', $user, $new_pass );
[3346] Fix | Delete
[3347] Fix | Delete
wp_set_password( $new_pass, $user->ID );
[3348] Fix | Delete
update_user_meta( $user->ID, 'default_password_nag', false );
[3349] Fix | Delete
[3350] Fix | Delete
/**
[3351] Fix | Delete
* Fires after the user's password is reset.
[3352] Fix | Delete
*
[3353] Fix | Delete
* @since 4.4.0
[3354] Fix | Delete
*
[3355] Fix | Delete
* @param WP_User $user The user.
[3356] Fix | Delete
* @param string $new_pass New user password.
[3357] Fix | Delete
*/
[3358] Fix | Delete
do_action( 'after_password_reset', $user, $new_pass );
[3359] Fix | Delete
}
[3360] Fix | Delete
[3361] Fix | Delete
/**
[3362] Fix | Delete
* Handles registering a new user.
[3363] Fix | Delete
*
[3364] Fix | Delete
* @since 2.5.0
[3365] Fix | Delete
*
[3366] Fix | Delete
* @param string $user_login User's username for logging in
[3367] Fix | Delete
* @param string $user_email User's email address to send password and add
[3368] Fix | Delete
* @return int|WP_Error Either user's ID or error on failure.
[3369] Fix | Delete
*/
[3370] Fix | Delete
function register_new_user( $user_login, $user_email ) {
[3371] Fix | Delete
$errors = new WP_Error();
[3372] Fix | Delete
[3373] Fix | Delete
$sanitized_user_login = sanitize_user( $user_login );
[3374] Fix | Delete
/**
[3375] Fix | Delete
* Filters the email address of a user being registered.
[3376] Fix | Delete
*
[3377] Fix | Delete
* @since 2.1.0
[3378] Fix | Delete
*
[3379] Fix | Delete
* @param string $user_email The email address of the new user.
[3380] Fix | Delete
*/
[3381] Fix | Delete
$user_email = apply_filters( 'user_registration_email', $user_email );
[3382] Fix | Delete
[3383] Fix | Delete
// Check the username.
[3384] Fix | Delete
if ( '' === $sanitized_user_login ) {
[3385] Fix | Delete
$errors->add( 'empty_username', __( '<strong>Error:</strong> Please enter a username.' ) );
[3386] Fix | Delete
} elseif ( ! validate_username( $user_login ) ) {
[3387] Fix | Delete
$errors->add( 'invalid_username', __( '<strong>Error:</strong> This username is invalid because it uses illegal characters. Please enter a valid username.' ) );
[3388] Fix | Delete
$sanitized_user_login = '';
[3389] Fix | Delete
} elseif ( username_exists( $sanitized_user_login ) ) {
[3390] Fix | Delete
$errors->add( 'username_exists', __( '<strong>Error:</strong> This username is already registered. Please choose another one.' ) );
[3391] Fix | Delete
} else {
[3392] Fix | Delete
/** This filter is documented in wp-includes/user.php */
[3393] Fix | Delete
$illegal_user_logins = (array) apply_filters( 'illegal_user_logins', array() );
[3394] Fix | Delete
if ( in_array( strtolower( $sanitized_user_login ), array_map( 'strtolower', $illegal_user_logins ), true ) ) {
[3395] Fix | Delete
$errors->add( 'invalid_username', __( '<strong>Error:</strong> Sorry, that username is not allowed.' ) );
[3396] Fix | Delete
}
[3397] Fix | Delete
}
[3398] Fix | Delete
[3399] Fix | Delete
// Check the email address.
[3400] Fix | Delete
if ( '' === $user_email ) {
[3401] Fix | Delete
$errors->add( 'empty_email', __( '<strong>Error:</strong> Please type your email address.' ) );
[3402] Fix | Delete
} elseif ( ! is_email( $user_email ) ) {
[3403] Fix | Delete
$errors->add( 'invalid_email', __( '<strong>Error:</strong> The email address is not correct.' ) );
[3404] Fix | Delete
$user_email = '';
[3405] Fix | Delete
} elseif ( email_exists( $user_email ) ) {
[3406] Fix | Delete
$errors->add(
[3407] Fix | Delete
'email_exists',
[3408] Fix | Delete
sprintf(
[3409] Fix | Delete
/* translators: %s: Link to the login page. */
[3410] Fix | Delete
__( '<strong>Error:</strong> This email address is already registered. <a href="%s">Log in</a> with this address or choose another one.' ),
[3411] Fix | Delete
wp_login_url()
[3412] Fix | Delete
)
[3413] Fix | Delete
);
[3414] Fix | Delete
}
[3415] Fix | Delete
[3416] Fix | Delete
/**
[3417] Fix | Delete
* Fires when submitting registration form data, before the user is created.
[3418] Fix | Delete
*
[3419] Fix | Delete
* @since 2.1.0
[3420] Fix | Delete
*
[3421] Fix | Delete
* @param string $sanitized_user_login The submitted username after being sanitized.
[3422] Fix | Delete
* @param string $user_email The submitted email.
[3423] Fix | Delete
* @param WP_Error $errors Contains any errors with submitted username and email,
[3424] Fix | Delete
* e.g., an empty field, an invalid username or email,
[3425] Fix | Delete
* or an existing username or email.
[3426] Fix | Delete
*/
[3427] Fix | Delete
do_action( 'register_post', $sanitized_user_login, $user_email, $errors );
[3428] Fix | Delete
[3429] Fix | Delete
/**
[3430] Fix | Delete
* Filters the errors encountered when a new user is being registered.
[3431] Fix | Delete
*
[3432] Fix | Delete
* The filtered WP_Error object may, for example, contain errors for an invalid
[3433] Fix | Delete
* or existing username or email address. A WP_Error object should always be returned,
[3434] Fix | Delete
* but may or may not contain errors.
[3435] Fix | Delete
*
[3436] Fix | Delete
* If any errors are present in $errors, this will abort the user's registration.
[3437] Fix | Delete
*
[3438] Fix | Delete
* @since 2.1.0
[3439] Fix | Delete
*
[3440] Fix | Delete
* @param WP_Error $errors A WP_Error object containing any errors encountered
[3441] Fix | Delete
* during registration.
[3442] Fix | Delete
* @param string $sanitized_user_login User's username after it has been sanitized.
[3443] Fix | Delete
* @param string $user_email User's email.
[3444] Fix | Delete
*/
[3445] Fix | Delete
$errors = apply_filters( 'registration_errors', $errors, $sanitized_user_login, $user_email );
[3446] Fix | Delete
[3447] Fix | Delete
if ( $errors->has_errors() ) {
[3448] Fix | Delete
return $errors;
[3449] Fix | Delete
}
[3450] Fix | Delete
[3451] Fix | Delete
$user_pass = wp_generate_password( 12, false );
[3452] Fix | Delete
$user_id = wp_create_user( $sanitized_user_login, $user_pass, $user_email );
[3453] Fix | Delete
if ( ! $user_id || is_wp_error( $user_id ) ) {
[3454] Fix | Delete
$errors->add(
[3455] Fix | Delete
'registerfail',
[3456] Fix | Delete
sprintf(
[3457] Fix | Delete
/* translators: %s: Admin email address. */
[3458] Fix | Delete
__( '<strong>Error:</strong> Could not register you&hellip; please contact the <a href="mailto:%s">site admin</a>!' ),
[3459] Fix | Delete
get_option( 'admin_email' )
[3460] Fix | Delete
)
[3461] Fix | Delete
);
[3462] Fix | Delete
return $errors;
[3463] Fix | Delete
}
[3464] Fix | Delete
[3465] Fix | Delete
update_user_meta( $user_id, 'default_password_nag', true ); // Set up the password change nag.
[3466] Fix | Delete
[3467] Fix | Delete
if ( ! empty( $_COOKIE['wp_lang'] ) ) {
[3468] Fix | Delete
$wp_lang = sanitize_text_field( $_COOKIE['wp_lang'] );
[3469] Fix | Delete
if ( in_array( $wp_lang, get_available_languages(), true ) ) {
[3470] Fix | Delete
update_user_meta( $user_id, 'locale', $wp_lang ); // Set user locale if defined on registration.
[3471] Fix | Delete
}
[3472] Fix | Delete
}
[3473] Fix | Delete
[3474] Fix | Delete
/**
[3475] Fix | Delete
* Fires after a new user registration has been recorded.
[3476] Fix | Delete
*
[3477] Fix | Delete
* @since 4.4.0
[3478] Fix | Delete
*
[3479] Fix | Delete
* @param int $user_id ID of the newly registered user.
[3480] Fix | Delete
*/
[3481] Fix | Delete
do_action( 'register_new_user', $user_id );
[3482] Fix | Delete
[3483] Fix | Delete
return $user_id;
[3484] Fix | Delete
}
[3485] Fix | Delete
[3486] Fix | Delete
/**
[3487] Fix | Delete
* Initiates email notifications related to the creation of new users.
[3488] Fix | Delete
*
[3489] Fix | Delete
* Notifications are sent both to the site admin and to the newly created user.
[3490] Fix | Delete
*
[3491] Fix | Delete
* @since 4.4.0
[3492] Fix | Delete
* @since 4.6.0 Converted the `$notify` parameter to accept 'user' for sending
[3493] Fix | Delete
* notifications only to the user created.
[3494] Fix | Delete
*
[3495] Fix | Delete
* @param int $user_id ID of the newly created user.
[3496] Fix | Delete
* @param string $notify Optional. Type of notification that should happen. Accepts 'admin'
[3497] Fix | Delete
* or an empty string (admin only), 'user', or 'both' (admin and user).
[3498] Fix | Delete
* Default 'both'.
[3499] Fix | Delete
It is recommended that you Edit text format, this type of Fix handles quite a lot in one request
Function