use assign::assign;
use ruma_api::ruma_api;
#[cfg(feature = "unstable-pre-spec")]
use ruma_events::room::create::RoomType;
use ruma_events::{
room::{
create::{CreateEventContent, PreviousRoom},
power_levels::PowerLevelsEventContent,
},
AnyInitialStateEvent,
};
use ruma_identifiers::{RoomId, RoomVersionId, UserId};
use ruma_serde::{Raw, StringEnum};
use serde::{Deserialize, Serialize};
use super::Visibility;
use crate::r0::membership::{IncomingInvite3pid, Invite3pid};
ruma_api! {
metadata: {
description: "Create a new room.",
method: POST,
name: "create_room",
path: "/_matrix/client/r0/createRoom",
rate_limited: false,
authentication: AccessToken,
}
#[derive(Default)]
request: {
#[serde(default, skip_serializing_if = "CreationContent::is_empty")]
pub creation_content: CreationContent,
#[serde(default, skip_serializing_if = "<[_]>::is_empty")]
pub initial_state: &'a [Raw<AnyInitialStateEvent>],
#[serde(default, skip_serializing_if = "<[_]>::is_empty")]
pub invite: &'a [UserId],
#[serde(default, skip_serializing_if = "<[_]>::is_empty")]
pub invite_3pid: &'a [Invite3pid<'a>],
#[serde(default, skip_serializing_if = "ruma_serde::is_default")]
pub is_direct: bool,
#[serde(skip_serializing_if = "Option::is_none")]
pub name: Option<&'a str>,
#[serde(skip_serializing_if = "Option::is_none")]
pub power_level_content_override: Option<Raw<PowerLevelsEventContent>>,
#[serde(skip_serializing_if = "Option::is_none")]
pub preset: Option<RoomPreset>,
#[serde(skip_serializing_if = "Option::is_none")]
pub room_alias_name: Option<&'a str>,
#[serde(skip_serializing_if = "Option::is_none")]
pub room_version: Option<&'a RoomVersionId>,
#[serde(skip_serializing_if = "Option::is_none")]
pub topic: Option<&'a str>,
#[serde(default, skip_serializing_if = "ruma_serde::is_default")]
pub visibility: Visibility,
}
response: {
pub room_id: RoomId,
}
error: crate::Error
}
impl Request<'_> {
pub fn new() -> Self {
Default::default()
}
}
impl Response {
pub fn new(room_id: RoomId) -> Self {
Self { room_id }
}
}
#[derive(Clone, Debug, Deserialize, Serialize)]
#[cfg_attr(not(feature = "unstable-exhaustive-types"), non_exhaustive)]
pub struct CreationContent {
#[serde(
rename = "m.federate",
default = "ruma_serde::default_true",
skip_serializing_if = "ruma_serde::is_true"
)]
pub federate: bool,
#[serde(skip_serializing_if = "Option::is_none")]
pub predecessor: Option<PreviousRoom>,
#[cfg(feature = "unstable-pre-spec")]
#[serde(skip_serializing_if = "Option::is_none", rename = "type")]
pub room_type: Option<RoomType>,
}
impl CreationContent {
pub fn new() -> Self {
Self {
federate: true,
predecessor: None,
#[cfg(feature = "unstable-pre-spec")]
room_type: None,
}
}
pub fn into_event_content(
self,
creator: UserId,
room_version: RoomVersionId,
) -> CreateEventContent {
#[allow(unused_mut)]
let mut content = assign!(CreateEventContent::new(creator), {
federate: self.federate,
room_version: room_version,
predecessor: self.predecessor,
});
#[cfg(feature = "unstable-pre-spec")]
{
content.room_type = self.room_type;
}
content
}
pub fn is_empty(&self) -> bool {
let stable_fields = self.federate && self.predecessor.is_none();
#[cfg(feature = "unstable-pre-spec")]
{
stable_fields && self.room_type.is_none()
}
#[cfg(not(feature = "unstable-pre-spec"))]
{
stable_fields
}
}
}
impl Default for CreationContent {
fn default() -> Self {
Self::new()
}
}
#[derive(Clone, Debug, PartialEq, Eq, StringEnum)]
#[ruma_enum(rename_all = "snake_case")]
pub enum RoomPreset {
PrivateChat,
PublicChat,
TrustedPrivateChat,
#[doc(hidden)]
_Custom(String),
}