Convert alias mod and get_public_rooms to use Outgoing trait
This commit is contained in:
		
							parent
							
								
									30e73186e7
								
							
						
					
					
						commit
						7f0f5be1fe
					
				| @ -20,10 +20,10 @@ ruma_api! { | |||||||
|         pub auth: Option<AuthData>, |         pub auth: Option<AuthData>, | ||||||
| 
 | 
 | ||||||
|         /// Client-generated secret string used to protect this session.
 |         /// Client-generated secret string used to protect this session.
 | ||||||
|         pub client_secret: String, |         pub client_secret: &'a str, | ||||||
| 
 | 
 | ||||||
|         /// The session identifier given by the identity server.
 |         /// The session identifier given by the identity server.
 | ||||||
|         pub sid: String, |         pub sid: &'a str, | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     response: {} |     response: {} | ||||||
|  | |||||||
| @ -16,10 +16,10 @@ ruma_api! { | |||||||
|     request: { |     request: { | ||||||
|         /// The room alias to set.
 |         /// The room alias to set.
 | ||||||
|         #[ruma_api(path)] |         #[ruma_api(path)] | ||||||
|         pub room_alias: RoomAliasId, |         pub room_alias: &'a RoomAliasId, | ||||||
| 
 | 
 | ||||||
|         /// The room ID to set.
 |         /// The room ID to set.
 | ||||||
|         pub room_id: RoomId, |         pub room_id: &'a RoomId, | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     response: {} |     response: {} | ||||||
|  | |||||||
| @ -16,7 +16,7 @@ ruma_api! { | |||||||
|     request: { |     request: { | ||||||
|         /// The room alias to remove.
 |         /// The room alias to remove.
 | ||||||
|         #[ruma_api(path)] |         #[ruma_api(path)] | ||||||
|         pub room_alias: RoomAliasId, |         pub room_alias: &'a RoomAliasId, | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     response: {} |     response: {} | ||||||
|  | |||||||
| @ -16,15 +16,15 @@ ruma_api! { | |||||||
|     request: { |     request: { | ||||||
|         /// The room alias.
 |         /// The room alias.
 | ||||||
|         #[ruma_api(path)] |         #[ruma_api(path)] | ||||||
|         pub room_alias: RoomAliasId, |         pub room_alias: &'a RoomAliasId, | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     response: { |     response: { | ||||||
|         /// The room ID for this room alias.
 |         /// The room ID for this room alias.
 | ||||||
|         pub room_id: RoomId, |         pub room_id: &'a RoomId, | ||||||
| 
 | 
 | ||||||
|         /// A list of servers that are aware of this room ID.
 |         /// A list of servers that are aware of this room ID.
 | ||||||
|         pub servers: Vec<String>, |         pub servers: &'a [String], | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     error: crate::Error |     error: crate::Error | ||||||
|  | |||||||
| @ -6,33 +6,34 @@ pub mod get_room_visibility; | |||||||
| pub mod set_room_visibility; | pub mod set_room_visibility; | ||||||
| 
 | 
 | ||||||
| use js_int::UInt; | use js_int::UInt; | ||||||
|  | use ruma_api::Outgoing; | ||||||
| use ruma_identifiers::{RoomAliasId, RoomId}; | use ruma_identifiers::{RoomAliasId, RoomId}; | ||||||
| use serde::{Deserialize, Serialize}; | use serde::Serialize; | ||||||
| 
 | 
 | ||||||
| /// A chunk of a room list response, describing one room
 | /// A chunk of a room list response, describing one room
 | ||||||
| #[derive(Clone, Debug, Deserialize, Serialize)] | #[derive(Clone, Debug, Outgoing, Serialize)] | ||||||
| pub struct PublicRoomsChunk { | pub struct PublicRoomsChunk<'a> { | ||||||
|     /// Aliases of the room.
 |     /// Aliases of the room.
 | ||||||
|     #[serde(default, skip_serializing_if = "Vec::is_empty")] |     #[serde(default, skip_serializing_if = "Vec::is_empty")] | ||||||
|     pub aliases: Vec<RoomAliasId>, |     pub aliases: Vec<&'a RoomAliasId>, | ||||||
| 
 | 
 | ||||||
|     /// The canonical alias of the room, if any.
 |     /// The canonical alias of the room, if any.
 | ||||||
|     #[serde(skip_serializing_if = "Option::is_none")] |     #[serde(skip_serializing_if = "Option::is_none")] | ||||||
|     pub canonical_alias: Option<RoomAliasId>, |     pub canonical_alias: Option<&'a RoomAliasId>, | ||||||
| 
 | 
 | ||||||
|     /// The name of the room, if any.
 |     /// The name of the room, if any.
 | ||||||
|     #[serde(skip_serializing_if = "Option::is_none")] |     #[serde(skip_serializing_if = "Option::is_none")] | ||||||
|     pub name: Option<String>, |     pub name: Option<&'a str>, | ||||||
| 
 | 
 | ||||||
|     /// The number of members joined to the room.
 |     /// The number of members joined to the room.
 | ||||||
|     pub num_joined_members: UInt, |     pub num_joined_members: UInt, | ||||||
| 
 | 
 | ||||||
|     /// The ID of the room.
 |     /// The ID of the room.
 | ||||||
|     pub room_id: RoomId, |     pub room_id: &'a RoomId, | ||||||
| 
 | 
 | ||||||
|     /// The topic of the room, if any.
 |     /// The topic of the room, if any.
 | ||||||
|     #[serde(skip_serializing_if = "Option::is_none")] |     #[serde(skip_serializing_if = "Option::is_none")] | ||||||
|     pub topic: Option<String>, |     pub topic: Option<&'a str>, | ||||||
| 
 | 
 | ||||||
|     /// Whether the room may be viewed by guest users without joining.
 |     /// Whether the room may be viewed by guest users without joining.
 | ||||||
|     pub world_readable: bool, |     pub world_readable: bool, | ||||||
| @ -44,5 +45,5 @@ pub struct PublicRoomsChunk { | |||||||
| 
 | 
 | ||||||
|     /// The URL for the room's avatar, if one is set.
 |     /// The URL for the room's avatar, if one is set.
 | ||||||
|     #[serde(skip_serializing_if = "Option::is_none")] |     #[serde(skip_serializing_if = "Option::is_none")] | ||||||
|     pub avatar_url: Option<String>, |     pub avatar_url: Option<&'a str>, | ||||||
| } | } | ||||||
|  | |||||||
| @ -3,7 +3,7 @@ | |||||||
| use js_int::UInt; | use js_int::UInt; | ||||||
| use ruma_api::ruma_api; | use ruma_api::ruma_api; | ||||||
| 
 | 
 | ||||||
| use super::PublicRoomsChunk; | use super::{IncomingPublicRoomsChunk, PublicRoomsChunk}; | ||||||
| 
 | 
 | ||||||
| ruma_api! { | ruma_api! { | ||||||
|     metadata: { |     metadata: { | ||||||
| @ -24,25 +24,25 @@ ruma_api! { | |||||||
|         /// Pagination token from a previous request.
 |         /// Pagination token from a previous request.
 | ||||||
|         #[serde(skip_serializing_if = "Option::is_none")] |         #[serde(skip_serializing_if = "Option::is_none")] | ||||||
|         #[ruma_api(query)] |         #[ruma_api(query)] | ||||||
|         pub since: Option<String>, |         pub since: Option<&'a str>, | ||||||
| 
 | 
 | ||||||
|         /// The server to fetch the public room lists from.
 |         /// The server to fetch the public room lists from.
 | ||||||
|         ///
 |         ///
 | ||||||
|         /// `None` means the server this request is sent to.
 |         /// `None` means the server this request is sent to.
 | ||||||
|         #[serde(skip_serializing_if = "Option::is_none")] |         #[serde(skip_serializing_if = "Option::is_none")] | ||||||
|         #[ruma_api(query)] |         #[ruma_api(query)] | ||||||
|         pub server: Option<String>, |         pub server: Option<&'a str>, | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     response: { |     response: { | ||||||
|         /// A paginated chunk of public rooms.
 |         /// A paginated chunk of public rooms.
 | ||||||
|         pub chunk: Vec<PublicRoomsChunk>, |         pub chunk: Vec<PublicRoomsChunk<'a>>, | ||||||
| 
 | 
 | ||||||
|         /// A pagination token for the response.
 |         /// A pagination token for the response.
 | ||||||
|         pub next_batch: Option<String>, |         pub next_batch: Option<&'a str>, | ||||||
| 
 | 
 | ||||||
|         /// A pagination token that allows fetching previous results.
 |         /// A pagination token that allows fetching previous results.
 | ||||||
|         pub prev_batch: Option<String>, |         pub prev_batch: Option<&'a str>, | ||||||
| 
 | 
 | ||||||
|         /// An estimate on the total number of public rooms, if the server has an estimate.
 |         /// An estimate on the total number of public rooms, if the server has an estimate.
 | ||||||
|         pub total_room_count_estimate: Option<UInt>, |         pub total_room_count_estimate: Option<UInt>, | ||||||
| @ -50,3 +50,38 @@ ruma_api! { | |||||||
| 
 | 
 | ||||||
|     error: crate::Error |     error: crate::Error | ||||||
| } | } | ||||||
|  | 
 | ||||||
|  | #[test] | ||||||
|  | fn construct_request_from_refs() { | ||||||
|  |     let req: http::Request<Vec<u8>> = | ||||||
|  |         Request { limit: Some(js_int::uint!(10)), since: Some("hello"), server: Some("address") } | ||||||
|  |             .try_into_http_request("https://homeserver.tld", Some("auth_tok")) | ||||||
|  |             .unwrap(); | ||||||
|  | 
 | ||||||
|  |     let uri = req.uri(); | ||||||
|  |     let query = uri.query().unwrap(); | ||||||
|  | 
 | ||||||
|  |     assert_eq!(uri.path(), "/_matrix/client/r0/publicRooms"); | ||||||
|  |     assert!(query.contains("since=hello")); | ||||||
|  |     assert!(query.contains("limit=10")); | ||||||
|  |     assert!(query.contains("server=address")); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | #[test] | ||||||
|  | fn construct_response_from_refs() { | ||||||
|  |     use std::convert::TryInto; | ||||||
|  | 
 | ||||||
|  |     let res: http::Response<Vec<u8>> = Response { | ||||||
|  |         chunk: vec![], | ||||||
|  |         next_batch: Some("next_batch_token"), | ||||||
|  |         prev_batch: Some("prev_batch_token"), | ||||||
|  |         total_room_count_estimate: Some(js_int::uint!(10)), | ||||||
|  |     } | ||||||
|  |     .try_into() | ||||||
|  |     .unwrap(); | ||||||
|  | 
 | ||||||
|  |     assert_eq!( | ||||||
|  |         String::from_utf8_lossy(res.body()), | ||||||
|  |         r#"{"chunk":[],"next_batch":"next_batch_token","prev_batch":"prev_batch_token","total_room_count_estimate":10}"# | ||||||
|  |     ); | ||||||
|  | } | ||||||
|  | |||||||
| @ -12,7 +12,7 @@ use serde::{ | |||||||
| 
 | 
 | ||||||
| use serde_json::Value as JsonValue; | use serde_json::Value as JsonValue; | ||||||
| 
 | 
 | ||||||
| use super::PublicRoomsChunk; | use super::{IncomingPublicRoomsChunk, PublicRoomsChunk}; | ||||||
| 
 | 
 | ||||||
| ruma_api! { | ruma_api! { | ||||||
|     metadata: { |     metadata: { | ||||||
| @ -30,7 +30,7 @@ ruma_api! { | |||||||
|         /// `None` means the server this request is sent to.
 |         /// `None` means the server this request is sent to.
 | ||||||
|         #[serde(skip_serializing_if = "Option::is_none")] |         #[serde(skip_serializing_if = "Option::is_none")] | ||||||
|         #[ruma_api(query)] |         #[ruma_api(query)] | ||||||
|         pub server: Option<String>, |         pub server: Option<&'a str>, | ||||||
| 
 | 
 | ||||||
|         /// Limit for the number of results to return.
 |         /// Limit for the number of results to return.
 | ||||||
|         #[serde(skip_serializing_if = "Option::is_none")] |         #[serde(skip_serializing_if = "Option::is_none")] | ||||||
| @ -38,7 +38,7 @@ ruma_api! { | |||||||
| 
 | 
 | ||||||
|         /// Pagination token from a previous request.
 |         /// Pagination token from a previous request.
 | ||||||
|         #[serde(skip_serializing_if = "Option::is_none")] |         #[serde(skip_serializing_if = "Option::is_none")] | ||||||
|         pub since: Option<String>, |         pub since: Option<&'a str>, | ||||||
| 
 | 
 | ||||||
|         /// Filter to apply to the results.
 |         /// Filter to apply to the results.
 | ||||||
|         #[serde(skip_serializing_if = "Option::is_none")] |         #[serde(skip_serializing_if = "Option::is_none")] | ||||||
| @ -51,13 +51,13 @@ ruma_api! { | |||||||
| 
 | 
 | ||||||
|     response: { |     response: { | ||||||
|         /// A paginated chunk of public rooms.
 |         /// A paginated chunk of public rooms.
 | ||||||
|         pub chunk: Vec<PublicRoomsChunk>, |         pub chunk: Vec<PublicRoomsChunk<'a>>, | ||||||
| 
 | 
 | ||||||
|         /// A pagination token for the response.
 |         /// A pagination token for the response.
 | ||||||
|         pub next_batch: Option<String>, |         pub next_batch: Option<&'a str>, | ||||||
| 
 | 
 | ||||||
|         /// A pagination token that allows fetching previous results.
 |         /// A pagination token that allows fetching previous results.
 | ||||||
|         pub prev_batch: Option<String>, |         pub prev_batch: Option<&'a str>, | ||||||
| 
 | 
 | ||||||
|         /// An estimate on the total number of public rooms, if the server has an estimate.
 |         /// An estimate on the total number of public rooms, if the server has an estimate.
 | ||||||
|         pub total_room_count_estimate: Option<UInt>, |         pub total_room_count_estimate: Option<UInt>, | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user