2022-10-21 10:41:20 +02:00

67 lines
2.3 KiB
Rust

//! `GET /_matrix/federation/*/make_leave/{roomId}/{userId}`
//!
//! Endpoint to asks the receiving server to return information that the sending server will need
//! to prepare a leave event to get out of the room.
pub mod v1 {
//! `/v1/` ([spec])
//!
//! [spec]: https://spec.matrix.org/v1.4/server-server-api/#get_matrixfederationv1make_leaveroomiduserid
use ruma_common::{api::ruma_api, RoomId, RoomVersionId, UserId};
use serde_json::value::RawValue as RawJsonValue;
ruma_api! {
metadata: {
description: "Asks the receiving server to return information that the sending server will need to prepare a leave event to get out of the room.",
name: "get_leave_event",
method: GET,
stable_path: "/_matrix/federation/v1/make_leave/:room_id/:user_id",
rate_limited: false,
authentication: ServerSignatures,
added: 1.0,
}
request: {
/// The room ID that is about to be left.
#[ruma_api(path)]
pub room_id: &'a RoomId,
/// The user ID the leave event will be for.
#[ruma_api(path)]
pub user_id: &'a UserId,
}
response: {
/// The version of the room where the server is trying to leave.
///
/// If not provided, the room version is assumed to be either "1" or "2".
pub room_version: Option<RoomVersionId>,
/// An unsigned template event.
///
/// Note that events have a different format depending on the room version - check the room
/// version specification for precise event formats.
pub event: Box<RawJsonValue>,
}
}
impl<'a> Request<'a> {
/// Creates a new `Request` with:
/// * the room ID that is about to be left.
/// * the user ID the leave event will be for.
pub fn new(room_id: &'a RoomId, user_id: &'a UserId) -> Self {
Self { room_id, user_id }
}
}
impl Response {
/// Creates a new `Response` with:
/// * the version of the room where the server is trying to leave.
/// * an unsigned template event.
pub fn new(room_version: Option<RoomVersionId>, event: Box<RawJsonValue>) -> Self {
Self { room_version, event }
}
}
}