mod external;
mod stage_instance;
mod voice;
pub use self::{
external::CreateGuildExternalScheduledEvent,
stage_instance::CreateGuildStageInstanceScheduledEvent, voice::CreateGuildVoiceScheduledEvent,
};
use super::EntityMetadataFields;
use crate::{
client::Client,
error::Error,
request::{AuditLogReason, Request, RequestBuilder},
response::ResponseFuture,
routing::Route,
};
use serde::Serialize;
use twilight_model::{
guild::scheduled_event::{EntityType, GuildScheduledEvent, PrivacyLevel},
id::{
marker::{ChannelMarker, GuildMarker},
Id,
},
util::Timestamp,
};
use twilight_validate::request::{
audit_reason as validate_audit_reason, scheduled_event_name as validate_scheduled_event_name,
ValidationError,
};
#[derive(Serialize)]
struct CreateGuildScheduledEventFields<'a> {
#[serde(skip_serializing_if = "Option::is_none")]
channel_id: Option<Id<ChannelMarker>>,
#[serde(skip_serializing_if = "Option::is_none")]
description: Option<&'a str>,
#[serde(skip_serializing_if = "Option::is_none")]
entity_metadata: Option<EntityMetadataFields<'a>>,
#[serde(skip_serializing_if = "Option::is_none")]
entity_type: Option<EntityType>,
#[serde(skip_serializing_if = "Option::is_none")]
image: Option<&'a str>,
#[serde(skip_serializing_if = "Option::is_none")]
name: Option<&'a str>,
#[serde(skip_serializing_if = "Option::is_none")]
privacy_level: Option<PrivacyLevel>,
#[serde(skip_serializing_if = "Option::is_none")]
scheduled_end_time: Option<&'a Timestamp>,
#[serde(skip_serializing_if = "Option::is_none")]
scheduled_start_time: Option<&'a Timestamp>,
}
pub struct CreateGuildScheduledEvent<'a> {
guild_id: Id<GuildMarker>,
http: &'a Client,
fields: CreateGuildScheduledEventFields<'a>,
reason: Option<&'a str>,
}
impl<'a> CreateGuildScheduledEvent<'a> {
pub(crate) const fn new(
http: &'a Client,
guild_id: Id<GuildMarker>,
privacy_level: PrivacyLevel,
) -> Self {
Self {
guild_id,
http,
fields: CreateGuildScheduledEventFields {
channel_id: None,
description: None,
entity_metadata: None,
entity_type: None,
image: None,
name: None,
privacy_level: Some(privacy_level),
scheduled_end_time: None,
scheduled_start_time: None,
},
reason: None,
}
}
pub fn external(
self,
name: &'a str,
location: &'a str,
scheduled_start_time: &'a Timestamp,
scheduled_end_time: &'a Timestamp,
) -> Result<CreateGuildExternalScheduledEvent<'a>, ValidationError> {
validate_scheduled_event_name(name)?;
Ok(CreateGuildExternalScheduledEvent::new(
self,
name,
location,
scheduled_start_time,
scheduled_end_time,
))
}
pub fn stage_instance(
self,
channel_id: Id<ChannelMarker>,
name: &'a str,
scheduled_start_time: &'a Timestamp,
) -> Result<CreateGuildStageInstanceScheduledEvent<'a>, ValidationError> {
validate_scheduled_event_name(name)?;
Ok(CreateGuildStageInstanceScheduledEvent::new(
self,
channel_id,
name,
scheduled_start_time,
))
}
pub fn voice(
self,
channel_id: Id<ChannelMarker>,
name: &'a str,
scheduled_start_time: &'a Timestamp,
) -> Result<CreateGuildVoiceScheduledEvent<'a>, ValidationError> {
validate_scheduled_event_name(name)?;
Ok(CreateGuildVoiceScheduledEvent::new(
self,
channel_id,
name,
scheduled_start_time,
))
}
fn exec(self) -> ResponseFuture<GuildScheduledEvent> {
let http = self.http;
match self.try_into_request() {
Ok(request) => http.request(request),
Err(source) => ResponseFuture::error(source),
}
}
fn try_into_request(self) -> Result<Request, Error> {
Request::builder(&Route::CreateGuildScheduledEvent {
guild_id: self.guild_id.get(),
})
.json(&self.fields)
.map(RequestBuilder::build)
}
}
impl<'a> AuditLogReason<'a> for CreateGuildScheduledEvent<'a> {
fn reason(mut self, reason: &'a str) -> Result<Self, ValidationError> {
validate_audit_reason(reason)?;
self.reason.replace(reason);
Ok(self)
}
}