-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathmain.go
124 lines (107 loc) · 2.3 KB
/
main.go
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
package main
import (
"log"
"os"
"os/signal"
"syscall"
"github.com/joho/godotenv"
"go.uber.org/zap"
"net/http"
_ "net/http/pprof"
)
var (
logger *zap.Logger
scheduleStore ScheduleStore
)
type ModeInfo struct {
Mode
ModeName string
Identifier string
Color int
}
type Mode interface {
getModeName() string
getIdentifier() string
getColor() int
}
func (mi ModeInfo) getModeName() string {
return mi.ModeName
}
func (mi ModeInfo) getIdentifier() string {
return mi.Identifier
}
func (mi ModeInfo) getColor() int {
return mi.Color
}
var ModeTable map[string]ModeInfo
func init() {
ModeTable = map[string]ModeInfo{
"OPEN": {
ModeName: "バンカラマッチ(オープン)",
Identifier: "OPEN",
Color: 0xf64a10,
},
"CHALLENGE": {
ModeName: "バンカラマッチ(チャレンジ)",
Identifier: "CHALLENGE",
Color: 0xf64a10,
},
"X": {
ModeName: "Xマッチ",
Identifier: "X",
Color: 0x74f1a2,
},
"SALMON": {
ModeName: "サーモンラン",
Identifier: "SALMON",
Color: 0xff501e,
},
"BIGRUN": {
ModeName: "ビッグラン",
Identifier: "SALMON",
Color: 0xfe0de8,
},
"REGULAR": {
ModeName: "レギュラーマッチ",
Identifier: "REGULAR",
Color: 0xd0f623,
},
}
}
func getMode(identifier string) Mode {
mode, found := ModeTable[identifier]
if found {
return mode
} else {
return ModeInfo{
ModeName: "",
Identifier: identifier,
Color: 0x0,
}
}
}
// https://discord.com/oauth2/authorize?client_id=1018084105587544166&scope=bot&permissions=10737436672
func main() {
err := godotenv.Load()
if err != nil {
log.Fatal("Error loading .env file")
}
logger, _ = zap.NewProduction()
defer func() {
_ = logger.Sync()
}()
go func() {
logger.Sugar().Info(http.ListenAndServe("localhost:6060", nil))
}()
scheduleStore = NewScheduleStore()
scheduleStore.MaybeRefresh()
bot, err := LaunchDiscordBot(os.Getenv("IKABOT3_TOKEN"), os.Getenv("IKABOT3_ALLOW_MESSAGE_CONTENT_INTENT") == "TRUE")
if err != nil {
logger.Sugar().Errorw("bot creation failed", err)
}
logger.Sugar().Info("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
bot.CloseDiscordBot()
}