-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmain.go
63 lines (50 loc) · 1.36 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
package main
import (
"flag"
"log"
"os"
"sync"
"github.com/Bccp-Team/bccp-server/api/rest"
"github.com/Bccp-Team/bccp-server/api/rpc"
"github.com/Bccp-Team/bccp-server/mysql"
"github.com/Bccp-Team/bccp-server/runners"
"github.com/Bccp-Team/bccp-server/scheduler"
"github.com/BurntSushi/toml"
)
type Config struct {
APIPort string
RPCPort string
RunnerService string
RunnerToken string
KeyFile string
CrtFile string
MysqlService string
MysqlDatabase string
MysqlUser string
MysqlPassword string
}
func ReadConfig(configfile string) Config {
_, err := os.Stat(configfile)
if err != nil {
log.Fatal("Config file is missing: ", configfile)
}
var config Config
if _, err := toml.DecodeFile(configfile, &config); err != nil {
log.Fatal(err)
}
return config
}
func main() {
var configPath string
var wait sync.WaitGroup
flag.StringVar(&configPath, "config", "/etc/bccp/bccp.conf", "config path")
flag.Parse()
var config = ReadConfig(configPath)
mysql.Db.Connect(config.MysqlService, config.MysqlDatabase, config.MysqlUser, config.MysqlPassword)
go scheduler.DefaultScheduler.Start()
go runners.WaitRunners(&scheduler.DefaultScheduler, config.RunnerService, config.RunnerToken)
rest.SetupRestAPI(&wait, config.APIPort, config.CrtFile, config.KeyFile)
//wait.Wait()
err := rpc.SetupRpc(config.RPCPort)
log.Panic(err)
}