Merge pull request 'improvement: handle limit and set limited in /user_directory/search' (#169) from user-dir-limit into master

Reviewed-on: https://git.koesters.xyz/timo/conduit/pulls/169
merge-requests/22/head
Timo Kösters 4 years ago
commit 100e3d6d6d

@ -2262,39 +2262,42 @@ pub fn search_users_route(
db: State<'_, Database>, db: State<'_, Database>,
body: Ruma<search_users::Request>, body: Ruma<search_users::Request>,
) -> ConduitResult<search_users::Response> { ) -> ConduitResult<search_users::Response> {
Ok(search_users::Response { let limit = if let Some(limit) = body.limit {
results: db u64::from(limit)
.users } else {
.iter() 10
.filter_map(|user_id| { } as usize;
// Filter out buggy users (they should not exist, but you never know...)
let user_id = user_id.ok()?; let mut users = db.users.iter().filter_map(|user_id| {
if db.users.is_deactivated(&user_id).ok()? { // Filter out buggy users (they should not exist, but you never know...)
return None; let user_id = user_id.ok()?;
} if db.users.is_deactivated(&user_id).ok()? {
return None;
}
let user = search_users::User { let user = search_users::User {
user_id: user_id.clone(), user_id: user_id.clone(),
display_name: db.users.displayname(&user_id).ok()?, display_name: db.users.displayname(&user_id).ok()?,
avatar_url: db.users.avatar_url(&user_id).ok()?, avatar_url: db.users.avatar_url(&user_id).ok()?,
}; };
if !user.user_id.to_string().contains(&body.search_term)
&& user
.display_name
.as_ref()
.filter(|name| name.contains(&body.search_term))
.is_none()
{
return None;
}
Some(user) if !user.user_id.to_string().contains(&body.search_term)
}) && user
.collect(), .display_name
limited: false, .as_ref()
} .filter(|name| name.contains(&body.search_term))
.into()) .is_none()
{
return None;
}
Some(user)
});
let results = users.by_ref().take(limit).collect();
let limited = users.next().is_some();
Ok(search_users::Response { results, limited }.into())
} }
#[cfg_attr( #[cfg_attr(

Loading…
Cancel
Save