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
* @return int|false The user ID on success, false on failure.
[2000] Fix | Delete
*/
[2001] Fix | Delete
function email_exists( $email ) {
[2002] Fix | Delete
$user = get_user_by( 'email', $email );
[2003] Fix | Delete
if ( $user ) {
[2004] Fix | Delete
$user_id = $user->ID;
[2005] Fix | Delete
} else {
[2006] Fix | Delete
$user_id = false;
[2007] Fix | Delete
}
[2008] Fix | Delete
[2009] Fix | Delete
/**
[2010] Fix | Delete
* Filters whether the given email exists.
[2011] Fix | Delete
*
[2012] Fix | Delete
* @since 5.6.0
[2013] Fix | Delete
*
[2014] Fix | Delete
* @param int|false $user_id The user ID associated with the email,
[2015] Fix | Delete
* or false if the email does not exist.
[2016] Fix | Delete
* @param string $email The email to check for existence.
[2017] Fix | Delete
*/
[2018] Fix | Delete
return apply_filters( 'email_exists', $user_id, $email );
[2019] Fix | Delete
}
[2020] Fix | Delete
[2021] Fix | Delete
/**
[2022] Fix | Delete
* Checks whether a username is valid.
[2023] Fix | Delete
*
[2024] Fix | Delete
* @since 2.0.1
[2025] Fix | Delete
* @since 4.4.0 Empty sanitized usernames are now considered invalid.
[2026] Fix | Delete
*
[2027] Fix | Delete
* @param string $username Username.
[2028] Fix | Delete
* @return bool Whether username given is valid.
[2029] Fix | Delete
*/
[2030] Fix | Delete
function validate_username( $username ) {
[2031] Fix | Delete
$sanitized = sanitize_user( $username, true );
[2032] Fix | Delete
$valid = ( $sanitized === $username && ! empty( $sanitized ) );
[2033] Fix | Delete
[2034] Fix | Delete
/**
[2035] Fix | Delete
* Filters whether the provided username is valid.
[2036] Fix | Delete
*
[2037] Fix | Delete
* @since 2.0.1
[2038] Fix | Delete
*
[2039] Fix | Delete
* @param bool $valid Whether given username is valid.
[2040] Fix | Delete
* @param string $username Username to check.
[2041] Fix | Delete
*/
[2042] Fix | Delete
return apply_filters( 'validate_username', $valid, $username );
[2043] Fix | Delete
}
[2044] Fix | Delete
[2045] Fix | Delete
/**
[2046] Fix | Delete
* Inserts a user into the database.
[2047] Fix | Delete
*
[2048] Fix | Delete
* Most of the `$userdata` array fields have filters associated with the values. Exceptions are
[2049] Fix | Delete
* 'ID', 'rich_editing', 'syntax_highlighting', 'comment_shortcuts', 'admin_color', 'use_ssl',
[2050] Fix | Delete
* 'user_registered', 'user_activation_key', 'spam', and 'role'. The filters have the prefix
[2051] Fix | Delete
* 'pre_user_' followed by the field name. An example using 'description' would have the filter
[2052] Fix | Delete
* called 'pre_user_description' that can be hooked into.
[2053] Fix | Delete
*
[2054] Fix | Delete
* @since 2.0.0
[2055] Fix | Delete
* @since 3.6.0 The `aim`, `jabber`, and `yim` fields were removed as default user contact
[2056] Fix | Delete
* methods for new installations. See wp_get_user_contact_methods().
[2057] Fix | Delete
* @since 4.7.0 The `locale` field can be passed to `$userdata`.
[2058] Fix | Delete
* @since 5.3.0 The `user_activation_key` field can be passed to `$userdata`.
[2059] Fix | Delete
* @since 5.3.0 The `spam` field can be passed to `$userdata` (Multisite only).
[2060] Fix | Delete
* @since 5.9.0 The `meta_input` field can be passed to `$userdata` to allow addition of user meta data.
[2061] Fix | Delete
*
[2062] Fix | Delete
* @global wpdb $wpdb WordPress database abstraction object.
[2063] Fix | Delete
*
[2064] Fix | Delete
* @param array|object|WP_User $userdata {
[2065] Fix | Delete
* An array, object, or WP_User object of user data arguments.
[2066] Fix | Delete
*
[2067] Fix | Delete
* @type int $ID User ID. If supplied, the user will be updated.
[2068] Fix | Delete
* @type string $user_pass The plain-text user password for new users.
[2069] Fix | Delete
* Hashed password for existing users.
[2070] Fix | Delete
* @type string $user_login The user's login username.
[2071] Fix | Delete
* @type string $user_nicename The URL-friendly user name.
[2072] Fix | Delete
* @type string $user_url The user URL.
[2073] Fix | Delete
* @type string $user_email The user email address.
[2074] Fix | Delete
* @type string $display_name The user's display name.
[2075] Fix | Delete
* Default is the user's username.
[2076] Fix | Delete
* @type string $nickname The user's nickname.
[2077] Fix | Delete
* Default is the user's username.
[2078] Fix | Delete
* @type string $first_name The user's first name. For new users, will be used
[2079] Fix | Delete
* to build the first part of the user's display name
[2080] Fix | Delete
* if `$display_name` is not specified.
[2081] Fix | Delete
* @type string $last_name The user's last name. For new users, will be used
[2082] Fix | Delete
* to build the second part of the user's display name
[2083] Fix | Delete
* if `$display_name` is not specified.
[2084] Fix | Delete
* @type string $description The user's biographical description.
[2085] Fix | Delete
* @type string $rich_editing Whether to enable the rich-editor for the user.
[2086] Fix | Delete
* Accepts 'true' or 'false' as a string literal,
[2087] Fix | Delete
* not boolean. Default 'true'.
[2088] Fix | Delete
* @type string $syntax_highlighting Whether to enable the rich code editor for the user.
[2089] Fix | Delete
* Accepts 'true' or 'false' as a string literal,
[2090] Fix | Delete
* not boolean. Default 'true'.
[2091] Fix | Delete
* @type string $comment_shortcuts Whether to enable comment moderation keyboard
[2092] Fix | Delete
* shortcuts for the user. Accepts 'true' or 'false'
[2093] Fix | Delete
* as a string literal, not boolean. Default 'false'.
[2094] Fix | Delete
* @type string $admin_color Admin color scheme for the user. Default 'fresh'.
[2095] Fix | Delete
* @type bool $use_ssl Whether the user should always access the admin over
[2096] Fix | Delete
* https. Default false.
[2097] Fix | Delete
* @type string $user_registered Date the user registered in UTC. Format is 'Y-m-d H:i:s'.
[2098] Fix | Delete
* @type string $user_activation_key Password reset key. Default empty.
[2099] Fix | Delete
* @type bool $spam Multisite only. Whether the user is marked as spam.
[2100] Fix | Delete
* Default false.
[2101] Fix | Delete
* @type string $show_admin_bar_front Whether to display the Admin Bar for the user
[2102] Fix | Delete
* on the site's front end. Accepts 'true' or 'false'
[2103] Fix | Delete
* as a string literal, not boolean. Default 'true'.
[2104] Fix | Delete
* @type string $role User's role.
[2105] Fix | Delete
* @type string $locale User's locale. Default empty.
[2106] Fix | Delete
* @type array $meta_input Array of custom user meta values keyed by meta key.
[2107] Fix | Delete
* Default empty.
[2108] Fix | Delete
* }
[2109] Fix | Delete
* @return int|WP_Error The newly created user's ID or a WP_Error object if the user could not
[2110] Fix | Delete
* be created.
[2111] Fix | Delete
*/
[2112] Fix | Delete
function wp_insert_user( $userdata ) {
[2113] Fix | Delete
global $wpdb;
[2114] Fix | Delete
[2115] Fix | Delete
if ( $userdata instanceof stdClass ) {
[2116] Fix | Delete
$userdata = get_object_vars( $userdata );
[2117] Fix | Delete
} elseif ( $userdata instanceof WP_User ) {
[2118] Fix | Delete
$userdata = $userdata->to_array();
[2119] Fix | Delete
}
[2120] Fix | Delete
[2121] Fix | Delete
// Are we updating or creating?
[2122] Fix | Delete
if ( ! empty( $userdata['ID'] ) ) {
[2123] Fix | Delete
$user_id = (int) $userdata['ID'];
[2124] Fix | Delete
$update = true;
[2125] Fix | Delete
$old_user_data = get_userdata( $user_id );
[2126] Fix | Delete
[2127] Fix | Delete
if ( ! $old_user_data ) {
[2128] Fix | Delete
return new WP_Error( 'invalid_user_id', __( 'Invalid user ID.' ) );
[2129] Fix | Delete
}
[2130] Fix | Delete
[2131] Fix | Delete
// Slash current user email to compare it later with slashed new user email.
[2132] Fix | Delete
$old_user_data->user_email = wp_slash( $old_user_data->user_email );
[2133] Fix | Delete
[2134] Fix | Delete
// Hashed in wp_update_user(), plaintext if called directly.
[2135] Fix | Delete
$user_pass = ! empty( $userdata['user_pass'] ) ? $userdata['user_pass'] : $old_user_data->user_pass;
[2136] Fix | Delete
} else {
[2137] Fix | Delete
$update = false;
[2138] Fix | Delete
// Hash the password.
[2139] Fix | Delete
$user_pass = wp_hash_password( $userdata['user_pass'] );
[2140] Fix | Delete
}
[2141] Fix | Delete
[2142] Fix | Delete
$sanitized_user_login = sanitize_user( $userdata['user_login'], true );
[2143] Fix | Delete
[2144] Fix | Delete
/**
[2145] Fix | Delete
* Filters a username after it has been sanitized.
[2146] Fix | Delete
*
[2147] Fix | Delete
* This filter is called before the user is created or updated.
[2148] Fix | Delete
*
[2149] Fix | Delete
* @since 2.0.3
[2150] Fix | Delete
*
[2151] Fix | Delete
* @param string $sanitized_user_login Username after it has been sanitized.
[2152] Fix | Delete
*/
[2153] Fix | Delete
$pre_user_login = apply_filters( 'pre_user_login', $sanitized_user_login );
[2154] Fix | Delete
[2155] Fix | Delete
// Remove any non-printable chars from the login string to see if we have ended up with an empty username.
[2156] Fix | Delete
$user_login = trim( $pre_user_login );
[2157] Fix | Delete
[2158] Fix | Delete
// user_login must be between 0 and 60 characters.
[2159] Fix | Delete
if ( empty( $user_login ) ) {
[2160] Fix | Delete
return new WP_Error( 'empty_user_login', __( 'Cannot create a user with an empty login name.' ) );
[2161] Fix | Delete
} elseif ( mb_strlen( $user_login ) > 60 ) {
[2162] Fix | Delete
return new WP_Error( 'user_login_too_long', __( 'Username may not be longer than 60 characters.' ) );
[2163] Fix | Delete
}
[2164] Fix | Delete
[2165] Fix | Delete
if ( ! $update && username_exists( $user_login ) ) {
[2166] Fix | Delete
return new WP_Error( 'existing_user_login', __( 'Sorry, that username already exists!' ) );
[2167] Fix | Delete
}
[2168] Fix | Delete
[2169] Fix | Delete
/**
[2170] Fix | Delete
* Filters the list of disallowed usernames.
[2171] Fix | Delete
*
[2172] Fix | Delete
* @since 4.4.0
[2173] Fix | Delete
*
[2174] Fix | Delete
* @param array $usernames Array of disallowed usernames.
[2175] Fix | Delete
*/
[2176] Fix | Delete
$illegal_logins = (array) apply_filters( 'illegal_user_logins', array() );
[2177] Fix | Delete
[2178] Fix | Delete
if ( in_array( strtolower( $user_login ), array_map( 'strtolower', $illegal_logins ), true ) ) {
[2179] Fix | Delete
return new WP_Error( 'invalid_username', __( 'Sorry, that username is not allowed.' ) );
[2180] Fix | Delete
}
[2181] Fix | Delete
[2182] Fix | Delete
/*
[2183] Fix | Delete
* If a nicename is provided, remove unsafe user characters before using it.
[2184] Fix | Delete
* Otherwise build a nicename from the user_login.
[2185] Fix | Delete
*/
[2186] Fix | Delete
if ( ! empty( $userdata['user_nicename'] ) ) {
[2187] Fix | Delete
$user_nicename = sanitize_user( $userdata['user_nicename'], true );
[2188] Fix | Delete
} else {
[2189] Fix | Delete
$user_nicename = mb_substr( $user_login, 0, 50 );
[2190] Fix | Delete
}
[2191] Fix | Delete
[2192] Fix | Delete
$user_nicename = sanitize_title( $user_nicename );
[2193] Fix | Delete
[2194] Fix | Delete
/**
[2195] Fix | Delete
* Filters a user's nicename before the user is created or updated.
[2196] Fix | Delete
*
[2197] Fix | Delete
* @since 2.0.3
[2198] Fix | Delete
*
[2199] Fix | Delete
* @param string $user_nicename The user's nicename.
[2200] Fix | Delete
*/
[2201] Fix | Delete
$user_nicename = apply_filters( 'pre_user_nicename', $user_nicename );
[2202] Fix | Delete
[2203] Fix | Delete
if ( mb_strlen( $user_nicename ) > 50 ) {
[2204] Fix | Delete
return new WP_Error( 'user_nicename_too_long', __( 'Nicename may not be longer than 50 characters.' ) );
[2205] Fix | Delete
}
[2206] Fix | Delete
[2207] Fix | Delete
$user_nicename_check = $wpdb->get_var( $wpdb->prepare( "SELECT ID FROM $wpdb->users WHERE user_nicename = %s AND user_login != %s LIMIT 1", $user_nicename, $user_login ) );
[2208] Fix | Delete
[2209] Fix | Delete
if ( $user_nicename_check ) {
[2210] Fix | Delete
$suffix = 2;
[2211] Fix | Delete
while ( $user_nicename_check ) {
[2212] Fix | Delete
// user_nicename allows 50 chars. Subtract one for a hyphen, plus the length of the suffix.
[2213] Fix | Delete
$base_length = 49 - mb_strlen( $suffix );
[2214] Fix | Delete
$alt_user_nicename = mb_substr( $user_nicename, 0, $base_length ) . "-$suffix";
[2215] Fix | Delete
$user_nicename_check = $wpdb->get_var( $wpdb->prepare( "SELECT ID FROM $wpdb->users WHERE user_nicename = %s AND user_login != %s LIMIT 1", $alt_user_nicename, $user_login ) );
[2216] Fix | Delete
++$suffix;
[2217] Fix | Delete
}
[2218] Fix | Delete
$user_nicename = $alt_user_nicename;
[2219] Fix | Delete
}
[2220] Fix | Delete
[2221] Fix | Delete
$raw_user_email = empty( $userdata['user_email'] ) ? '' : $userdata['user_email'];
[2222] Fix | Delete
[2223] Fix | Delete
/**
[2224] Fix | Delete
* Filters a user's email before the user is created or updated.
[2225] Fix | Delete
*
[2226] Fix | Delete
* @since 2.0.3
[2227] Fix | Delete
*
[2228] Fix | Delete
* @param string $raw_user_email The user's email.
[2229] Fix | Delete
*/
[2230] Fix | Delete
$user_email = apply_filters( 'pre_user_email', $raw_user_email );
[2231] Fix | Delete
[2232] Fix | Delete
/*
[2233] Fix | Delete
* If there is no update, just check for `email_exists`. If there is an update,
[2234] Fix | Delete
* check if current email and new email are the same, and check `email_exists`
[2235] Fix | Delete
* accordingly.
[2236] Fix | Delete
*/
[2237] Fix | Delete
if ( ( ! $update || ( ! empty( $old_user_data ) && 0 !== strcasecmp( $user_email, $old_user_data->user_email ) ) )
[2238] Fix | Delete
&& ! defined( 'WP_IMPORTING' )
[2239] Fix | Delete
&& email_exists( $user_email )
[2240] Fix | Delete
) {
[2241] Fix | Delete
return new WP_Error( 'existing_user_email', __( 'Sorry, that email address is already used!' ) );
[2242] Fix | Delete
}
[2243] Fix | Delete
[2244] Fix | Delete
$raw_user_url = empty( $userdata['user_url'] ) ? '' : $userdata['user_url'];
[2245] Fix | Delete
[2246] Fix | Delete
/**
[2247] Fix | Delete
* Filters a user's URL before the user is created or updated.
[2248] Fix | Delete
*
[2249] Fix | Delete
* @since 2.0.3
[2250] Fix | Delete
*
[2251] Fix | Delete
* @param string $raw_user_url The user's URL.
[2252] Fix | Delete
*/
[2253] Fix | Delete
$user_url = apply_filters( 'pre_user_url', $raw_user_url );
[2254] Fix | Delete
[2255] Fix | Delete
if ( mb_strlen( $user_url ) > 100 ) {
[2256] Fix | Delete
return new WP_Error( 'user_url_too_long', __( 'User URL may not be longer than 100 characters.' ) );
[2257] Fix | Delete
}
[2258] Fix | Delete
[2259] Fix | Delete
$user_registered = empty( $userdata['user_registered'] ) ? gmdate( 'Y-m-d H:i:s' ) : $userdata['user_registered'];
[2260] Fix | Delete
[2261] Fix | Delete
$user_activation_key = empty( $userdata['user_activation_key'] ) ? '' : $userdata['user_activation_key'];
[2262] Fix | Delete
[2263] Fix | Delete
if ( ! empty( $userdata['spam'] ) && ! is_multisite() ) {
[2264] Fix | Delete
return new WP_Error( 'no_spam', __( 'Sorry, marking a user as spam is only supported on Multisite.' ) );
[2265] Fix | Delete
}
[2266] Fix | Delete
[2267] Fix | Delete
$spam = empty( $userdata['spam'] ) ? 0 : (bool) $userdata['spam'];
[2268] Fix | Delete
[2269] Fix | Delete
// Store values to save in user meta.
[2270] Fix | Delete
$meta = array();
[2271] Fix | Delete
[2272] Fix | Delete
$nickname = empty( $userdata['nickname'] ) ? $user_login : $userdata['nickname'];
[2273] Fix | Delete
[2274] Fix | Delete
/**
[2275] Fix | Delete
* Filters a user's nickname before the user is created or updated.
[2276] Fix | Delete
*
[2277] Fix | Delete
* @since 2.0.3
[2278] Fix | Delete
*
[2279] Fix | Delete
* @param string $nickname The user's nickname.
[2280] Fix | Delete
*/
[2281] Fix | Delete
$meta['nickname'] = apply_filters( 'pre_user_nickname', $nickname );
[2282] Fix | Delete
[2283] Fix | Delete
$first_name = empty( $userdata['first_name'] ) ? '' : $userdata['first_name'];
[2284] Fix | Delete
[2285] Fix | Delete
/**
[2286] Fix | Delete
* Filters a user's first name before the user is created or updated.
[2287] Fix | Delete
*
[2288] Fix | Delete
* @since 2.0.3
[2289] Fix | Delete
*
[2290] Fix | Delete
* @param string $first_name The user's first name.
[2291] Fix | Delete
*/
[2292] Fix | Delete
$meta['first_name'] = apply_filters( 'pre_user_first_name', $first_name );
[2293] Fix | Delete
[2294] Fix | Delete
$last_name = empty( $userdata['last_name'] ) ? '' : $userdata['last_name'];
[2295] Fix | Delete
[2296] Fix | Delete
/**
[2297] Fix | Delete
* Filters a user's last name before the user is created or updated.
[2298] Fix | Delete
*
[2299] Fix | Delete
* @since 2.0.3
[2300] Fix | Delete
*
[2301] Fix | Delete
* @param string $last_name The user's last name.
[2302] Fix | Delete
*/
[2303] Fix | Delete
$meta['last_name'] = apply_filters( 'pre_user_last_name', $last_name );
[2304] Fix | Delete
[2305] Fix | Delete
if ( empty( $userdata['display_name'] ) ) {
[2306] Fix | Delete
if ( $update ) {
[2307] Fix | Delete
$display_name = $user_login;
[2308] Fix | Delete
} elseif ( $meta['first_name'] && $meta['last_name'] ) {
[2309] Fix | Delete
$display_name = sprintf(
[2310] Fix | Delete
/* translators: 1: User's first name, 2: Last name. */
[2311] Fix | Delete
_x( '%1$s %2$s', 'Display name based on first name and last name' ),
[2312] Fix | Delete
$meta['first_name'],
[2313] Fix | Delete
$meta['last_name']
[2314] Fix | Delete
);
[2315] Fix | Delete
} elseif ( $meta['first_name'] ) {
[2316] Fix | Delete
$display_name = $meta['first_name'];
[2317] Fix | Delete
} elseif ( $meta['last_name'] ) {
[2318] Fix | Delete
$display_name = $meta['last_name'];
[2319] Fix | Delete
} else {
[2320] Fix | Delete
$display_name = $user_login;
[2321] Fix | Delete
}
[2322] Fix | Delete
} else {
[2323] Fix | Delete
$display_name = $userdata['display_name'];
[2324] Fix | Delete
}
[2325] Fix | Delete
[2326] Fix | Delete
/**
[2327] Fix | Delete
* Filters a user's display name before the user is created or updated.
[2328] Fix | Delete
*
[2329] Fix | Delete
* @since 2.0.3
[2330] Fix | Delete
*
[2331] Fix | Delete
* @param string $display_name The user's display name.
[2332] Fix | Delete
*/
[2333] Fix | Delete
$display_name = apply_filters( 'pre_user_display_name', $display_name );
[2334] Fix | Delete
[2335] Fix | Delete
$description = empty( $userdata['description'] ) ? '' : $userdata['description'];
[2336] Fix | Delete
[2337] Fix | Delete
/**
[2338] Fix | Delete
* Filters a user's description before the user is created or updated.
[2339] Fix | Delete
*
[2340] Fix | Delete
* @since 2.0.3
[2341] Fix | Delete
*
[2342] Fix | Delete
* @param string $description The user's description.
[2343] Fix | Delete
*/
[2344] Fix | Delete
$meta['description'] = apply_filters( 'pre_user_description', $description );
[2345] Fix | Delete
[2346] Fix | Delete
$meta['rich_editing'] = empty( $userdata['rich_editing'] ) ? 'true' : $userdata['rich_editing'];
[2347] Fix | Delete
[2348] Fix | Delete
$meta['syntax_highlighting'] = empty( $userdata['syntax_highlighting'] ) ? 'true' : $userdata['syntax_highlighting'];
[2349] Fix | Delete
[2350] Fix | Delete
$meta['comment_shortcuts'] = empty( $userdata['comment_shortcuts'] ) || 'false' === $userdata['comment_shortcuts'] ? 'false' : 'true';
[2351] Fix | Delete
[2352] Fix | Delete
$admin_color = empty( $userdata['admin_color'] ) ? 'fresh' : $userdata['admin_color'];
[2353] Fix | Delete
$meta['admin_color'] = preg_replace( '|[^a-z0-9 _.\-@]|i', '', $admin_color );
[2354] Fix | Delete
[2355] Fix | Delete
$meta['use_ssl'] = empty( $userdata['use_ssl'] ) ? 0 : (bool) $userdata['use_ssl'];
[2356] Fix | Delete
[2357] Fix | Delete
$meta['show_admin_bar_front'] = empty( $userdata['show_admin_bar_front'] ) ? 'true' : $userdata['show_admin_bar_front'];
[2358] Fix | Delete
[2359] Fix | Delete
$meta['locale'] = isset( $userdata['locale'] ) ? $userdata['locale'] : '';
[2360] Fix | Delete
[2361] Fix | Delete
$compacted = compact( 'user_pass', 'user_nicename', 'user_email', 'user_url', 'user_registered', 'user_activation_key', 'display_name' );
[2362] Fix | Delete
$data = wp_unslash( $compacted );
[2363] Fix | Delete
[2364] Fix | Delete
if ( ! $update ) {
[2365] Fix | Delete
$data = $data + compact( 'user_login' );
[2366] Fix | Delete
}
[2367] Fix | Delete
[2368] Fix | Delete
if ( is_multisite() ) {
[2369] Fix | Delete
$data = $data + compact( 'spam' );
[2370] Fix | Delete
}
[2371] Fix | Delete
[2372] Fix | Delete
/**
[2373] Fix | Delete
* Filters user data before the record is created or updated.
[2374] Fix | Delete
*
[2375] Fix | Delete
* It only includes data in the users table, not any user metadata.
[2376] Fix | Delete
*
[2377] Fix | Delete
* @since 4.9.0
[2378] Fix | Delete
* @since 5.8.0 The `$userdata` parameter was added.
[2379] Fix | Delete
*
[2380] Fix | Delete
* @param array $data {
[2381] Fix | Delete
* Values and keys for the user.
[2382] Fix | Delete
*
[2383] Fix | Delete
* @type string $user_login The user's login. Only included if $update == false
[2384] Fix | Delete
* @type string $user_pass The user's password.
[2385] Fix | Delete
* @type string $user_email The user's email.
[2386] Fix | Delete
* @type string $user_url The user's url.
[2387] Fix | Delete
* @type string $user_nicename The user's nice name. Defaults to a URL-safe version of user's login
[2388] Fix | Delete
* @type string $display_name The user's display name.
[2389] Fix | Delete
* @type string $user_registered MySQL timestamp describing the moment when the user registered. Defaults to
[2390] Fix | Delete
* the current UTC timestamp.
[2391] Fix | Delete
* }
[2392] Fix | Delete
* @param bool $update Whether the user is being updated rather than created.
[2393] Fix | Delete
* @param int|null $user_id ID of the user to be updated, or NULL if the user is being created.
[2394] Fix | Delete
* @param array $userdata The raw array of data passed to wp_insert_user().
[2395] Fix | Delete
*/
[2396] Fix | Delete
$data = apply_filters( 'wp_pre_insert_user_data', $data, $update, ( $update ? $user_id : null ), $userdata );
[2397] Fix | Delete
[2398] Fix | Delete
if ( empty( $data ) || ! is_array( $data ) ) {
[2399] Fix | Delete
return new WP_Error( 'empty_data', __( 'Not enough data to create this user.' ) );
[2400] Fix | Delete
}
[2401] Fix | Delete
[2402] Fix | Delete
if ( $update ) {
[2403] Fix | Delete
if ( $user_email !== $old_user_data->user_email || $user_pass !== $old_user_data->user_pass ) {
[2404] Fix | Delete
$data['user_activation_key'] = '';
[2405] Fix | Delete
}
[2406] Fix | Delete
$wpdb->update( $wpdb->users, $data, array( 'ID' => $user_id ) );
[2407] Fix | Delete
} else {
[2408] Fix | Delete
$wpdb->insert( $wpdb->users, $data );
[2409] Fix | Delete
$user_id = (int) $wpdb->insert_id;
[2410] Fix | Delete
}
[2411] Fix | Delete
[2412] Fix | Delete
$user = new WP_User( $user_id );
[2413] Fix | Delete
[2414] Fix | Delete
/**
[2415] Fix | Delete
* Filters a user's meta values and keys immediately after the user is created or updated
[2416] Fix | Delete
* and before any user meta is inserted or updated.
[2417] Fix | Delete
*
[2418] Fix | Delete
* Does not include contact methods. These are added using `wp_get_user_contact_methods( $user )`.
[2419] Fix | Delete
*
[2420] Fix | Delete
* For custom meta fields, see the {@see 'insert_custom_user_meta'} filter.
[2421] Fix | Delete
*
[2422] Fix | Delete
* @since 4.4.0
[2423] Fix | Delete
* @since 5.8.0 The `$userdata` parameter was added.
[2424] Fix | Delete
*
[2425] Fix | Delete
* @param array $meta {
[2426] Fix | Delete
* Default meta values and keys for the user.
[2427] Fix | Delete
*
[2428] Fix | Delete
* @type string $nickname The user's nickname. Default is the user's username.
[2429] Fix | Delete
* @type string $first_name The user's first name.
[2430] Fix | Delete
* @type string $last_name The user's last name.
[2431] Fix | Delete
* @type string $description The user's description.
[2432] Fix | Delete
* @type string $rich_editing Whether to enable the rich-editor for the user. Default 'true'.
[2433] Fix | Delete
* @type string $syntax_highlighting Whether to enable the rich code editor for the user. Default 'true'.
[2434] Fix | Delete
* @type string $comment_shortcuts Whether to enable keyboard shortcuts for the user. Default 'false'.
[2435] Fix | Delete
* @type string $admin_color The color scheme for a user's admin screen. Default 'fresh'.
[2436] Fix | Delete
* @type int|bool $use_ssl Whether to force SSL on the user's admin area. 0|false if SSL
[2437] Fix | Delete
* is not forced.
[2438] Fix | Delete
* @type string $show_admin_bar_front Whether to show the admin bar on the front end for the user.
[2439] Fix | Delete
* Default 'true'.
[2440] Fix | Delete
* @type string $locale User's locale. Default empty.
[2441] Fix | Delete
* }
[2442] Fix | Delete
* @param WP_User $user User object.
[2443] Fix | Delete
* @param bool $update Whether the user is being updated rather than created.
[2444] Fix | Delete
* @param array $userdata The raw array of data passed to wp_insert_user().
[2445] Fix | Delete
*/
[2446] Fix | Delete
$meta = apply_filters( 'insert_user_meta', $meta, $user, $update, $userdata );
[2447] Fix | Delete
[2448] Fix | Delete
$custom_meta = array();
[2449] Fix | Delete
if ( array_key_exists( 'meta_input', $userdata ) && is_array( $userdata['meta_input'] ) && ! empty( $userdata['meta_input'] ) ) {
[2450] Fix | Delete
$custom_meta = $userdata['meta_input'];
[2451] Fix | Delete
}
[2452] Fix | Delete
[2453] Fix | Delete
/**
[2454] Fix | Delete
* Filters a user's custom meta values and keys immediately after the user is created or updated
[2455] Fix | Delete
* and before any user meta is inserted or updated.
[2456] Fix | Delete
*
[2457] Fix | Delete
* For non-custom meta fields, see the {@see 'insert_user_meta'} filter.
[2458] Fix | Delete
*
[2459] Fix | Delete
* @since 5.9.0
[2460] Fix | Delete
*
[2461] Fix | Delete
* @param array $custom_meta Array of custom user meta values keyed by meta key.
[2462] Fix | Delete
* @param WP_User $user User object.
[2463] Fix | Delete
* @param bool $update Whether the user is being updated rather than created.
[2464] Fix | Delete
* @param array $userdata The raw array of data passed to wp_insert_user().
[2465] Fix | Delete
*/
[2466] Fix | Delete
$custom_meta = apply_filters( 'insert_custom_user_meta', $custom_meta, $user, $update, $userdata );
[2467] Fix | Delete
[2468] Fix | Delete
$meta = array_merge( $meta, $custom_meta );
[2469] Fix | Delete
[2470] Fix | Delete
if ( $update ) {
[2471] Fix | Delete
// Update user meta.
[2472] Fix | Delete
foreach ( $meta as $key => $value ) {
[2473] Fix | Delete
update_user_meta( $user_id, $key, $value );
[2474] Fix | Delete
}
[2475] Fix | Delete
} else {
[2476] Fix | Delete
// Add user meta.
[2477] Fix | Delete
foreach ( $meta as $key => $value ) {
[2478] Fix | Delete
add_user_meta( $user_id, $key, $value );
[2479] Fix | Delete
}
[2480] Fix | Delete
}
[2481] Fix | Delete
[2482] Fix | Delete
foreach ( wp_get_user_contact_methods( $user ) as $key => $value ) {
[2483] Fix | Delete
if ( isset( $userdata[ $key ] ) ) {
[2484] Fix | Delete
update_user_meta( $user_id, $key, $userdata[ $key ] );
[2485] Fix | Delete
}
[2486] Fix | Delete
}
[2487] Fix | Delete
[2488] Fix | Delete
if ( isset( $userdata['role'] ) ) {
[2489] Fix | Delete
$user->set_role( $userdata['role'] );
[2490] Fix | Delete
} elseif ( ! $update ) {
[2491] Fix | Delete
$user->set_role( get_option( 'default_role' ) );
[2492] Fix | Delete
}
[2493] Fix | Delete
[2494] Fix | Delete
clean_user_cache( $user_id );
[2495] Fix | Delete
[2496] Fix | Delete
if ( $update ) {
[2497] Fix | Delete
/**
[2498] Fix | Delete
* Fires immediately after an existing user is updated.
[2499] Fix | Delete
It is recommended that you Edit text format, this type of Fix handles quite a lot in one request
Function