mastodon-group-bot/bot.go

164 lines
4.2 KiB
Go
Raw Normal View History

2022-08-22 11:46:49 +00:00
package main
import (
"context"
2022-09-01 11:31:27 +00:00
"crypto/sha512"
2022-08-22 11:46:49 +00:00
"fmt"
"regexp"
"strings"
"github.com/mattn/go-mastodon"
)
2022-09-08 12:26:25 +00:00
var (
c = mastodon.NewClient(&mastodon.Config{
2022-08-22 11:46:49 +00:00
Server: Conf.Server,
ClientID: Conf.ClientID,
ClientSecret: Conf.ClientSecret,
AccessToken: Conf.AccessToken,
})
2022-09-08 12:26:25 +00:00
ctx = context.Background()
my_account, _ = c.GetAccountCurrentUser(ctx)
)
func RunBot() {
2022-08-22 11:46:49 +00:00
events, err := c.StreamingUser(ctx)
if err != nil {
2022-08-28 16:37:43 +00:00
ErrorLogger.Println("Streaming")
2022-08-22 11:46:49 +00:00
}
// Run bot
for {
notifEvent, ok := (<-events).(*mastodon.NotificationEvent)
if !ok {
continue
}
notif := notifEvent.Notification
// New follower
2022-09-08 15:00:27 +00:00
if notif.Type == "follow" {
2022-09-08 18:28:32 +00:00
acct := notif.Account.Acct
2022-09-08 15:00:27 +00:00
2022-09-08 12:26:25 +00:00
if !exist_in_database(acct) { // Add to db and post welcome message
2022-08-28 16:37:43 +00:00
InfoLogger.Printf("%s followed", acct)
2022-09-01 11:31:27 +00:00
add_to_db(acct)
2022-08-28 16:37:43 +00:00
InfoLogger.Printf("%s added to database", acct)
2022-09-06 09:31:05 +00:00
message := fmt.Sprintf("%s @%s", Conf.WelcomeMessage, acct)
2022-09-08 12:26:25 +00:00
_, err := postToot(message, "public")
2022-08-28 16:37:43 +00:00
if err != nil {
ErrorLogger.Println("Post welcome message")
}
InfoLogger.Printf("%s was welcomed", acct)
2022-08-25 19:23:44 +00:00
}
2022-08-22 11:46:49 +00:00
}
// Read message
2022-09-08 15:00:27 +00:00
if notif.Type == "mention" {
2022-09-23 02:10:13 +00:00
var account_id = []string{string(notif.Status.Account.ID)}
2022-09-08 15:00:27 +00:00
acct := notif.Status.Account.Acct
content := notif.Status.Content
tooturl := notif.Status.URL
2022-09-23 02:10:13 +00:00
// Fetch relationship
relationship, err := c.GetAccountRelationships(ctx, account_id)
if err != nil {
ErrorLogger.Println("Fetch relationship")
2022-09-09 05:44:09 +00:00
}
2022-09-08 18:28:32 +00:00
// Follow check
2022-09-23 02:10:13 +00:00
if relationship[0].FollowedBy {
2022-09-08 18:28:32 +00:00
if notif.Status.Visibility == "public" { // Reblog toot
if notif.Status.InReplyToID == nil { // Not boost replies
// Duplicate protection
content_hash := sha512.New()
content_hash.Write([]byte(content))
hash := fmt.Sprintf("%x", content_hash.Sum(nil))
if !check_msg_hash(hash) {
save_msg_hash(hash)
InfoLogger.Printf("Hash of %s added to database", tooturl)
} else {
WarnLogger.Printf("%s is a duplicate and not boosted", tooturl)
}
2022-09-01 11:31:27 +00:00
2022-09-08 18:28:32 +00:00
// Add to db if needed
if !exist_in_database(acct) {
add_to_db(acct)
InfoLogger.Printf("%s added to database", acct)
}
2022-09-01 11:31:27 +00:00
2022-09-08 18:28:32 +00:00
// Message order
if check_order(acct) < Conf.Order_limit {
if check_ticket(acct) > 0 { // Message limit
take_ticket(acct)
InfoLogger.Printf("Ticket of %s was taken", acct)
2022-09-06 09:31:05 +00:00
2022-09-08 18:28:32 +00:00
count_order(acct)
InfoLogger.Printf("Order of %s was counted", acct)
2022-09-06 09:31:05 +00:00
2022-09-08 18:28:32 +00:00
c.Reblog(ctx, notif.Status.ID)
InfoLogger.Printf("Toot %s of %s was rebloged", tooturl, acct)
2022-08-28 16:37:43 +00:00
} else {
2022-09-08 18:28:32 +00:00
WarnLogger.Printf("%s haven't tickets", acct)
2022-08-25 19:23:44 +00:00
}
2022-08-28 16:37:43 +00:00
} else {
2022-09-08 18:28:32 +00:00
WarnLogger.Printf("%s order limit", acct)
2022-08-22 18:05:40 +00:00
}
2022-09-08 18:28:32 +00:00
} else {
WarnLogger.Printf("%s is reply and not boosted", tooturl)
}
} else if notif.Status.Visibility == "direct" { // Admin commands
for y := range Conf.Admins {
if acct == Conf.Admins[y] {
recmd := regexp.MustCompile(`<[^>]+>`)
command := recmd.ReplaceAllString(content, "")
args := strings.Split(command, " ")
if len(args) == 3 {
mID := mastodon.ID((args[2]))
switch args[1] {
case "unboost":
c.Unreblog(ctx, mID)
WarnLogger.Printf("%s was unrebloged", mID)
case "delete":
c.DeleteStatus(ctx, mID)
WarnLogger.Printf("%s was deleted", mID)
default:
WarnLogger.Printf("%s entered wrong command", acct)
2022-08-22 11:46:49 +00:00
}
2022-08-28 16:37:43 +00:00
} else {
2022-09-08 18:28:32 +00:00
WarnLogger.Printf("%s entered wrong command", acct)
2022-08-22 11:46:49 +00:00
}
}
}
2022-09-08 18:28:32 +00:00
} else {
WarnLogger.Printf("%s is not public toot and not boosted", tooturl)
2022-08-22 11:46:49 +00:00
}
2022-09-08 18:28:32 +00:00
} else { // Notify user
if got_notice(acct) == 0 {
if !exist_in_database(acct) {
add_to_db(acct)
InfoLogger.Printf("%s added to database", acct)
}
2022-09-08 12:26:25 +00:00
2022-09-08 18:28:32 +00:00
message := fmt.Sprintf("@%s %s", acct, Conf.NotFollowedMessage)
_, err := postToot(message, "direct")
if err != nil {
ErrorLogger.Printf("Notify %s", acct)
2022-09-08 12:26:25 +00:00
}
2022-09-08 18:28:32 +00:00
InfoLogger.Printf("%s has been notified", acct)
mark_notice(acct)
InfoLogger.Printf("%s marked notification in database", acct)
2022-09-08 12:26:25 +00:00
}
2022-08-22 11:46:49 +00:00
}
}
}
}