Compare commits

..

No commits in common. "master" and "v0.0.4" have entirely different histories.

8 changed files with 89 additions and 49 deletions

View File

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

View File

@ -1,9 +1,8 @@
package disgoman package disgoman
import ( import (
"github.com/bwmarrin/discordgo"
"io" "io"
"github.com/dustinpianalto/discordgo"
) )
/* context.go: /* context.go:
@ -33,8 +32,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 // 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. // 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) { func (c *Context) SendError(message string, err error) {
if c.CommandManager.ErrorChannel != nil { if c.ErrorChannel != nil {
c.CommandManager.ErrorChannel <- CommandError{ c.ErrorChannel <- CommandError{
Context: *c, Context: *c,
Message: message, Message: message,
Error: err, Error: err,

2
go.mod
View File

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

2
go.sum
View File

@ -1,3 +1,5 @@
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 h1:WDFjx/TMzVgy9VdMMQi2K2Emtwi2QcUQsztZ/zLaH/Q=
github.com/gorilla/websocket v1.4.0/go.mod h1:E7qHFY5m1UJ88s3WnNqhKjPHQ0heANvMoAMk2YaljkQ= github.com/gorilla/websocket v1.4.0/go.mod h1:E7qHFY5m1UJ88s3WnNqhKjPHQ0heANvMoAMk2YaljkQ=
github.com/kballard/go-shellquote v0.0.0-20180428030007-95032a82bc51 h1:Z9n2FFNUXsshfwJMBgNA0RU6/i7WVaAegv3PtuIHPMs= github.com/kballard/go-shellquote v0.0.0-20180428030007-95032a82bc51 h1:Z9n2FFNUXsshfwJMBgNA0RU6/i7WVaAegv3PtuIHPMs=

View File

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

View File

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

View File

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

View File

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