#![allow(clippy::exhaustive_structs)]
#![allow(dead_code)]
use std::borrow::Cow;
use bytes::BufMut;
use http::{header::CONTENT_TYPE, method::Method};
use ruma_common::{
OwnedRoomAliasId, OwnedRoomId,
api::{
EndpointError, IncomingRequest, IncomingResponse, MatrixVersion, Metadata, OutgoingRequest,
OutgoingResponse, SupportedVersions,
auth_scheme::NoAuthentication,
error::{Error, FromHttpRequestError, FromHttpResponseError, IntoHttpError},
path_builder::{StablePathSelector, VersionHistory},
},
};
use serde::{Deserialize, Serialize};
#[derive(Debug, Clone)]
pub struct Request {
pub room_id: OwnedRoomId, pub room_alias: OwnedRoomAliasId, }
impl Metadata for Request {
const METHOD: Method = Method::PUT;
const RATE_LIMITED: bool = false;
type Authentication = NoAuthentication;
type PathBuilder = VersionHistory;
const PATH_BUILDER: VersionHistory = VersionHistory::new(
&[
(None, "/_matrix/client/unstable/directory/room/{room_alias}"),
(
Some("org.bar.directory"),
"/_matrix/client/unstable/org.bar.directory/room/{room_alias}",
),
],
&[
(
StablePathSelector::FeatureAndVersion {
feature: "org.bar.directory.stable",
version: MatrixVersion::V1_0,
},
"/_matrix/client/r0/directory/room/{room_alias}",
),
(
StablePathSelector::Version(MatrixVersion::V1_1),
"/_matrix/client/v3/directory/room/{room_alias}",
),
],
Some(MatrixVersion::V1_2),
Some(MatrixVersion::V1_3),
);
}
impl OutgoingRequest for Request {
type EndpointError = Error;
type IncomingResponse = Response;
fn try_into_http_request<T: Default + BufMut>(
self,
base_url: &str,
_input: (),
considering: Cow<'_, SupportedVersions>,
) -> Result<http::Request<T>, IntoHttpError> {
let url = Self::make_endpoint_url(considering, base_url, &[&self.room_alias], "")?;
let request_body = RequestBody { room_id: self.room_id };
let http_request = http::Request::builder()
.method(Self::METHOD)
.uri(url)
.body(ruma_common::serde::json_to_buf(&request_body)?)
.unwrap();
Ok(http_request)
}
}
impl IncomingRequest for Request {
type EndpointError = Error;
type OutgoingResponse = Response;
fn try_from_http_request<B, S>(
request: http::Request<B>,
path_args: &[S],
) -> Result<Self, FromHttpRequestError>
where
B: AsRef<[u8]>,
S: AsRef<str>,
{
Self::check_request_method(request.method())?;
let (room_alias,) = Deserialize::deserialize(serde::de::value::SeqDeserializer::<
_,
serde::de::value::Error,
>::new(
path_args.iter().map(::std::convert::AsRef::as_ref),
))?;
let request_body: RequestBody = serde_json::from_slice(request.body().as_ref())?;
Ok(Request { room_id: request_body.room_id, room_alias })
}
}
#[derive(Debug, Serialize, Deserialize)]
struct RequestBody {
room_id: OwnedRoomId,
}
#[derive(Clone, Copy, Debug)]
pub struct Response;
impl IncomingResponse for Response {
type EndpointError = Error;
fn try_from_http_response<T: AsRef<[u8]>>(
http_response: http::Response<T>,
) -> Result<Self, FromHttpResponseError<Error>> {
if http_response.status().as_u16() < 400 {
Ok(Response)
} else {
Err(FromHttpResponseError::Server(Error::from_http_response(http_response)))
}
}
}
impl OutgoingResponse for Response {
fn try_into_http_response<T: Default + BufMut>(
self,
) -> Result<http::Response<T>, IntoHttpError> {
let response = http::Response::builder()
.header(CONTENT_TYPE, ruma_common::http_headers::APPLICATION_JSON)
.body(ruma_common::serde::slice_to_buf(b"{}"))
.unwrap();
Ok(response)
}
}