mirror of
https://github.com/Xevion/r2park.git
synced 2025-12-06 13:16:04 -06:00
96 lines
2.7 KiB
Go
96 lines
2.7 KiB
Go
package main
|
|
|
|
import (
|
|
"log"
|
|
"os"
|
|
"os/signal"
|
|
|
|
"github.com/bwmarrin/discordgo"
|
|
"github.com/go-redis/redis"
|
|
"github.com/joho/godotenv"
|
|
)
|
|
|
|
var (
|
|
session *discordgo.Session
|
|
commandDefinitions = []*discordgo.ApplicationCommand{RegisterCommandDefinition, CodeCommandDefinition}
|
|
commandHandlers = map[string]func(s *discordgo.Session, i *discordgo.InteractionCreate){
|
|
"register": RegisterCommandHandler,
|
|
"code": CodeCommandHandler,
|
|
}
|
|
db *redis.Client
|
|
)
|
|
|
|
func main() {
|
|
// Load environment variables
|
|
if err := godotenv.Load(); err != nil {
|
|
log.Fatal("Error loading .env file")
|
|
}
|
|
|
|
opt := &redis.Options{
|
|
Addr: os.Getenv("REDIS_HOST"),
|
|
Password: os.Getenv("REDIS_PASSWORD"),
|
|
}
|
|
db = redis.NewClient(opt)
|
|
|
|
ping_result, err := db.Ping().Result()
|
|
if err != nil {
|
|
log.Fatal(err)
|
|
}
|
|
log.Printf("Redis connection established (%s).", ping_result)
|
|
|
|
session, err = discordgo.New("Bot " + os.Getenv("BOT_TOKEN"))
|
|
if err != nil {
|
|
log.Fatalf("Invalid bot parameters: %v", err)
|
|
}
|
|
|
|
session.AddHandler(func(s *discordgo.Session, r *discordgo.Ready) {
|
|
log.Printf("Logged in as: %v#%v", s.State.User.Username, s.State.User.Discriminator)
|
|
|
|
// Count serers
|
|
guilds := s.State.Guilds
|
|
log.Printf("Connected to %d server%s", len(guilds), Plural(len(guilds)))
|
|
})
|
|
err = session.Open()
|
|
if err != nil {
|
|
log.Fatalf("Cannot open the session: %v", err)
|
|
}
|
|
defer session.Close()
|
|
defer client.CloseIdleConnections()
|
|
|
|
session.AddHandler(func(internalSession *discordgo.Session, interaction *discordgo.InteractionCreate) {
|
|
if handler, ok := commandHandlers[interaction.ApplicationCommandData().Name]; ok {
|
|
handler(internalSession, interaction)
|
|
}
|
|
})
|
|
|
|
log.Printf("Adding %d command%s...", len(commandDefinitions), Plural(len(commandDefinitions)))
|
|
registeredCommands := make([]*discordgo.ApplicationCommand, len(commandDefinitions))
|
|
for definitionIndex, commandDefinition := range commandDefinitions {
|
|
command, err := session.ApplicationCommandCreate(session.State.User.ID, os.Getenv("BOT_TARGET_GUILD"), commandDefinition)
|
|
if err != nil {
|
|
log.Panicf("Failed while registering '%v' command: %v", commandDefinition.Name, err)
|
|
}
|
|
registeredCommands[definitionIndex] = command
|
|
}
|
|
|
|
tryReload("")
|
|
|
|
stop := make(chan os.Signal, 1)
|
|
signal.Notify(stop, os.Interrupt)
|
|
log.Println("Press Ctrl+C to exit")
|
|
<-stop
|
|
|
|
if true {
|
|
log.Printf("Removing %d command%s...\n", len(registeredCommands), Plural(len(registeredCommands)))
|
|
|
|
for _, v := range registeredCommands {
|
|
err := session.ApplicationCommandDelete(session.State.User.ID, os.Getenv("BOT_TARGET_GUILD"), v.ID)
|
|
if err != nil {
|
|
log.Panicf("Cannot delete '%v' command: %v", v.Name, err)
|
|
}
|
|
}
|
|
}
|
|
|
|
log.Println("Gracefully shutting down.")
|
|
}
|