Use Pdu
on create_join_event
endpoints
Sending requests to this endpoints to Synapse/Dendrite homeservers leads to some deserialization errors. After claryfing it (https://github.com/matrix-org/matrix-doc/issues/2856), `room_id` and `event_id` fields are expected to appear on request's body and also on path params. It seems that there's some initiative, in any case, to remove the parameters from path: https://github.com/matrix-org/matrix-doc/issues/2330
This commit is contained in:
parent
9a4206b1b2
commit
b168c38d83
@ -5,6 +5,7 @@ Breaking Changes:
|
||||
* Replace `directory::get_public_rooms::v1::{PublicRoomsChunk, RoomNetwork}` with types from
|
||||
`ruma_common::directory`
|
||||
* Wrap `PduStub`s in `membership::create_join_event` in `Raw`
|
||||
* Use `Pdu` instead of `PduStub` in `membership::create_join_event` endpoints
|
||||
|
||||
Improvements:
|
||||
|
||||
|
@ -2,7 +2,7 @@
|
||||
|
||||
use ruma_api::ruma_api;
|
||||
use ruma_common::Raw;
|
||||
use ruma_events::pdu::PduStub;
|
||||
use ruma_events::pdu::Pdu;
|
||||
use ruma_identifiers::{EventId, RoomId};
|
||||
|
||||
use super::RoomState;
|
||||
@ -26,9 +26,9 @@ ruma_api! {
|
||||
#[ruma_api(path)]
|
||||
pub event_id: &'a EventId,
|
||||
|
||||
/// PDU type without event and room IDs.
|
||||
/// PDU type
|
||||
#[ruma_api(body)]
|
||||
pub pdu_stub: Raw<PduStub>,
|
||||
pub pdu_stub: Raw<Pdu>,
|
||||
}
|
||||
|
||||
response: {
|
||||
@ -39,10 +39,9 @@ ruma_api! {
|
||||
}
|
||||
}
|
||||
|
||||
// FIXME: Construct from Pdu, same for similar endpoints
|
||||
impl<'a> Request<'a> {
|
||||
/// Creates a `Request` from the given room ID, event ID and `PduStub`.
|
||||
pub fn new(room_id: &'a RoomId, event_id: &'a EventId, pdu_stub: Raw<PduStub>) -> Self {
|
||||
/// Creates a `Request` from the given room ID, event ID and `Pdu`.
|
||||
pub fn new(room_id: &'a RoomId, event_id: &'a EventId, pdu_stub: Raw<Pdu>) -> Self {
|
||||
Self { room_id, event_id, pdu_stub }
|
||||
}
|
||||
}
|
||||
|
@ -2,7 +2,7 @@
|
||||
|
||||
use ruma_api::ruma_api;
|
||||
use ruma_common::Raw;
|
||||
use ruma_events::pdu::PduStub;
|
||||
use ruma_events::pdu::Pdu;
|
||||
use ruma_identifiers::{EventId, RoomId};
|
||||
|
||||
use super::RoomState;
|
||||
@ -26,9 +26,9 @@ ruma_api! {
|
||||
#[ruma_api(path)]
|
||||
pub event_id: &'a EventId,
|
||||
|
||||
/// PDU type without event and room IDs.
|
||||
/// PDU type
|
||||
#[ruma_api(body)]
|
||||
pub pdu_stub: Raw<PduStub>,
|
||||
pub pdu_stub: Raw<Pdu>,
|
||||
}
|
||||
|
||||
response: {
|
||||
@ -38,10 +38,9 @@ ruma_api! {
|
||||
}
|
||||
}
|
||||
|
||||
// FIXME: Construct from Pdu, same for similar endpoints
|
||||
impl<'a> Request<'a> {
|
||||
/// Creates a `Request` from the given room ID, event ID and `PduStub`.
|
||||
pub fn new(room_id: &'a RoomId, event_id: &'a EventId, pdu_stub: Raw<PduStub>) -> Self {
|
||||
/// Creates a `Request` from the given room ID, event ID and `Pdu`.
|
||||
pub fn new(room_id: &'a RoomId, event_id: &'a EventId, pdu_stub: Raw<Pdu>) -> Self {
|
||||
Self { room_id, event_id, pdu_stub }
|
||||
}
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user