//! `GET /_matrix/federation/*/backfill/{roomId}` //! //! Endpoint to request more history from another homeserver. pub mod v1 { //! `/v1/` ([spec]) //! //! [spec]: https://spec.matrix.org/v1.2/server-server-api/#get_matrixfederationv1backfillroomid use js_int::UInt; use ruma_common::{ api::ruma_api, MilliSecondsSinceUnixEpoch, OwnedEventId, OwnedServerName, RoomId, }; use serde_json::value::RawValue as RawJsonValue; ruma_api! { metadata: { description: "Request more history from another homeserver", name: "get_backfill", method: GET, stable_path: "/_matrix/federation/v1/backfill/:room_id", rate_limited: false, authentication: ServerSignatures, added: 1.0, } request: { /// The room ID to backfill. #[ruma_api(path)] pub room_id: &'a RoomId, /// The event IDs to backfill from. #[ruma_api(query)] pub v: &'a [OwnedEventId], /// The maximum number of PDUs to retrieve, including the given events. #[ruma_api(query)] pub limit: UInt, } response: { /// The `server_name` of the homeserver sending this transaction. pub origin: OwnedServerName, /// POSIX timestamp in milliseconds on originating homeserver when this transaction started. pub origin_server_ts: MilliSecondsSinceUnixEpoch, /// List of persistent updates to rooms. pub pdus: Vec>, } } impl<'a> Request<'a> { /// Creates a new `Request` with: /// * the given room id. /// * the event IDs to backfill from. /// * the maximum number of PDUs to retrieve, including the given events. pub fn new(room_id: &'a RoomId, v: &'a [OwnedEventId], limit: UInt) -> Self { Self { room_id, v, limit } } } impl Response { /// Creates a new `Response` with: /// * the `server_name` of the homeserver. /// * the timestamp in milliseconds of when this transaction started. /// * the list of persistent updates to rooms. pub fn new( origin: OwnedServerName, origin_server_ts: MilliSecondsSinceUnixEpoch, pdus: Vec>, ) -> Self { Self { origin, origin_server_ts, pdus } } } }