client-api: Do not send request body for logout and logout_all
Due to a clarification in the spec.
This commit is contained in:
parent
e815eb7603
commit
14d7415f0d
@ -34,6 +34,8 @@ Bug fixes:
|
|||||||
- `user_id` of `SlidingSyncRoomHero` is now mandatory
|
- `user_id` of `SlidingSyncRoomHero` is now mandatory
|
||||||
- Make authentication with access token optional for the `change_password` and
|
- Make authentication with access token optional for the `change_password` and
|
||||||
`deactivate` endpoints.
|
`deactivate` endpoints.
|
||||||
|
- Do not send a request body for the `logout` and `logout_all` endpoints, due
|
||||||
|
to a clarification in the spec.
|
||||||
|
|
||||||
# 0.18.0
|
# 0.18.0
|
||||||
|
|
||||||
|
@ -8,7 +8,7 @@ pub mod v3 {
|
|||||||
//! [spec]: https://spec.matrix.org/latest/client-server-api/#post_matrixclientv3logout
|
//! [spec]: https://spec.matrix.org/latest/client-server-api/#post_matrixclientv3logout
|
||||||
|
|
||||||
use ruma_common::{
|
use ruma_common::{
|
||||||
api::{request, response, Metadata},
|
api::{response, Metadata},
|
||||||
metadata,
|
metadata,
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -23,15 +23,10 @@ pub mod v3 {
|
|||||||
};
|
};
|
||||||
|
|
||||||
/// Request type for the `logout` endpoint.
|
/// Request type for the `logout` endpoint.
|
||||||
#[request(error = crate::Error)]
|
#[derive(Debug, Clone, Default)]
|
||||||
#[derive(Default)]
|
#[cfg_attr(not(feature = "unstable-exhaustive-types"), non_exhaustive)]
|
||||||
pub struct Request {}
|
pub struct Request {}
|
||||||
|
|
||||||
/// Response type for the `logout` endpoint.
|
|
||||||
#[response(error = crate::Error)]
|
|
||||||
#[derive(Default)]
|
|
||||||
pub struct Response {}
|
|
||||||
|
|
||||||
impl Request {
|
impl Request {
|
||||||
/// Creates an empty `Request`.
|
/// Creates an empty `Request`.
|
||||||
pub fn new() -> Self {
|
pub fn new() -> Self {
|
||||||
@ -39,6 +34,69 @@ pub mod v3 {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[cfg(feature = "client")]
|
||||||
|
impl ruma_common::api::OutgoingRequest for Request {
|
||||||
|
type EndpointError = crate::Error;
|
||||||
|
type IncomingResponse = Response;
|
||||||
|
|
||||||
|
const METADATA: Metadata = METADATA;
|
||||||
|
|
||||||
|
fn try_into_http_request<T: Default + bytes::BufMut>(
|
||||||
|
self,
|
||||||
|
base_url: &str,
|
||||||
|
access_token: ruma_common::api::SendAccessToken<'_>,
|
||||||
|
considering_versions: &'_ [ruma_common::api::MatrixVersion],
|
||||||
|
) -> Result<http::Request<T>, ruma_common::api::error::IntoHttpError> {
|
||||||
|
let url = METADATA.make_endpoint_url(considering_versions, base_url, &[], "")?;
|
||||||
|
|
||||||
|
http::Request::builder()
|
||||||
|
.method(METADATA.method)
|
||||||
|
.uri(url)
|
||||||
|
.header(
|
||||||
|
http::header::AUTHORIZATION,
|
||||||
|
format!(
|
||||||
|
"Bearer {}",
|
||||||
|
access_token
|
||||||
|
.get_required_for_endpoint()
|
||||||
|
.ok_or(ruma_common::api::error::IntoHttpError::NeedsAuthentication)?,
|
||||||
|
),
|
||||||
|
)
|
||||||
|
.body(T::default())
|
||||||
|
.map_err(Into::into)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#[cfg(feature = "server")]
|
||||||
|
impl ruma_common::api::IncomingRequest for Request {
|
||||||
|
type EndpointError = crate::Error;
|
||||||
|
type OutgoingResponse = Response;
|
||||||
|
|
||||||
|
const METADATA: Metadata = METADATA;
|
||||||
|
|
||||||
|
fn try_from_http_request<B, S>(
|
||||||
|
request: http::Request<B>,
|
||||||
|
_path_args: &[S],
|
||||||
|
) -> Result<Self, ruma_common::api::error::FromHttpRequestError>
|
||||||
|
where
|
||||||
|
B: AsRef<[u8]>,
|
||||||
|
S: AsRef<str>,
|
||||||
|
{
|
||||||
|
if request.method() != METADATA.method {
|
||||||
|
return Err(ruma_common::api::error::FromHttpRequestError::MethodMismatch {
|
||||||
|
expected: METADATA.method,
|
||||||
|
received: request.method().clone(),
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
Ok(Self {})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Response type for the `logout` endpoint.
|
||||||
|
#[response(error = crate::Error)]
|
||||||
|
#[derive(Default)]
|
||||||
|
pub struct Response {}
|
||||||
|
|
||||||
impl Response {
|
impl Response {
|
||||||
/// Creates an empty `Response`.
|
/// Creates an empty `Response`.
|
||||||
pub fn new() -> Self {
|
pub fn new() -> Self {
|
||||||
|
@ -8,7 +8,7 @@ pub mod v3 {
|
|||||||
//! [spec]: https://spec.matrix.org/latest/client-server-api/#post_matrixclientv3logoutall
|
//! [spec]: https://spec.matrix.org/latest/client-server-api/#post_matrixclientv3logoutall
|
||||||
|
|
||||||
use ruma_common::{
|
use ruma_common::{
|
||||||
api::{request, response, Metadata},
|
api::{response, Metadata},
|
||||||
metadata,
|
metadata,
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -23,15 +23,10 @@ pub mod v3 {
|
|||||||
};
|
};
|
||||||
|
|
||||||
/// Request type for the `logout_all` endpoint.
|
/// Request type for the `logout_all` endpoint.
|
||||||
#[request(error = crate::Error)]
|
#[derive(Debug, Clone, Default)]
|
||||||
#[derive(Default)]
|
#[cfg_attr(not(feature = "unstable-exhaustive-types"), non_exhaustive)]
|
||||||
pub struct Request {}
|
pub struct Request {}
|
||||||
|
|
||||||
/// Response type for the `logout_all` endpoint.
|
|
||||||
#[response(error = crate::Error)]
|
|
||||||
#[derive(Default)]
|
|
||||||
pub struct Response {}
|
|
||||||
|
|
||||||
impl Request {
|
impl Request {
|
||||||
/// Creates an empty `Request`.
|
/// Creates an empty `Request`.
|
||||||
pub fn new() -> Self {
|
pub fn new() -> Self {
|
||||||
@ -39,6 +34,69 @@ pub mod v3 {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[cfg(feature = "client")]
|
||||||
|
impl ruma_common::api::OutgoingRequest for Request {
|
||||||
|
type EndpointError = crate::Error;
|
||||||
|
type IncomingResponse = Response;
|
||||||
|
|
||||||
|
const METADATA: Metadata = METADATA;
|
||||||
|
|
||||||
|
fn try_into_http_request<T: Default + bytes::BufMut>(
|
||||||
|
self,
|
||||||
|
base_url: &str,
|
||||||
|
access_token: ruma_common::api::SendAccessToken<'_>,
|
||||||
|
considering_versions: &'_ [ruma_common::api::MatrixVersion],
|
||||||
|
) -> Result<http::Request<T>, ruma_common::api::error::IntoHttpError> {
|
||||||
|
let url = METADATA.make_endpoint_url(considering_versions, base_url, &[], "")?;
|
||||||
|
|
||||||
|
http::Request::builder()
|
||||||
|
.method(METADATA.method)
|
||||||
|
.uri(url)
|
||||||
|
.header(
|
||||||
|
http::header::AUTHORIZATION,
|
||||||
|
format!(
|
||||||
|
"Bearer {}",
|
||||||
|
access_token
|
||||||
|
.get_required_for_endpoint()
|
||||||
|
.ok_or(ruma_common::api::error::IntoHttpError::NeedsAuthentication)?,
|
||||||
|
),
|
||||||
|
)
|
||||||
|
.body(T::default())
|
||||||
|
.map_err(Into::into)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#[cfg(feature = "server")]
|
||||||
|
impl ruma_common::api::IncomingRequest for Request {
|
||||||
|
type EndpointError = crate::Error;
|
||||||
|
type OutgoingResponse = Response;
|
||||||
|
|
||||||
|
const METADATA: Metadata = METADATA;
|
||||||
|
|
||||||
|
fn try_from_http_request<B, S>(
|
||||||
|
request: http::Request<B>,
|
||||||
|
_path_args: &[S],
|
||||||
|
) -> Result<Self, ruma_common::api::error::FromHttpRequestError>
|
||||||
|
where
|
||||||
|
B: AsRef<[u8]>,
|
||||||
|
S: AsRef<str>,
|
||||||
|
{
|
||||||
|
if request.method() != METADATA.method {
|
||||||
|
return Err(ruma_common::api::error::FromHttpRequestError::MethodMismatch {
|
||||||
|
expected: METADATA.method,
|
||||||
|
received: request.method().clone(),
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
Ok(Self {})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Response type for the `logout_all` endpoint.
|
||||||
|
#[response(error = crate::Error)]
|
||||||
|
#[derive(Default)]
|
||||||
|
pub struct Response {}
|
||||||
|
|
||||||
impl Response {
|
impl Response {
|
||||||
/// Creates an empty `Response`.
|
/// Creates an empty `Response`.
|
||||||
pub fn new() -> Self {
|
pub fn new() -> Self {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user