mirror of
https://github.com/OffchainLabs/prysm.git
synced 2026-01-09 13:28:01 -05:00
* wip passing e2e * reverting temp comment * remove unneeded comments * fixing merge errors * fixing more bugs from merge * fixing test * WIP moving code around and fixing tests * unused linting * gaz * temp removing these tests as we need placeholder/wrapper APIs for them with the removal of the gateway * attempting to remove dependencies to gRPC gateway , 1 mroe left in deps.bzl * renaming flags and other gateway services to http * goimport * fixing deepsource * git mv * Update validator/package/validator.yaml Co-authored-by: Radosław Kapka <rkapka@wp.pl> * Update validator/package/validator.yaml Co-authored-by: Radosław Kapka <rkapka@wp.pl> * Update cmd/beacon-chain/flags/base.go Co-authored-by: Radosław Kapka <rkapka@wp.pl> * Update cmd/beacon-chain/flags/base.go Co-authored-by: Radosław Kapka <rkapka@wp.pl> * Update cmd/beacon-chain/flags/base.go Co-authored-by: Radosław Kapka <rkapka@wp.pl> * addressing feedback * missed lint * renaming import * reversal based on feedback * fixing web ui registration * don't require mux handler * gaz * removing gRPC service from validator completely, merged with http service, renames are a work in progress * updating go.sum * linting * trailing white space * realized there was more cleanup i could do with code reuse * adding wrapper for routes * reverting version * fixing dependencies from merging develop * gaz * fixing unit test * fixing dependencies * reverting unit test * fixing conflict * updating change log * Update log.go Co-authored-by: Preston Van Loon <pvanloon@offchainlabs.com> * gaz * Update api/server/httprest/server.go Co-authored-by: Preston Van Loon <pvanloon@offchainlabs.com> * addressing some feedback * forgot to remove deprecated flag in usage * gofmt * fixing test * fixing deepsource issue * moving deprecated flag and adding timeout handler * missed removal of a flag * fixing test: * Update CHANGELOG.md Co-authored-by: Radosław Kapka <rkapka@wp.pl> * addressing feedback * updating comments based on feedback * removing unused field for now, we can add it back in if we need to use the option * removing unused struct * changing api-timeout flag based on feedback --------- Co-authored-by: Radosław Kapka <rkapka@wp.pl> Co-authored-by: Preston Van Loon <pvanloon@offchainlabs.com>
102 lines
2.3 KiB
Go
102 lines
2.3 KiB
Go
package httprest
|
|
|
|
import (
|
|
"context"
|
|
"net/http"
|
|
"time"
|
|
|
|
"github.com/gorilla/mux"
|
|
"github.com/pkg/errors"
|
|
"github.com/prysmaticlabs/prysm/v5/runtime"
|
|
)
|
|
|
|
var _ runtime.Service = (*Server)(nil)
|
|
|
|
// Config parameters for setting up the http-rest service.
|
|
type config struct {
|
|
httpAddr string
|
|
router *mux.Router
|
|
timeout time.Duration
|
|
}
|
|
|
|
// Server serves HTTP traffic.
|
|
type Server struct {
|
|
cfg *config
|
|
server *http.Server
|
|
cancel context.CancelFunc
|
|
ctx context.Context
|
|
startFailure error
|
|
}
|
|
|
|
// New returns a new instance of the Server.
|
|
func New(ctx context.Context, opts ...Option) (*Server, error) {
|
|
g := &Server{
|
|
ctx: ctx,
|
|
cfg: &config{},
|
|
}
|
|
for _, opt := range opts {
|
|
if err := opt(g); err != nil {
|
|
return nil, err
|
|
}
|
|
}
|
|
if g.cfg.router == nil {
|
|
return nil, errors.New("router option not configured")
|
|
}
|
|
var handler http.Handler
|
|
defaultReadHeaderTimeout := time.Second
|
|
if g.cfg.timeout > 0*time.Second {
|
|
defaultReadHeaderTimeout = g.cfg.timeout
|
|
handler = http.TimeoutHandler(g.cfg.router, g.cfg.timeout, "request timed out")
|
|
} else {
|
|
handler = g.cfg.router
|
|
}
|
|
g.server = &http.Server{
|
|
Addr: g.cfg.httpAddr,
|
|
Handler: handler,
|
|
ReadHeaderTimeout: defaultReadHeaderTimeout,
|
|
}
|
|
|
|
return g, nil
|
|
}
|
|
|
|
// Start the http rest service.
|
|
func (g *Server) Start() {
|
|
g.ctx, g.cancel = context.WithCancel(g.ctx)
|
|
|
|
go func() {
|
|
log.WithField("address", g.cfg.httpAddr).Info("Starting HTTP server")
|
|
if err := g.server.ListenAndServe(); err != http.ErrServerClosed {
|
|
log.WithError(err).Error("Failed to start HTTP server")
|
|
g.startFailure = err
|
|
return
|
|
}
|
|
}()
|
|
}
|
|
|
|
// Status of the HTTP server. Returns an error if this service is unhealthy.
|
|
func (g *Server) Status() error {
|
|
if g.startFailure != nil {
|
|
return g.startFailure
|
|
}
|
|
return nil
|
|
}
|
|
|
|
// Stop the HTTP server with a graceful shutdown.
|
|
func (g *Server) Stop() error {
|
|
if g.server != nil {
|
|
shutdownCtx, shutdownCancel := context.WithTimeout(g.ctx, 2*time.Second)
|
|
defer shutdownCancel()
|
|
if err := g.server.Shutdown(shutdownCtx); err != nil {
|
|
if errors.Is(err, context.DeadlineExceeded) {
|
|
log.Warn("Existing connections terminated")
|
|
} else {
|
|
log.WithError(err).Error("Failed to gracefully shut down server")
|
|
}
|
|
}
|
|
}
|
|
if g.cancel != nil {
|
|
g.cancel()
|
|
}
|
|
return nil
|
|
}
|