aboutsummaryrefslogtreecommitdiff
path: root/commands/reset.go
diff options
context:
space:
mode:
authorAnhgelus Morhtuuzh <anhgelus.morhtuuzh@proton.me>2024-04-16 15:58:20 +0200
committerAnhgelus Morhtuuzh <anhgelus.morhtuuzh@proton.me>2024-04-16 15:58:20 +0200
commitfe789ad0722924c47243859906497ee2a3a55134 (patch)
treeaac8b09a03b43d0cc75622d9dd0747c74dbeaea4 /commands/reset.go
parent6b595b8b11e9ac05302ee15ab7734e49b89594e5 (diff)
feat(command): reset and reset-user
Diffstat (limited to 'commands/reset.go')
-rw-r--r--commands/reset.go35
1 files changed, 35 insertions, 0 deletions
diff --git a/commands/reset.go b/commands/reset.go
new file mode 100644
index 0000000..f0c6d9a
--- /dev/null
+++ b/commands/reset.go
@@ -0,0 +1,35 @@
+package commands
+
+import (
+ "github.com/anhgelus/gokord"
+ "github.com/anhgelus/gokord/utils"
+ "github.com/anhgelus/les-copaings-bot/xp"
+ "github.com/bwmarrin/discordgo"
+)
+
+func Reset(s *discordgo.Session, i *discordgo.InteractionCreate) {
+ var copaings []*xp.Copaing
+ gokord.DB.Where("guild_id = ?", i.GuildID).Delete(&copaings)
+ resp := utils.ResponseBuilder{C: s, I: i}
+ if err := resp.IsEphemeral().Message("L'XP a été reset.").Send(); err != nil {
+ utils.SendAlert("commands/reset.go - Sending success (all)", err.Error())
+ }
+}
+
+func ResetUser(s *discordgo.Session, i *discordgo.InteractionCreate) {
+ resp := utils.ResponseBuilder{C: s, I: i}
+ resp.IsEphemeral()
+ optMap := utils.GenerateOptionMap(i)
+ v, ok := optMap["copaing"]
+ if !ok {
+ if err := resp.Message("Le copaing n'a pas été renseigné.").Send(); err != nil {
+ utils.SendAlert("commands/reset.go - Copaing not set", err.Error())
+ }
+ return
+ }
+ m := v.UserValue(s)
+ xp.GetCopaing(m.ID, i.GuildID).Reset()
+ if err := resp.Message("Le a bien été reset.").Send(); err != nil {
+ utils.SendAlert("commands/reset.go - Sending success (copaing)", err.Error())
+ }
+}