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 $input_user;
[500] Fix | Delete
}
[501] Fix | Delete
[502] Fix | Delete
$authenticated = wp_authenticate_application_password( null, $_SERVER['PHP_AUTH_USER'], $_SERVER['PHP_AUTH_PW'] );
[503] Fix | Delete
[504] Fix | Delete
if ( $authenticated instanceof WP_User ) {
[505] Fix | Delete
return $authenticated->ID;
[506] Fix | Delete
}
[507] Fix | Delete
[508] Fix | Delete
// If it wasn't a user what got returned, just pass on what we had received originally.
[509] Fix | Delete
return $input_user;
[510] Fix | Delete
}
[511] Fix | Delete
[512] Fix | Delete
/**
[513] Fix | Delete
* For Multisite blogs, checks if the authenticated user has been marked as a
[514] Fix | Delete
* spammer, or if the user's primary blog has been marked as spam.
[515] Fix | Delete
*
[516] Fix | Delete
* @since 3.7.0
[517] Fix | Delete
*
[518] Fix | Delete
* @param WP_User|WP_Error|null $user WP_User or WP_Error object from a previous callback. Default null.
[519] Fix | Delete
* @return WP_User|WP_Error WP_User on success, WP_Error if the user is considered a spammer.
[520] Fix | Delete
*/
[521] Fix | Delete
function wp_authenticate_spam_check( $user ) {
[522] Fix | Delete
if ( $user instanceof WP_User && is_multisite() ) {
[523] Fix | Delete
/**
[524] Fix | Delete
* Filters whether the user has been marked as a spammer.
[525] Fix | Delete
*
[526] Fix | Delete
* @since 3.7.0
[527] Fix | Delete
*
[528] Fix | Delete
* @param bool $spammed Whether the user is considered a spammer.
[529] Fix | Delete
* @param WP_User $user User to check against.
[530] Fix | Delete
*/
[531] Fix | Delete
$spammed = apply_filters( 'check_is_user_spammed', is_user_spammy( $user ), $user );
[532] Fix | Delete
[533] Fix | Delete
if ( $spammed ) {
[534] Fix | Delete
return new WP_Error( 'spammer_account', __( '<strong>Error:</strong> Your account has been marked as a spammer.' ) );
[535] Fix | Delete
}
[536] Fix | Delete
}
[537] Fix | Delete
return $user;
[538] Fix | Delete
}
[539] Fix | Delete
[540] Fix | Delete
/**
[541] Fix | Delete
* Validates the logged-in cookie.
[542] Fix | Delete
*
[543] Fix | Delete
* Checks the logged-in cookie if the previous auth cookie could not be
[544] Fix | Delete
* validated and parsed.
[545] Fix | Delete
*
[546] Fix | Delete
* This is a callback for the {@see 'determine_current_user'} filter, rather than API.
[547] Fix | Delete
*
[548] Fix | Delete
* @since 3.9.0
[549] Fix | Delete
*
[550] Fix | Delete
* @param int|false $user_id The user ID (or false) as received from
[551] Fix | Delete
* the `determine_current_user` filter.
[552] Fix | Delete
* @return int|false User ID if validated, false otherwise. If a user ID from
[553] Fix | Delete
* an earlier filter callback is received, that value is returned.
[554] Fix | Delete
*/
[555] Fix | Delete
function wp_validate_logged_in_cookie( $user_id ) {
[556] Fix | Delete
if ( $user_id ) {
[557] Fix | Delete
return $user_id;
[558] Fix | Delete
}
[559] Fix | Delete
[560] Fix | Delete
if ( is_blog_admin() || is_network_admin() || empty( $_COOKIE[ LOGGED_IN_COOKIE ] ) ) {
[561] Fix | Delete
return false;
[562] Fix | Delete
}
[563] Fix | Delete
[564] Fix | Delete
return wp_validate_auth_cookie( $_COOKIE[ LOGGED_IN_COOKIE ], 'logged_in' );
[565] Fix | Delete
}
[566] Fix | Delete
[567] Fix | Delete
/**
[568] Fix | Delete
* Gets the number of posts a user has written.
[569] Fix | Delete
*
[570] Fix | Delete
* @since 3.0.0
[571] Fix | Delete
* @since 4.1.0 Added `$post_type` argument.
[572] Fix | Delete
* @since 4.3.0 Added `$public_only` argument. Added the ability to pass an array
[573] Fix | Delete
* of post types to `$post_type`.
[574] Fix | Delete
*
[575] Fix | Delete
* @global wpdb $wpdb WordPress database abstraction object.
[576] Fix | Delete
*
[577] Fix | Delete
* @param int $userid User ID.
[578] Fix | Delete
* @param array|string $post_type Optional. Single post type or array of post types to count the number of posts for. Default 'post'.
[579] Fix | Delete
* @param bool $public_only Optional. Whether to only return counts for public posts. Default false.
[580] Fix | Delete
* @return string Number of posts the user has written in this post type.
[581] Fix | Delete
*/
[582] Fix | Delete
function count_user_posts( $userid, $post_type = 'post', $public_only = false ) {
[583] Fix | Delete
global $wpdb;
[584] Fix | Delete
[585] Fix | Delete
$where = get_posts_by_author_sql( $post_type, true, $userid, $public_only );
[586] Fix | Delete
[587] Fix | Delete
$count = $wpdb->get_var( "SELECT COUNT(*) FROM $wpdb->posts $where" );
[588] Fix | Delete
[589] Fix | Delete
/**
[590] Fix | Delete
* Filters the number of posts a user has written.
[591] Fix | Delete
*
[592] Fix | Delete
* @since 2.7.0
[593] Fix | Delete
* @since 4.1.0 Added `$post_type` argument.
[594] Fix | Delete
* @since 4.3.1 Added `$public_only` argument.
[595] Fix | Delete
*
[596] Fix | Delete
* @param int $count The user's post count.
[597] Fix | Delete
* @param int $userid User ID.
[598] Fix | Delete
* @param string|array $post_type Single post type or array of post types to count the number of posts for.
[599] Fix | Delete
* @param bool $public_only Whether to limit counted posts to public posts.
[600] Fix | Delete
*/
[601] Fix | Delete
return apply_filters( 'get_usernumposts', $count, $userid, $post_type, $public_only );
[602] Fix | Delete
}
[603] Fix | Delete
[604] Fix | Delete
/**
[605] Fix | Delete
* Gets the number of posts written by a list of users.
[606] Fix | Delete
*
[607] Fix | Delete
* @since 3.0.0
[608] Fix | Delete
*
[609] Fix | Delete
* @global wpdb $wpdb WordPress database abstraction object.
[610] Fix | Delete
*
[611] Fix | Delete
* @param int[] $users Array of user IDs.
[612] Fix | Delete
* @param string|string[] $post_type Optional. Single post type or array of post types to check. Defaults to 'post'.
[613] Fix | Delete
* @param bool $public_only Optional. Only return counts for public posts. Defaults to false.
[614] Fix | Delete
* @return string[] Amount of posts each user has written, as strings, keyed by user ID.
[615] Fix | Delete
*/
[616] Fix | Delete
function count_many_users_posts( $users, $post_type = 'post', $public_only = false ) {
[617] Fix | Delete
global $wpdb;
[618] Fix | Delete
[619] Fix | Delete
$count = array();
[620] Fix | Delete
if ( empty( $users ) || ! is_array( $users ) ) {
[621] Fix | Delete
return $count;
[622] Fix | Delete
}
[623] Fix | Delete
[624] Fix | Delete
$userlist = implode( ',', array_map( 'absint', $users ) );
[625] Fix | Delete
$where = get_posts_by_author_sql( $post_type, true, null, $public_only );
[626] Fix | Delete
[627] Fix | Delete
$result = $wpdb->get_results( "SELECT post_author, COUNT(*) FROM $wpdb->posts $where AND post_author IN ($userlist) GROUP BY post_author", ARRAY_N );
[628] Fix | Delete
foreach ( $result as $row ) {
[629] Fix | Delete
$count[ $row[0] ] = $row[1];
[630] Fix | Delete
}
[631] Fix | Delete
[632] Fix | Delete
foreach ( $users as $id ) {
[633] Fix | Delete
if ( ! isset( $count[ $id ] ) ) {
[634] Fix | Delete
$count[ $id ] = 0;
[635] Fix | Delete
}
[636] Fix | Delete
}
[637] Fix | Delete
[638] Fix | Delete
return $count;
[639] Fix | Delete
}
[640] Fix | Delete
[641] Fix | Delete
//
[642] Fix | Delete
// User option functions.
[643] Fix | Delete
//
[644] Fix | Delete
[645] Fix | Delete
/**
[646] Fix | Delete
* Gets the current user's ID.
[647] Fix | Delete
*
[648] Fix | Delete
* @since MU (3.0.0)
[649] Fix | Delete
*
[650] Fix | Delete
* @return int The current user's ID, or 0 if no user is logged in.
[651] Fix | Delete
*/
[652] Fix | Delete
function get_current_user_id() {
[653] Fix | Delete
if ( ! function_exists( 'wp_get_current_user' ) ) {
[654] Fix | Delete
return 0;
[655] Fix | Delete
}
[656] Fix | Delete
$user = wp_get_current_user();
[657] Fix | Delete
return ( isset( $user->ID ) ? (int) $user->ID : 0 );
[658] Fix | Delete
}
[659] Fix | Delete
[660] Fix | Delete
/**
[661] Fix | Delete
* Retrieves user option that can be either per Site or per Network.
[662] Fix | Delete
*
[663] Fix | Delete
* If the user ID is not given, then the current user will be used instead. If
[664] Fix | Delete
* the user ID is given, then the user data will be retrieved. The filter for
[665] Fix | Delete
* the result, will also pass the original option name and finally the user data
[666] Fix | Delete
* object as the third parameter.
[667] Fix | Delete
*
[668] Fix | Delete
* The option will first check for the per site name and then the per Network name.
[669] Fix | Delete
*
[670] Fix | Delete
* @since 2.0.0
[671] Fix | Delete
*
[672] Fix | Delete
* @global wpdb $wpdb WordPress database abstraction object.
[673] Fix | Delete
*
[674] Fix | Delete
* @param string $option User option name.
[675] Fix | Delete
* @param int $user Optional. User ID.
[676] Fix | Delete
* @param string $deprecated Use get_option() to check for an option in the options table.
[677] Fix | Delete
* @return mixed User option value on success, false on failure.
[678] Fix | Delete
*/
[679] Fix | Delete
function get_user_option( $option, $user = 0, $deprecated = '' ) {
[680] Fix | Delete
global $wpdb;
[681] Fix | Delete
[682] Fix | Delete
if ( ! empty( $deprecated ) ) {
[683] Fix | Delete
_deprecated_argument( __FUNCTION__, '3.0.0' );
[684] Fix | Delete
}
[685] Fix | Delete
[686] Fix | Delete
if ( empty( $user ) ) {
[687] Fix | Delete
$user = get_current_user_id();
[688] Fix | Delete
}
[689] Fix | Delete
[690] Fix | Delete
$user = get_userdata( $user );
[691] Fix | Delete
if ( ! $user ) {
[692] Fix | Delete
return false;
[693] Fix | Delete
}
[694] Fix | Delete
[695] Fix | Delete
$prefix = $wpdb->get_blog_prefix();
[696] Fix | Delete
if ( $user->has_prop( $prefix . $option ) ) { // Blog-specific.
[697] Fix | Delete
$result = $user->get( $prefix . $option );
[698] Fix | Delete
} elseif ( $user->has_prop( $option ) ) { // User-specific and cross-blog.
[699] Fix | Delete
$result = $user->get( $option );
[700] Fix | Delete
} else {
[701] Fix | Delete
$result = false;
[702] Fix | Delete
}
[703] Fix | Delete
[704] Fix | Delete
/**
[705] Fix | Delete
* Filters a specific user option value.
[706] Fix | Delete
*
[707] Fix | Delete
* The dynamic portion of the hook name, `$option`, refers to the user option name.
[708] Fix | Delete
*
[709] Fix | Delete
* @since 2.5.0
[710] Fix | Delete
*
[711] Fix | Delete
* @param mixed $result Value for the user's option.
[712] Fix | Delete
* @param string $option Name of the option being retrieved.
[713] Fix | Delete
* @param WP_User $user WP_User object of the user whose option is being retrieved.
[714] Fix | Delete
*/
[715] Fix | Delete
return apply_filters( "get_user_option_{$option}", $result, $option, $user );
[716] Fix | Delete
}
[717] Fix | Delete
[718] Fix | Delete
/**
[719] Fix | Delete
* Updates user option with global blog capability.
[720] Fix | Delete
*
[721] Fix | Delete
* User options are just like user metadata except that they have support for
[722] Fix | Delete
* global blog options. If the 'is_global' parameter is false, which it is by default,
[723] Fix | Delete
* it will prepend the WordPress table prefix to the option name.
[724] Fix | Delete
*
[725] Fix | Delete
* Deletes the user option if $newvalue is empty.
[726] Fix | Delete
*
[727] Fix | Delete
* @since 2.0.0
[728] Fix | Delete
*
[729] Fix | Delete
* @global wpdb $wpdb WordPress database abstraction object.
[730] Fix | Delete
*
[731] Fix | Delete
* @param int $user_id User ID.
[732] Fix | Delete
* @param string $option_name User option name.
[733] Fix | Delete
* @param mixed $newvalue User option value.
[734] Fix | Delete
* @param bool $is_global Optional. Whether option name is global or blog specific.
[735] Fix | Delete
* Default false (blog specific).
[736] Fix | Delete
* @return int|bool User meta ID if the option didn't exist, true on successful update,
[737] Fix | Delete
* false on failure.
[738] Fix | Delete
*/
[739] Fix | Delete
function update_user_option( $user_id, $option_name, $newvalue, $is_global = false ) {
[740] Fix | Delete
global $wpdb;
[741] Fix | Delete
[742] Fix | Delete
if ( ! $is_global ) {
[743] Fix | Delete
$option_name = $wpdb->get_blog_prefix() . $option_name;
[744] Fix | Delete
}
[745] Fix | Delete
[746] Fix | Delete
return update_user_meta( $user_id, $option_name, $newvalue );
[747] Fix | Delete
}
[748] Fix | Delete
[749] Fix | Delete
/**
[750] Fix | Delete
* Deletes user option with global blog capability.
[751] Fix | Delete
*
[752] Fix | Delete
* User options are just like user metadata except that they have support for
[753] Fix | Delete
* global blog options. If the 'is_global' parameter is false, which it is by default,
[754] Fix | Delete
* it will prepend the WordPress table prefix to the option name.
[755] Fix | Delete
*
[756] Fix | Delete
* @since 3.0.0
[757] Fix | Delete
*
[758] Fix | Delete
* @global wpdb $wpdb WordPress database abstraction object.
[759] Fix | Delete
*
[760] Fix | Delete
* @param int $user_id User ID
[761] Fix | Delete
* @param string $option_name User option name.
[762] Fix | Delete
* @param bool $is_global Optional. Whether option name is global or blog specific.
[763] Fix | Delete
* Default false (blog specific).
[764] Fix | Delete
* @return bool True on success, false on failure.
[765] Fix | Delete
*/
[766] Fix | Delete
function delete_user_option( $user_id, $option_name, $is_global = false ) {
[767] Fix | Delete
global $wpdb;
[768] Fix | Delete
[769] Fix | Delete
if ( ! $is_global ) {
[770] Fix | Delete
$option_name = $wpdb->get_blog_prefix() . $option_name;
[771] Fix | Delete
}
[772] Fix | Delete
[773] Fix | Delete
return delete_user_meta( $user_id, $option_name );
[774] Fix | Delete
}
[775] Fix | Delete
[776] Fix | Delete
/**
[777] Fix | Delete
* Retrieves list of users matching criteria.
[778] Fix | Delete
*
[779] Fix | Delete
* @since 3.1.0
[780] Fix | Delete
*
[781] Fix | Delete
* @see WP_User_Query
[782] Fix | Delete
*
[783] Fix | Delete
* @param array $args Optional. Arguments to retrieve users. See WP_User_Query::prepare_query()
[784] Fix | Delete
* for more information on accepted arguments.
[785] Fix | Delete
* @return array List of users.
[786] Fix | Delete
*/
[787] Fix | Delete
function get_users( $args = array() ) {
[788] Fix | Delete
[789] Fix | Delete
$args = wp_parse_args( $args );
[790] Fix | Delete
$args['count_total'] = false;
[791] Fix | Delete
[792] Fix | Delete
$user_search = new WP_User_Query( $args );
[793] Fix | Delete
[794] Fix | Delete
return (array) $user_search->get_results();
[795] Fix | Delete
}
[796] Fix | Delete
[797] Fix | Delete
/**
[798] Fix | Delete
* Lists all the users of the site, with several options available.
[799] Fix | Delete
*
[800] Fix | Delete
* @since 5.9.0
[801] Fix | Delete
*
[802] Fix | Delete
* @param string|array $args {
[803] Fix | Delete
* Optional. Array or string of default arguments.
[804] Fix | Delete
*
[805] Fix | Delete
* @type string $orderby How to sort the users. Accepts 'nicename', 'email', 'url', 'registered',
[806] Fix | Delete
* 'user_nicename', 'user_email', 'user_url', 'user_registered', 'name',
[807] Fix | Delete
* 'display_name', 'post_count', 'ID', 'meta_value', 'user_login'. Default 'name'.
[808] Fix | Delete
* @type string $order Sorting direction for $orderby. Accepts 'ASC', 'DESC'. Default 'ASC'.
[809] Fix | Delete
* @type int $number Maximum users to return or display. Default empty (all users).
[810] Fix | Delete
* @type bool $exclude_admin Whether to exclude the 'admin' account, if it exists. Default false.
[811] Fix | Delete
* @type bool $show_fullname Whether to show the user's full name. Default false.
[812] Fix | Delete
* @type string $feed If not empty, show a link to the user's feed and use this text as the alt
[813] Fix | Delete
* parameter of the link. Default empty.
[814] Fix | Delete
* @type string $feed_image If not empty, show a link to the user's feed and use this image URL as
[815] Fix | Delete
* clickable anchor. Default empty.
[816] Fix | Delete
* @type string $feed_type The feed type to link to, such as 'rss2'. Defaults to default feed type.
[817] Fix | Delete
* @type bool $echo Whether to output the result or instead return it. Default true.
[818] Fix | Delete
* @type string $style If 'list', each user is wrapped in an `<li>` element, otherwise the users
[819] Fix | Delete
* will be separated by commas.
[820] Fix | Delete
* @type bool $html Whether to list the items in HTML form or plaintext. Default true.
[821] Fix | Delete
* @type string $exclude An array, comma-, or space-separated list of user IDs to exclude. Default empty.
[822] Fix | Delete
* @type string $include An array, comma-, or space-separated list of user IDs to include. Default empty.
[823] Fix | Delete
* }
[824] Fix | Delete
* @return string|null The output if echo is false. Otherwise null.
[825] Fix | Delete
*/
[826] Fix | Delete
function wp_list_users( $args = array() ) {
[827] Fix | Delete
$defaults = array(
[828] Fix | Delete
'orderby' => 'name',
[829] Fix | Delete
'order' => 'ASC',
[830] Fix | Delete
'number' => '',
[831] Fix | Delete
'exclude_admin' => true,
[832] Fix | Delete
'show_fullname' => false,
[833] Fix | Delete
'feed' => '',
[834] Fix | Delete
'feed_image' => '',
[835] Fix | Delete
'feed_type' => '',
[836] Fix | Delete
'echo' => true,
[837] Fix | Delete
'style' => 'list',
[838] Fix | Delete
'html' => true,
[839] Fix | Delete
'exclude' => '',
[840] Fix | Delete
'include' => '',
[841] Fix | Delete
);
[842] Fix | Delete
[843] Fix | Delete
$parsed_args = wp_parse_args( $args, $defaults );
[844] Fix | Delete
[845] Fix | Delete
$return = '';
[846] Fix | Delete
[847] Fix | Delete
$query_args = wp_array_slice_assoc( $parsed_args, array( 'orderby', 'order', 'number', 'exclude', 'include' ) );
[848] Fix | Delete
$query_args['fields'] = 'ids';
[849] Fix | Delete
[850] Fix | Delete
/**
[851] Fix | Delete
* Filters the query arguments for the list of all users of the site.
[852] Fix | Delete
*
[853] Fix | Delete
* @since 6.1.0
[854] Fix | Delete
*
[855] Fix | Delete
* @param array $query_args The query arguments for get_users().
[856] Fix | Delete
* @param array $parsed_args The arguments passed to wp_list_users() combined with the defaults.
[857] Fix | Delete
*/
[858] Fix | Delete
$query_args = apply_filters( 'wp_list_users_args', $query_args, $parsed_args );
[859] Fix | Delete
[860] Fix | Delete
$users = get_users( $query_args );
[861] Fix | Delete
[862] Fix | Delete
foreach ( $users as $user_id ) {
[863] Fix | Delete
$user = get_userdata( $user_id );
[864] Fix | Delete
[865] Fix | Delete
if ( $parsed_args['exclude_admin'] && 'admin' === $user->display_name ) {
[866] Fix | Delete
continue;
[867] Fix | Delete
}
[868] Fix | Delete
[869] Fix | Delete
if ( $parsed_args['show_fullname'] && '' !== $user->first_name && '' !== $user->last_name ) {
[870] Fix | Delete
$name = sprintf(
[871] Fix | Delete
/* translators: 1: User's first name, 2: Last name. */
[872] Fix | Delete
_x( '%1$s %2$s', 'Display name based on first name and last name' ),
[873] Fix | Delete
$user->first_name,
[874] Fix | Delete
$user->last_name
[875] Fix | Delete
);
[876] Fix | Delete
} else {
[877] Fix | Delete
$name = $user->display_name;
[878] Fix | Delete
}
[879] Fix | Delete
[880] Fix | Delete
if ( ! $parsed_args['html'] ) {
[881] Fix | Delete
$return .= $name . ', ';
[882] Fix | Delete
[883] Fix | Delete
continue; // No need to go further to process HTML.
[884] Fix | Delete
}
[885] Fix | Delete
[886] Fix | Delete
if ( 'list' === $parsed_args['style'] ) {
[887] Fix | Delete
$return .= '<li>';
[888] Fix | Delete
}
[889] Fix | Delete
[890] Fix | Delete
$row = $name;
[891] Fix | Delete
[892] Fix | Delete
if ( ! empty( $parsed_args['feed_image'] ) || ! empty( $parsed_args['feed'] ) ) {
[893] Fix | Delete
$row .= ' ';
[894] Fix | Delete
if ( empty( $parsed_args['feed_image'] ) ) {
[895] Fix | Delete
$row .= '(';
[896] Fix | Delete
}
[897] Fix | Delete
[898] Fix | Delete
$row .= '<a href="' . get_author_feed_link( $user->ID, $parsed_args['feed_type'] ) . '"';
[899] Fix | Delete
[900] Fix | Delete
$alt = '';
[901] Fix | Delete
if ( ! empty( $parsed_args['feed'] ) ) {
[902] Fix | Delete
$alt = ' alt="' . esc_attr( $parsed_args['feed'] ) . '"';
[903] Fix | Delete
$name = $parsed_args['feed'];
[904] Fix | Delete
}
[905] Fix | Delete
[906] Fix | Delete
$row .= '>';
[907] Fix | Delete
[908] Fix | Delete
if ( ! empty( $parsed_args['feed_image'] ) ) {
[909] Fix | Delete
$row .= '<img src="' . esc_url( $parsed_args['feed_image'] ) . '" style="border: none;"' . $alt . ' />';
[910] Fix | Delete
} else {
[911] Fix | Delete
$row .= $name;
[912] Fix | Delete
}
[913] Fix | Delete
[914] Fix | Delete
$row .= '</a>';
[915] Fix | Delete
[916] Fix | Delete
if ( empty( $parsed_args['feed_image'] ) ) {
[917] Fix | Delete
$row .= ')';
[918] Fix | Delete
}
[919] Fix | Delete
}
[920] Fix | Delete
[921] Fix | Delete
$return .= $row;
[922] Fix | Delete
$return .= ( 'list' === $parsed_args['style'] ) ? '</li>' : ', ';
[923] Fix | Delete
}
[924] Fix | Delete
[925] Fix | Delete
$return = rtrim( $return, ', ' );
[926] Fix | Delete
[927] Fix | Delete
if ( ! $parsed_args['echo'] ) {
[928] Fix | Delete
return $return;
[929] Fix | Delete
}
[930] Fix | Delete
echo $return;
[931] Fix | Delete
}
[932] Fix | Delete
[933] Fix | Delete
/**
[934] Fix | Delete
* Gets the sites a user belongs to.
[935] Fix | Delete
*
[936] Fix | Delete
* @since 3.0.0
[937] Fix | Delete
* @since 4.7.0 Converted to use `get_sites()`.
[938] Fix | Delete
*
[939] Fix | Delete
* @global wpdb $wpdb WordPress database abstraction object.
[940] Fix | Delete
*
[941] Fix | Delete
* @param int $user_id User ID
[942] Fix | Delete
* @param bool $all Whether to retrieve all sites, or only sites that are not
[943] Fix | Delete
* marked as deleted, archived, or spam.
[944] Fix | Delete
* @return object[] A list of the user's sites. An empty array if the user doesn't exist
[945] Fix | Delete
* or belongs to no sites.
[946] Fix | Delete
*/
[947] Fix | Delete
function get_blogs_of_user( $user_id, $all = false ) {
[948] Fix | Delete
global $wpdb;
[949] Fix | Delete
[950] Fix | Delete
$user_id = (int) $user_id;
[951] Fix | Delete
[952] Fix | Delete
// Logged out users can't have sites.
[953] Fix | Delete
if ( empty( $user_id ) ) {
[954] Fix | Delete
return array();
[955] Fix | Delete
}
[956] Fix | Delete
[957] Fix | Delete
/**
[958] Fix | Delete
* Filters the list of a user's sites before it is populated.
[959] Fix | Delete
*
[960] Fix | Delete
* Returning a non-null value from the filter will effectively short circuit
[961] Fix | Delete
* get_blogs_of_user(), returning that value instead.
[962] Fix | Delete
*
[963] Fix | Delete
* @since 4.6.0
[964] Fix | Delete
*
[965] Fix | Delete
* @param null|object[] $sites An array of site objects of which the user is a member.
[966] Fix | Delete
* @param int $user_id User ID.
[967] Fix | Delete
* @param bool $all Whether the returned array should contain all sites, including
[968] Fix | Delete
* those marked 'deleted', 'archived', or 'spam'. Default false.
[969] Fix | Delete
*/
[970] Fix | Delete
$sites = apply_filters( 'pre_get_blogs_of_user', null, $user_id, $all );
[971] Fix | Delete
[972] Fix | Delete
if ( null !== $sites ) {
[973] Fix | Delete
return $sites;
[974] Fix | Delete
}
[975] Fix | Delete
[976] Fix | Delete
$keys = get_user_meta( $user_id );
[977] Fix | Delete
if ( empty( $keys ) ) {
[978] Fix | Delete
return array();
[979] Fix | Delete
}
[980] Fix | Delete
[981] Fix | Delete
if ( ! is_multisite() ) {
[982] Fix | Delete
$site_id = get_current_blog_id();
[983] Fix | Delete
$sites = array( $site_id => new stdClass() );
[984] Fix | Delete
$sites[ $site_id ]->userblog_id = $site_id;
[985] Fix | Delete
$sites[ $site_id ]->blogname = get_option( 'blogname' );
[986] Fix | Delete
$sites[ $site_id ]->domain = '';
[987] Fix | Delete
$sites[ $site_id ]->path = '';
[988] Fix | Delete
$sites[ $site_id ]->site_id = 1;
[989] Fix | Delete
$sites[ $site_id ]->siteurl = get_option( 'siteurl' );
[990] Fix | Delete
$sites[ $site_id ]->archived = 0;
[991] Fix | Delete
$sites[ $site_id ]->spam = 0;
[992] Fix | Delete
$sites[ $site_id ]->deleted = 0;
[993] Fix | Delete
return $sites;
[994] Fix | Delete
}
[995] Fix | Delete
[996] Fix | Delete
$site_ids = array();
[997] Fix | Delete
[998] Fix | Delete
if ( isset( $keys[ $wpdb->base_prefix . 'capabilities' ] ) && defined( 'MULTISITE' ) ) {
[999] Fix | Delete
It is recommended that you Edit text format, this type of Fix handles quite a lot in one request
Function