-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathmain.go
More file actions
128 lines (109 loc) · 3.35 KB
/
main.go
File metadata and controls
128 lines (109 loc) · 3.35 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
// Package main is the entry point for the application.
package main
import (
"log"
"os"
"os/signal"
"strings"
"syscall"
"github.com/bwmarrin/discordgo"
"github.com/joho/godotenv"
openaiapi "voltgpt/internal/apis/openai"
"voltgpt/internal/config"
"voltgpt/internal/db"
"voltgpt/internal/gamble"
"voltgpt/internal/handler"
"voltgpt/internal/hasher"
"voltgpt/internal/memory"
"voltgpt/internal/reminder"
)
func init() {
if err := godotenv.Load(); err != nil {
log.Print("No .env file found")
}
db.Open("voltgpt.db")
hasher.Init(db.DB)
gamble.Init(db.DB)
memory.Init(db.DB)
if _, err := openaiapi.GetClient(); err != nil {
log.Printf("Warning: OpenAI client init failed: %v", err)
}
}
func main() {
discordToken := os.Getenv("DISCORD_TOKEN")
if discordToken == "" {
log.Fatal("DISCORD_TOKEN is not set")
}
dg, err := discordgo.New("Bot " + discordToken)
if err != nil {
log.Fatal("error creating Discord session,", err)
return
}
dg.Identify.Intents = discordgo.IntentGuildMessages | discordgo.IntentMessageContent
dg.ShouldReconnectOnError = true
dg.ShouldRetryOnRateLimit = true
dg.AddHandler(func(s *discordgo.Session, i *discordgo.InteractionCreate) {
switch i.Type {
case discordgo.InteractionApplicationCommand:
if h, ok := handler.Commands[i.ApplicationCommandData().Name]; ok {
go h(s, i)
}
case discordgo.InteractionMessageComponent:
split := strings.Split(i.MessageComponentData().CustomID, "-")
if h, ok := handler.Components[split[0]]; ok {
go h(s, i)
}
case discordgo.InteractionModalSubmit:
split := strings.Split(i.ModalSubmitData().CustomID, "-")
if h, ok := handler.Modals[split[0]]; ok {
go h(s, i)
}
}
})
dg.AddHandler(func(s *discordgo.Session, m *discordgo.MessageCreate) {
go handler.HandleMessage(s, m)
})
dg.AddHandler(func(s *discordgo.Session, _ *discordgo.Ready) {
log.Printf("Logged in as: %v#%v", s.State.User.Username, s.State.User.Discriminator)
log.Printf("Hashes: %d", hasher.TotalHashes())
log.Printf("Rounds: %d", gamble.GameState.TotalRounds())
log.Printf("Stored notes: %d", memory.TotalNotes())
log.Printf("Active reminders: %d", reminder.TotalActive())
})
err = dg.Open()
if err != nil {
log.Fatal("error opening connection,", err)
return
}
reminder.Init(db.DB, dg)
for _, guild := range dg.State.Guilds {
log.Printf("Loading commands for %s", guild.ID)
for _, command := range config.Commands {
_, err := dg.ApplicationCommandCreate(dg.State.User.ID, guild.ID, command)
if err != nil {
log.Printf("could not create '%s' command: %v", command.Name, err)
}
}
commands, err := dg.ApplicationCommands(dg.State.User.ID, guild.ID)
if err != nil {
log.Printf("could not get commands for guild %s: %v", guild.ID, err)
}
for _, command := range commands {
if _, ok := handler.Commands[command.Name]; !ok {
err := dg.ApplicationCommandDelete(dg.State.User.ID, guild.ID, command.ID)
if err != nil {
log.Printf("could not delete '%s' command: %v", command.Name, err)
}
}
}
log.Printf("Loaded %d commands for %s", len(config.Commands), guild.ID)
}
log.Println("Bot is now running. Press CTRL-C to exit.")
sc := make(chan os.Signal, 1)
signal.Notify(sc, syscall.SIGINT, syscall.SIGTERM, os.Interrupt)
<-sc
defer db.Close()
defer memory.Shutdown()
defer dg.Close()
defer log.Print("Bot is shutting down.")
}