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"
)
// pluginCmd handles the `/plugin` command and routes it to the correct subcommand.
func pluginCmd(s *discordgo.Session, i *discordgo.InteractionCreate) error {
// pluginadmCmd handles the `/plugin` command and routes it to the correct subcommand.
func pluginadmCmd(s *discordgo.Session, i *discordgo.InteractionCreate) error {
data := i.ApplicationCommandData()
switch name := data.Options[0].Name; name {
case "list":
@ -22,7 +22,7 @@ func pluginCmd(s *discordgo.Session, i *discordgo.InteractionCreate) error {
case "disable":
return disableCmd(s, i)
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))
}
// phelpCmd handles the `/phelp` command.
func phelpCmd(s *discordgo.Session, i *discordgo.InteractionCreate) error {
func pluginCmd(s *discordgo.Session, i *discordgo.InteractionCreate) error {
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)
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])
}
// prunCmd handles the `/prunCmd` command.
func prunCmd(s *discordgo.Session, i *discordgo.InteractionCreate) error {
// pluginRunCmd handles the `/pluginRunCmd` command.
func pluginRunCmd(s *discordgo.Session, i *discordgo.InteractionCreate) error {
data := i.ApplicationCommandData()
cmdStr := data.Options[0].StringValue()
cmdStr := data.Options[0].Options[0].StringValue()
args, err := shellquote.Split(cmdStr)
if err != nil {

View File

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

View File

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