diff options
| author | ascpial <mail@ascpial.fr> | 2025-09-27 23:35:32 +0200 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2025-09-27 23:35:32 +0200 |
| commit | bc86bb4859c4537032f9ca8d57ac32cc14dbd629 (patch) | |
| tree | e94686d7b091857788fe3f1b582f6ce540e00d71 /rolereact/events.go | |
| parent | cfdba5f417bb31aac564d13becc09874f17d075d (diff) | |
[Feat] Role reaction (#15)
* first draft of rolereact
* fix(rolereact): fill description when setting it
* fix(rolereact): fix some issues
* feat(rolereact): split the code in multiple files
Diffstat (limited to 'rolereact/events.go')
| -rw-r--r-- | rolereact/events.go | 46 |
1 files changed, 46 insertions, 0 deletions
diff --git a/rolereact/events.go b/rolereact/events.go new file mode 100644 index 0000000..1de3fe0 --- /dev/null +++ b/rolereact/events.go @@ -0,0 +1,46 @@ +package rolereact + +import ( + "git.anhgelus.world/anhgelus/les-copaings-bot/config" + oldGokord "github.com/anhgelus/gokord" + "github.com/nyttikord/gokord/bot" + "github.com/nyttikord/gokord/event" +) + +type RoleReact struct { + RoleID string +} + +func HandleReactionAdd( + s bot.Session, + e *event.MessageReactionAdd, +) { + results := []RoleReact{} + oldGokord.DB.Model(&config.RoleReact{}). + Joins("JOIN role_react_messages ON role_reacts.role_react_message_id = role_react_messages.id"). + Where("role_react_messages.message_id = ? AND role_reacts.reaction = ?", e.MessageID, e.MessageReaction.Emoji.APIName()). + Scan(&results) + for _, role := range results { + err := s.GuildAPI().MemberRoleAdd(e.GuildID, e.UserID, role.RoleID) + if err != nil { + s.Logger().Error("Unable to add role after member added reaction", "error", err) + } + } +} + +func HandleReactionRemove( + s bot.Session, + e *event.MessageReactionRemove, +) { + results := []RoleReact{} + oldGokord.DB.Model(&config.RoleReact{}). + Joins("JOIN role_react_messages ON role_reacts.role_react_message_id = role_react_messages.id"). + Where("role_react_messages.message_id = ? AND role_reacts.reaction = ?", e.MessageID, e.MessageReaction.Emoji.APIName()). + Scan(&results) + for _, role := range results { + err := s.GuildAPI().MemberRoleRemove(e.GuildID, e.UserID, role.RoleID) + if err != nil { + s.Logger().Error("Unable to remove role after member removed reaction", "error", err) + } + } +} |
