7cd210737215cc157ddc5401b492db0d27797b03
[nonrtric/plt/sme.git] / 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         "fmt"
11         "net/http"
12         "net/url"
13         "path"
14         "strings"
15
16         "github.com/deepmap/oapi-codegen/pkg/runtime"
17         "github.com/getkin/kin-openapi/openapi3"
18         "github.com/labstack/echo/v4"
19         externalRef0 "oransc.org/nonrtric/sme/internal/common29122"
20         externalRef1 "oransc.org/nonrtric/sme/internal/common29571"
21         externalRef2 "oransc.org/nonrtric/sme/internal/publishserviceapi"
22 )
23
24 // ServerInterface represents all server handlers.
25 type ServerInterface interface {
26
27         // (GET /allServiceAPIs)
28         GetAllServiceAPIs(ctx echo.Context, params GetAllServiceAPIsParams) error
29 }
30
31 // ServerInterfaceWrapper converts echo contexts to parameters.
32 type ServerInterfaceWrapper struct {
33         Handler ServerInterface
34 }
35
36 // GetAllServiceAPIs converts echo context to params.
37 func (w *ServerInterfaceWrapper) GetAllServiceAPIs(ctx echo.Context) error {
38         var err error
39
40         // Parameter object where we will unmarshal all parameters from the context
41         var params GetAllServiceAPIsParams
42         // ------------- Required query parameter "api-invoker-id" -------------
43
44         err = runtime.BindQueryParameter("form", true, true, "api-invoker-id", ctx.QueryParams(), &params.ApiInvokerId)
45         if err != nil {
46                 return echo.NewHTTPError(http.StatusBadRequest, fmt.Sprintf("Invalid format for parameter api-invoker-id: %s", err))
47         }
48
49         // ------------- Optional query parameter "api-name" -------------
50
51         err = runtime.BindQueryParameter("form", true, false, "api-name", ctx.QueryParams(), &params.ApiName)
52         if err != nil {
53                 return echo.NewHTTPError(http.StatusBadRequest, fmt.Sprintf("Invalid format for parameter api-name: %s", err))
54         }
55
56         // ------------- Optional query parameter "api-version" -------------
57
58         err = runtime.BindQueryParameter("form", true, false, "api-version", ctx.QueryParams(), &params.ApiVersion)
59         if err != nil {
60                 return echo.NewHTTPError(http.StatusBadRequest, fmt.Sprintf("Invalid format for parameter api-version: %s", err))
61         }
62
63         // ------------- Optional query parameter "comm-type" -------------
64
65         err = runtime.BindQueryParameter("form", true, false, "comm-type", ctx.QueryParams(), &params.CommType)
66         if err != nil {
67                 return echo.NewHTTPError(http.StatusBadRequest, fmt.Sprintf("Invalid format for parameter comm-type: %s", err))
68         }
69
70         // ------------- Optional query parameter "protocol" -------------
71
72         err = runtime.BindQueryParameter("form", true, false, "protocol", ctx.QueryParams(), &params.Protocol)
73         if err != nil {
74                 return echo.NewHTTPError(http.StatusBadRequest, fmt.Sprintf("Invalid format for parameter protocol: %s", err))
75         }
76
77         // ------------- Optional query parameter "aef-id" -------------
78
79         err = runtime.BindQueryParameter("form", true, false, "aef-id", ctx.QueryParams(), &params.AefId)
80         if err != nil {
81                 return echo.NewHTTPError(http.StatusBadRequest, fmt.Sprintf("Invalid format for parameter aef-id: %s", err))
82         }
83
84         // ------------- Optional query parameter "data-format" -------------
85
86         err = runtime.BindQueryParameter("form", true, false, "data-format", ctx.QueryParams(), &params.DataFormat)
87         if err != nil {
88                 return echo.NewHTTPError(http.StatusBadRequest, fmt.Sprintf("Invalid format for parameter data-format: %s", err))
89         }
90
91         // ------------- Optional query parameter "api-cat" -------------
92
93         err = runtime.BindQueryParameter("form", true, false, "api-cat", ctx.QueryParams(), &params.ApiCat)
94         if err != nil {
95                 return echo.NewHTTPError(http.StatusBadRequest, fmt.Sprintf("Invalid format for parameter api-cat: %s", err))
96         }
97
98         // ------------- Optional query parameter "supported-features" -------------
99
100         err = runtime.BindQueryParameter("form", true, false, "supported-features", ctx.QueryParams(), &params.SupportedFeatures)
101         if err != nil {
102                 return echo.NewHTTPError(http.StatusBadRequest, fmt.Sprintf("Invalid format for parameter supported-features: %s", err))
103         }
104
105         // ------------- Optional query parameter "api-supported-features" -------------
106
107         err = runtime.BindQueryParameter("form", true, false, "api-supported-features", ctx.QueryParams(), &params.ApiSupportedFeatures)
108         if err != nil {
109                 return echo.NewHTTPError(http.StatusBadRequest, fmt.Sprintf("Invalid format for parameter api-supported-features: %s", err))
110         }
111
112         // Invoke the callback with all the unmarshalled arguments
113         err = w.Handler.GetAllServiceAPIs(ctx, params)
114         return err
115 }
116
117 // This is a simple interface which specifies echo.Route addition functions which
118 // are present on both echo.Echo and echo.Group, since we want to allow using
119 // either of them for path registration
120 type EchoRouter interface {
121         CONNECT(path string, h echo.HandlerFunc, m ...echo.MiddlewareFunc) *echo.Route
122         DELETE(path string, h echo.HandlerFunc, m ...echo.MiddlewareFunc) *echo.Route
123         GET(path string, h echo.HandlerFunc, m ...echo.MiddlewareFunc) *echo.Route
124         HEAD(path string, h echo.HandlerFunc, m ...echo.MiddlewareFunc) *echo.Route
125         OPTIONS(path string, h echo.HandlerFunc, m ...echo.MiddlewareFunc) *echo.Route
126         PATCH(path string, h echo.HandlerFunc, m ...echo.MiddlewareFunc) *echo.Route
127         POST(path string, h echo.HandlerFunc, m ...echo.MiddlewareFunc) *echo.Route
128         PUT(path string, h echo.HandlerFunc, m ...echo.MiddlewareFunc) *echo.Route
129         TRACE(path string, h echo.HandlerFunc, m ...echo.MiddlewareFunc) *echo.Route
130 }
131
132 // RegisterHandlers adds each server route to the EchoRouter.
133 func RegisterHandlers(router EchoRouter, si ServerInterface) {
134         RegisterHandlersWithBaseURL(router, si, "")
135 }
136
137 // Registers handlers, and prepends BaseURL to the paths, so that the paths
138 // can be served under a prefix.
139 func RegisterHandlersWithBaseURL(router EchoRouter, si ServerInterface, baseURL string) {
140
141         wrapper := ServerInterfaceWrapper{
142                 Handler: si,
143         }
144
145         router.GET(baseURL+"/allServiceAPIs", wrapper.GetAllServiceAPIs)
146
147 }
148
149 // Base64 encoded, gzipped, json marshaled Swagger object
150 var swaggerSpec = []string{
151
152         "H4sIAAAAAAAC/7xX23IaPRJ+lS7tXiRVMAPjU8wda+MUe+GwhuzNJuUSmoZRopEmkgaHdfFA+xr7ZH+1",
153         "NByMsf9ySP03Bovur78+qvXIhCkro1F7x3qPzIkCSx6+XksnzAIt5v3RMJzk6ISVlZdGsx67w8qiI0Xg",
154         "oKTzYGZAoiBqa1F7tQSLc+k8YYDU4AuEq/5oeAPCWIRZrQVhAdc5OO6lmy2lngMHXZdTtIQ3k8qjBWGl",
155         "Rys5VNYsZI45TJcBrj8agjDa1SXahLVYZU2F1kuM3qBdSIH90fB6S/2AKzu/klECblSDAe6gqqdKumJr",
156         "uPk9gQEXxRPpHWhwBVcKpBaqzhH6gxtyYCYVOii5FwW5S2h7bpIn0mMZqP7d4oz12GScXWZZdh8CeD+K",
157         "fO7H0fB9fzRMlrxUf0u3+UybZKbjQ2FgqxYrpR5GM90W88sKWY9xa/mSrVabAzP9hsKzFR3hT49Wc3Vt",
158         "xIEwnnwcjWAyhuwyybIM/t29SE6SDlyZsjQ6xObG8hIfjP0OM2MhyN8a64upqXUeioe1WG0V67HC+6qX",
159         "pg8PD8nJvKoSY+fpzFfpuELhUm5FIReYZpf3Dq1El0ajKbkl9cw8Z0f2yWre1DXFfidvLvmi//8/yDpZ",
160         "txWZfbJzruV/OelzBSNuvUbr4F3/bviPFvQnw3ELrq7G/RYMJuNhCybj6/Ax6dOfq/fJF91XCqycF94B",
161         "NYtdYJ580azFvPSKohvTue613XyyFlugdZF8N8mSTpurquBJRj6aCjWvJEU96SQdKn3ui5CUlCu1TXk4",
162         "mqM/UPWN0Z3i3o1HaEuL3kpcIHAQRikU6x6JEkIYm4ciNiDQei71oVqmngxhHOasxz6i7z9lSOSpMjxa",
163         "x3r/2Sc69iFZMkftZZwR696XemG+owXunJzrbXseGDMJDD1w5QzY7eQKslc3a2yJ9smgap+n5whSe7Qz",
164         "LjD0JTH6UaNdshbTvAw9U8l2w6Qtc9ZiFn/U0mLOet7W2GrGKqWgaSoXXKI2O1SmBNsC6UE6cOhpAD3y",
165         "St7yEldQcevXU+rz3RCct7XwtUUSy3EmdZy2rp4KxWuHcJqcksJOe551uq/5Er6+mXXJvxkLTc1u6L3D",
166         "ZJ7Aovv+NYPrQn+TTZortZYiVBaQONTu6dUQjd8N/vV5MJ7c3w3Go0+348GLVIQpy3awu0vk+AH8hOmE",
167         "8A+4M7LGG2HUvhMvka0a+d/MdU3jYJYHm06J1+3BfOIsNsEbUnnNPafhXHLvXkgijXmumnEMa+fhn+NP",
168         "t0HjxaTm3PN2xP7NoSLWNxH4gE+TvS1CcI9zY5c0Kx8KKYpne8YUldFzB9681itiz48/De4NchoPDlxd",
169         "Vcb6bXRvbzbLU7gat5NzczeMt/xeIrWBbc8aSy/F+eyiex+3AQrdKwvLGnFN/W1u5ZvN9Ul4pc6pBaPc",
170         "eszB5uZJYFJI2suWYLRawhShuSZAzrbywfmtFo3oRuy1pP01MfpKN4+rjHZx/806HfoQRnvUYQPgVaWa",
171         "OZR+cxTHx+c0Dhf70+dAWAefF/zaPExNvqTiopUgXrMWXa38dr+mFQ5CjdH/6wfEzoshLGW065x0LvaC",
172         "1KWGfSVImyikpBsgPhwB8YEgTmMwfwmCdANE9wiIboQ4OQLiJEKcHgFxGiHOj4A4DxDdI1h0I4vs8tch",
173         "skuCODsiqWcxqWdHZOQsZiTHGa+V/2WYtf5qFdoyvDOaTTo+pmh7vDPGr9JmILZ5JV266NIjg1vJpypO",
174         "jEYuPhYaUuEp5nppij95WSlMhCnZfvM3ii/uoBfJ2d4OmmVZQoy/rv4IAAD//37ZMOyFEAAA",
175 }
176
177 // GetSwagger returns the content of the embedded swagger specification file
178 // or error if failed to decode
179 func decodeSpec() ([]byte, error) {
180         zipped, err := base64.StdEncoding.DecodeString(strings.Join(swaggerSpec, ""))
181         if err != nil {
182                 return nil, fmt.Errorf("error base64 decoding spec: %s", err)
183         }
184         zr, err := gzip.NewReader(bytes.NewReader(zipped))
185         if err != nil {
186                 return nil, fmt.Errorf("error decompressing spec: %s", err)
187         }
188         var buf bytes.Buffer
189         _, err = buf.ReadFrom(zr)
190         if err != nil {
191                 return nil, fmt.Errorf("error decompressing spec: %s", err)
192         }
193
194         return buf.Bytes(), nil
195 }
196
197 var rawSpec = decodeSpecCached()
198
199 // a naive cached of a decoded swagger spec
200 func decodeSpecCached() func() ([]byte, error) {
201         data, err := decodeSpec()
202         return func() ([]byte, error) {
203                 return data, err
204         }
205 }
206
207 // Constructs a synthetic filesystem for resolving external references when loading openapi specifications.
208 func PathToRawSpec(pathToFile string) map[string]func() ([]byte, error) {
209         var res = make(map[string]func() ([]byte, error))
210         if len(pathToFile) > 0 {
211                 res[pathToFile] = rawSpec
212         }
213
214         pathPrefix := path.Dir(pathToFile)
215
216         for rawPath, rawFunc := range externalRef0.PathToRawSpec(path.Join(pathPrefix, "TS29122_CommonData.yaml")) {
217                 if _, ok := res[rawPath]; ok {
218                         // it is not possible to compare functions in golang, so always overwrite the old value
219                 }
220                 res[rawPath] = rawFunc
221         }
222         for rawPath, rawFunc := range externalRef2.PathToRawSpec(path.Join(pathPrefix, "TS29222_CAPIF_Publish_Service_API.yaml")) {
223                 if _, ok := res[rawPath]; ok {
224                         // it is not possible to compare functions in golang, so always overwrite the old value
225                 }
226                 res[rawPath] = rawFunc
227         }
228         for rawPath, rawFunc := range externalRef1.PathToRawSpec(path.Join(pathPrefix, "TS29571_CommonData.yaml")) {
229                 if _, ok := res[rawPath]; ok {
230                         // it is not possible to compare functions in golang, so always overwrite the old value
231                 }
232                 res[rawPath] = rawFunc
233         }
234         return res
235 }
236
237 // GetSwagger returns the Swagger specification corresponding to the generated code
238 // in this file. The external references of Swagger specification are resolved.
239 // The logic of resolving external references is tightly connected to "import-mapping" feature.
240 // Externally referenced files must be embedded in the corresponding golang packages.
241 // Urls can be supported but this task was out of the scope.
242 func GetSwagger() (swagger *openapi3.T, err error) {
243         var resolvePath = PathToRawSpec("")
244
245         loader := openapi3.NewLoader()
246         loader.IsExternalRefsAllowed = true
247         loader.ReadFromURIFunc = func(loader *openapi3.Loader, url *url.URL) ([]byte, error) {
248                 var pathToFile = url.String()
249                 pathToFile = path.Clean(pathToFile)
250                 getSpec, ok := resolvePath[pathToFile]
251                 if !ok {
252                         err1 := fmt.Errorf("path not found: %s", pathToFile)
253                         return nil, err1
254                 }
255                 return getSpec()
256         }
257         var specData []byte
258         specData, err = rawSpec()
259         if err != nil {
260                 return
261         }
262         swagger, err = loader.LoadFromData(specData)
263         if err != nil {
264                 return
265         }
266         return
267 }