Use ruma-api-macros for the search endpoints.

This commit is contained in:
Jimmy Cuadra 2017-07-06 22:50:56 -07:00
parent fc29d7bf40
commit e71760bb65
3 changed files with 38 additions and 64 deletions

View File

@ -35,7 +35,7 @@ pub mod r0 {
pub mod receipt; pub mod receipt;
pub mod redact; pub mod redact;
pub mod room; pub mod room;
// pub mod search; pub mod search;
pub mod send; pub mod send;
// pub mod server; // pub mod server;
pub mod session; pub mod session;

View File

@ -131,7 +131,7 @@ pub mod get_profile {
request { request {
/// The user whose profile will be retrieved. /// The user whose profile will be retrieved.
#[ruma_api(path)] #[ruma_api(path)]
pub user_id: UserId pub user_id: UserId,
} }
response { response {
@ -140,7 +140,7 @@ pub mod get_profile {
pub avatar_url: Option<String>, pub avatar_url: Option<String>,
/// The user's display name, if set. /// The user's display name, if set.
#[serde(skip_serializing_if = "Option::is_none")] #[serde(skip_serializing_if = "Option::is_none")]
pub displayname: Option<String> pub displayname: Option<String>,
} }
} }
} }

View File

@ -2,19 +2,38 @@
/// [POST /_matrix/client/r0/search](https://matrix.org/docs/spec/client_server/r0.2.0.html#post-matrix-client-r0-search) /// [POST /_matrix/client/r0/search](https://matrix.org/docs/spec/client_server/r0.2.0.html#post-matrix-client-r0-search)
pub mod search_events { pub mod search_events {
use std::collections::HashMap;
use ruma_api_macros::ruma_api;
use ruma_events::collections::all::Event; use ruma_events::collections::all::Event;
use ruma_identifiers::{EventId, RoomId, UserId}; use ruma_identifiers::{EventId, RoomId, UserId};
use r0::filter::RoomEventFilter; use r0::filter::RoomEventFilter;
use r0::profile::get_profile::Response as UserProfile;
use std::collections::HashMap; ruma_api! {
metadata {
description: "Search events.",
method: Method::Post,
name: "search",
path: "/_matrix/client/r0/search",
rate_limited: true,
requires_authentication: true,
}
/// This API endpoint's body parameters. request {
#[derive(Clone, Debug, Deserialize, Serialize)] /// The point to return events from.
pub struct BodyParams { ///
/// Describes which categories to search in and their criteria. /// If given, this should be a `next_batch` result from a previous call to this endpoint.
pub search_categories: Categories, #[ruma_api(query)]
pub next_batch: Option<String>,
/// Describes which categories to search in and their criteria.
pub search_categories: Categories,
}
response {
/// A grouping of search results by category.
pub search_categories: ResultCategories,
}
} }
/// Categories of events that can be searched for. /// Categories of events that can be searched for.
@ -53,11 +72,6 @@ pub mod search_events {
pub search_term: String, pub search_term: String,
} }
/// Details about this API endpoint.
#[derive(Clone, Copy, Debug)]
pub struct Endpoint;
/// Configures whether any context for the events returned are included in the response. /// Configures whether any context for the events returned are included in the response.
#[derive(Clone, Debug, Deserialize, Serialize)] #[derive(Clone, Debug, Deserialize, Serialize)]
pub struct EventContext { pub struct EventContext {
@ -140,22 +154,6 @@ pub mod search_events {
Recent, Recent,
} }
/// This API endpoint's query string parameters.
#[derive(Clone, Debug, Deserialize, Serialize)]
pub struct QueryParams {
/// The point to return events from.
///
/// If given, this should be a `next_batch` result from a previous call to this endpoint.
pub next_batch: Option<String>,
}
/// This API endpoint's response.
#[derive(Clone, Debug, Deserialize, Serialize)]
pub struct Response {
/// A grouping of search results by category.
pub search_categories: ResultCategories,
}
/// Categories of events that can be searched for. /// Categories of events that can be searched for.
#[derive(Clone, Debug, Deserialize, Serialize)] #[derive(Clone, Debug, Deserialize, Serialize)]
pub struct ResultCategories { pub struct ResultCategories {
@ -211,38 +209,14 @@ pub mod search_events {
pub result: Event, pub result: Event,
} }
impl ::Endpoint for Endpoint { /// A user profile.
type BodyParams = BodyParams; #[derive(Clone, Debug, Deserialize, Serialize)]
type PathParams = (); pub struct UserProfile {
type QueryParams = QueryParams; /// The user's avatar URL, if set.
type Response = Response; #[serde(skip_serializing_if = "Option::is_none")]
pub avatar_url: Option<String>,
fn method() -> ::Method { /// The user's display name, if set.
::Method::Post #[serde(skip_serializing_if = "Option::is_none")]
} pub displayname: Option<String>,
fn request_path(_params: Self::PathParams) -> String {
Self::router_path().to_string()
}
fn router_path() -> &'static str {
"/_matrix/client/r0/search"
}
fn name() -> &'static str {
"search"
}
fn description() -> &'static str {
"Search events."
}
fn requires_authentication() -> bool {
true
}
fn rate_limited() -> bool {
true
}
} }
} }