pub mod v3 {
use ruma_common::{
OwnedUserId,
api::{auth_scheme::AccessToken, request, response},
metadata,
};
use crate::filter::FilterDefinition;
metadata! {
method: POST,
rate_limited: false,
authentication: AccessToken,
history: {
1.0 => "/_matrix/client/r0/user/{user_id}/filter",
1.1 => "/_matrix/client/v3/user/{user_id}/filter",
}
}
#[request(error = crate::Error)]
pub struct Request {
#[ruma_api(path)]
pub user_id: OwnedUserId,
#[ruma_api(body)]
pub filter: FilterDefinition,
}
#[response(error = crate::Error)]
pub struct Response {
pub filter_id: String,
}
impl Request {
pub fn new(user_id: OwnedUserId, filter: FilterDefinition) -> Self {
Self { user_id, filter }
}
}
impl Response {
pub fn new(filter_id: String) -> Self {
Self { filter_id }
}
}
#[cfg(all(test, any(feature = "client", feature = "server")))]
mod tests {
#[cfg(feature = "server")]
#[test]
fn deserialize_request() {
use ruma_common::api::IncomingRequest as _;
use super::Request;
let req = Request::try_from_http_request(
http::Request::builder()
.method(http::Method::POST)
.uri("https://matrix.org/_matrix/client/r0/user/@foo:bar.com/filter")
.body(b"{}" as &[u8])
.unwrap(),
&["@foo:bar.com"],
)
.unwrap();
assert_eq!(req.user_id, "@foo:bar.com");
assert!(req.filter.is_empty());
}
#[cfg(feature = "client")]
#[test]
fn serialize_request() {
use std::borrow::Cow;
use ruma_common::{
api::{
MatrixVersion, OutgoingRequest, SupportedVersions, auth_scheme::SendAccessToken,
},
owned_user_id,
};
use crate::filter::FilterDefinition;
let supported = SupportedVersions {
versions: [MatrixVersion::V1_1].into(),
features: Default::default(),
};
let req =
super::Request::new(owned_user_id!("@foo:bar.com"), FilterDefinition::default())
.try_into_http_request::<Vec<u8>>(
"https://matrix.org",
SendAccessToken::IfRequired("tok"),
Cow::Owned(supported),
)
.unwrap();
assert_eq!(req.body(), b"{}");
}
}
}