From 095ca48e872cc3178bc76356553fc9ed50ceec05 Mon Sep 17 00:00:00 2001 From: Julien Perrochet Date: Thu, 11 Jan 2024 15:56:09 +0100 Subject: [PATCH] [scd] return proper http code for too big area search on the SCD subscriptions endpoint (#985) --- pkg/scd/subscriptions_handler.go | 16 ++++++++++++++-- 1 file changed, 14 insertions(+), 2 deletions(-) diff --git a/pkg/scd/subscriptions_handler.go b/pkg/scd/subscriptions_handler.go index 846824081..6fb6301ab 100644 --- a/pkg/scd/subscriptions_handler.go +++ b/pkg/scd/subscriptions_handler.go @@ -439,8 +439,20 @@ func (a *Server) QuerySubscriptions(ctx context.Context, req *restapi.QuerySubsc err = a.Store.Transact(ctx, action) if err != nil { - return restapi.QuerySubscriptionsResponseSet{Response500: &api.InternalServerErrorBody{ - ErrorMessage: *dsserr.Handle(ctx, stacktrace.Propagate(err, "Got an unexpected error"))}} + + errResp := &restapi.ErrorResponse{Message: dsserr.Handle(ctx, err)} + switch stacktrace.GetCode(err) { + case dsserr.BadRequest: + return restapi.QuerySubscriptionsResponseSet{Response400: errResp} + case dsserr.PermissionDenied: + return restapi.QuerySubscriptionsResponseSet{Response403: errResp} + case dsserr.AreaTooLarge: + return restapi.QuerySubscriptionsResponseSet{Response413: errResp} + default: + return restapi.QuerySubscriptionsResponseSet{Response500: &api.InternalServerErrorBody{ + ErrorMessage: *dsserr.Handle(ctx, stacktrace.Propagate(err, "Got an unexpected error"))}} + + } } return restapi.QuerySubscriptionsResponseSet{Response200: response}