Compare commits

...

25 Commits

Author SHA1 Message Date
Dusty.P
b8ee6898cd
Update go.mod 2024-01-06 20:21:06 -09:00
Dusty.P
52b28f3a82
Update go.mod 2024-01-06 20:16:46 -09:00
Dusty.P
d2ed70afda
Update go.mod 2024-01-06 20:10:16 -09:00
Dusty.P
48dc096efc
Update go.mod 2024-01-06 19:58:04 -09:00
Dusty.P
8baa49cac3
Update utils.go 2024-01-06 19:53:30 -09:00
Dusty.P
60af09880f
Update structs.go 2024-01-06 19:53:19 -09:00
Dusty.P
e3c96befb2
Update status-manager.go 2024-01-06 19:53:10 -09:00
Dusty.P
1fcdf10c40
Update go.sum 2024-01-06 19:53:01 -09:00
Dusty.P
242ac2f708
Update go.mod 2024-01-06 19:52:46 -09:00
Dusty.P
cad0dca1b2
Update context.go 2024-01-06 19:52:26 -09:00
Dusty.P
5561865b61
Update command-manager.go 2024-01-06 19:52:14 -09:00
Dustin Pianalto
458250eb80 Update status updater 2021-08-05 23:21:20 -08:00
Dustin Pianalto
5258cf33a7 Test statis update 2021-08-05 22:46:32 -08:00
Dustin Pianalto
f70fa91b00 Test status update 2021-08-05 22:40:25 -08:00
Dustin Pianalto
e73e3fba54 Update types to fix discordgo updates 2021-08-05 21:17:47 -08:00
Dustin Pianalto
01be0e3c2f Update types to fix discordgo updates 2021-08-05 21:07:24 -08:00
Dustin Pianalto
0701c6f791 Update types to fix discordgo updates 2021-08-05 20:38:36 -08:00
Dustin Pianalto
c38729441b Pass full command manager to context (breaking) 2020-09-18 18:01:32 -08:00
Dustin Pianalto
a389de2c77 Pass full command manager to context (breaking) 2020-09-18 17:48:02 -08:00
Dustin Pianalto
bc86a36745 Fix bug in regex which removed newlines 2020-09-01 20:56:27 -08:00
Dustin Pianalto
3151e1479a Change method of splitting cmd 2020-09-01 20:10:28 -08:00
Dusty Pianalto
12b47f1fed Use single Context struct updating Invoked 2020-06-04 16:29:36 -08:00
Dustin Pianalto
c2f03b7f61 Change shellquote error check 2020-06-02 18:49:15 -08:00
Dustin Pianalto
2cac64f91b Add log on shellquote error 2020-06-02 13:34:13 -08:00
Dustin Pianalto
71efaa0d45 Increase default interval on status manager 2020-06-01 15:02:24 -08:00
8 changed files with 44 additions and 88 deletions

View File

@ -9,9 +9,10 @@ package disgoman
import (
"errors"
"fmt"
"github.com/bwmarrin/discordgo"
"github.com/kballard/go-shellquote"
"regexp"
"strings"
"github.com/dustinpianalto/discordgo"
)
// AddCommand adds the Command at the address passed in to the Commands array on the CommandManager.
@ -90,13 +91,6 @@ func (c *CommandManager) OnMessage(session *discordgo.Session, m *discordgo.Mess
guild, _ := session.Guild(m.GuildID)
var cmd []string
// If we found our prefix then remove it and split the command into pieces
cmd, err = shellquote.Split(strings.TrimPrefix(content, prefix))
if err != nil {
if err.Error() == "Unterminated double-quoted string" || err.Error() == "Unterminated single-quoted string" {
cmd = strings.Split(strings.TrimPrefix(content, prefix), " ")
} else {
ctx := Context{
Session: session,
Channel: channel,
@ -105,15 +99,16 @@ func (c *CommandManager) OnMessage(session *discordgo.Session, m *discordgo.Mess
Guild: guild,
Member: m.Member,
Invoked: "",
ErrorChannel: c.ErrorChannel,
}
c.ErrorChannel <- CommandError{
Context: ctx,
Message: "",
Error: err,
}
return
CommandManager: c,
}
var cmd []string
// If we found our prefix then remove it and split the command into pieces
content = strings.TrimPrefix(content, prefix)
r := regexp.MustCompile(`[^ "]+|"([^"]*)"`)
cmd = r.FindAllString(content, -1)
for i, val := range cmd {
cmd[i] = strings.Trim(val, "\"")
}
if len(cmd) < 1 {
@ -121,8 +116,8 @@ func (c *CommandManager) OnMessage(session *discordgo.Session, m *discordgo.Mess
}
var command *Command
invoked := cmd[0]
if cmnd, ok := c.Commands[invoked]; ok {
ctx.Invoked = cmd[0]
if cmnd, ok := c.Commands[ctx.Invoked]; ok {
command = cmnd
} else {
fmt.Println("Command Not Found")
@ -137,16 +132,6 @@ func (c *CommandManager) OnMessage(session *discordgo.Session, m *discordgo.Mess
}
if !CheckPermissions(session, m.Author.ID, *channel, command.RequiredPermissions) {
ctx := Context{
Session: session,
Channel: channel,
Message: m.Message,
User: m.Author,
Guild: guild,
Member: m.Member,
Invoked: cmd[0],
ErrorChannel: c.ErrorChannel,
}
c.ErrorChannel <- CommandError{
Context: ctx,
Message: "You don't have the correct permissions to run this command.",
@ -156,16 +141,6 @@ func (c *CommandManager) OnMessage(session *discordgo.Session, m *discordgo.Mess
}
if !CheckPermissions(session, session.State.User.ID, *channel, command.RequiredPermissions) {
ctx := Context{
Session: session,
Channel: channel,
Message: m.Message,
User: m.Author,
Guild: guild,
Member: m.Member,
Invoked: cmd[0],
ErrorChannel: c.ErrorChannel,
}
c.ErrorChannel <- CommandError{
Context: ctx,
Message: "I don't have the correct permissions to run this command.",
@ -176,16 +151,6 @@ func (c *CommandManager) OnMessage(session *discordgo.Session, m *discordgo.Mess
}
if command.OwnerOnly && !c.IsOwner(m.Author.ID) {
ctx := Context{
Session: session,
Channel: channel,
Message: m.Message,
User: m.Author,
Guild: guild,
Member: m.Member,
Invoked: cmd[0],
ErrorChannel: c.ErrorChannel,
}
c.ErrorChannel <- CommandError{
Context: ctx,
Message: "Sorry, only the bot owner(s) can run that command!",
@ -195,16 +160,5 @@ func (c *CommandManager) OnMessage(session *discordgo.Session, m *discordgo.Mess
}
context := Context{
Session: session,
Channel: channel,
Message: m.Message,
User: m.Author,
Guild: guild,
Member: m.Member,
Invoked: invoked,
ErrorChannel: c.ErrorChannel,
}
go command.Invoke(context, cmd[1:])
go command.Invoke(ctx, cmd[1:])
}

View File

@ -1,8 +1,9 @@
package disgoman
import (
"github.com/bwmarrin/discordgo"
"io"
"github.com/dustinpianalto/discordgo"
)
/* context.go:
@ -32,8 +33,8 @@ func (c *Context) SendFile(filename string, file io.Reader) (*discordgo.Message,
// Will block if the channel buffer is full. It is up to the client to implement a channel for the errors as well as
// a function to handle the errors from said channel. If the ErrorChannel is nil then this does nothing.
func (c *Context) SendError(message string, err error) {
if c.ErrorChannel != nil {
c.ErrorChannel <- CommandError{
if c.CommandManager.ErrorChannel != nil {
c.CommandManager.ErrorChannel <- CommandError{
Context: *c,
Message: message,
Error: err,

2
go.mod
View File

@ -3,6 +3,6 @@ module github.com/dustinpianalto/disgoman
go 1.14
require (
github.com/bwmarrin/discordgo v0.20.2
github.com/dustinpianalto/discordgo v0.0.4
github.com/kballard/go-shellquote v0.0.0-20180428030007-95032a82bc51
)

2
go.sum
View File

@ -1,5 +1,3 @@
github.com/bwmarrin/discordgo v0.20.2 h1:nA7jiTtqUA9lT93WL2jPjUp8ZTEInRujBdx1C9gkr20=
github.com/bwmarrin/discordgo v0.20.2/go.mod h1:O9S4p+ofTFwB02em7jkpkV8M3R0/PUVOwN61zSZ0r4Q=
github.com/gorilla/websocket v1.4.0 h1:WDFjx/TMzVgy9VdMMQi2K2Emtwi2QcUQsztZ/zLaH/Q=
github.com/gorilla/websocket v1.4.0/go.mod h1:E7qHFY5m1UJ88s3WnNqhKjPHQ0heANvMoAMk2YaljkQ=
github.com/kballard/go-shellquote v0.0.0-20180428030007-95032a82bc51 h1:Z9n2FFNUXsshfwJMBgNA0RU6/i7WVaAegv3PtuIHPMs=

View File

@ -1,10 +1,11 @@
package disgoman
import (
"github.com/bwmarrin/discordgo"
"log"
"math/rand"
"time"
"github.com/dustinpianalto/discordgo"
)
/* status-manager.go:
@ -37,7 +38,8 @@ func (s *StatusManager) SetInterval(interval string) {
// UpdateStatus updates the status of the bot
func (s *StatusManager) UpdateStatus(session *discordgo.Session) error {
i := rand.Intn(len(s.Values))
err := session.UpdateStatus(0, s.Values[i])
err := session.UpdateGameStatus(0, s.Values[i])
log.Println(err)
return err
}

View File

@ -6,7 +6,7 @@ package disgoman
* Disgoman (c) 2020 Dusty.P/dustinpianalto
*/
import "github.com/bwmarrin/discordgo"
import "github.com/dustinpianalto/discordgo"
// CommandManager holds the info and structures required for handling command messages
type CommandManager struct {
@ -80,6 +80,6 @@ type Context struct {
Member *discordgo.Member
// Name of the command as it was invoked (this is so you know what alias was used to call the command)
Invoked string
// Error channel
ErrorChannel chan CommandError
// Command Manager
CommandManager *CommandManager
}

View File

@ -13,7 +13,7 @@ type CommandInvokeFunc func(Context, []string)
type PrefixesFunc func(string) []string
// Permission type to help with managing permissions for commands
type Permission int
type Permission int64
// Defining permissions based on the Discord API
const (

View File

@ -9,8 +9,9 @@ package disgoman
import (
"errors"
"fmt"
"github.com/bwmarrin/discordgo"
"sort"
"github.com/dustinpianalto/discordgo"
)
// GetDefaultStatusManager returns a default Status Manager
@ -20,7 +21,7 @@ func GetDefaultStatusManager() StatusManager {
"Golang!",
"DiscordGo!",
"Disgoman!",
}, "30s"}
}, "300s"}
}
// HasHigherRole checks if the caller has a higher role than the target in the given guild
@ -72,9 +73,9 @@ func CheckPermissions(session *discordgo.Session, memberID string, channel disco
for _, overwrite := range channel.PermissionOverwrites {
if overwrite.ID == memberID {
if overwrite.Allow&int(perms) != 0 {
if overwrite.Allow&int64(perms) != 0 {
return true // If the channel has an overwrite for the user then true
} else if overwrite.Deny&int(perms) != 0 {
} else if overwrite.Deny&int64(perms) != 0 {
return false // If there is an explicit deny then false
}
}
@ -93,19 +94,19 @@ func CheckPermissions(session *discordgo.Session, memberID string, channel disco
for _, overwrite := range channel.PermissionOverwrites {
if overwrite.ID == roleID {
if overwrite.Allow&int(perms) != 0 {
if overwrite.Allow&int64(perms) != 0 {
return true // If the channel has an overwrite for the role then true
} else if overwrite.Deny&int(perms) != 0 {
} else if overwrite.Deny&int64(perms) != 0 {
return false // If there is an explicit deny then false
}
}
}
if role.Permissions&int(PermissionAdministrator) != 0 {
if role.Permissions&int64(PermissionAdministrator) != 0 {
return true // If they are an administrator then they automatically have all permissions
}
if role.Permissions&int(perms) != 0 {
if role.Permissions&int64(perms) != 0 {
return true // The role has the required permissions
}
}