Add option to toggle server name
This commit is contained in:
parent
74198b8930
commit
c0076759a4
34
main.go
34
main.go
@ -5,13 +5,11 @@ import (
|
||||
"os"
|
||||
"regexp"
|
||||
|
||||
|
||||
"github.com/BurntSushi/toml"
|
||||
"github.com/bwmarrin/discordgo"
|
||||
"git.directme.in/Joren/SmsHook/ringbuffer"
|
||||
)
|
||||
|
||||
|
||||
var (
|
||||
Token string
|
||||
Servers []ServerConfig
|
||||
@ -29,6 +27,7 @@ type ServerConfig struct {
|
||||
} `toml:"CHANNEL_BLACKLIST"`
|
||||
PrefixEnabled bool `toml:"PREFIX_ENABLED"`
|
||||
AllowDuplicates bool `toml:"ALLOW_DUPLICATES"`
|
||||
ServerIDEnabled bool `toml:"SERVER_ID_ENABLED"`
|
||||
}
|
||||
|
||||
func init() {
|
||||
@ -110,19 +109,25 @@ func messageCreate(s *discordgo.Session, m *discordgo.MessageCreate) {
|
||||
return
|
||||
}
|
||||
|
||||
checkMessageContent(s, server, m)
|
||||
checkEmbeds(s, server, m)
|
||||
guild, err := s.Guild(m.GuildID)
|
||||
if err != nil {
|
||||
fmt.Println("Error getting guild:", err)
|
||||
return
|
||||
}
|
||||
|
||||
checkMessageContent(s, server, m, guild.Name)
|
||||
checkEmbeds(s, server, m, guild.Name)
|
||||
return
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
func checkMessageContent(s *discordgo.Session, server ServerConfig, m *discordgo.MessageCreate) {
|
||||
func checkMessageContent(s *discordgo.Session, server ServerConfig, m *discordgo.MessageCreate, serverName string) {
|
||||
for coin, regex := range CoinRegexes {
|
||||
match := regex.FindStringSubmatch(m.Content)
|
||||
if len(match) > 0 {
|
||||
matchedAddress := match[0]
|
||||
message := formatMessage(server, coin, m.Author.Username, matchedAddress)
|
||||
message := formatMessage(server, coin, m.Author.Username, matchedAddress, serverName)
|
||||
|
||||
if !server.AllowDuplicates && MessageHistory[server.ServerID].ContainsItem(message) {
|
||||
return
|
||||
@ -134,14 +139,14 @@ func checkMessageContent(s *discordgo.Session, server ServerConfig, m *discordgo
|
||||
}
|
||||
}
|
||||
|
||||
func checkEmbeds(s *discordgo.Session, server ServerConfig, m *discordgo.MessageCreate) {
|
||||
func checkEmbeds(s *discordgo.Session, server ServerConfig, m *discordgo.MessageCreate, serverName string) {
|
||||
for _, embed := range m.Message.Embeds {
|
||||
if embed.Type == "rich" && embed.Description != "" {
|
||||
for coin, regex := range CoinRegexes {
|
||||
match := regex.FindStringSubmatch(embed.Description)
|
||||
if len(match) > 0 {
|
||||
matchedAddress := match[0]
|
||||
message := formatMessage(server, coin, m.Author.Username, matchedAddress)
|
||||
message := formatMessage(server, coin, m.Author.Username, matchedAddress, serverName)
|
||||
|
||||
if !server.AllowDuplicates && MessageHistory[server.ServerID].ContainsItem(message) {
|
||||
return
|
||||
@ -155,11 +160,18 @@ func checkEmbeds(s *discordgo.Session, server ServerConfig, m *discordgo.Message
|
||||
}
|
||||
}
|
||||
|
||||
func formatMessage(server ServerConfig, coin, username, address string) string {
|
||||
func formatMessage(server ServerConfig, coin, username, address, serverName string) string {
|
||||
message := address
|
||||
|
||||
if server.PrefixEnabled {
|
||||
return fmt.Sprintf("%s: %s", coin, address)
|
||||
message = fmt.Sprintf("%s: %s", coin, address)
|
||||
}
|
||||
return address
|
||||
|
||||
if server.ServerIDEnabled {
|
||||
message = fmt.Sprintf("%s (Server: %s)", message, serverName)
|
||||
}
|
||||
|
||||
return message
|
||||
}
|
||||
|
||||
func isChannelBlacklisted(serverID, channelID string) bool {
|
||||
|
Loading…
Reference in New Issue
Block a user