From fe789ad0722924c47243859906497ee2a3a55134 Mon Sep 17 00:00:00 2001 From: Anhgelus Morhtuuzh Date: Tue, 16 Apr 2024 15:58:20 +0200 Subject: feat(command): reset and reset-user --- commands/reset.go | 35 +++++++++++++++++++++++++++++++++++ 1 file changed, 35 insertions(+) create mode 100644 commands/reset.go (limited to 'commands/reset.go') 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()) + } +} -- cgit v1.2.3