package discord import ( "fmt" "time" "github.com/diamondburned/arikawa/v3/utils/json" "github.com/diamondburned/arikawa/v3/utils/json/option" "github.com/pkg/errors" ) // CommandType is the type of the command, which describes the intended // invokation source of the command. type CommandType uint const ( ChatInputCommand CommandType = iota + 1 UserCommand MessageCommand ) // Command is the base "command" model that belongs to an application. This is // what you are creating when you POST a new command. // // https://discord.com/developers/docs/interactions/application-commands#application-command-object-application-command-structure type Command struct { // ID is the unique id of the command. ID CommandID `json:"id"` // Type is the intended source of the command. Type CommandType `json:"type,omitempty"` // AppID is the unique id of the parent application. AppID AppID `json:"application_id"` // GuildID is the guild id of the command, if not global. GuildID GuildID `json:"guild_id,omitempty"` // Name is the 1-32 lowercase character name matching ^[\w-]{1,32}$. Name string `json:"name"` // Description is the 1-100 character description. Description string `json:"description"` // Options are the parameters for the command. Its types are value types, // which can either be a SubcommandOption or a SubcommandGroupOption. // // Note that required options must be listed before optional options, and // a command, or each individual subcommand, can have a maximum of 25 // options. // // It is only present on ChatInputCommands. Options CommandOptions `json:"options,omitempty"` // NoDefaultPermissions defines whether the command is NOT enabled by // default when the app is added to a guild. NoDefaultPermission bool `json:"-"` // Version is an autoincrementing version identifier updated during // substantial record changes Version Snowflake `json:"version,omitempty"` } // CreatedAt returns a time object representing when the command was created. func (c *Command) CreatedAt() time.Time { return c.ID.Time() } func (c *Command) MarshalJSON() ([]byte, error) { type RawCommand Command cmd := struct { *RawCommand DefaultPermission bool `json:"default_permission"` }{RawCommand: (*RawCommand)(c)} // Discord defaults default_permission to true, so we need to invert the // meaning of the field (>NoNo