Rename /plugin to /pluginadm and make /prun and /phelp subcommands of /plugin instead
All checks were successful
ci/woodpecker/push/woodpecker Pipeline was successful
ci/woodpecker/tag/woodpecker Pipeline was successful

This commit is contained in:
Elara 2024-04-24 06:30:31 -07:00
parent 5d327f3fd2
commit 4f533eac6b
3 changed files with 59 additions and 40 deletions

View File

@ -11,8 +11,8 @@ import (
"go.elara.ws/owobot/internal/util" "go.elara.ws/owobot/internal/util"
) )
// pluginCmd handles the `/plugin` command and routes it to the correct subcommand. // pluginadmCmd handles the `/plugin` command and routes it to the correct subcommand.
func pluginCmd(s *discordgo.Session, i *discordgo.InteractionCreate) error { func pluginadmCmd(s *discordgo.Session, i *discordgo.InteractionCreate) error {
data := i.ApplicationCommandData() data := i.ApplicationCommandData()
switch name := data.Options[0].Name; name { switch name := data.Options[0].Name; name {
case "list": case "list":
@ -22,7 +22,7 @@ func pluginCmd(s *discordgo.Session, i *discordgo.InteractionCreate) error {
case "disable": case "disable":
return disableCmd(s, i) return disableCmd(s, i)
default: default:
return fmt.Errorf("unknown plugin subcommand: %s", name) return fmt.Errorf("unknown pluginadm subcommand: %s", name)
} }
} }
@ -107,10 +107,22 @@ func disableCmd(s *discordgo.Session, i *discordgo.InteractionCreate) error {
return util.RespondEphemeral(s, i.Interaction, fmt.Sprintf("Successfully disabled the %q plugin", pluginName)) return util.RespondEphemeral(s, i.Interaction, fmt.Sprintf("Successfully disabled the %q plugin", pluginName))
} }
// phelpCmd handles the `/phelp` command. func pluginCmd(s *discordgo.Session, i *discordgo.InteractionCreate) error {
func phelpCmd(s *discordgo.Session, i *discordgo.InteractionCreate) error {
data := i.ApplicationCommandData() data := i.ApplicationCommandData()
cmdStr := data.Options[0].StringValue() switch name := data.Options[0].Name; name {
case "run":
return pluginRunCmd(s, i)
case "help":
return pluginHelpCmd(s, i)
default:
return fmt.Errorf("unknown plugin subcommand: %s", name)
}
}
// pluginHelpCmd handles the `/phelp` command.
func pluginHelpCmd(s *discordgo.Session, i *discordgo.InteractionCreate) error {
data := i.ApplicationCommandData()
cmdStr := data.Options[0].Options[0].StringValue()
args, err := shellquote.Split(cmdStr) args, err := shellquote.Split(cmdStr)
if err != nil { if err != nil {
@ -176,10 +188,10 @@ func phelpCmd(s *discordgo.Session, i *discordgo.InteractionCreate) error {
return fmt.Errorf("command not found: %q", args[0]) return fmt.Errorf("command not found: %q", args[0])
} }
// prunCmd handles the `/prunCmd` command. // pluginRunCmd handles the `/pluginRunCmd` command.
func prunCmd(s *discordgo.Session, i *discordgo.InteractionCreate) error { func pluginRunCmd(s *discordgo.Session, i *discordgo.InteractionCreate) error {
data := i.ApplicationCommandData() data := i.ApplicationCommandData()
cmdStr := data.Options[0].StringValue() cmdStr := data.Options[0].Options[0].StringValue()
args, err := shellquote.Split(cmdStr) args, err := shellquote.Split(cmdStr)
if err != nil { if err != nil {

View File

@ -70,11 +70,11 @@ func handleAutocomplete(s *discordgo.Session, i *discordgo.InteractionCreate) {
} }
data := i.ApplicationCommandData() data := i.ApplicationCommandData()
if data.Name != "prun" && data.Name != "phelp" { if data.Name != "plugin" {
return return
} }
cmdStr := data.Options[0].StringValue() cmdStr := data.Options[0].Options[0].StringValue()
s.InteractionRespond(i.Interaction, &discordgo.InteractionResponse{ s.InteractionRespond(i.Interaction, &discordgo.InteractionResponse{
Type: discordgo.InteractionApplicationCommandAutocompleteResult, Type: discordgo.InteractionApplicationCommandAutocompleteResult,

View File

@ -22,8 +22,13 @@ func Init(s *discordgo.Session) error {
return err return err
} }
commands.Register(s, prunCmd, &discordgo.ApplicationCommand{ commands.Register(s, pluginCmd, &discordgo.ApplicationCommand{
Name: "prun", Name: "plugin",
Description: "Interact with the plugins on this server",
Options: []*discordgo.ApplicationCommandOption{
{
Type: discordgo.ApplicationCommandOptionSubCommand,
Name: "run",
Description: "Run a plugin command", Description: "Run a plugin command",
Options: []*discordgo.ApplicationCommandOption{ Options: []*discordgo.ApplicationCommandOption{
{ {
@ -34,24 +39,26 @@ func Init(s *discordgo.Session) error {
Autocomplete: true, Autocomplete: true,
}, },
}, },
}) },
{
commands.Register(s, phelpCmd, &discordgo.ApplicationCommand{ Type: discordgo.ApplicationCommandOptionSubCommand,
Name: "phelp", Name: "help",
Description: "Display help for a plugin command", Description: "See how to use a plugin command",
Options: []*discordgo.ApplicationCommandOption{ Options: []*discordgo.ApplicationCommandOption{
{ {
Type: discordgo.ApplicationCommandOptionString, Type: discordgo.ApplicationCommandOptionString,
Name: "cmd", Name: "cmd",
Description: "The plugin command to display help for", Description: "The plugin command to help with",
Required: true, Required: true,
Autocomplete: true, Autocomplete: true,
}, },
}, },
},
},
}) })
commands.Register(s, pluginCmd, &discordgo.ApplicationCommand{ commands.Register(s, pluginadmCmd, &discordgo.ApplicationCommand{
Name: "plugin", Name: "pluginadm",
Description: "Manage dynamic plugins for your server", Description: "Manage dynamic plugins for your server",
DefaultMemberPermissions: util.Pointer[int64](discordgo.PermissionManageServer), DefaultMemberPermissions: util.Pointer[int64](discordgo.PermissionManageServer),
Options: []*discordgo.ApplicationCommandOption{ Options: []*discordgo.ApplicationCommandOption{