-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathserver.go
More file actions
100 lines (85 loc) · 2.35 KB
/
server.go
File metadata and controls
100 lines (85 loc) · 2.35 KB
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
package main
import (
"context"
"crypto/tls"
"fmt"
"sync"
"time"
"github.com/gochik/chik"
"github.com/gochik/chik/config"
"github.com/gochik/chik/handlers/heartbeat"
"github.com/gochik/chik/handlers/router"
"github.com/rs/zerolog/log"
)
var peers sync.Map
// Version executable version
var Version = "dev"
func main() {
log.Info().Msgf("Version: %v", Version)
config.SetConfigFileName("server.conf")
config.AddSearchPath("/etc/chik")
config.AddSearchPath(".")
err := config.ParseConfig()
if err != nil {
log.Warn().Msgf("Error parsing config file: %v", err)
}
ok := true
var token string
config.GetStruct("connection.token", &token)
if token == "" {
config.Set("connection.token", "")
log.Warn().Msg("Cannot get CA token from config file")
ok = false
}
var port uint16
config.GetStruct("connection.port", &port)
if port == 0 {
config.Set("connection.port", uint16(6767))
log.Warn().Msg("Cannot get port from config file")
ok = false
}
if !ok {
config.Sync()
log.Fatal().Msg("Config file contains errors, check the logfile.")
}
ctx, cancel := context.WithCancel(context.Background())
defer cancel()
conf, err := config.TLSConfig(ctx, token)
if err != nil {
log.Fatal().Msgf("Failed to get TLS config: %v", err)
}
srv, err := tls.Listen("tcp", fmt.Sprintf("0.0.0.0:%d", port), conf)
if err != nil {
log.Fatal().Msgf("Error starting server: %v", err)
}
for {
connection, err := srv.Accept()
if err != nil {
log.Error().Msgf("Connection error: %v", err)
continue
}
// Creating the controller that is handling the newly connected client
go func() {
log.Info().Str("client", connection.RemoteAddr().String()).Msg("New connection")
tlsConn := connection.(*tls.Conn)
err := tlsConn.Handshake()
if err != nil {
log.Err(err).Msg("Handshake failed.")
tlsConn.Close()
return
}
log.Info().Msg("Creating a new controller")
controller := chik.NewController()
innerctx, innercancel := context.WithCancel(context.Background())
go controller.Start(innerctx, []chik.Handler{
router.New(&peers),
heartbeat.New(),
})
time.Sleep(5 * time.Millisecond) // TODO: we need to be sure handlers are started before being able to receive messages
ctx, remoteCancel := chik.StartRemote(controller, connection, chik.MaxIdleTime)
<-ctx.Done()
innercancel()
remoteCancel()
}()
}
}