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.../public_h.../wp-inclu...
File: user.php
*
[2500] Fix | Delete
* @since 2.0.0
[2501] Fix | Delete
* @since 5.8.0 The `$userdata` parameter was added.
[2502] Fix | Delete
*
[2503] Fix | Delete
* @param int $user_id User ID.
[2504] Fix | Delete
* @param WP_User $old_user_data Object containing user's data prior to update.
[2505] Fix | Delete
* @param array $userdata The raw array of data passed to wp_insert_user().
[2506] Fix | Delete
*/
[2507] Fix | Delete
do_action( 'profile_update', $user_id, $old_user_data, $userdata );
[2508] Fix | Delete
[2509] Fix | Delete
if ( isset( $userdata['spam'] ) && $userdata['spam'] !== $old_user_data->spam ) {
[2510] Fix | Delete
if ( '1' === $userdata['spam'] ) {
[2511] Fix | Delete
/**
[2512] Fix | Delete
* Fires after the user is marked as a SPAM user.
[2513] Fix | Delete
*
[2514] Fix | Delete
* @since 3.0.0
[2515] Fix | Delete
*
[2516] Fix | Delete
* @param int $user_id ID of the user marked as SPAM.
[2517] Fix | Delete
*/
[2518] Fix | Delete
do_action( 'make_spam_user', $user_id );
[2519] Fix | Delete
} else {
[2520] Fix | Delete
/**
[2521] Fix | Delete
* Fires after the user is marked as a HAM user. Opposite of SPAM.
[2522] Fix | Delete
*
[2523] Fix | Delete
* @since 3.0.0
[2524] Fix | Delete
*
[2525] Fix | Delete
* @param int $user_id ID of the user marked as HAM.
[2526] Fix | Delete
*/
[2527] Fix | Delete
do_action( 'make_ham_user', $user_id );
[2528] Fix | Delete
}
[2529] Fix | Delete
}
[2530] Fix | Delete
} else {
[2531] Fix | Delete
/**
[2532] Fix | Delete
* Fires immediately after a new user is registered.
[2533] Fix | Delete
*
[2534] Fix | Delete
* @since 1.5.0
[2535] Fix | Delete
* @since 5.8.0 The `$userdata` parameter was added.
[2536] Fix | Delete
*
[2537] Fix | Delete
* @param int $user_id User ID.
[2538] Fix | Delete
* @param array $userdata The raw array of data passed to wp_insert_user().
[2539] Fix | Delete
*/
[2540] Fix | Delete
do_action( 'user_register', $user_id, $userdata );
[2541] Fix | Delete
}
[2542] Fix | Delete
[2543] Fix | Delete
return $user_id;
[2544] Fix | Delete
}
[2545] Fix | Delete
[2546] Fix | Delete
/**
[2547] Fix | Delete
* Updates a user in the database.
[2548] Fix | Delete
*
[2549] Fix | Delete
* It is possible to update a user's password by specifying the 'user_pass'
[2550] Fix | Delete
* value in the $userdata parameter array.
[2551] Fix | Delete
*
[2552] Fix | Delete
* If current user's password is being updated, then the cookies will be
[2553] Fix | Delete
* cleared.
[2554] Fix | Delete
*
[2555] Fix | Delete
* @since 2.0.0
[2556] Fix | Delete
*
[2557] Fix | Delete
* @see wp_insert_user() For what fields can be set in $userdata.
[2558] Fix | Delete
*
[2559] Fix | Delete
* @param array|object|WP_User $userdata An array of user data or a user object of type stdClass or WP_User.
[2560] Fix | Delete
* @return int|WP_Error The updated user's ID or a WP_Error object if the user could not be updated.
[2561] Fix | Delete
*/
[2562] Fix | Delete
function wp_update_user( $userdata ) {
[2563] Fix | Delete
if ( $userdata instanceof stdClass ) {
[2564] Fix | Delete
$userdata = get_object_vars( $userdata );
[2565] Fix | Delete
} elseif ( $userdata instanceof WP_User ) {
[2566] Fix | Delete
$userdata = $userdata->to_array();
[2567] Fix | Delete
}
[2568] Fix | Delete
[2569] Fix | Delete
$userdata_raw = $userdata;
[2570] Fix | Delete
[2571] Fix | Delete
$user_id = isset( $userdata['ID'] ) ? (int) $userdata['ID'] : 0;
[2572] Fix | Delete
if ( ! $user_id ) {
[2573] Fix | Delete
return new WP_Error( 'invalid_user_id', __( 'Invalid user ID.' ) );
[2574] Fix | Delete
}
[2575] Fix | Delete
[2576] Fix | Delete
// First, get all of the original fields.
[2577] Fix | Delete
$user_obj = get_userdata( $user_id );
[2578] Fix | Delete
if ( ! $user_obj ) {
[2579] Fix | Delete
return new WP_Error( 'invalid_user_id', __( 'Invalid user ID.' ) );
[2580] Fix | Delete
}
[2581] Fix | Delete
[2582] Fix | Delete
$user = $user_obj->to_array();
[2583] Fix | Delete
[2584] Fix | Delete
// Add additional custom fields.
[2585] Fix | Delete
foreach ( _get_additional_user_keys( $user_obj ) as $key ) {
[2586] Fix | Delete
$user[ $key ] = get_user_meta( $user_id, $key, true );
[2587] Fix | Delete
}
[2588] Fix | Delete
[2589] Fix | Delete
// Escape data pulled from DB.
[2590] Fix | Delete
$user = add_magic_quotes( $user );
[2591] Fix | Delete
[2592] Fix | Delete
if ( ! empty( $userdata['user_pass'] ) && $userdata['user_pass'] !== $user_obj->user_pass ) {
[2593] Fix | Delete
// If password is changing, hash it now.
[2594] Fix | Delete
$plaintext_pass = $userdata['user_pass'];
[2595] Fix | Delete
$userdata['user_pass'] = wp_hash_password( $userdata['user_pass'] );
[2596] Fix | Delete
[2597] Fix | Delete
/**
[2598] Fix | Delete
* Filters whether to send the password change email.
[2599] Fix | Delete
*
[2600] Fix | Delete
* @since 4.3.0
[2601] Fix | Delete
*
[2602] Fix | Delete
* @see wp_insert_user() For `$user` and `$userdata` fields.
[2603] Fix | Delete
*
[2604] Fix | Delete
* @param bool $send Whether to send the email.
[2605] Fix | Delete
* @param array $user The original user array.
[2606] Fix | Delete
* @param array $userdata The updated user array.
[2607] Fix | Delete
*/
[2608] Fix | Delete
$send_password_change_email = apply_filters( 'send_password_change_email', true, $user, $userdata );
[2609] Fix | Delete
}
[2610] Fix | Delete
[2611] Fix | Delete
if ( isset( $userdata['user_email'] ) && $user['user_email'] !== $userdata['user_email'] ) {
[2612] Fix | Delete
/**
[2613] Fix | Delete
* Filters whether to send the email change email.
[2614] Fix | Delete
*
[2615] Fix | Delete
* @since 4.3.0
[2616] Fix | Delete
*
[2617] Fix | Delete
* @see wp_insert_user() For `$user` and `$userdata` fields.
[2618] Fix | Delete
*
[2619] Fix | Delete
* @param bool $send Whether to send the email.
[2620] Fix | Delete
* @param array $user The original user array.
[2621] Fix | Delete
* @param array $userdata The updated user array.
[2622] Fix | Delete
*/
[2623] Fix | Delete
$send_email_change_email = apply_filters( 'send_email_change_email', true, $user, $userdata );
[2624] Fix | Delete
}
[2625] Fix | Delete
[2626] Fix | Delete
clean_user_cache( $user_obj );
[2627] Fix | Delete
[2628] Fix | Delete
// Merge old and new fields with new fields overwriting old ones.
[2629] Fix | Delete
$userdata = array_merge( $user, $userdata );
[2630] Fix | Delete
$user_id = wp_insert_user( $userdata );
[2631] Fix | Delete
[2632] Fix | Delete
if ( is_wp_error( $user_id ) ) {
[2633] Fix | Delete
return $user_id;
[2634] Fix | Delete
}
[2635] Fix | Delete
[2636] Fix | Delete
$blog_name = wp_specialchars_decode( get_option( 'blogname' ), ENT_QUOTES );
[2637] Fix | Delete
[2638] Fix | Delete
$switched_locale = false;
[2639] Fix | Delete
if ( ! empty( $send_password_change_email ) || ! empty( $send_email_change_email ) ) {
[2640] Fix | Delete
$switched_locale = switch_to_user_locale( $user_id );
[2641] Fix | Delete
}
[2642] Fix | Delete
[2643] Fix | Delete
if ( ! empty( $send_password_change_email ) ) {
[2644] Fix | Delete
/* translators: Do not translate USERNAME, ADMIN_EMAIL, EMAIL, SITENAME, SITEURL: those are placeholders. */
[2645] Fix | Delete
$pass_change_text = __(
[2646] Fix | Delete
'Hi ###USERNAME###,
[2647] Fix | Delete
[2648] Fix | Delete
This notice confirms that your password was changed on ###SITENAME###.
[2649] Fix | Delete
[2650] Fix | Delete
If you did not change your password, please contact the Site Administrator at
[2651] Fix | Delete
###ADMIN_EMAIL###
[2652] Fix | Delete
[2653] Fix | Delete
This email has been sent to ###EMAIL###
[2654] Fix | Delete
[2655] Fix | Delete
Regards,
[2656] Fix | Delete
All at ###SITENAME###
[2657] Fix | Delete
###SITEURL###'
[2658] Fix | Delete
);
[2659] Fix | Delete
[2660] Fix | Delete
$pass_change_email = array(
[2661] Fix | Delete
'to' => $user['user_email'],
[2662] Fix | Delete
/* translators: Password change notification email subject. %s: Site title. */
[2663] Fix | Delete
'subject' => __( '[%s] Password Changed' ),
[2664] Fix | Delete
'message' => $pass_change_text,
[2665] Fix | Delete
'headers' => '',
[2666] Fix | Delete
);
[2667] Fix | Delete
[2668] Fix | Delete
/**
[2669] Fix | Delete
* Filters the contents of the email sent when the user's password is changed.
[2670] Fix | Delete
*
[2671] Fix | Delete
* @since 4.3.0
[2672] Fix | Delete
*
[2673] Fix | Delete
* @param array $pass_change_email {
[2674] Fix | Delete
* Used to build wp_mail().
[2675] Fix | Delete
*
[2676] Fix | Delete
* @type string $to The intended recipients. Add emails in a comma separated string.
[2677] Fix | Delete
* @type string $subject The subject of the email.
[2678] Fix | Delete
* @type string $message The content of the email.
[2679] Fix | Delete
* The following strings have a special meaning and will get replaced dynamically:
[2680] Fix | Delete
* - ###USERNAME### The current user's username.
[2681] Fix | Delete
* - ###ADMIN_EMAIL### The admin email in case this was unexpected.
[2682] Fix | Delete
* - ###EMAIL### The user's email address.
[2683] Fix | Delete
* - ###SITENAME### The name of the site.
[2684] Fix | Delete
* - ###SITEURL### The URL to the site.
[2685] Fix | Delete
* @type string $headers Headers. Add headers in a newline (\r\n) separated string.
[2686] Fix | Delete
* }
[2687] Fix | Delete
* @param array $user The original user array.
[2688] Fix | Delete
* @param array $userdata The updated user array.
[2689] Fix | Delete
*/
[2690] Fix | Delete
$pass_change_email = apply_filters( 'password_change_email', $pass_change_email, $user, $userdata );
[2691] Fix | Delete
[2692] Fix | Delete
$pass_change_email['message'] = str_replace( '###USERNAME###', $user['user_login'], $pass_change_email['message'] );
[2693] Fix | Delete
$pass_change_email['message'] = str_replace( '###ADMIN_EMAIL###', get_option( 'admin_email' ), $pass_change_email['message'] );
[2694] Fix | Delete
$pass_change_email['message'] = str_replace( '###EMAIL###', $user['user_email'], $pass_change_email['message'] );
[2695] Fix | Delete
$pass_change_email['message'] = str_replace( '###SITENAME###', $blog_name, $pass_change_email['message'] );
[2696] Fix | Delete
$pass_change_email['message'] = str_replace( '###SITEURL###', home_url(), $pass_change_email['message'] );
[2697] Fix | Delete
[2698] Fix | Delete
wp_mail( $pass_change_email['to'], sprintf( $pass_change_email['subject'], $blog_name ), $pass_change_email['message'], $pass_change_email['headers'] );
[2699] Fix | Delete
}
[2700] Fix | Delete
[2701] Fix | Delete
if ( ! empty( $send_email_change_email ) ) {
[2702] Fix | Delete
/* translators: Do not translate USERNAME, ADMIN_EMAIL, NEW_EMAIL, EMAIL, SITENAME, SITEURL: those are placeholders. */
[2703] Fix | Delete
$email_change_text = __(
[2704] Fix | Delete
'Hi ###USERNAME###,
[2705] Fix | Delete
[2706] Fix | Delete
This notice confirms that your email address on ###SITENAME### was changed to ###NEW_EMAIL###.
[2707] Fix | Delete
[2708] Fix | Delete
If you did not change your email, please contact the Site Administrator at
[2709] Fix | Delete
###ADMIN_EMAIL###
[2710] Fix | Delete
[2711] Fix | Delete
This email has been sent to ###EMAIL###
[2712] Fix | Delete
[2713] Fix | Delete
Regards,
[2714] Fix | Delete
All at ###SITENAME###
[2715] Fix | Delete
###SITEURL###'
[2716] Fix | Delete
);
[2717] Fix | Delete
[2718] Fix | Delete
$email_change_email = array(
[2719] Fix | Delete
'to' => $user['user_email'],
[2720] Fix | Delete
/* translators: Email change notification email subject. %s: Site title. */
[2721] Fix | Delete
'subject' => __( '[%s] Email Changed' ),
[2722] Fix | Delete
'message' => $email_change_text,
[2723] Fix | Delete
'headers' => '',
[2724] Fix | Delete
);
[2725] Fix | Delete
[2726] Fix | Delete
/**
[2727] Fix | Delete
* Filters the contents of the email sent when the user's email is changed.
[2728] Fix | Delete
*
[2729] Fix | Delete
* @since 4.3.0
[2730] Fix | Delete
*
[2731] Fix | Delete
* @param array $email_change_email {
[2732] Fix | Delete
* Used to build wp_mail().
[2733] Fix | Delete
*
[2734] Fix | Delete
* @type string $to The intended recipients.
[2735] Fix | Delete
* @type string $subject The subject of the email.
[2736] Fix | Delete
* @type string $message The content of the email.
[2737] Fix | Delete
* The following strings have a special meaning and will get replaced dynamically:
[2738] Fix | Delete
* - ###USERNAME### The current user's username.
[2739] Fix | Delete
* - ###ADMIN_EMAIL### The admin email in case this was unexpected.
[2740] Fix | Delete
* - ###NEW_EMAIL### The new email address.
[2741] Fix | Delete
* - ###EMAIL### The old email address.
[2742] Fix | Delete
* - ###SITENAME### The name of the site.
[2743] Fix | Delete
* - ###SITEURL### The URL to the site.
[2744] Fix | Delete
* @type string $headers Headers.
[2745] Fix | Delete
* }
[2746] Fix | Delete
* @param array $user The original user array.
[2747] Fix | Delete
* @param array $userdata The updated user array.
[2748] Fix | Delete
*/
[2749] Fix | Delete
$email_change_email = apply_filters( 'email_change_email', $email_change_email, $user, $userdata );
[2750] Fix | Delete
[2751] Fix | Delete
$email_change_email['message'] = str_replace( '###USERNAME###', $user['user_login'], $email_change_email['message'] );
[2752] Fix | Delete
$email_change_email['message'] = str_replace( '###ADMIN_EMAIL###', get_option( 'admin_email' ), $email_change_email['message'] );
[2753] Fix | Delete
$email_change_email['message'] = str_replace( '###NEW_EMAIL###', $userdata['user_email'], $email_change_email['message'] );
[2754] Fix | Delete
$email_change_email['message'] = str_replace( '###EMAIL###', $user['user_email'], $email_change_email['message'] );
[2755] Fix | Delete
$email_change_email['message'] = str_replace( '###SITENAME###', $blog_name, $email_change_email['message'] );
[2756] Fix | Delete
$email_change_email['message'] = str_replace( '###SITEURL###', home_url(), $email_change_email['message'] );
[2757] Fix | Delete
[2758] Fix | Delete
wp_mail( $email_change_email['to'], sprintf( $email_change_email['subject'], $blog_name ), $email_change_email['message'], $email_change_email['headers'] );
[2759] Fix | Delete
}
[2760] Fix | Delete
[2761] Fix | Delete
if ( $switched_locale ) {
[2762] Fix | Delete
restore_previous_locale();
[2763] Fix | Delete
}
[2764] Fix | Delete
[2765] Fix | Delete
// Update the cookies if the password changed.
[2766] Fix | Delete
$current_user = wp_get_current_user();
[2767] Fix | Delete
if ( $current_user->ID === $user_id ) {
[2768] Fix | Delete
if ( isset( $plaintext_pass ) ) {
[2769] Fix | Delete
wp_clear_auth_cookie();
[2770] Fix | Delete
[2771] Fix | Delete
/*
[2772] Fix | Delete
* Here we calculate the expiration length of the current auth cookie and compare it to the default expiration.
[2773] Fix | Delete
* If it's greater than this, then we know the user checked 'Remember Me' when they logged in.
[2774] Fix | Delete
*/
[2775] Fix | Delete
$logged_in_cookie = wp_parse_auth_cookie( '', 'logged_in' );
[2776] Fix | Delete
/** This filter is documented in wp-includes/pluggable.php */
[2777] Fix | Delete
$default_cookie_life = apply_filters( 'auth_cookie_expiration', ( 2 * DAY_IN_SECONDS ), $user_id, false );
[2778] Fix | Delete
[2779] Fix | Delete
$remember = false;
[2780] Fix | Delete
[2781] Fix | Delete
if ( false !== $logged_in_cookie && ( $logged_in_cookie['expiration'] - time() ) > $default_cookie_life ) {
[2782] Fix | Delete
$remember = true;
[2783] Fix | Delete
}
[2784] Fix | Delete
[2785] Fix | Delete
wp_set_auth_cookie( $user_id, $remember );
[2786] Fix | Delete
}
[2787] Fix | Delete
}
[2788] Fix | Delete
[2789] Fix | Delete
/**
[2790] Fix | Delete
* Fires after the user has been updated and emails have been sent.
[2791] Fix | Delete
*
[2792] Fix | Delete
* @since 6.3.0
[2793] Fix | Delete
*
[2794] Fix | Delete
* @param int $user_id The ID of the user that was just updated.
[2795] Fix | Delete
* @param array $userdata The array of user data that was updated.
[2796] Fix | Delete
* @param array $userdata_raw The unedited array of user data that was updated.
[2797] Fix | Delete
*/
[2798] Fix | Delete
do_action( 'wp_update_user', $user_id, $userdata, $userdata_raw );
[2799] Fix | Delete
[2800] Fix | Delete
return $user_id;
[2801] Fix | Delete
}
[2802] Fix | Delete
[2803] Fix | Delete
/**
[2804] Fix | Delete
* Provides a simpler way of inserting a user into the database.
[2805] Fix | Delete
*
[2806] Fix | Delete
* Creates a new user with just the username, password, and email. For more
[2807] Fix | Delete
* complex user creation use wp_insert_user() to specify more information.
[2808] Fix | Delete
*
[2809] Fix | Delete
* @since 2.0.0
[2810] Fix | Delete
*
[2811] Fix | Delete
* @see wp_insert_user() More complete way to create a new user.
[2812] Fix | Delete
*
[2813] Fix | Delete
* @param string $username The user's username.
[2814] Fix | Delete
* @param string $password The user's password.
[2815] Fix | Delete
* @param string $email Optional. The user's email. Default empty.
[2816] Fix | Delete
* @return int|WP_Error The newly created user's ID or a WP_Error object if the user could not
[2817] Fix | Delete
* be created.
[2818] Fix | Delete
*/
[2819] Fix | Delete
function wp_create_user( $username, $password, $email = '' ) {
[2820] Fix | Delete
$user_login = wp_slash( $username );
[2821] Fix | Delete
$user_email = wp_slash( $email );
[2822] Fix | Delete
$user_pass = $password;
[2823] Fix | Delete
[2824] Fix | Delete
$userdata = compact( 'user_login', 'user_email', 'user_pass' );
[2825] Fix | Delete
return wp_insert_user( $userdata );
[2826] Fix | Delete
}
[2827] Fix | Delete
[2828] Fix | Delete
/**
[2829] Fix | Delete
* Returns a list of meta keys to be (maybe) populated in wp_update_user().
[2830] Fix | Delete
*
[2831] Fix | Delete
* The list of keys returned via this function are dependent on the presence
[2832] Fix | Delete
* of those keys in the user meta data to be set.
[2833] Fix | Delete
*
[2834] Fix | Delete
* @since 3.3.0
[2835] Fix | Delete
* @access private
[2836] Fix | Delete
*
[2837] Fix | Delete
* @param WP_User $user WP_User instance.
[2838] Fix | Delete
* @return string[] List of user keys to be populated in wp_update_user().
[2839] Fix | Delete
*/
[2840] Fix | Delete
function _get_additional_user_keys( $user ) {
[2841] Fix | Delete
$keys = array( 'first_name', 'last_name', 'nickname', 'description', 'rich_editing', 'syntax_highlighting', 'comment_shortcuts', 'admin_color', 'use_ssl', 'show_admin_bar_front', 'locale' );
[2842] Fix | Delete
return array_merge( $keys, array_keys( wp_get_user_contact_methods( $user ) ) );
[2843] Fix | Delete
}
[2844] Fix | Delete
[2845] Fix | Delete
/**
[2846] Fix | Delete
* Sets up the user contact methods.
[2847] Fix | Delete
*
[2848] Fix | Delete
* Default contact methods were removed in 3.6. A filter dictates contact methods.
[2849] Fix | Delete
*
[2850] Fix | Delete
* @since 3.7.0
[2851] Fix | Delete
*
[2852] Fix | Delete
* @param WP_User|null $user Optional. WP_User object.
[2853] Fix | Delete
* @return string[] Array of contact method labels keyed by contact method.
[2854] Fix | Delete
*/
[2855] Fix | Delete
function wp_get_user_contact_methods( $user = null ) {
[2856] Fix | Delete
$methods = array();
[2857] Fix | Delete
if ( get_site_option( 'initial_db_version' ) < 23588 ) {
[2858] Fix | Delete
$methods = array(
[2859] Fix | Delete
'aim' => __( 'AIM' ),
[2860] Fix | Delete
'yim' => __( 'Yahoo IM' ),
[2861] Fix | Delete
'jabber' => __( 'Jabber / Google Talk' ),
[2862] Fix | Delete
);
[2863] Fix | Delete
}
[2864] Fix | Delete
[2865] Fix | Delete
/**
[2866] Fix | Delete
* Filters the user contact methods.
[2867] Fix | Delete
*
[2868] Fix | Delete
* @since 2.9.0
[2869] Fix | Delete
*
[2870] Fix | Delete
* @param string[] $methods Array of contact method labels keyed by contact method.
[2871] Fix | Delete
* @param WP_User|null $user WP_User object or null if none was provided.
[2872] Fix | Delete
*/
[2873] Fix | Delete
return apply_filters( 'user_contactmethods', $methods, $user );
[2874] Fix | Delete
}
[2875] Fix | Delete
[2876] Fix | Delete
/**
[2877] Fix | Delete
* The old private function for setting up user contact methods.
[2878] Fix | Delete
*
[2879] Fix | Delete
* Use wp_get_user_contact_methods() instead.
[2880] Fix | Delete
*
[2881] Fix | Delete
* @since 2.9.0
[2882] Fix | Delete
* @access private
[2883] Fix | Delete
*
[2884] Fix | Delete
* @param WP_User|null $user Optional. WP_User object. Default null.
[2885] Fix | Delete
* @return string[] Array of contact method labels keyed by contact method.
[2886] Fix | Delete
*/
[2887] Fix | Delete
function _wp_get_user_contactmethods( $user = null ) {
[2888] Fix | Delete
return wp_get_user_contact_methods( $user );
[2889] Fix | Delete
}
[2890] Fix | Delete
[2891] Fix | Delete
/**
[2892] Fix | Delete
* Gets the text suggesting how to create strong passwords.
[2893] Fix | Delete
*
[2894] Fix | Delete
* @since 4.1.0
[2895] Fix | Delete
*
[2896] Fix | Delete
* @return string The password hint text.
[2897] Fix | Delete
*/
[2898] Fix | Delete
function wp_get_password_hint() {
[2899] Fix | Delete
$hint = __( 'Hint: The password should be at least twelve characters long. To make it stronger, use upper and lower case letters, numbers, and symbols like ! " ? $ % ^ &amp; ).' );
[2900] Fix | Delete
[2901] Fix | Delete
/**
[2902] Fix | Delete
* Filters the text describing the site's password complexity policy.
[2903] Fix | Delete
*
[2904] Fix | Delete
* @since 4.1.0
[2905] Fix | Delete
*
[2906] Fix | Delete
* @param string $hint The password hint text.
[2907] Fix | Delete
*/
[2908] Fix | Delete
return apply_filters( 'password_hint', $hint );
[2909] Fix | Delete
}
[2910] Fix | Delete
[2911] Fix | Delete
/**
[2912] Fix | Delete
* Creates, stores, then returns a password reset key for user.
[2913] Fix | Delete
*
[2914] Fix | Delete
* @since 4.4.0
[2915] Fix | Delete
*
[2916] Fix | Delete
* @global PasswordHash $wp_hasher Portable PHP password hashing framework instance.
[2917] Fix | Delete
*
[2918] Fix | Delete
* @param WP_User $user User to retrieve password reset key for.
[2919] Fix | Delete
* @return string|WP_Error Password reset key on success. WP_Error on error.
[2920] Fix | Delete
*/
[2921] Fix | Delete
function get_password_reset_key( $user ) {
[2922] Fix | Delete
global $wp_hasher;
[2923] Fix | Delete
[2924] Fix | Delete
if ( ! ( $user instanceof WP_User ) ) {
[2925] Fix | Delete
return new WP_Error( 'invalidcombo', __( '<strong>Error:</strong> There is no account with that username or email address.' ) );
[2926] Fix | Delete
}
[2927] Fix | Delete
[2928] Fix | Delete
/**
[2929] Fix | Delete
* Fires before a new password is retrieved.
[2930] Fix | Delete
*
[2931] Fix | Delete
* Use the {@see 'retrieve_password'} hook instead.
[2932] Fix | Delete
*
[2933] Fix | Delete
* @since 1.5.0
[2934] Fix | Delete
* @deprecated 1.5.1 Misspelled. Use {@see 'retrieve_password'} hook instead.
[2935] Fix | Delete
*
[2936] Fix | Delete
* @param string $user_login The user login name.
[2937] Fix | Delete
*/
[2938] Fix | Delete
do_action_deprecated( 'retreive_password', array( $user->user_login ), '1.5.1', 'retrieve_password' );
[2939] Fix | Delete
[2940] Fix | Delete
/**
[2941] Fix | Delete
* Fires before a new password is retrieved.
[2942] Fix | Delete
*
[2943] Fix | Delete
* @since 1.5.1
[2944] Fix | Delete
*
[2945] Fix | Delete
* @param string $user_login The user login name.
[2946] Fix | Delete
*/
[2947] Fix | Delete
do_action( 'retrieve_password', $user->user_login );
[2948] Fix | Delete
[2949] Fix | Delete
$password_reset_allowed = wp_is_password_reset_allowed_for_user( $user );
[2950] Fix | Delete
if ( ! $password_reset_allowed ) {
[2951] Fix | Delete
return new WP_Error( 'no_password_reset', __( 'Password reset is not allowed for this user' ) );
[2952] Fix | Delete
} elseif ( is_wp_error( $password_reset_allowed ) ) {
[2953] Fix | Delete
return $password_reset_allowed;
[2954] Fix | Delete
}
[2955] Fix | Delete
[2956] Fix | Delete
// Generate something random for a password reset key.
[2957] Fix | Delete
$key = wp_generate_password( 20, false );
[2958] Fix | Delete
[2959] Fix | Delete
/**
[2960] Fix | Delete
* Fires when a password reset key is generated.
[2961] Fix | Delete
*
[2962] Fix | Delete
* @since 2.5.0
[2963] Fix | Delete
*
[2964] Fix | Delete
* @param string $user_login The username for the user.
[2965] Fix | Delete
* @param string $key The generated password reset key.
[2966] Fix | Delete
*/
[2967] Fix | Delete
do_action( 'retrieve_password_key', $user->user_login, $key );
[2968] Fix | Delete
[2969] Fix | Delete
// Now insert the key, hashed, into the DB.
[2970] Fix | Delete
if ( empty( $wp_hasher ) ) {
[2971] Fix | Delete
require_once ABSPATH . WPINC . '/class-phpass.php';
[2972] Fix | Delete
$wp_hasher = new PasswordHash( 8, true );
[2973] Fix | Delete
}
[2974] Fix | Delete
[2975] Fix | Delete
$hashed = time() . ':' . $wp_hasher->HashPassword( $key );
[2976] Fix | Delete
[2977] Fix | Delete
$key_saved = wp_update_user(
[2978] Fix | Delete
array(
[2979] Fix | Delete
'ID' => $user->ID,
[2980] Fix | Delete
'user_activation_key' => $hashed,
[2981] Fix | Delete
)
[2982] Fix | Delete
);
[2983] Fix | Delete
[2984] Fix | Delete
if ( is_wp_error( $key_saved ) ) {
[2985] Fix | Delete
return $key_saved;
[2986] Fix | Delete
}
[2987] Fix | Delete
[2988] Fix | Delete
return $key;
[2989] Fix | Delete
}
[2990] Fix | Delete
[2991] Fix | Delete
/**
[2992] Fix | Delete
* Retrieves a user row based on password reset key and login.
[2993] Fix | Delete
*
[2994] Fix | Delete
* A key is considered 'expired' if it exactly matches the value of the
[2995] Fix | Delete
* user_activation_key field, rather than being matched after going through the
[2996] Fix | Delete
* hashing process. This field is now hashed; old values are no longer accepted
[2997] Fix | Delete
* but have a different WP_Error code so good user feedback can be provided.
[2998] Fix | Delete
*
[2999] Fix | Delete
It is recommended that you Edit text format, this type of Fix handles quite a lot in one request
Function