2020-03-08 17:54:06 +01:00
|
|
|
package bot
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"strings"
|
|
|
|
|
2022-01-12 19:44:06 +01:00
|
|
|
twitch "github.com/gempir/go-twitch-irc/v3"
|
2020-03-08 17:54:06 +01:00
|
|
|
"github.com/gempir/justlog/humanize"
|
|
|
|
log "github.com/sirupsen/logrus"
|
|
|
|
)
|
|
|
|
|
2021-10-02 20:50:56 +02:00
|
|
|
const (
|
2021-10-02 21:23:00 +02:00
|
|
|
commandPrefix = "!justlog"
|
2021-10-02 21:05:41 +02:00
|
|
|
errNoUsernames = ", at least 1 username has to be provided. multiple usernames have to be separated with a space"
|
|
|
|
errRequestingUserIDs = ", something went wrong requesting the userids"
|
2021-10-02 20:50:56 +02:00
|
|
|
)
|
|
|
|
|
2021-01-08 22:19:20 +01:00
|
|
|
func (b *Bot) handlePrivateMessageCommands(message twitch.PrivateMessage) {
|
2021-10-02 20:50:56 +02:00
|
|
|
if !strings.HasPrefix(strings.ToLower(message.Message), commandPrefix) {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2021-10-02 21:23:00 +02:00
|
|
|
args := strings.Fields(message.Message[len(commandPrefix):])
|
2021-12-27 18:48:23 +01:00
|
|
|
if len(args) < 1 {
|
|
|
|
return
|
|
|
|
}
|
2021-10-02 21:23:00 +02:00
|
|
|
commandName := args[0]
|
2021-10-02 20:50:56 +02:00
|
|
|
args = args[1:]
|
|
|
|
|
|
|
|
switch commandName {
|
|
|
|
case "status":
|
2022-07-31 15:03:21 +02:00
|
|
|
if !contains(b.cfg.Admins, message.User.Name) {
|
|
|
|
return
|
|
|
|
}
|
2021-10-02 20:50:56 +02:00
|
|
|
uptime := humanize.TimeSince(b.startTime)
|
|
|
|
b.Say(message.Channel, fmt.Sprintf("%s, uptime: %s", message.User.DisplayName, uptime))
|
|
|
|
|
|
|
|
case "join":
|
2022-07-31 15:03:21 +02:00
|
|
|
if !contains(b.cfg.Admins, message.User.Name) {
|
|
|
|
return
|
|
|
|
}
|
2021-10-02 20:50:56 +02:00
|
|
|
b.handleJoin(message, args)
|
|
|
|
|
|
|
|
case "part":
|
2022-07-31 15:03:21 +02:00
|
|
|
if !contains(b.cfg.Admins, message.User.Name) {
|
|
|
|
return
|
|
|
|
}
|
2021-10-02 20:50:56 +02:00
|
|
|
b.handlePart(message, args)
|
|
|
|
|
|
|
|
case "optout":
|
|
|
|
b.handleOptOut(message, args)
|
|
|
|
case "optin":
|
2022-07-31 15:03:21 +02:00
|
|
|
if !contains(b.cfg.Admins, message.User.Name) {
|
|
|
|
return
|
|
|
|
}
|
2021-10-02 20:50:56 +02:00
|
|
|
b.handleOptIn(message, args)
|
2020-03-08 17:54:06 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-10-02 20:50:56 +02:00
|
|
|
// Commands
|
|
|
|
|
|
|
|
func (b *Bot) handleJoin(message twitch.PrivateMessage, args []string) {
|
|
|
|
if len(args) < 1 {
|
2021-10-02 21:05:41 +02:00
|
|
|
b.Say(message.Channel, message.User.DisplayName+errNoUsernames)
|
2021-10-02 20:50:56 +02:00
|
|
|
return
|
|
|
|
}
|
2020-03-08 17:54:06 +01:00
|
|
|
|
2021-10-02 20:50:56 +02:00
|
|
|
users, err := b.helixClient.GetUsersByUsernames(args)
|
2020-03-08 17:54:06 +01:00
|
|
|
if err != nil {
|
|
|
|
log.Error(err)
|
2021-10-02 21:05:41 +02:00
|
|
|
b.Say(message.Channel, message.User.DisplayName+errRequestingUserIDs)
|
2020-03-08 17:54:06 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
ids := []string{}
|
|
|
|
for _, user := range users {
|
|
|
|
ids = append(ids, user.ID)
|
2020-12-05 18:32:21 +01:00
|
|
|
b.Join(user.Login)
|
2020-03-08 17:54:06 +01:00
|
|
|
}
|
|
|
|
b.cfg.AddChannels(ids...)
|
2020-12-05 18:32:21 +01:00
|
|
|
b.Say(message.Channel, fmt.Sprintf("%s, added channels: %v", message.User.DisplayName, ids))
|
2020-03-08 17:54:06 +01:00
|
|
|
}
|
|
|
|
|
2021-10-02 20:50:56 +02:00
|
|
|
func (b *Bot) handlePart(message twitch.PrivateMessage, args []string) {
|
|
|
|
if len(args) < 1 {
|
2021-10-02 21:05:41 +02:00
|
|
|
b.Say(message.Channel, message.User.DisplayName+errNoUsernames)
|
2021-10-02 20:50:56 +02:00
|
|
|
return
|
|
|
|
}
|
2020-03-08 17:54:06 +01:00
|
|
|
|
2021-10-02 20:50:56 +02:00
|
|
|
users, err := b.helixClient.GetUsersByUsernames(args)
|
2020-03-08 17:54:06 +01:00
|
|
|
if err != nil {
|
|
|
|
log.Error(err)
|
2021-10-02 21:05:41 +02:00
|
|
|
b.Say(message.Channel, message.User.DisplayName+errRequestingUserIDs)
|
2020-03-08 17:54:06 +01:00
|
|
|
}
|
|
|
|
|
2021-04-16 18:03:41 +02:00
|
|
|
ids := []string{}
|
|
|
|
for _, user := range users {
|
|
|
|
ids = append(ids, user.ID)
|
|
|
|
b.Part(user.Login)
|
2020-03-08 17:54:06 +01:00
|
|
|
}
|
2021-04-16 18:03:41 +02:00
|
|
|
b.cfg.RemoveChannels(ids...)
|
|
|
|
b.Say(message.Channel, fmt.Sprintf("%s, removed channels: %v", message.User.DisplayName, ids))
|
2020-03-08 17:54:06 +01:00
|
|
|
}
|
2020-08-27 03:35:20 +02:00
|
|
|
|
2021-10-02 20:50:56 +02:00
|
|
|
func (b *Bot) handleOptOut(message twitch.PrivateMessage, args []string) {
|
|
|
|
if len(args) < 1 {
|
2021-10-02 21:05:41 +02:00
|
|
|
b.Say(message.Channel, message.User.DisplayName+errNoUsernames)
|
2021-10-02 20:50:56 +02:00
|
|
|
return
|
|
|
|
}
|
2021-06-05 16:23:52 +02:00
|
|
|
|
2022-07-31 15:03:21 +02:00
|
|
|
if _, ok := b.OptoutCodes.LoadAndDelete(args[0]); ok {
|
|
|
|
b.cfg.OptOutUsers(message.User.ID)
|
|
|
|
b.Say(message.Channel, fmt.Sprintf("%s, opted you out", message.User.DisplayName))
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
if !contains(b.cfg.Admins, message.User.Name) {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2021-10-02 20:50:56 +02:00
|
|
|
users, err := b.helixClient.GetUsersByUsernames(args)
|
2021-06-05 16:23:52 +02:00
|
|
|
if err != nil {
|
|
|
|
log.Error(err)
|
2021-10-02 21:05:41 +02:00
|
|
|
b.Say(message.Channel, message.User.DisplayName+errRequestingUserIDs)
|
2021-06-05 16:23:52 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
ids := []string{}
|
|
|
|
for _, user := range users {
|
|
|
|
ids = append(ids, user.ID)
|
|
|
|
}
|
|
|
|
b.cfg.OptOutUsers(ids...)
|
|
|
|
b.Say(message.Channel, fmt.Sprintf("%s, opted out channels: %v", message.User.DisplayName, ids))
|
|
|
|
}
|
|
|
|
|
2021-10-02 20:50:56 +02:00
|
|
|
func (b *Bot) handleOptIn(message twitch.PrivateMessage, args []string) {
|
|
|
|
if len(args) < 1 {
|
2021-10-02 21:05:41 +02:00
|
|
|
b.Say(message.Channel, message.User.DisplayName+errNoUsernames)
|
2021-10-02 20:50:56 +02:00
|
|
|
return
|
|
|
|
}
|
2021-06-05 16:23:52 +02:00
|
|
|
|
2021-10-02 20:50:56 +02:00
|
|
|
users, err := b.helixClient.GetUsersByUsernames(args)
|
2021-06-05 16:23:52 +02:00
|
|
|
if err != nil {
|
|
|
|
log.Error(err)
|
2021-10-02 21:05:41 +02:00
|
|
|
b.Say(message.Channel, message.User.DisplayName+errRequestingUserIDs)
|
2021-06-05 16:23:52 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
ids := []string{}
|
|
|
|
for _, user := range users {
|
|
|
|
ids = append(ids, user.ID)
|
|
|
|
}
|
|
|
|
|
|
|
|
b.cfg.RemoveOptOut(ids...)
|
|
|
|
b.Say(message.Channel, fmt.Sprintf("%s, opted in channels: %v", message.User.DisplayName, ids))
|
|
|
|
}
|
|
|
|
|
2021-10-02 20:50:56 +02:00
|
|
|
// Utilities
|
|
|
|
|
2020-08-27 03:35:20 +02:00
|
|
|
func contains(arr []string, str string) bool {
|
|
|
|
for _, x := range arr {
|
|
|
|
if x == str {
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return false
|
|
|
|
}
|