Compare commits
28 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
b8ee6898cd | ||
|
|
52b28f3a82 | ||
|
|
d2ed70afda | ||
|
|
48dc096efc | ||
|
|
8baa49cac3 | ||
|
|
60af09880f | ||
|
|
e3c96befb2 | ||
|
|
1fcdf10c40 | ||
|
|
242ac2f708 | ||
|
|
cad0dca1b2 | ||
|
|
5561865b61 | ||
|
|
458250eb80 | ||
|
|
5258cf33a7 | ||
|
|
f70fa91b00 | ||
|
|
e73e3fba54 | ||
|
|
01be0e3c2f | ||
|
|
0701c6f791 | ||
|
|
c38729441b | ||
|
|
a389de2c77 | ||
|
|
bc86a36745 | ||
|
|
3151e1479a | ||
|
|
12b47f1fed | ||
|
|
c2f03b7f61 | ||
|
|
2cac64f91b | ||
|
|
71efaa0d45 | ||
|
|
fc4b370a1e | ||
|
|
30065b313f | ||
|
|
4236915c5b |
@ -9,9 +9,10 @@ package disgoman
|
|||||||
import (
|
import (
|
||||||
"errors"
|
"errors"
|
||||||
"fmt"
|
"fmt"
|
||||||
"github.com/bwmarrin/discordgo"
|
"regexp"
|
||||||
"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.
|
||||||
@ -90,52 +91,47 @@ 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
|
||||||
cmd, err = shellquote.Split(strings.TrimPrefix(content, prefix))
|
content = strings.TrimPrefix(content, prefix)
|
||||||
if err != nil {
|
r := regexp.MustCompile(`[^ "]+|"([^"]*)"`)
|
||||||
if err.Error() == "Unterminated double-quoted string" || err.Error() == "Unterminated single-quoted string" {
|
cmd = r.FindAllString(content, -1)
|
||||||
cmd = strings.Split(strings.TrimPrefix(content, prefix), " ")
|
for i, val := range cmd {
|
||||||
} else {
|
cmd[i] = strings.Trim(val, "\"")
|
||||||
ctx := Context{
|
}
|
||||||
Session: session,
|
|
||||||
Channel: channel,
|
if len(cmd) < 1 {
|
||||||
Message: m.Message,
|
return
|
||||||
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
|
||||||
invoked := cmd[0]
|
ctx.Invoked = cmd[0]
|
||||||
if cmnd, ok := c.Commands[invoked]; ok {
|
if cmnd, ok := c.Commands[ctx.Invoked]; ok {
|
||||||
command = cmnd
|
command = cmnd
|
||||||
} else {
|
} else {
|
||||||
fmt.Println("Command Not Found")
|
fmt.Println("Command Not Found")
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
if !CheckPermissions(session, m.Author.ID, *channel, command.RequiredPermissions) {
|
if command.SanitizeEveryone {
|
||||||
ctx := Context{
|
for i := 1; i < len(cmd); i++ {
|
||||||
Session: session,
|
cmd[i] = strings.ReplaceAll(cmd[i], "@everyone", "@\ufff0everyone")
|
||||||
Channel: channel,
|
cmd[i] = strings.ReplaceAll(cmd[i], "@here", "@\ufff0here")
|
||||||
Message: m.Message,
|
|
||||||
User: m.Author,
|
|
||||||
Guild: guild,
|
|
||||||
Member: m.Member,
|
|
||||||
Invoked: cmd[0],
|
|
||||||
ErrorChannel: c.ErrorChannel,
|
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if !CheckPermissions(session, m.Author.ID, *channel, command.RequiredPermissions) {
|
||||||
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.",
|
||||||
@ -145,16 +141,6 @@ 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.",
|
||||||
@ -165,16 +151,6 @@ 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!",
|
||||||
@ -184,16 +160,5 @@ func (c *CommandManager) OnMessage(session *discordgo.Session, m *discordgo.Mess
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
context := Context{
|
go command.Invoke(ctx, cmd[1:])
|
||||||
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:])
|
|
||||||
}
|
}
|
||||||
|
|||||||
@ -1,8 +1,9 @@
|
|||||||
package disgoman
|
package disgoman
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"github.com/bwmarrin/discordgo"
|
|
||||||
"io"
|
"io"
|
||||||
|
|
||||||
|
"github.com/dustinpianalto/discordgo"
|
||||||
)
|
)
|
||||||
|
|
||||||
/* context.go:
|
/* 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
|
// 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.ErrorChannel != nil {
|
if c.CommandManager.ErrorChannel != nil {
|
||||||
c.ErrorChannel <- CommandError{
|
c.CommandManager.ErrorChannel <- CommandError{
|
||||||
Context: *c,
|
Context: *c,
|
||||||
Message: message,
|
Message: message,
|
||||||
Error: err,
|
Error: err,
|
||||||
|
|||||||
2
go.mod
2
go.mod
@ -3,6 +3,6 @@ module github.com/dustinpianalto/disgoman
|
|||||||
go 1.14
|
go 1.14
|
||||||
|
|
||||||
require (
|
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
|
github.com/kballard/go-shellquote v0.0.0-20180428030007-95032a82bc51
|
||||||
)
|
)
|
||||||
|
|||||||
2
go.sum
2
go.sum
@ -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 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=
|
||||||
|
|||||||
@ -1,10 +1,11 @@
|
|||||||
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:
|
||||||
@ -37,7 +38,8 @@ 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.UpdateStatus(0, s.Values[i])
|
err := session.UpdateGameStatus(0, s.Values[i])
|
||||||
|
log.Println(err)
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@ -6,7 +6,7 @@ package disgoman
|
|||||||
* Disgoman (c) 2020 Dusty.P/dustinpianalto
|
* 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
|
// CommandManager holds the info and structures required for handling command messages
|
||||||
type CommandManager struct {
|
type CommandManager struct {
|
||||||
@ -48,6 +48,8 @@ type Command struct {
|
|||||||
Hidden bool
|
Hidden bool
|
||||||
// Permissions that are required for the command to function
|
// Permissions that are required for the command to function
|
||||||
RequiredPermissions Permission
|
RequiredPermissions Permission
|
||||||
|
// Should the message content be sanitized before invoking the command
|
||||||
|
SanitizeEveryone bool
|
||||||
// Function to invoke when command is called
|
// Function to invoke when command is called
|
||||||
Invoke CommandInvokeFunc
|
Invoke CommandInvokeFunc
|
||||||
}
|
}
|
||||||
@ -78,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
|
||||||
// Error channel
|
// Command Manager
|
||||||
ErrorChannel chan CommandError
|
CommandManager *CommandManager
|
||||||
}
|
}
|
||||||
|
|||||||
2
types.go
2
types.go
@ -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 int
|
type Permission int64
|
||||||
|
|
||||||
// Defining permissions based on the Discord API
|
// Defining permissions based on the Discord API
|
||||||
const (
|
const (
|
||||||
|
|||||||
17
utils.go
17
utils.go
@ -9,8 +9,9 @@ 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
|
||||||
@ -20,7 +21,7 @@ func GetDefaultStatusManager() StatusManager {
|
|||||||
"Golang!",
|
"Golang!",
|
||||||
"DiscordGo!",
|
"DiscordGo!",
|
||||||
"Disgoman!",
|
"Disgoman!",
|
||||||
}, "30s"}
|
}, "300s"}
|
||||||
}
|
}
|
||||||
|
|
||||||
// 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
|
||||||
@ -72,9 +73,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&int(perms) != 0 {
|
if overwrite.Allow&int64(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&int(perms) != 0 {
|
} else if overwrite.Deny&int64(perms) != 0 {
|
||||||
return false // If there is an explicit deny then false
|
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 {
|
for _, overwrite := range channel.PermissionOverwrites {
|
||||||
if overwrite.ID == roleID {
|
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
|
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
|
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
|
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
|
return true // The role has the required permissions
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user