From 83e853e7a341a7b10c8e9bf32e78db21ced1830d Mon Sep 17 00:00:00 2001 From: strawberry <strawberry@puppygock.gay> Date: Fri, 5 Jul 2024 16:39:57 -0400 Subject: [PATCH] add "unstable" endpoint legacy Element Android/iOS seems to call Signed-off-by: strawberry <strawberry@puppygock.gay> --- src/api/client/thirdparty.rs | 12 +++++++++++- src/api/routes.rs | 2 ++ 2 files changed, 13 insertions(+), 1 deletion(-) diff --git a/src/api/client/thirdparty.rs b/src/api/client/thirdparty.rs index de24c0ec7..f6af8729c 100644 --- a/src/api/client/thirdparty.rs +++ b/src/api/client/thirdparty.rs @@ -2,7 +2,7 @@ use ruma::api::client::thirdparty::get_protocols; -use crate::{Result, Ruma}; +use crate::{Result, Ruma, RumaResponse}; /// # `GET /_matrix/client/r0/thirdparty/protocols` /// @@ -15,3 +15,13 @@ pub(crate) async fn get_protocols_route( protocols: BTreeMap::new(), }) } + +/// # `GET /_matrix/client/unstable/thirdparty/protocols` +/// +/// Same as `get_protocols_route`, except for some reason Element Android legacy +/// calls this +pub(crate) async fn get_protocols_route_unstable( + body: Ruma<get_protocols::v3::Request>, +) -> Result<RumaResponse<get_protocols::v3::Response>> { + get_protocols_route(body).await.map(RumaResponse) +} diff --git a/src/api/routes.rs b/src/api/routes.rs index 94951aeca..b22a32cb9 100644 --- a/src/api/routes.rs +++ b/src/api/routes.rs @@ -94,6 +94,8 @@ pub fn build(router: Router, server: &Server) -> Router { .ruma_route(client::search_users_route) .ruma_route(client::get_member_events_route) .ruma_route(client::get_protocols_route) + .route("/_matrix/client/unstable/thirdparty/protocols", + get(client::get_protocols_route_unstable)) .ruma_route(client::send_message_event_route) .ruma_route(client::send_state_event_for_key_route) .ruma_route(client::get_state_events_route) -- GitLab