-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmain.go
57 lines (47 loc) · 1.28 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
package main
import (
"log"
"os"
"reacjira/bot"
"reacjira/config"
"github.com/slack-go/slack"
)
func main() {
log.Println("start reacjira.")
configName := os.Getenv("REACJIRA_CONFIG_NAME")
if configName == "" {
configName = "config.toml"
}
log.Printf("start reading %s.", configName)
loadedConfig, err := config.LoadConfigToml(configName)
if err != nil {
log.Printf("failed to load config: %s", err)
os.Exit(1)
}
log.Printf("finish reading %s.", configName)
reacjiraToml := os.Getenv("REACJIRA_REACJIRA_NAME")
if reacjiraToml == "" {
reacjiraToml = "reacjira.toml"
}
log.Printf("start reading %s.", reacjiraToml)
reacjiras, err := config.LoadReacjiraToml(reacjiraToml)
if err != nil {
log.Printf("failed to load reacjira: %s", err)
os.Exit(1)
}
log.Printf("finish reading %s.", configName)
slackClient := slack.New(
loadedConfig.SlackBotToken,
slack.OptionAppLevelToken(loadedConfig.SlackAppToken),
slack.OptionDebug(false),
)
botProfile, err := bot.GetSlackBotInfo(slackClient)
if err != nil {
log.Printf("failed to get bot info: %v", err)
os.Exit(1)
}
log.Printf("got a bot info %v\n", botProfile)
slackCtx := loadedConfig.ToSlackCtx()
jiraCtx := loadedConfig.ToJiraCtx()
os.Exit(bot.Run(slackClient, slackCtx, jiraCtx, botProfile, reacjiras))
}