//! `POST /_matrix/client/*/account/3pid/add` //! //! Add contact information to a user's account pub mod v3 { //! `/v3/` ([spec]) //! //! [spec]: https://spec.matrix.org/latest/client-server-api/#post_matrixclientv3account3pidadd use ruma_common::{ api::{request, response, Metadata}, metadata, OwnedClientSecret, OwnedSessionId, }; use crate::uiaa::{AuthData, UiaaResponse}; const METADATA: Metadata = metadata! { method: POST, rate_limited: true, authentication: AccessToken, history: { 1.0 => "/_matrix/client/r0/account/3pid/add", 1.1 => "/_matrix/client/v3/account/3pid/add", } }; /// Request type for the `add_3pid` endpoint. #[request(error = UiaaResponse)] pub struct Request { /// Additional information for the User-Interactive Authentication API. #[serde(skip_serializing_if = "Option::is_none")] pub auth: Option, /// Client-generated secret string used to protect this session. pub client_secret: OwnedClientSecret, /// The session identifier given by the identity server. pub sid: OwnedSessionId, } /// Response type for the `add_3pid` endpoint. #[response(error = UiaaResponse)] #[derive(Default)] pub struct Response {} impl Request { /// Creates a new `Request` with the given client secret and session identifier. pub fn new(client_secret: OwnedClientSecret, sid: OwnedSessionId) -> Self { Self { auth: None, client_secret, sid } } } impl Response { /// Creates an empty `Response`. pub fn new() -> Self { Self {} } } }