go-waku/waku/v2/rpc/waku_rpc.go

120 lines
2.8 KiB
Go
Raw Normal View History

package rpc
import (
"context"
"fmt"
"net/http"
2021-11-06 10:49:47 +00:00
"time"
"github.com/gorilla/rpc/v2"
"github.com/status-im/go-waku/waku/v2/node"
"go.uber.org/zap"
)
type WakuRpc struct {
node *node.WakuNode
server *http.Server
2021-11-18 14:20:58 +00:00
log *zap.Logger
2021-12-08 08:52:27 +00:00
relayService *RelayService
filterService *FilterService
privateService *PrivateService
adminService *AdminService
}
func NewWakuRpc(node *node.WakuNode, address string, port int, enableAdmin bool, enablePrivate bool, log *zap.Logger) *WakuRpc {
wrpc := new(WakuRpc)
wrpc.log = log.Named("rpc")
s := rpc.NewServer()
s.RegisterCodec(NewSnakeCaseCodec(), "application/json")
s.RegisterCodec(NewSnakeCaseCodec(), "application/json;charset=UTF-8")
2021-11-02 14:42:22 +00:00
err := s.RegisterService(&DebugService{node}, "Debug")
if err != nil {
wrpc.log.Error("registering debug service", zap.Error(err))
}
relayService := NewRelayService(node, log)
2021-11-18 14:20:58 +00:00
err = s.RegisterService(relayService, "Relay")
2021-11-06 10:49:47 +00:00
if err != nil {
wrpc.log.Error("registering relay service", zap.Error(err))
2021-11-06 10:49:47 +00:00
}
2022-05-06 19:29:31 +00:00
err = s.RegisterService(&StoreService{node, log}, "Store")
if err != nil {
wrpc.log.Error("registering store service", zap.Error(err))
}
if enableAdmin {
adminService := &AdminService{node, log.Named("admin")}
err = s.RegisterService(adminService, "Admin")
if err != nil {
wrpc.log.Error("registering admin service", zap.Error(err))
}
wrpc.adminService = adminService
2021-11-10 13:36:51 +00:00
}
filterService := NewFilterService(node, log)
err = s.RegisterService(filterService, "Filter")
2021-11-17 16:04:54 +00:00
if err != nil {
wrpc.log.Error("registering filter service", zap.Error(err))
2021-11-17 16:04:54 +00:00
}
if enablePrivate {
privateService := NewPrivateService(node, log)
err = s.RegisterService(privateService, "Private")
if err != nil {
wrpc.log.Error("registering private service", zap.Error(err))
}
wrpc.privateService = privateService
}
mux := http.NewServeMux()
mux.HandleFunc("/", func(w http.ResponseWriter, r *http.Request) {
2021-11-06 10:49:47 +00:00
t := time.Now()
s.ServeHTTP(w, r)
wrpc.log.Info("served request", zap.String("path", r.URL.Path), zap.Duration("duration", time.Since(t)))
2021-11-06 10:49:47 +00:00
})
listenAddr := fmt.Sprintf("%s:%d", address, port)
server := &http.Server{
Addr: listenAddr,
Handler: mux,
}
server.RegisterOnShutdown(func() {
filterService.Stop()
relayService.Stop()
2022-06-13 18:30:35 +00:00
if wrpc.privateService != nil {
wrpc.privateService.Stop()
}
})
wrpc.node = node
wrpc.server = server
wrpc.relayService = relayService
wrpc.filterService = filterService
return wrpc
}
func (r *WakuRpc) Start() {
2021-11-18 14:20:58 +00:00
go r.relayService.Start()
go r.filterService.Start()
2022-06-13 18:30:35 +00:00
if r.privateService != nil {
go r.privateService.Start()
}
go func() {
_ = r.server.ListenAndServe()
}()
r.log.Info("server started", zap.String("addr", r.server.Addr))
}
func (r *WakuRpc) Stop(ctx context.Context) error {
r.log.Info("shutting down server")
return r.server.Shutdown(ctx)
}