From 9f7ddae77616c0dea45e7b84a4972ffb9bc495b7 Mon Sep 17 00:00:00 2001 From: Michael Barroco Date: Tue, 26 Mar 2024 15:54:29 +0100 Subject: [PATCH] [dss][scd] DSS0210,A2-7-2,4d: Do not return expired subscriptions in QuerySubscriptions --- pkg/scd/subscriptions_handler.go | 9 +++++++-- 1 file changed, 7 insertions(+), 2 deletions(-) diff --git a/pkg/scd/subscriptions_handler.go b/pkg/scd/subscriptions_handler.go index a457c4286..574132031 100644 --- a/pkg/scd/subscriptions_handler.go +++ b/pkg/scd/subscriptions_handler.go @@ -2,6 +2,7 @@ package scd import ( "context" + "time" "github.com/golang/geo/s2" "github.com/interuss/dss/pkg/api" @@ -375,6 +376,7 @@ func (a *Server) GetSubscription(ctx context.Context, req *restapi.GetSubscripti // QuerySubscriptions queries existing subscriptions in the given bounds. func (a *Server) QuerySubscriptions(ctx context.Context, req *restapi.QuerySubscriptionsRequest, ) restapi.QuerySubscriptionsResponseSet { + nowMarker := time.Now() if req.Auth.Error != nil { resp := restapi.QuerySubscriptionsResponseSet{} setAuthError(ctx, stacktrace.Propagate(req.Auth.Error, "Auth failed"), &resp.Response401, &resp.Response403, &resp.Response500) @@ -419,7 +421,10 @@ func (a *Server) QuerySubscriptions(ctx context.Context, req *restapi.QuerySubsc Subscriptions: make([]restapi.Subscription, 0), } for _, sub := range subs { - if sub.Manager == dssmodels.Manager(*req.Auth.ClientID) { + // Do not return subscriptions which are expired. + // TODO: Add reference to TSC investigation outcome. + isExpired := sub.EndTime.Before(nowMarker) + if !isExpired && sub.Manager == dssmodels.Manager(*req.Auth.ClientID) { // Get dependent Operations dependentOps, err := r.GetDependentOperationalIntents(ctx, sub.ID) if err != nil { @@ -430,10 +435,10 @@ func (a *Server) QuerySubscriptions(ctx context.Context, req *restapi.QuerySubsc if err != nil { return stacktrace.Propagate(err, "Error converting Subscription model to REST") } + response.Subscriptions = append(response.Subscriptions, *p) } } - return nil }