NONRTRIC-946: Add support for Kong routes
[nonrtric/plt/sme.git] / servicemanager / internal / discoverserviceapi / discoverserviceapi-server.gen.go
1 // Package discoverserviceapi provides primitives to interact with the openapi HTTP API.
2 //
3 // Code generated by github.com/deepmap/oapi-codegen version v1.10.1 DO NOT EDIT.
4 package discoverserviceapi
5
6 import (
7         "bytes"
8         "compress/gzip"
9         "encoding/base64"
10         "encoding/json"
11         "fmt"
12         "net/http"
13         "net/url"
14         "path"
15         "strings"
16
17         "github.com/deepmap/oapi-codegen/pkg/runtime"
18         "github.com/getkin/kin-openapi/openapi3"
19         "github.com/labstack/echo/v4"
20         externalRef0 "oransc.org/nonrtric/servicemanager/internal/common29122"
21         externalRef1 "oransc.org/nonrtric/servicemanager/internal/common29571"
22         externalRef2 "oransc.org/nonrtric/servicemanager/internal/publishserviceapi"
23 )
24
25 // ServerInterface represents all server handlers.
26 type ServerInterface interface {
27
28         // (GET /allServiceAPIs)
29         GetAllServiceAPIs(ctx echo.Context, params GetAllServiceAPIsParams) error
30 }
31
32 // ServerInterfaceWrapper converts echo contexts to parameters.
33 type ServerInterfaceWrapper struct {
34         Handler ServerInterface
35 }
36
37 // GetAllServiceAPIs converts echo context to params.
38 func (w *ServerInterfaceWrapper) GetAllServiceAPIs(ctx echo.Context) error {
39         var err error
40
41         // Parameter object where we will unmarshal all parameters from the context
42         var params GetAllServiceAPIsParams
43         // ------------- Required query parameter "api-invoker-id" -------------
44
45         err = runtime.BindQueryParameter("form", true, true, "api-invoker-id", ctx.QueryParams(), &params.ApiInvokerId)
46         if err != nil {
47                 return echo.NewHTTPError(http.StatusBadRequest, fmt.Sprintf("Invalid format for parameter api-invoker-id: %s", err))
48         }
49
50         // ------------- Optional query parameter "api-name" -------------
51
52         err = runtime.BindQueryParameter("form", true, false, "api-name", ctx.QueryParams(), &params.ApiName)
53         if err != nil {
54                 return echo.NewHTTPError(http.StatusBadRequest, fmt.Sprintf("Invalid format for parameter api-name: %s", err))
55         }
56
57         // ------------- Optional query parameter "api-version" -------------
58
59         err = runtime.BindQueryParameter("form", true, false, "api-version", ctx.QueryParams(), &params.ApiVersion)
60         if err != nil {
61                 return echo.NewHTTPError(http.StatusBadRequest, fmt.Sprintf("Invalid format for parameter api-version: %s", err))
62         }
63
64         // ------------- Optional query parameter "comm-type" -------------
65
66         err = runtime.BindQueryParameter("form", true, false, "comm-type", ctx.QueryParams(), &params.CommType)
67         if err != nil {
68                 return echo.NewHTTPError(http.StatusBadRequest, fmt.Sprintf("Invalid format for parameter comm-type: %s", err))
69         }
70
71         // ------------- Optional query parameter "protocol" -------------
72
73         err = runtime.BindQueryParameter("form", true, false, "protocol", ctx.QueryParams(), &params.Protocol)
74         if err != nil {
75                 return echo.NewHTTPError(http.StatusBadRequest, fmt.Sprintf("Invalid format for parameter protocol: %s", err))
76         }
77
78         // ------------- Optional query parameter "aef-id" -------------
79
80         err = runtime.BindQueryParameter("form", true, false, "aef-id", ctx.QueryParams(), &params.AefId)
81         if err != nil {
82                 return echo.NewHTTPError(http.StatusBadRequest, fmt.Sprintf("Invalid format for parameter aef-id: %s", err))
83         }
84
85         // ------------- Optional query parameter "data-format" -------------
86
87         err = runtime.BindQueryParameter("form", true, false, "data-format", ctx.QueryParams(), &params.DataFormat)
88         if err != nil {
89                 return echo.NewHTTPError(http.StatusBadRequest, fmt.Sprintf("Invalid format for parameter data-format: %s", err))
90         }
91
92         // ------------- Optional query parameter "api-cat" -------------
93
94         err = runtime.BindQueryParameter("form", true, false, "api-cat", ctx.QueryParams(), &params.ApiCat)
95         if err != nil {
96                 return echo.NewHTTPError(http.StatusBadRequest, fmt.Sprintf("Invalid format for parameter api-cat: %s", err))
97         }
98
99         // ------------- Optional query parameter "preferred-aef-loc" -------------
100
101         if paramValue := ctx.QueryParam("preferred-aef-loc"); paramValue != "" {
102
103                 var value externalRef2.AefLocation
104                 err = json.Unmarshal([]byte(paramValue), &value)
105                 if err != nil {
106                         return echo.NewHTTPError(http.StatusBadRequest, "Error unmarshaling parameter 'preferred-aef-loc' as JSON")
107                 }
108                 params.PreferredAefLoc = &value
109
110         }
111
112         // ------------- Optional query parameter "supported-features" -------------
113
114         err = runtime.BindQueryParameter("form", true, false, "supported-features", ctx.QueryParams(), &params.SupportedFeatures)
115         if err != nil {
116                 return echo.NewHTTPError(http.StatusBadRequest, fmt.Sprintf("Invalid format for parameter supported-features: %s", err))
117         }
118
119         // ------------- Optional query parameter "api-supported-features" -------------
120
121         err = runtime.BindQueryParameter("form", true, false, "api-supported-features", ctx.QueryParams(), &params.ApiSupportedFeatures)
122         if err != nil {
123                 return echo.NewHTTPError(http.StatusBadRequest, fmt.Sprintf("Invalid format for parameter api-supported-features: %s", err))
124         }
125
126         // Invoke the callback with all the unmarshalled arguments
127         err = w.Handler.GetAllServiceAPIs(ctx, params)
128         return err
129 }
130
131 // This is a simple interface which specifies echo.Route addition functions which
132 // are present on both echo.Echo and echo.Group, since we want to allow using
133 // either of them for path registration
134 type EchoRouter interface {
135         CONNECT(path string, h echo.HandlerFunc, m ...echo.MiddlewareFunc) *echo.Route
136         DELETE(path string, h echo.HandlerFunc, m ...echo.MiddlewareFunc) *echo.Route
137         GET(path string, h echo.HandlerFunc, m ...echo.MiddlewareFunc) *echo.Route
138         HEAD(path string, h echo.HandlerFunc, m ...echo.MiddlewareFunc) *echo.Route
139         OPTIONS(path string, h echo.HandlerFunc, m ...echo.MiddlewareFunc) *echo.Route
140         PATCH(path string, h echo.HandlerFunc, m ...echo.MiddlewareFunc) *echo.Route
141         POST(path string, h echo.HandlerFunc, m ...echo.MiddlewareFunc) *echo.Route
142         PUT(path string, h echo.HandlerFunc, m ...echo.MiddlewareFunc) *echo.Route
143         TRACE(path string, h echo.HandlerFunc, m ...echo.MiddlewareFunc) *echo.Route
144 }
145
146 // RegisterHandlers adds each server route to the EchoRouter.
147 func RegisterHandlers(router EchoRouter, si ServerInterface) {
148         RegisterHandlersWithBaseURL(router, si, "")
149 }
150
151 // Registers handlers, and prepends BaseURL to the paths, so that the paths
152 // can be served under a prefix.
153 func RegisterHandlersWithBaseURL(router EchoRouter, si ServerInterface, baseURL string) {
154
155         wrapper := ServerInterfaceWrapper{
156                 Handler: si,
157         }
158
159         router.GET(baseURL+"/allServiceAPIs", wrapper.GetAllServiceAPIs)
160
161 }
162
163 // Base64 encoded, gzipped, json marshaled Swagger object
164 var swaggerSpec = []string{
165
166         "H4sIAAAAAAAC/7xX3W4bOw5+FUK7Fy1gz8STv8Z33sQpvFik3tjdm20RyBqOrVYjTSWNU2/gB9rXOE92",
167         "QGn8E8cOkLo4N006oT5+JD9S1BMTpqyMRu0d6z4xJ2ZY8vDrjXTCzNFi3hsOwpccnbCy8tJo1mX3WFl0",
168         "dBA4KOk8mALIFERtLWqvFmBxKp0nDJAa/Azhujcc3IIwFqGotSAs4DoHx710xULqKXDQdTlBS3iFVB4t",
169         "CCs9WsmhsmYuc8xhsghwveEAhNGuLtEmXzRrscqaCq2XGONBO5cCe8PBzYb8nmC2/kpuCbo5GlxwB1U9",
170         "UdLNNq6bvyfQ52L2zHoLGtyMKwVSC1XnCL3+LYVQSIUOSu7FjAImtJ1AYyzSYxnI/t1iwbpsPMqusix7",
171         "CEl8GEZGD6Po+qE3HCQLXqq/pZuapk1B09G+RLBli5VSD6KbTov5RYWsy7i1fMGWy/UHM/mGwrMlfcKf",
172         "Hq3m6saIPYk8/TgcwngE2VWSZRn8p3OZXCQncG3K0uiQnVvLS3w09jsUxkKwvzPWzyam1nkQEGux2irW",
173         "ZTPvK9dN08fHx+R0WlWJsdO08FU6qlC4lFsxk3NMs6sHh1aiS6PXlOKSujAv6REBcps34qb0b5XOJQBf",
174         "9B//h+wky1qR3Cc75Vr+jxMCVzDk1mu0Dt717gf/aEFvPBi14Pp61GtBfzwatGA8ugk/xj365/p9wOwp",
175         "BVZOZ94BdY2dYx5r7KVXlOJY01XTbReVtdgcrYsBdJIs6VB8pkLNK0kpT06SE1I+97NQkZQrtal3+DRF",
176         "v0f0jbMtbW/nIvSlRW8lzhE4CKMUilWLRAshjM2Dhg0ItJ5LvV/K1JQhhYOcddlH9L3nHIk+CcOjdaz7",
177         "312qIx9KJXPUXsYxsWp/qefmO1rgzsmp3vTnnkmTwMADV86A3QyvYHt9u8KWaJ/NqvZFeoEgtUdbcIFN",
178         "YxKnHzXaBWsxzcvQNJVsN1zaMmctZvFHLS3mrOttja1mtlIZmq5yISjqs30yJdgWSA/SgUNPM+iJV/KO",
179         "l7iEilu/GlSf7wfgvK2Fry2SWY6F1HHkCsVrh3CeZMkZ2W+1ZyfLXg8m/Ppm2iX/Ziw0gl3ze4fJNIF5",
180         "533yisOVyt/kkyZLraUI4gIyh9o9vyCi8/v+vz/3R+OH+/5o+Olu1D9IRZiybAe/20SOH8HPmI4Jf084",
181         "Q2u8EUbtBnGIbNXY/2auKxp7q9xfNwvag/XEInbBG0p5wz2n6Vxy7w4UkeY8V800hlXw8M/Rp7tw4mBR",
182         "c+55O2L/5lQR69sIvCem8c4mIbjHqbELGpiPMylmL3aNCSqjpw68ea1XxE4ce5IrjPaow9znVaUa4aXf",
183         "HBF7+q056GHxLxPx45LwMgmVxQItbYKkH9VYH5Z1Y90mISkj2MvU3iKniefA1VVlrN/o5e52vRSG235z",
184         "HayvvNEm44c4rGHbRePpkHLOLzsPccMhMbyyhK0QV9T3KeZwWPl6I38mGKlzqm20Ww1uWF+nCYxnkrbN",
185         "BRitFjAJtaC7D2SxsQ/Bb07RrdOYvX5L/DVZ+krXqauMdnGvz05O6MdbJb6/gZ8/dA7od+UeJiZfkLxo",
186         "14nbg0VXK795N9BeCkFl9P/V02jrLRQ2zS9h/T49udxJU4da8JU0rfOQ0tkA8eEIiA8EcRbT+UsQdDZA",
187         "dI6A6ESI0yMgTiPE2REQZxHi4giIiwDROYJFJ7LIrn4dIrsiiPMjinoei3p+REXOY0VyLHit/C/DrM4v",
188         "l6Exw9OpeSLERyItxffG+GXaDMU2r6RL5x16N3Er+UTFmdHYxXdQQ2r9xMSfvKwUJsKUbLf9m4P7V+vL",
189         "5Hxnsc6yLCG6X5d/BgAA//+yTjhGXhEAAA==",
190 }
191
192 // GetSwagger returns the content of the embedded swagger specification file
193 // or error if failed to decode
194 func decodeSpec() ([]byte, error) {
195         zipped, err := base64.StdEncoding.DecodeString(strings.Join(swaggerSpec, ""))
196         if err != nil {
197                 return nil, fmt.Errorf("error base64 decoding spec: %s", err)
198         }
199         zr, err := gzip.NewReader(bytes.NewReader(zipped))
200         if err != nil {
201                 return nil, fmt.Errorf("error decompressing spec: %s", err)
202         }
203         var buf bytes.Buffer
204         _, err = buf.ReadFrom(zr)
205         if err != nil {
206                 return nil, fmt.Errorf("error decompressing spec: %s", err)
207         }
208
209         return buf.Bytes(), nil
210 }
211
212 var rawSpec = decodeSpecCached()
213
214 // a naive cached of a decoded swagger spec
215 func decodeSpecCached() func() ([]byte, error) {
216         data, err := decodeSpec()
217         return func() ([]byte, error) {
218                 return data, err
219         }
220 }
221
222 // Constructs a synthetic filesystem for resolving external references when loading openapi specifications.
223 func PathToRawSpec(pathToFile string) map[string]func() ([]byte, error) {
224         var res = make(map[string]func() ([]byte, error))
225         if len(pathToFile) > 0 {
226                 res[pathToFile] = rawSpec
227         }
228
229         pathPrefix := path.Dir(pathToFile)
230
231         for rawPath, rawFunc := range externalRef0.PathToRawSpec(path.Join(pathPrefix, "TS29122_CommonData.yaml")) {
232                 if _, ok := res[rawPath]; ok {
233                         // it is not possible to compare functions in golang, so always overwrite the old value
234                 }
235                 res[rawPath] = rawFunc
236         }
237         for rawPath, rawFunc := range externalRef2.PathToRawSpec(path.Join(pathPrefix, "TS29222_CAPIF_Publish_Service_API.yaml")) {
238                 if _, ok := res[rawPath]; ok {
239                         // it is not possible to compare functions in golang, so always overwrite the old value
240                 }
241                 res[rawPath] = rawFunc
242         }
243         for rawPath, rawFunc := range externalRef1.PathToRawSpec(path.Join(pathPrefix, "TS29571_CommonData.yaml")) {
244                 if _, ok := res[rawPath]; ok {
245                         // it is not possible to compare functions in golang, so always overwrite the old value
246                 }
247                 res[rawPath] = rawFunc
248         }
249         return res
250 }
251
252 // GetSwagger returns the Swagger specification corresponding to the generated code
253 // in this file. The external references of Swagger specification are resolved.
254 // The logic of resolving external references is tightly connected to "import-mapping" feature.
255 // Externally referenced files must be embedded in the corresponding golang packages.
256 // Urls can be supported but this task was out of the scope.
257 func GetSwagger() (swagger *openapi3.T, err error) {
258         var resolvePath = PathToRawSpec("")
259
260         loader := openapi3.NewLoader()
261         loader.IsExternalRefsAllowed = true
262         loader.ReadFromURIFunc = func(loader *openapi3.Loader, url *url.URL) ([]byte, error) {
263                 var pathToFile = url.String()
264                 pathToFile = path.Clean(pathToFile)
265                 getSpec, ok := resolvePath[pathToFile]
266                 if !ok {
267                         err1 := fmt.Errorf("path not found: %s", pathToFile)
268                         return nil, err1
269                 }
270                 return getSpec()
271         }
272         var specData []byte
273         specData, err = rawSpec()
274         if err != nil {
275                 return
276         }
277         swagger, err = loader.LoadFromData(specData)
278         if err != nil {
279                 return
280         }
281         return
282 }