2025-01-08 13:40:11 -08:00
|
|
|
package confession
|
|
|
|
|
|
|
|
|
|
import (
|
|
|
|
|
"errors"
|
2025-01-13 15:45:07 -08:00
|
|
|
"fmt"
|
2025-01-08 13:40:11 -08:00
|
|
|
"sync"
|
|
|
|
|
|
|
|
|
|
"github.com/bwmarrin/discordgo"
|
|
|
|
|
"gitlab.com/whom/bingobot/internal/logging"
|
|
|
|
|
"gitlab.com/whom/bingobot/internal/state"
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
/* Activity module
|
|
|
|
|
* This module posts anonymous confessions according to a linked channel map
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
const (
|
|
|
|
|
ActivityModuleStartFail = "failed to start activity module"
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
var (
|
|
|
|
|
// guild ID to channel ID
|
|
|
|
|
linkLock sync.RWMutex
|
2025-01-13 15:45:07 -08:00
|
|
|
confessionChannelLinks = make(map[string]state.ConfessionsChannelLinkEvent)
|
2025-01-08 13:40:11 -08:00
|
|
|
)
|
|
|
|
|
|
|
|
|
|
func Start() error {
|
|
|
|
|
ch, err := state.ConfessionsChannelLink.Subscribe()
|
|
|
|
|
if err != nil {
|
|
|
|
|
return errors.Join(
|
|
|
|
|
errors.New(ActivityModuleStartFail),
|
|
|
|
|
err,
|
|
|
|
|
)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// process incoming events loop
|
|
|
|
|
go func() {
|
|
|
|
|
for {
|
|
|
|
|
ev := <- ch
|
2025-01-13 17:07:37 -08:00
|
|
|
logging.Debug("recieved new confessional channel link")
|
2025-01-08 13:40:11 -08:00
|
|
|
e := ev.(state.ConfessionsChannelLinkEvent)
|
|
|
|
|
linkLock.Lock()
|
|
|
|
|
confessionChannelLinks[e.GuildID] = e
|
|
|
|
|
linkLock.Unlock()
|
|
|
|
|
}
|
|
|
|
|
}()
|
|
|
|
|
|
|
|
|
|
return nil
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func MakeConfession(s *discordgo.Session, guildID string, content string) {
|
|
|
|
|
linkLock.RLock()
|
|
|
|
|
link, ok := confessionChannelLinks[guildID]
|
|
|
|
|
linkLock.RUnlock()
|
|
|
|
|
if !ok {
|
2025-01-13 15:45:07 -08:00
|
|
|
logging.Error(fmt.Sprintf("Failed to send confession in guild %s: no link exists in map", guildID))
|
2025-01-08 13:40:11 -08:00
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
s.ChannelMessageSend(link.ChannelID, content)
|
|
|
|
|
}
|