2021-01-27 17:43:38 +00:00
|
|
|
package discord
|
|
|
|
|
2021-08-03 18:44:20 +00:00
|
|
|
import (
|
|
|
|
"time"
|
2021-05-20 22:47:44 +00:00
|
|
|
|
2021-08-03 18:44:20 +00:00
|
|
|
"github.com/diamondburned/arikawa/v3/utils/json"
|
|
|
|
)
|
|
|
|
|
|
|
|
// Command is the base "command" model that belongs to an application. This is
|
|
|
|
// what you are creating when you POST a new command.
|
|
|
|
//
|
2021-09-24 04:37:50 +00:00
|
|
|
// https://discord.com/developers/docs/interactions/application-commands#application-command-object-application-command-structure
|
2021-01-27 17:43:38 +00:00
|
|
|
type Command struct {
|
2021-08-03 18:44:20 +00:00
|
|
|
// ID is the unique id of the command.
|
|
|
|
ID CommandID `json:"id"`
|
2021-09-09 23:06:44 +00:00
|
|
|
// Type is the type of command.
|
|
|
|
Type CommandType `json:"type,omitempty"`
|
2021-08-03 18:44:20 +00:00
|
|
|
// 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.
|
|
|
|
//
|
|
|
|
// Note that required options must be listed before optional options, and
|
|
|
|
// a command, or each individual subcommand, can have a maximum of 25
|
|
|
|
// options.
|
2021-09-09 23:06:44 +00:00
|
|
|
//
|
|
|
|
// It is only present on ChatInputCommands.
|
2021-08-03 18:44:20 +00:00
|
|
|
Options []CommandOption `json:"options,omitempty"`
|
|
|
|
// NoDefaultPermissions defines whether the command is NOT enabled by
|
|
|
|
// default when the app is added to a guild.
|
2021-09-09 23:06:44 +00:00
|
|
|
NoDefaultPermission bool `json:"-"`
|
2021-09-24 04:37:50 +00:00
|
|
|
// Version is an autoincrementing version identifier updated during
|
|
|
|
// substantial record changes
|
|
|
|
Version Snowflake `json:"version,omitempty"`
|
2021-08-03 18:44:20 +00:00
|
|
|
}
|
|
|
|
|
2021-09-09 23:06:44 +00:00
|
|
|
type CommandType uint
|
|
|
|
|
|
|
|
const (
|
|
|
|
ChatInputCommand CommandType = iota + 1
|
|
|
|
UserCommand
|
|
|
|
MessageCommand
|
|
|
|
)
|
|
|
|
|
2021-08-03 18:44:20 +00:00
|
|
|
func (c Command) MarshalJSON() ([]byte, error) {
|
|
|
|
type RawCommand Command
|
2021-09-09 23:06:44 +00:00
|
|
|
cmd := struct {
|
|
|
|
RawCommand
|
|
|
|
DefaultPermission bool `json:"default_permission"`
|
|
|
|
}{RawCommand: RawCommand(c)}
|
2021-08-03 18:44:20 +00:00
|
|
|
|
|
|
|
// Discord defaults default_permission to true, so we need to invert the
|
|
|
|
// meaning of the field (>No<DefaultPermission) to match Go's default
|
|
|
|
// value, false.
|
2021-09-09 23:06:44 +00:00
|
|
|
cmd.DefaultPermission = !c.NoDefaultPermission
|
2021-08-03 18:44:20 +00:00
|
|
|
|
2021-09-09 23:06:44 +00:00
|
|
|
return json.Marshal(cmd)
|
2021-08-03 18:44:20 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func (c *Command) UnmarshalJSON(data []byte) error {
|
|
|
|
type RawCommand Command
|
2021-09-09 23:06:44 +00:00
|
|
|
cmd := struct {
|
|
|
|
*RawCommand
|
|
|
|
DefaultPermission bool `json:"default_permission"`
|
|
|
|
}{RawCommand: (*RawCommand)(c)}
|
|
|
|
if err := json.Unmarshal(data, &cmd); err != nil {
|
2021-08-03 18:44:20 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
// Discord defaults default_permission to true, so we need to invert the
|
|
|
|
// meaning of the field (>No<DefaultPermission) to match Go's default
|
|
|
|
// value, false.
|
2021-09-09 23:06:44 +00:00
|
|
|
c.NoDefaultPermission = !cmd.DefaultPermission
|
|
|
|
|
|
|
|
// Discord defaults type to 1 if omitted.
|
|
|
|
if c.Type == 0 {
|
|
|
|
c.Type = ChatInputCommand
|
|
|
|
}
|
2021-08-03 18:44:20 +00:00
|
|
|
|
|
|
|
return nil
|
2021-01-27 17:43:38 +00:00
|
|
|
}
|
|
|
|
|
2021-05-20 22:47:44 +00:00
|
|
|
// CreatedAt returns a time object representing when the command was created.
|
|
|
|
func (c Command) CreatedAt() time.Time {
|
|
|
|
return c.ID.Time()
|
|
|
|
}
|
|
|
|
|
2021-01-27 17:43:38 +00:00
|
|
|
type CommandOption struct {
|
|
|
|
Type CommandOptionType `json:"type"`
|
|
|
|
Name string `json:"name"`
|
|
|
|
Description string `json:"description"`
|
|
|
|
Required bool `json:"required"`
|
|
|
|
Choices []CommandOptionChoice `json:"choices,omitempty"`
|
|
|
|
Options []CommandOption `json:"options,omitempty"`
|
|
|
|
}
|
|
|
|
|
|
|
|
type CommandOptionType uint
|
|
|
|
|
|
|
|
const (
|
|
|
|
SubcommandOption CommandOptionType = iota + 1
|
|
|
|
SubcommandGroupOption
|
|
|
|
StringOption
|
|
|
|
IntegerOption
|
|
|
|
BooleanOption
|
|
|
|
UserOption
|
|
|
|
ChannelOption
|
|
|
|
RoleOption
|
2021-08-03 15:54:17 +00:00
|
|
|
MentionableOption
|
|
|
|
NumberOption
|
2021-01-27 17:43:38 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
type CommandOptionChoice struct {
|
|
|
|
Name string `json:"name"`
|
|
|
|
Value string `json:"value"`
|
|
|
|
}
|
2021-08-03 18:44:20 +00:00
|
|
|
|
|
|
|
// https://discord.com/developers/docs/interactions/slash-commands#application-command-permissions-object-guild-application-command-permissions-structure
|
|
|
|
type GuildCommandPermissions struct {
|
|
|
|
ID CommandID `json:"id"`
|
|
|
|
AppID AppID `json:"application_id"`
|
|
|
|
GuildID GuildID `json:"guild_id"`
|
|
|
|
Permissions []CommandPermissions `json:"permissions"`
|
|
|
|
}
|
|
|
|
|
|
|
|
// https://discord.com/developers/docs/interactions/slash-commands#application-command-permissions-object-application-command-permissions-structure
|
|
|
|
type CommandPermissions struct {
|
|
|
|
ID Snowflake `json:"id"`
|
|
|
|
Type CommandPermissionType `json:"type"`
|
|
|
|
Permission bool `json:"permission"`
|
|
|
|
}
|
|
|
|
|
|
|
|
type CommandPermissionType uint8
|
|
|
|
|
|
|
|
// https://discord.com/developers/docs/interactions/slash-commands#application-command-permissions-object-application-command-permission-type
|
|
|
|
const (
|
|
|
|
RoleCommandPermission = iota + 1
|
|
|
|
UserCommandPermission
|
|
|
|
)
|