forked from allen13/golerta
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathgolerta.go
63 lines (51 loc) · 1.45 KB
/
golerta.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 (
"fmt"
"github.com/allen13/golerta/app"
"github.com/allen13/golerta/app/auth/token"
"github.com/allen13/golerta/app/config"
"github.com/docopt/docopt-go"
"log"
"strings"
)
const version = "Golerta 0.1.0"
const usage = `Golerta.
Usage:
golerta server [--config=<config>]
golerta createAgentToken <name> [--config=<config>]
golerta --help
golerta --version
Options:
--config=<config> The golerta config [default: ./golerta.toml].
--help Show this screen.
--version Show version.
`
func main() {
args, err := docopt.Parse(usage, nil, true, version, false)
if err != nil {
log.Fatalln(err)
}
configFile := args["--config"].(string)
config := config.BuildConfig(configFile)
if args["server"].(bool) {
echo := app.BuildApp(config)
log.Println("Starting golerta server...")
var err error
if config.Golerta.TLSEnabled {
if config.Golerta.TLSAutoEnabled {
tlsHosts := strings.Split(config.Golerta.TLSAutoHosts, ",")
err = echo.StartAutoTLS(config.Golerta.BindAddr, tlsHosts, "cert-cache")
} else {
err = echo.StartTLS(config.Golerta.BindAddr, config.Golerta.TLSCert, config.Golerta.TLSKey)
}
} else {
err = echo.Start(config.Golerta.BindAddr)
}
if err != nil {
echo.Logger.Fatal(err)
}
}
if args["createAgentToken"].(bool) {
fmt.Println(token.CreateExpirationFreeAgentToken(args["<name>"].(string), config.Golerta.SigningKey))
}
}