1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99
mod chat_input;
mod message;
mod user;
pub use self::{
chat_input::CreateGuildChatInputCommand, message::CreateGuildMessageCommand,
user::CreateGuildUserCommand,
};
use super::super::{InteractionError, InteractionErrorType};
use crate::{request::validate_inner, Client};
use twilight_model::id::{ApplicationId, GuildId};
/// Create a new command in a guild.
///
/// The name must be between 1 and 32 characters in length. Creating a guild
/// command with the same name as an already-existing guild command in the same
/// guild will overwrite the old command. See [the discord docs] for more
/// information.
///
/// [the discord docs]: https://discord.com/developers/docs/interactions/application-commands#create-guild-application-command
#[must_use = "the command must have a type"]
pub struct CreateGuildCommand<'a> {
application_id: ApplicationId,
guild_id: GuildId,
http: &'a Client,
name: &'a str,
}
impl<'a> CreateGuildCommand<'a> {
pub(crate) fn new(
http: &'a Client,
application_id: ApplicationId,
guild_id: GuildId,
name: &'a str,
) -> Result<Self, InteractionError> {
if !validate_inner::command_name(name) {
return Err(InteractionError {
kind: InteractionErrorType::CommandNameValidationFailed,
});
}
Ok(Self {
application_id,
guild_id,
http,
name,
})
}
/// Create a chat input command in a guild.
///
/// The description must be between 1 and 100 characters in length. Creating
/// a guild command with the same name as an already-existing guild command
/// in the same guild will overwrite the old command. See [the discord docs]
/// for more information.
///
/// # Errors
///
/// Returns an [`InteractionErrorType::CommandDescriptionValidationFailed`]
/// error type if the command description is not between 1 and
/// 100 characters.
///
/// [the discord docs]: https://discord.com/developers/docs/interactions/application-commands#create-guild-application-command
pub fn chat_input(
self,
description: &'a str,
) -> Result<CreateGuildChatInputCommand<'a>, InteractionError> {
CreateGuildChatInputCommand::new(
self.http,
self.application_id,
self.guild_id,
self.name,
description,
)
}
/// Create a message command in a guild.
///
/// Creating a guild command with the same name as an already-existing guild
/// command in the same guild will overwrite the old command. See [the
/// discord docs] for more information.
///
/// [the discord docs]: https://discord.com/developers/docs/interactions/application-commands#create-guild-application-command
pub const fn message(self) -> CreateGuildMessageCommand<'a> {
CreateGuildMessageCommand::new(self.http, self.application_id, self.guild_id, self.name)
}
/// Create a user command in a guild.
///
/// Creating a guild command with the same name as an already-existing guild
/// command in the same guild will overwrite the old command. See [the
/// discord docs] for more information.
///
/// [the discord docs]: https://discord.com/developers/docs/interactions/application-commands#create-guild-application-command
pub const fn user(self) -> CreateGuildUserCommand<'a> {
CreateGuildUserCommand::new(self.http, self.application_id, self.guild_id, self.name)
}
}