feat: suggest servers to join at /_matrix/client/v3/directory/room/{roomAlias}
Signed-off-by: strawberry <strawberry@puppygock.gay>
This commit is contained in:
parent
da3ac7a2f1
commit
49b6f338fd
1 changed files with 53 additions and 9 deletions
|
@ -10,7 +10,7 @@ use ruma::{
|
||||||
},
|
},
|
||||||
federation,
|
federation,
|
||||||
},
|
},
|
||||||
OwnedRoomAliasId,
|
OwnedRoomAliasId, OwnedServerName,
|
||||||
};
|
};
|
||||||
|
|
||||||
/// # `PUT /_matrix/client/r0/directory/room/{roomAlias}`
|
/// # `PUT /_matrix/client/r0/directory/room/{roomAlias}`
|
||||||
|
@ -66,11 +66,9 @@ pub async fn delete_alias_route(
|
||||||
Ok(delete_alias::v3::Response::new())
|
Ok(delete_alias::v3::Response::new())
|
||||||
}
|
}
|
||||||
|
|
||||||
/// # `GET /_matrix/client/r0/directory/room/{roomAlias}`
|
/// # `GET /_matrix/client/v3/directory/room/{roomAlias}`
|
||||||
///
|
///
|
||||||
/// Resolve an alias locally or over federation.
|
/// Resolve an alias locally or over federation.
|
||||||
///
|
|
||||||
/// - TODO: Suggest more servers to join via
|
|
||||||
pub async fn get_alias_route(
|
pub async fn get_alias_route(
|
||||||
body: Ruma<get_alias::v3::Request>,
|
body: Ruma<get_alias::v3::Request>,
|
||||||
) -> Result<get_alias::v3::Response> {
|
) -> Result<get_alias::v3::Response> {
|
||||||
|
@ -91,10 +89,34 @@ pub(crate) async fn get_alias_helper(
|
||||||
)
|
)
|
||||||
.await?;
|
.await?;
|
||||||
|
|
||||||
|
let room_id = response.room_id;
|
||||||
|
|
||||||
let mut servers = response.servers;
|
let mut servers = response.servers;
|
||||||
|
|
||||||
|
// find active servers in room state cache to suggest
|
||||||
|
for extra_servers in services()
|
||||||
|
.rooms
|
||||||
|
.state_cache
|
||||||
|
.room_servers(&room_id)
|
||||||
|
.filter_map(|r| r.ok())
|
||||||
|
{
|
||||||
|
servers.push(extra_servers);
|
||||||
|
}
|
||||||
|
|
||||||
|
// shuffle list of servers randomly
|
||||||
servers.shuffle(&mut rand::thread_rng());
|
servers.shuffle(&mut rand::thread_rng());
|
||||||
|
|
||||||
return Ok(get_alias::v3::Response::new(response.room_id, servers));
|
// insert our server as the very first choice if in list
|
||||||
|
if let Some(server_index) = servers
|
||||||
|
.clone()
|
||||||
|
.into_iter()
|
||||||
|
.position(|server| server == services().globals.server_name())
|
||||||
|
{
|
||||||
|
servers.remove(server_index);
|
||||||
|
servers.insert(0, services().globals.server_name().to_owned());
|
||||||
|
}
|
||||||
|
|
||||||
|
return Ok(get_alias::v3::Response::new(room_id, servers));
|
||||||
}
|
}
|
||||||
|
|
||||||
let mut room_id = None;
|
let mut room_id = None;
|
||||||
|
@ -152,8 +174,30 @@ pub(crate) async fn get_alias_helper(
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
Ok(get_alias::v3::Response::new(
|
let mut servers: Vec<OwnedServerName> = Vec::new();
|
||||||
room_id,
|
|
||||||
vec![services().globals.server_name().to_owned()],
|
// find active servers in room state cache to suggest
|
||||||
))
|
for extra_servers in services()
|
||||||
|
.rooms
|
||||||
|
.state_cache
|
||||||
|
.room_servers(&room_id)
|
||||||
|
.filter_map(|r| r.ok())
|
||||||
|
{
|
||||||
|
servers.push(extra_servers);
|
||||||
|
}
|
||||||
|
|
||||||
|
// shuffle list of servers randomly
|
||||||
|
servers.shuffle(&mut rand::thread_rng());
|
||||||
|
|
||||||
|
// insert our server as the very first choice if in list
|
||||||
|
if let Some(server_index) = servers
|
||||||
|
.clone()
|
||||||
|
.into_iter()
|
||||||
|
.position(|server| server == services().globals.server_name())
|
||||||
|
{
|
||||||
|
servers.remove(server_index);
|
||||||
|
servers.insert(0, services().globals.server_name().to_owned());
|
||||||
|
}
|
||||||
|
|
||||||
|
Ok(get_alias::v3::Response::new(room_id, servers))
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue