Fix path segments being parsed as JSON
This commit is contained in:
parent
a811a709ec
commit
9861aa20c8
@ -160,7 +160,7 @@ impl ToTokens for Api {
|
|||||||
let decoded =
|
let decoded =
|
||||||
ruma_api::exports::percent_encoding::percent_decode(segment)
|
ruma_api::exports::percent_encoding::percent_decode(segment)
|
||||||
.decode_utf8_lossy();
|
.decode_utf8_lossy();
|
||||||
match ruma_api::exports::serde_json::from_str(decoded.deref()) {
|
match std::convert::TryFrom::try_from(decoded.deref()) {
|
||||||
Ok(val) => val,
|
Ok(val) => val,
|
||||||
Err(err) => {
|
Err(err) => {
|
||||||
return Err(
|
return Err(
|
||||||
|
16
src/error.rs
16
src/error.rs
@ -193,6 +193,7 @@ enum SerializationError {
|
|||||||
pub enum DeserializationError {
|
pub enum DeserializationError {
|
||||||
Json(serde_json::Error),
|
Json(serde_json::Error),
|
||||||
Query(serde_urlencoded::de::Error),
|
Query(serde_urlencoded::de::Error),
|
||||||
|
Ident(ruma_identifiers::Error),
|
||||||
}
|
}
|
||||||
|
|
||||||
impl Display for DeserializationError {
|
impl Display for DeserializationError {
|
||||||
@ -200,6 +201,7 @@ impl Display for DeserializationError {
|
|||||||
match self {
|
match self {
|
||||||
DeserializationError::Json(err) => Display::fmt(err, f),
|
DeserializationError::Json(err) => Display::fmt(err, f),
|
||||||
DeserializationError::Query(err) => Display::fmt(err, f),
|
DeserializationError::Query(err) => Display::fmt(err, f),
|
||||||
|
DeserializationError::Ident(err) => Display::fmt(err, f),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -217,3 +219,17 @@ impl From<serde_urlencoded::de::Error> for DeserializationError {
|
|||||||
Self::Query(err)
|
Self::Query(err)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[doc(hidden)]
|
||||||
|
impl From<ruma_identifiers::Error> for DeserializationError {
|
||||||
|
fn from(err: ruma_identifiers::Error) -> Self {
|
||||||
|
Self::Ident(err)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#[doc(hidden)]
|
||||||
|
impl From<std::convert::Infallible> for DeserializationError {
|
||||||
|
fn from(err: std::convert::Infallible) -> Self {
|
||||||
|
match err {}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
61
tests/conversions.rs
Normal file
61
tests/conversions.rs
Normal file
@ -0,0 +1,61 @@
|
|||||||
|
use ruma_api::ruma_api;
|
||||||
|
use ruma_identifiers::UserId;
|
||||||
|
|
||||||
|
ruma_api! {
|
||||||
|
metadata {
|
||||||
|
description: "Does something.",
|
||||||
|
method: POST,
|
||||||
|
name: "my_endpoint",
|
||||||
|
path: "/_matrix/foo/:bar/:baz",
|
||||||
|
rate_limited: false,
|
||||||
|
requires_authentication: false,
|
||||||
|
}
|
||||||
|
|
||||||
|
request {
|
||||||
|
pub hello: String,
|
||||||
|
#[ruma_api(header = CONTENT_TYPE)]
|
||||||
|
pub world: String,
|
||||||
|
#[ruma_api(query)]
|
||||||
|
pub q1: String,
|
||||||
|
#[ruma_api(query)]
|
||||||
|
pub q2: u32,
|
||||||
|
#[ruma_api(path)]
|
||||||
|
pub bar: String,
|
||||||
|
#[ruma_api(path)]
|
||||||
|
pub baz: UserId,
|
||||||
|
}
|
||||||
|
|
||||||
|
response {
|
||||||
|
pub hello: String,
|
||||||
|
#[ruma_api(header = CONTENT_TYPE)]
|
||||||
|
pub world: String,
|
||||||
|
#[serde(skip_serializing_if = "Option::is_none")]
|
||||||
|
pub optional_flag: Option<bool>,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn request_serde() -> Result<(), Box<dyn std::error::Error + 'static>> {
|
||||||
|
use std::convert::TryFrom;
|
||||||
|
|
||||||
|
let req = Request {
|
||||||
|
hello: "hi".to_owned(),
|
||||||
|
world: "test".to_owned(),
|
||||||
|
q1: "query_param_special_chars %/&@!".to_owned(),
|
||||||
|
q2: 55,
|
||||||
|
bar: "bar".to_owned(),
|
||||||
|
baz: UserId::try_from("@bazme:ruma.io")?,
|
||||||
|
};
|
||||||
|
|
||||||
|
let http_req = http::Request::<Vec<u8>>::try_from(req.clone())?;
|
||||||
|
let req2 = Request::try_from(http_req)?;
|
||||||
|
|
||||||
|
assert_eq!(req.hello, req2.hello);
|
||||||
|
assert_eq!(req.world, req2.world);
|
||||||
|
assert_eq!(req.q1, req2.q1);
|
||||||
|
assert_eq!(req.q2, req2.q2);
|
||||||
|
assert_eq!(req.bar, req2.bar);
|
||||||
|
assert_eq!(req.baz, req2.baz);
|
||||||
|
|
||||||
|
Ok(())
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user