Update /register to most recent spec
This commit is contained in:
parent
3beeef7ccf
commit
a7bce18b59
@ -2,15 +2,55 @@
|
|||||||
|
|
||||||
/// [POST /_matrix/client/r0/register](https://matrix.org/docs/spec/client_server/r0.2.0.html#post-matrix-client-r0-register)
|
/// [POST /_matrix/client/r0/register](https://matrix.org/docs/spec/client_server/r0.2.0.html#post-matrix-client-r0-register)
|
||||||
pub mod register {
|
pub mod register {
|
||||||
|
use ruma_identifiers::UserId;
|
||||||
|
|
||||||
/// This API endpoint's body parameters.
|
/// This API endpoint's body parameters.
|
||||||
#[derive(Clone, Debug, Deserialize, Serialize)]
|
#[derive(Clone, Debug, Deserialize, Serialize)]
|
||||||
pub struct BodyParams {
|
pub struct BodyParams {
|
||||||
|
/// If true, the server binds the email used for authentication
|
||||||
|
/// to the Matrix ID with the ID Server.
|
||||||
#[serde(skip_serializing_if = "Option::is_none")]
|
#[serde(skip_serializing_if = "Option::is_none")]
|
||||||
pub bind_email: Option<bool>,
|
pub bind_email: Option<bool>,
|
||||||
pub password: String,
|
/// The desired password for the account.
|
||||||
|
///
|
||||||
|
/// Should only be empty for guest accounts.
|
||||||
|
// TODO: the spec says nothing about when it is actually required.
|
||||||
|
#[serde(skip_serializing_if = "Option::is_none")]
|
||||||
|
pub password: Option<String>,
|
||||||
|
/// local part of the desired Matrix ID.
|
||||||
|
///
|
||||||
|
/// If omitted, the homeserver MUST generate a Matrix ID local part.
|
||||||
#[serde(skip_serializing_if = "Option::is_none")]
|
#[serde(skip_serializing_if = "Option::is_none")]
|
||||||
pub username: Option<String>,
|
pub username: Option<String>,
|
||||||
// TODO: `auth` field
|
/// ID of the client device.
|
||||||
|
///
|
||||||
|
/// If this does not correspond to a known client device, a new device will be created.
|
||||||
|
/// The server will auto-generate a device_id if this is not specified.
|
||||||
|
#[serde(skip_serializing_if = "Option::is_none")]
|
||||||
|
pub device_id: Option<String>,
|
||||||
|
/// A display name to assign to the newly-created device.
|
||||||
|
///
|
||||||
|
/// Ignored if `device_id` corresponds to a known device.
|
||||||
|
#[serde(skip_serializing_if = "Option::is_none")]
|
||||||
|
pub initial_device_display_name: Option<String>,
|
||||||
|
/// Additional authentication information for the user-interactive authentication API.
|
||||||
|
///
|
||||||
|
/// Note that this information is not used to define how the registered user should be
|
||||||
|
/// authenticated, but is instead used to authenticate the register call itself.
|
||||||
|
/// It should be left empty, or omitted, unless an earlier call returned an response
|
||||||
|
/// with status code 401.
|
||||||
|
#[serde(skip_serializing_if = "Option::is_none")]
|
||||||
|
pub auth: Option<AuthenticationData>
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Additional authentication information for the user-interactive authentication API.
|
||||||
|
#[derive(Clone, Debug, Deserialize, Serialize)]
|
||||||
|
pub struct AuthenticationData {
|
||||||
|
/// The login type that the client is attempting to complete.
|
||||||
|
#[serde(rename = "type")]
|
||||||
|
kind: String,
|
||||||
|
/// The value of the session key given by the homeserver.
|
||||||
|
session: Option<String>
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Details about this API endpoint.
|
/// Details about this API endpoint.
|
||||||
@ -20,6 +60,9 @@ pub mod register {
|
|||||||
/// This API endpoint's query string parameters.
|
/// This API endpoint's query string parameters.
|
||||||
#[derive(Clone, Debug, Deserialize, Serialize)]
|
#[derive(Clone, Debug, Deserialize, Serialize)]
|
||||||
pub struct QueryParams {
|
pub struct QueryParams {
|
||||||
|
/// Kind of account to register
|
||||||
|
///
|
||||||
|
/// Defaults to `User` if ommited.
|
||||||
#[serde(skip_serializing_if = "Option::is_none")]
|
#[serde(skip_serializing_if = "Option::is_none")]
|
||||||
pub kind: Option<RegistrationKind>,
|
pub kind: Option<RegistrationKind>,
|
||||||
}
|
}
|
||||||
@ -27,8 +70,12 @@ pub mod register {
|
|||||||
/// The kind of account being registered.
|
/// The kind of account being registered.
|
||||||
#[derive(Copy, Clone, Debug, Deserialize, Serialize)]
|
#[derive(Copy, Clone, Debug, Deserialize, Serialize)]
|
||||||
pub enum RegistrationKind {
|
pub enum RegistrationKind {
|
||||||
|
/// A guest account
|
||||||
|
///
|
||||||
|
/// These accounts may have limited permissions and may not be supported by all servers.
|
||||||
#[serde(rename="guest")]
|
#[serde(rename="guest")]
|
||||||
Guest,
|
Guest,
|
||||||
|
/// A regular user account
|
||||||
#[serde(rename="user")]
|
#[serde(rename="user")]
|
||||||
User,
|
User,
|
||||||
}
|
}
|
||||||
@ -36,10 +83,18 @@ pub mod register {
|
|||||||
/// This API endpoint's response.
|
/// This API endpoint's response.
|
||||||
#[derive(Clone, Debug, Deserialize, Serialize)]
|
#[derive(Clone, Debug, Deserialize, Serialize)]
|
||||||
pub struct Response {
|
pub struct Response {
|
||||||
|
/// An access token for the account.
|
||||||
|
///
|
||||||
|
/// This access token can then be used to authorize other requests.
|
||||||
pub access_token: String,
|
pub access_token: String,
|
||||||
|
/// The hostname of the homeserver on which the account has been registered.
|
||||||
pub home_server: String,
|
pub home_server: String,
|
||||||
pub user_id: String,
|
/// The fully-qualified Matrix ID that has been registered.
|
||||||
// TODO: `refresh_token` field? (more or less deprecated?)
|
pub user_id: UserId,
|
||||||
|
/// ID of the registered device.
|
||||||
|
///
|
||||||
|
/// Will be the same as the corresponding parameter in the request, if one was specified.
|
||||||
|
pub device_id: String
|
||||||
}
|
}
|
||||||
|
|
||||||
impl ::Endpoint for Endpoint {
|
impl ::Endpoint for Endpoint {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user