split spaces service
Signed-off-by: Jason Volk <jason@zemos.net>
This commit is contained in:
parent
31ab84e928
commit
d8e94ee965
4 changed files with 318 additions and 322 deletions
|
@ -1,7 +1,12 @@
|
|||
use axum::extract::State;
|
||||
use ruma::api::{client::error::ErrorKind, federation::space::get_hierarchy};
|
||||
use conduwuit::{Err, Result};
|
||||
use ruma::{api::federation::space::get_hierarchy, RoomId, ServerName};
|
||||
use service::{
|
||||
rooms::spaces::{get_parent_children_via, Identifier, SummaryAccessibility},
|
||||
Services,
|
||||
};
|
||||
|
||||
use crate::{Error, Result, Ruma};
|
||||
use crate::Ruma;
|
||||
|
||||
/// # `GET /_matrix/federation/v1/hierarchy/{roomId}`
|
||||
///
|
||||
|
@ -11,13 +16,58 @@ pub(crate) async fn get_hierarchy_route(
|
|||
State(services): State<crate::State>,
|
||||
body: Ruma<get_hierarchy::v1::Request>,
|
||||
) -> Result<get_hierarchy::v1::Response> {
|
||||
if services.rooms.metadata.exists(&body.room_id).await {
|
||||
services
|
||||
.rooms
|
||||
.spaces
|
||||
.get_federation_hierarchy(&body.room_id, body.origin(), body.suggested_only)
|
||||
.await
|
||||
} else {
|
||||
Err(Error::BadRequest(ErrorKind::NotFound, "Room does not exist."))
|
||||
if !services.rooms.metadata.exists(&body.room_id).await {
|
||||
return Err!(Request(NotFound("Room does not exist.")));
|
||||
}
|
||||
|
||||
get_hierarchy(&services, &body.room_id, body.origin(), body.suggested_only).await
|
||||
}
|
||||
|
||||
/// Gets the response for the space hierarchy over federation request
|
||||
///
|
||||
/// Errors if the room does not exist, so a check if the room exists should
|
||||
/// be done
|
||||
async fn get_hierarchy(
|
||||
services: &Services,
|
||||
room_id: &RoomId,
|
||||
server_name: &ServerName,
|
||||
suggested_only: bool,
|
||||
) -> Result<get_hierarchy::v1::Response> {
|
||||
match services
|
||||
.rooms
|
||||
.spaces
|
||||
.get_summary_and_children_local(&room_id.to_owned(), Identifier::ServerName(server_name))
|
||||
.await?
|
||||
{
|
||||
| Some(SummaryAccessibility::Accessible(room)) => {
|
||||
let mut children = Vec::new();
|
||||
let mut inaccessible_children = Vec::new();
|
||||
|
||||
for (child, _via) in get_parent_children_via(&room, suggested_only) {
|
||||
match services
|
||||
.rooms
|
||||
.spaces
|
||||
.get_summary_and_children_local(&child, Identifier::ServerName(server_name))
|
||||
.await?
|
||||
{
|
||||
| Some(SummaryAccessibility::Accessible(summary)) => {
|
||||
children.push((*summary).into());
|
||||
},
|
||||
| Some(SummaryAccessibility::Inaccessible) => {
|
||||
inaccessible_children.push(child);
|
||||
},
|
||||
| None => (),
|
||||
}
|
||||
}
|
||||
|
||||
Ok(get_hierarchy::v1::Response {
|
||||
room: *room,
|
||||
children,
|
||||
inaccessible_children,
|
||||
})
|
||||
},
|
||||
| Some(SummaryAccessibility::Inaccessible) =>
|
||||
Err!(Request(NotFound("The requested room is inaccessible"))),
|
||||
| None => Err!(Request(NotFound("The requested room was not found"))),
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue