-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmain.go
70 lines (59 loc) · 1.45 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
package main
import (
"context"
"errors"
"flag"
"fmt"
"log"
"os"
"os/signal"
"syscall"
"slack2logs/envflag"
"slack2logs/flagutil"
"slack2logs/httpserver"
"slack2logs/slack"
"slack2logs/transporter"
"slack2logs/vmlogs"
)
func main() {
flag.CommandLine.SetOutput(os.Stdout)
flag.Usage = usage
envflag.Parse()
// Create a context that can be used to cancel goroutine
ctx, cancel := context.WithCancel(context.Background())
log.Println("Init slack client")
slackClient := slack.New()
go func() {
log.Println("Start listen message in the channels")
if err := slackClient.Run(ctx); err != nil && !errors.Is(err, context.Canceled) {
log.Fatalf("error run slack client: %s", err)
}
}()
log.Println("Init vmlogs client")
logs, err := vmlogs.New()
if err != nil {
log.Fatalf("error initialize VictoriaLogs client: %s", err)
}
trp := transporter.New(slackClient, logs)
go httpserver.Serve()
c := make(chan os.Signal, 1)
signal.Notify(c, syscall.SIGINT, syscall.SIGTERM)
go func() {
<-c
fmt.Println("\r- Gracefully shutting down process")
// Make this cancel called properly in a real program, graceful shutdown etc
cancel()
}()
trp.Run(ctx)
err = httpserver.Stop()
if err != nil {
log.Fatalf("error shutdown http server: %s", err)
}
log.Println("Process stopped successfully")
}
func usage() {
const s = `
slack2logs collects messages from the slack channels, converts them and save to the VictoriaLogs.
`
flagutil.Usage(s)
}