From c9b498262265dc5d32f29179c6d554d022516845 Mon Sep 17 00:00:00 2001 From: Daniel N <2color@users.noreply.github.com> Date: Thu, 14 Nov 2024 11:49:25 +0100 Subject: [PATCH 1/3] feat: add routing timeouts to delegated server --- routing/http/server/server.go | 30 ++++++++++++++++++++++++++---- 1 file changed, 26 insertions(+), 4 deletions(-) diff --git a/routing/http/server/server.go b/routing/http/server/server.go index 6177da125..f6d0f1993 100644 --- a/routing/http/server/server.go +++ b/routing/http/server/server.go @@ -41,6 +41,7 @@ const ( DefaultRecordsLimit = 20 DefaultStreamingRecordsLimit = 0 + DefaultRoutingTimeout = 30 * time.Second ) var logger = logging.Logger("routing/http/server") @@ -132,11 +133,18 @@ func WithPrometheusRegistry(reg prometheus.Registerer) Option { } } +func WithRoutingTimeout(timeout time.Duration) Option { + return func(s *server) { + s.routingTimeout = timeout + } +} + func Handler(svc ContentRouter, opts ...Option) http.Handler { server := &server{ svc: svc, recordsLimit: DefaultRecordsLimit, streamingRecordsLimit: DefaultStreamingRecordsLimit, + routingTimeout: DefaultRoutingTimeout, } for _, opt := range opts { @@ -174,6 +182,7 @@ type server struct { recordsLimit int streamingRecordsLimit int promRegistry prometheus.Registerer + routingTimeout time.Duration } func (s *server) detectResponseType(r *http.Request) (string, error) { @@ -246,7 +255,10 @@ func (s *server) findProviders(w http.ResponseWriter, httpReq *http.Request) { recordsLimit = s.recordsLimit } - provIter, err := s.svc.FindProviders(httpReq.Context(), cid, recordsLimit) + ctx, cancel := context.WithTimeout(httpReq.Context(), s.routingTimeout) + defer cancel() + + provIter, err := s.svc.FindProviders(ctx, cid, recordsLimit) if err != nil { if errors.Is(err, routing.ErrNotFound) { // handlerFunc takes care of setting the 404 and necessary headers @@ -335,7 +347,11 @@ func (s *server) findPeers(w http.ResponseWriter, r *http.Request) { recordsLimit = s.recordsLimit } - provIter, err := s.svc.FindPeers(r.Context(), pid, recordsLimit) + // Add timeout to the routing operation + ctx, cancel := context.WithTimeout(r.Context(), s.routingTimeout) + defer cancel() + + provIter, err := s.svc.FindPeers(ctx, pid, recordsLimit) if err != nil { if errors.Is(err, routing.ErrNotFound) { // handlerFunc takes care of setting the 404 and necessary headers @@ -466,7 +482,10 @@ func (s *server) GetIPNS(w http.ResponseWriter, r *http.Request) { return } - record, err := s.svc.GetIPNS(r.Context(), name) + ctx, cancel := context.WithTimeout(r.Context(), s.routingTimeout) + defer cancel() + + record, err := s.svc.GetIPNS(ctx, name) if err != nil { if errors.Is(err, routing.ErrNotFound) { writeErr(w, "GetIPNS", http.StatusNotFound, fmt.Errorf("delegate error: %w", err)) @@ -550,7 +569,10 @@ func (s *server) PutIPNS(w http.ResponseWriter, r *http.Request) { return } - err = s.svc.PutIPNS(r.Context(), name, record) + ctx, cancel := context.WithTimeout(r.Context(), s.routingTimeout) + defer cancel() + + err = s.svc.PutIPNS(ctx, name, record) if err != nil { writeErr(w, "PutIPNS", http.StatusInternalServerError, fmt.Errorf("delegate error: %w", err)) return From 3256e3973573d98fc8b6d3c7454a72a4ac274351 Mon Sep 17 00:00:00 2001 From: Daniel N <2color@users.noreply.github.com> Date: Mon, 18 Nov 2024 16:46:20 +0100 Subject: [PATCH 2/3] chore: update changelog --- CHANGELOG.md | 1 + 1 file changed, 1 insertion(+) diff --git a/CHANGELOG.md b/CHANGELOG.md index faca07433..8bc8c8333 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -17,6 +17,7 @@ The following emojis are used to highlight certain changes: ### Added - `routing/http/server`: added Prometheus instrumentation to http delegated routing endpoints. +- `routing/http/server`: added a routing timeout with default value of 30 seconds to delegated routing server to avoid indefinite hanging on content/peer routing requests. ### Changed From d699f73cddfbad06def7b9f1d28fd88b4bee1e13 Mon Sep 17 00:00:00 2001 From: Marcin Rataj Date: Tue, 19 Nov 2024 01:17:19 +0100 Subject: [PATCH 3/3] docs: CHANGELOG.md --- CHANGELOG.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 8bc8c8333..8ed1fb078 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -17,7 +17,7 @@ The following emojis are used to highlight certain changes: ### Added - `routing/http/server`: added Prometheus instrumentation to http delegated routing endpoints. -- `routing/http/server`: added a routing timeout with default value of 30 seconds to delegated routing server to avoid indefinite hanging on content/peer routing requests. +- `routing/http/server`: added configurable routing timeout (`DefaultRoutingTimeout` being 30s) to prevent indefinite hangs during content/peer routing. Set custom duration via `WithRoutingTimeout`. ### Changed