From 44255db7fd5e1ddfd88e18a7878935e97e40f4c3 Mon Sep 17 00:00:00 2001 From: Jack Ding Date: Mon, 6 Jan 2025 11:18:21 -0500 Subject: [PATCH] update sdk-go and rest-api Signed-off-by: Jack Ding --- go.mod | 4 ++-- go.sum | 8 ++++---- vendor/github.com/redhat-cne/rest-api/.gitignore | 5 ++++- .../github.com/redhat-cne/rest-api/v2/routes.go | 13 +++++++------ .../github.com/redhat-cne/rest-api/v2/server.go | 3 +++ .../sdk-go/pkg/pubsub/pubsub_unmarshal.go | 10 +++++++++- .../sdk-go/v1/subscriber/subscriber.go | 16 +--------------- vendor/modules.txt | 4 ++-- 8 files changed, 32 insertions(+), 31 deletions(-) diff --git a/go.mod b/go.mod index e4f111b8..d33536aa 100644 --- a/go.mod +++ b/go.mod @@ -12,8 +12,8 @@ require ( github.com/onsi/ginkgo v1.16.5 github.com/onsi/gomega v1.23.0 github.com/prometheus/client_golang v1.14.0 - github.com/redhat-cne/rest-api v1.22.0 - github.com/redhat-cne/sdk-go v1.22.1 + github.com/redhat-cne/rest-api v1.22.2 + github.com/redhat-cne/sdk-go v1.22.3 github.com/sirupsen/logrus v1.9.0 github.com/stretchr/testify v1.8.1 golang.org/x/net v0.23.0 diff --git a/go.sum b/go.sum index e3d1adae..99fd7571 100644 --- a/go.sum +++ b/go.sum @@ -419,10 +419,10 @@ github.com/prometheus/procfs v0.7.3/go.mod h1:cz+aTbrPOrUb4q7XlbU9ygM+/jj0fzG6c1 github.com/prometheus/procfs v0.8.0 h1:ODq8ZFEaYeCaZOJlZZdJA2AbQR98dSHSM1KW/You5mo= github.com/prometheus/procfs v0.8.0/go.mod h1:z7EfXMXOkbkqb9IINtpCn86r/to3BnA0uaxHdg830/4= github.com/prometheus/tsdb v0.7.1/go.mod h1:qhTCs0VvXwvX/y3TZrWD7rabWM+ijKTux40TwIPHuXU= -github.com/redhat-cne/rest-api v1.22.0 h1:A0IbrLi07eYteFGimhmrOHVD6q1wk3kPKpG4oVAenrk= -github.com/redhat-cne/rest-api v1.22.0/go.mod h1:9Bb+edIo4zJ3/QUwgTWlwP/ZBbtGExxhnAzzLkQLtEA= -github.com/redhat-cne/sdk-go v1.22.1 h1:g5Kuyu92bwEmrjrapK12HvNxzZym+PMh6YhQ0463znw= -github.com/redhat-cne/sdk-go v1.22.1/go.mod h1:qeir05dwTscLvqGCIoQPCUM6HUoVmhR7521nXn28utA= +github.com/redhat-cne/rest-api v1.22.2 h1:L1gYpjdUg8NTb0tNBwrsA3EK++wnmpUhB+aunEzLqO0= +github.com/redhat-cne/rest-api v1.22.2/go.mod h1:2AmXrQWYJ//l+AfshOaP2YlWH4zgXgT0CN0i6NmZEVQ= +github.com/redhat-cne/sdk-go v1.22.3 h1:XiXnZf2c7CwWW3MAdnGYEj1sKTWdXGCUjECL6U69sqc= +github.com/redhat-cne/sdk-go v1.22.3/go.mod h1:qeir05dwTscLvqGCIoQPCUM6HUoVmhR7521nXn28utA= github.com/rogpeppe/fastuuid v0.0.0-20150106093220-6724a57986af/go.mod h1:XWv6SoW27p1b0cqNHllgS5HIMJraePCO15w5zCzIWYg= github.com/rogpeppe/fastuuid v1.2.0/go.mod h1:jVj6XXZzXRy/MSR5jhDC/2q6DgLz+nrA6LYCDYWNEvQ= github.com/rogpeppe/go-internal v1.3.0/go.mod h1:M8bDsm7K2OlrFYOpmOWEs/qY81heoFRclV5y23lUDJ4= diff --git a/vendor/github.com/redhat-cne/rest-api/.gitignore b/vendor/github.com/redhat-cne/rest-api/.gitignore index 77ab3bee..da77c882 100644 --- a/vendor/github.com/redhat-cne/rest-api/.gitignore +++ b/vendor/github.com/redhat-cne/rest-api/.gitignore @@ -17,4 +17,7 @@ cover.out pub.json sub.json -.idea \ No newline at end of file +.idea +.cache +.dccache + diff --git a/vendor/github.com/redhat-cne/rest-api/v2/routes.go b/vendor/github.com/redhat-cne/rest-api/v2/routes.go index 6ba577ae..3c291acf 100644 --- a/vendor/github.com/redhat-cne/rest-api/v2/routes.go +++ b/vendor/github.com/redhat-cne/rest-api/v2/routes.go @@ -68,12 +68,13 @@ func (s *Server) createSubscription(w http.ResponseWriter, r *http.Request) { localmetrics.UpdateSubscriptionCount(localmetrics.FAILCREATE, 1) return } - clientIDs := s.subscriberAPI.GetClientIDByResource(sub.GetResource()) - if len(clientIDs) != 0 { - respondWithStatusCode(w, http.StatusConflict, - fmt.Sprintf("subscription (clientID: %s) with same resource already exists, skipping creation", - clientIDs[0])) - return + for id, address := range s.subscriberAPI.GetClientIDAddressByResource(sub.GetResource()) { + if address.String() == endPointURI { + respondWithStatusCode(w, http.StatusConflict, + fmt.Sprintf("subscription (clientID: %s) with same resource already exists, skipping creation", + id)) + return + } } id := uuid.New().String() diff --git a/vendor/github.com/redhat-cne/rest-api/v2/server.go b/vendor/github.com/redhat-cne/rest-api/v2/server.go index fc459be5..f748c392 100644 --- a/vendor/github.com/redhat-cne/rest-api/v2/server.go +++ b/vendor/github.com/redhat-cne/rest-api/v2/server.go @@ -309,7 +309,10 @@ func (s *Server) Start() { io.WriteString(w, "OK") //nolint:errcheck }).Methods(http.MethodGet) + // for internal test api.HandleFunc("/dummy", dummy).Methods(http.MethodPost) + // for internal test: test multiple clients + api.HandleFunc("/dummy2", dummy).Methods(http.MethodPost) api.HandleFunc("/log", s.logEvent).Methods(http.MethodPost) //publishEvent create event and send it to a channel that is shared by middleware to process diff --git a/vendor/github.com/redhat-cne/sdk-go/pkg/pubsub/pubsub_unmarshal.go b/vendor/github.com/redhat-cne/sdk-go/pkg/pubsub/pubsub_unmarshal.go index dd95e7db..c3a96184 100644 --- a/vendor/github.com/redhat-cne/sdk-go/pkg/pubsub/pubsub_unmarshal.go +++ b/vendor/github.com/redhat-cne/sdk-go/pkg/pubsub/pubsub_unmarshal.go @@ -15,6 +15,7 @@ package pubsub import ( + "fmt" "io" "sync" @@ -91,7 +92,14 @@ func readJSONFromIterator(out *PubSub, iterator *jsoniter.Iterator) error { if iterator.Error != nil { return iterator.Error } - + // Skip checking EndPointURI here since it is not used in http transport. + // Check EndPointURI in O-RAN REST API handler + //if endpointUri == "" { + // return fmt.Errorf("mandatory field EndPointURI is not set") + //} + if resource == "" { + return fmt.Errorf("mandatory field ResourceAddress is not set") + } out.SetID(id) out.SetEndpointURI(endpointUri) //nolint:errcheck out.SetURILocation(uriLocation) //nolint:errcheck diff --git a/vendor/github.com/redhat-cne/sdk-go/v1/subscriber/subscriber.go b/vendor/github.com/redhat-cne/sdk-go/v1/subscriber/subscriber.go index a2aac0c8..66c5d9e9 100644 --- a/vendor/github.com/redhat-cne/sdk-go/v1/subscriber/subscriber.go +++ b/vendor/github.com/redhat-cne/sdk-go/v1/subscriber/subscriber.go @@ -272,20 +272,6 @@ func (p *API) GetSubscriberURLByResource(resource string) (urls []string) { return urls } -// GetClientIDByResource get subscriptionOne information -func (p *API) GetClientIDByResource(resource string) (clientIDs []uuid.UUID) { - p.SubscriberStore.RLock() - defer p.SubscriberStore.RUnlock() - for _, subs := range p.SubscriberStore.Store { - for _, sub := range subs.SubStore.Store { - if strings.Contains(sub.GetResource(), resource) { - clientIDs = append(clientIDs, subs.ClientID) - } - } - } - return clientIDs -} - // GetClientIDBySubID ... func (p *API) GetClientIDBySubID(subID string) (clientIDs []uuid.UUID) { p.SubscriberStore.RLock() @@ -300,7 +286,7 @@ func (p *API) GetClientIDBySubID(subID string) (clientIDs []uuid.UUID) { return clientIDs } -// GetClientIDAddressByResource get subscriptionOne information +// GetClientIDAddressByResource get subscriptionOne information func (p *API) GetClientIDAddressByResource(resource string) map[uuid.UUID]*types.URI { clients := map[uuid.UUID]*types.URI{} p.SubscriberStore.RLock() diff --git a/vendor/modules.txt b/vendor/modules.txt index 17757411..9813dc0f 100644 --- a/vendor/modules.txt +++ b/vendor/modules.txt @@ -184,13 +184,13 @@ github.com/prometheus/common/model github.com/prometheus/procfs github.com/prometheus/procfs/internal/fs github.com/prometheus/procfs/internal/util -# github.com/redhat-cne/rest-api v1.22.0 +# github.com/redhat-cne/rest-api v1.22.2 ## explicit; go 1.22 github.com/redhat-cne/rest-api github.com/redhat-cne/rest-api/pkg/localmetrics github.com/redhat-cne/rest-api/pkg/restclient github.com/redhat-cne/rest-api/v2 -# github.com/redhat-cne/sdk-go v1.22.1 +# github.com/redhat-cne/sdk-go v1.22.3 ## explicit; go 1.22 github.com/redhat-cne/sdk-go/pkg/channel github.com/redhat-cne/sdk-go/pkg/common