-
Notifications
You must be signed in to change notification settings - Fork 22
/
server.go
121 lines (102 loc) · 3.56 KB
/
server.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
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
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
// Copyright (C) 2023 Gobalsky Labs Limited
//
// This program is free software: you can redistribute it and/or modify
// it under the terms of the GNU Affero General Public License as
// published by the Free Software Foundation, either version 3 of the
// License, or (at your option) any later version.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU Affero General Public License for more details.
//
// You should have received a copy of the GNU Affero General Public License
// along with this program. If not, see <http://www.gnu.org/licenses/>.
package admin
import (
"context"
"net"
"net/http"
"os"
"code.vegaprotocol.io/vega/logging"
"code.vegaprotocol.io/vega/paths"
"github.com/gorilla/mux"
"github.com/gorilla/rpc"
"github.com/gorilla/rpc/json"
)
type Server struct {
log *logging.Logger
cfg Config
srv *http.Server
networkHistoryAdminService *NetworkHistoryAdminService
}
func NewServer(log *logging.Logger, config Config, vegaPaths paths.Paths, service *NetworkHistoryAdminService) *Server {
// setup logger
log = log.Named(namedLogger)
log.SetLevel(config.Level.Get())
return &Server{
log: log,
cfg: config,
srv: nil,
networkHistoryAdminService: service,
}
}
// Start starts the RPC based API server.
func (s *Server) Start(ctx context.Context) error {
s.log.Info("Starting Data Node Admin Server<>RPC based API",
logging.String("socket-path", s.cfg.Server.SocketPath),
logging.String("http-path", s.cfg.Server.HTTPPath),
)
rs := rpc.NewServer()
rs.RegisterCodec(json.NewCodec(), "application/json")
rs.RegisterCodec(json.NewCodec(), "application/json;charset=UTF-8")
if err := rs.RegisterService(s.networkHistoryAdminService, "networkhistory"); err != nil {
s.log.Panic("failed to register network history service", logging.Error(err))
}
r := mux.NewRouter()
r.Handle(s.cfg.Server.HTTPPath, rs)
// Try to remove the existing socket file just in case
if err := os.Remove(s.cfg.Server.SocketPath); err != nil {
// If we can't remove the socket and the error is not that the file doesn't exist, then we should panic
if !os.IsNotExist(err) {
s.log.Panic("failed to remove socket file", logging.Error(err))
}
}
l, err := net.Listen("unix", s.cfg.Server.SocketPath)
if err != nil {
s.log.Panic("failed to open unix socket", logging.Error(err))
}
s.srv = &http.Server{
Handler: r,
}
go func() {
<-ctx.Done()
s.Stop()
}()
s.log.Info("Data Node Admin Server<>RPC based API started")
return s.srv.Serve(l)
}
// Stop stops the RPC based API server.
func (s *Server) Stop() {
if s.srv != nil {
s.log.Info("Stopping Data Node Admin Server<>RPC based API")
if err := s.srv.Shutdown(context.Background()); err != nil {
s.log.Error("failed to stop Data Node Admin server<>RPC based API cleanly",
logging.Error(err))
}
}
}
// ReloadConf update the internal configuration of the server.
func (s *Server) ReloadConf(cfg Config) {
s.log.Info("reloading configuration")
if s.log.GetLevel() != cfg.Level.Get() {
s.log.Info("updating log level",
logging.String("old", s.log.GetLevel().String()),
logging.String("new", cfg.Level.String()),
)
s.log.SetLevel(cfg.Level.Get())
}
// TODO(): not updating the actual server for now, may need to look at this later
// e.g restart the http server on another port or whatever
s.cfg = cfg
}