mirror of
https://gitlab.com/pulsechaincom/erigon-pulse.git
synced 2024-12-31 16:21:21 +00:00
70 lines
2.2 KiB
Go
70 lines
2.2 KiB
Go
package beacon
|
|
|
|
import (
|
|
"context"
|
|
"net"
|
|
"net/http"
|
|
"strings"
|
|
|
|
"github.com/go-chi/chi/v5"
|
|
"github.com/ledgerwatch/erigon/cl/beacon/beacon_router_configuration"
|
|
"github.com/ledgerwatch/erigon/cl/beacon/handler"
|
|
"github.com/ledgerwatch/erigon/cl/beacon/validatorapi"
|
|
"github.com/ledgerwatch/log/v3"
|
|
)
|
|
|
|
type LayeredBeaconHandler struct {
|
|
ValidatorApi *validatorapi.ValidatorApiHandler
|
|
ArchiveApi *handler.ApiHandler
|
|
}
|
|
|
|
func ListenAndServe(beaconHandler *LayeredBeaconHandler, routerCfg beacon_router_configuration.RouterConfiguration) error {
|
|
listener, err := net.Listen(routerCfg.Protocol, routerCfg.Address)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
defer listener.Close()
|
|
mux := chi.NewRouter()
|
|
// enforce json content type
|
|
mux.Use(func(h http.Handler) http.Handler {
|
|
return http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
|
|
contentType := r.Header.Get("Content-Type")
|
|
if len(contentType) > 0 && !strings.EqualFold(contentType, "application/json") {
|
|
http.Error(w, "Content-Type header must be application/json", http.StatusUnsupportedMediaType)
|
|
return
|
|
}
|
|
h.ServeHTTP(w, r)
|
|
})
|
|
})
|
|
// layered handling - 404 on first handler falls back to the second
|
|
mux.HandleFunc("/eth/*", func(w http.ResponseWriter, r *http.Request) {
|
|
nfw := ¬FoundNoWriter{rw: w}
|
|
beaconHandler.ValidatorApi.ServeHTTP(nfw, r)
|
|
r = r.WithContext(context.WithValue(r.Context(), chi.RouteCtxKey, chi.NewRouteContext()))
|
|
if isNotFound(nfw.code) || nfw.code == 0 {
|
|
beaconHandler.ArchiveApi.ServeHTTP(w, r)
|
|
}
|
|
})
|
|
mux.HandleFunc("/validator/*", func(w http.ResponseWriter, r *http.Request) {
|
|
http.StripPrefix("/validator", beaconHandler.ValidatorApi).ServeHTTP(w, r)
|
|
})
|
|
mux.HandleFunc("/archive/*", func(w http.ResponseWriter, r *http.Request) {
|
|
http.StripPrefix("/archive", beaconHandler.ArchiveApi).ServeHTTP(w, r)
|
|
})
|
|
server := &http.Server{
|
|
Handler: mux,
|
|
ReadTimeout: routerCfg.ReadTimeTimeout,
|
|
IdleTimeout: routerCfg.IdleTimeout,
|
|
WriteTimeout: routerCfg.IdleTimeout,
|
|
}
|
|
if err != nil {
|
|
log.Warn("[Beacon API] Failed to start listening", "addr", routerCfg.Address, "err", err)
|
|
}
|
|
|
|
if err := server.Serve(listener); err != nil {
|
|
log.Warn("[Beacon API] failed to start serving", "addr", routerCfg.Address, "err", err)
|
|
return err
|
|
}
|
|
return nil
|
|
}
|