// Package swagger provides primitives to interact with the openapi HTTP API. // // Code generated by github.com/deepmap/oapi-codegen version v1.12.4 DO NOT EDIT. package swagger import ( "bytes" "compress/gzip" "encoding/base64" "fmt" "net/http" "net/url" "path" "strings" "github.com/deepmap/oapi-codegen/pkg/runtime" "github.com/getkin/kin-openapi/openapi3" "github.com/labstack/echo/v4" ) // ServerInterface represents all server handlers. type ServerInterface interface { // удалить собственный аккаунт // (DELETE /account) DeleteAccount(ctx echo.Context) error // Получение текущего аккаунта юзера // (GET /account) GetAccount(ctx echo.Context) error // Отредактировать аккаунт // (PATCH /account) ChangeAccount(ctx echo.Context) error // Создать новый аккаунт // (POST /account) AddAccount(ctx echo.Context) error // Удалить аккаунт по айди // (DELETE /account/{userId}) DeleteDirectAccount(ctx echo.Context, userId string) error // Получить аккаунт по ID пользователя системы единой авторизации // (GET /account/{userId}) GetDirectAccount(ctx echo.Context, userId string) error // Выставление статуса верификации // (PATCH /account/{userId}) SetAccountVerificationStatus(ctx echo.Context, userId string) error // списко аккаунтов с пагинацией // (GET /accounts) PaginationAccounts(ctx echo.Context, params PaginationAccountsParams) error // Удаляем из корзины тариф // (DELETE /cart) RemoveFromCart(ctx echo.Context, params RemoveFromCartParams) error // Добавляем в корзину тариф // (PATCH /cart) Add2cart(ctx echo.Context, params Add2cartParams) error // оплатить козину // (POST /cart/pay) PayCart(ctx echo.Context) error // получить список одобренных валют // (GET /currencies) GetCurrencies(ctx echo.Context) error // обновляет список одобренных валют // (PUT /currencies) UpdateCurrencies(ctx echo.Context) error // Получение лога событий связанных с аккаунтом // (GET /history) GetHistory(ctx echo.Context, params GetHistoryParams) error // Изменить валюту кошелька // (PATCH /wallet) ChangeCurrency(ctx echo.Context) error // Запрос на получение ссылки на оплату // (POST /wallet) RequestMoney(ctx echo.Context) error } // ServerInterfaceWrapper converts echo contexts to parameters. type ServerInterfaceWrapper struct { Handler ServerInterface } // DeleteAccount converts echo context to params. func (w *ServerInterfaceWrapper) DeleteAccount(ctx echo.Context) error { var err error ctx.Set(BearerScopes, []string{""}) // Invoke the callback with all the unmarshalled arguments err = w.Handler.DeleteAccount(ctx) return err } // GetAccount converts echo context to params. func (w *ServerInterfaceWrapper) GetAccount(ctx echo.Context) error { var err error ctx.Set(BearerScopes, []string{""}) // Invoke the callback with all the unmarshalled arguments err = w.Handler.GetAccount(ctx) return err } // ChangeAccount converts echo context to params. func (w *ServerInterfaceWrapper) ChangeAccount(ctx echo.Context) error { var err error ctx.Set(BearerScopes, []string{""}) // Invoke the callback with all the unmarshalled arguments err = w.Handler.ChangeAccount(ctx) return err } // AddAccount converts echo context to params. func (w *ServerInterfaceWrapper) AddAccount(ctx echo.Context) error { var err error ctx.Set(BearerScopes, []string{""}) // Invoke the callback with all the unmarshalled arguments err = w.Handler.AddAccount(ctx) return err } // DeleteDirectAccount converts echo context to params. func (w *ServerInterfaceWrapper) DeleteDirectAccount(ctx echo.Context) error { var err error // ------------- Path parameter "userId" ------------- var userId string err = runtime.BindStyledParameterWithLocation("simple", false, "userId", runtime.ParamLocationPath, ctx.Param("userId"), &userId) if err != nil { return echo.NewHTTPError(http.StatusBadRequest, fmt.Sprintf("Invalid format for parameter userId: %s", err)) } ctx.Set(BearerScopes, []string{""}) // Invoke the callback with all the unmarshalled arguments err = w.Handler.DeleteDirectAccount(ctx, userId) return err } // GetDirectAccount converts echo context to params. func (w *ServerInterfaceWrapper) GetDirectAccount(ctx echo.Context) error { var err error // ------------- Path parameter "userId" ------------- var userId string err = runtime.BindStyledParameterWithLocation("simple", false, "userId", runtime.ParamLocationPath, ctx.Param("userId"), &userId) if err != nil { return echo.NewHTTPError(http.StatusBadRequest, fmt.Sprintf("Invalid format for parameter userId: %s", err)) } ctx.Set(BearerScopes, []string{""}) // Invoke the callback with all the unmarshalled arguments err = w.Handler.GetDirectAccount(ctx, userId) return err } // SetAccountVerificationStatus converts echo context to params. func (w *ServerInterfaceWrapper) SetAccountVerificationStatus(ctx echo.Context) error { var err error // ------------- Path parameter "userId" ------------- var userId string err = runtime.BindStyledParameterWithLocation("simple", false, "userId", runtime.ParamLocationPath, ctx.Param("userId"), &userId) if err != nil { return echo.NewHTTPError(http.StatusBadRequest, fmt.Sprintf("Invalid format for parameter userId: %s", err)) } ctx.Set(BearerScopes, []string{""}) // Invoke the callback with all the unmarshalled arguments err = w.Handler.SetAccountVerificationStatus(ctx, userId) return err } // PaginationAccounts converts echo context to params. func (w *ServerInterfaceWrapper) PaginationAccounts(ctx echo.Context) error { var err error // Parameter object where we will unmarshal all parameters from the context var params PaginationAccountsParams // ------------- Optional query parameter "page" ------------- err = runtime.BindQueryParameter("form", false, false, "page", ctx.QueryParams(), ¶ms.Page) if err != nil { return echo.NewHTTPError(http.StatusBadRequest, fmt.Sprintf("Invalid format for parameter page: %s", err)) } // ------------- Optional query parameter "limit" ------------- err = runtime.BindQueryParameter("form", false, false, "limit", ctx.QueryParams(), ¶ms.Limit) if err != nil { return echo.NewHTTPError(http.StatusBadRequest, fmt.Sprintf("Invalid format for parameter limit: %s", err)) } // Invoke the callback with all the unmarshalled arguments err = w.Handler.PaginationAccounts(ctx, params) return err } // RemoveFromCart converts echo context to params. func (w *ServerInterfaceWrapper) RemoveFromCart(ctx echo.Context) error { var err error ctx.Set(BearerScopes, []string{""}) // Parameter object where we will unmarshal all parameters from the context var params RemoveFromCartParams // ------------- Required query parameter "id" ------------- err = runtime.BindQueryParameter("form", true, true, "id", ctx.QueryParams(), ¶ms.Id) if err != nil { return echo.NewHTTPError(http.StatusBadRequest, fmt.Sprintf("Invalid format for parameter id: %s", err)) } // Invoke the callback with all the unmarshalled arguments err = w.Handler.RemoveFromCart(ctx, params) return err } // Add2cart converts echo context to params. func (w *ServerInterfaceWrapper) Add2cart(ctx echo.Context) error { var err error ctx.Set(BearerScopes, []string{""}) // Parameter object where we will unmarshal all parameters from the context var params Add2cartParams // ------------- Required query parameter "id" ------------- err = runtime.BindQueryParameter("form", true, true, "id", ctx.QueryParams(), ¶ms.Id) if err != nil { return echo.NewHTTPError(http.StatusBadRequest, fmt.Sprintf("Invalid format for parameter id: %s", err)) } // Invoke the callback with all the unmarshalled arguments err = w.Handler.Add2cart(ctx, params) return err } // PayCart converts echo context to params. func (w *ServerInterfaceWrapper) PayCart(ctx echo.Context) error { var err error ctx.Set(BearerScopes, []string{""}) // Invoke the callback with all the unmarshalled arguments err = w.Handler.PayCart(ctx) return err } // GetCurrencies converts echo context to params. func (w *ServerInterfaceWrapper) GetCurrencies(ctx echo.Context) error { var err error // Invoke the callback with all the unmarshalled arguments err = w.Handler.GetCurrencies(ctx) return err } // UpdateCurrencies converts echo context to params. func (w *ServerInterfaceWrapper) UpdateCurrencies(ctx echo.Context) error { var err error ctx.Set(BearerScopes, []string{""}) // Invoke the callback with all the unmarshalled arguments err = w.Handler.UpdateCurrencies(ctx) return err } // GetHistory converts echo context to params. func (w *ServerInterfaceWrapper) GetHistory(ctx echo.Context) error { var err error ctx.Set(BearerScopes, []string{""}) // Parameter object where we will unmarshal all parameters from the context var params GetHistoryParams // ------------- Optional query parameter "page" ------------- err = runtime.BindQueryParameter("form", false, false, "page", ctx.QueryParams(), ¶ms.Page) if err != nil { return echo.NewHTTPError(http.StatusBadRequest, fmt.Sprintf("Invalid format for parameter page: %s", err)) } // ------------- Optional query parameter "limit" ------------- err = runtime.BindQueryParameter("form", false, false, "limit", ctx.QueryParams(), ¶ms.Limit) if err != nil { return echo.NewHTTPError(http.StatusBadRequest, fmt.Sprintf("Invalid format for parameter limit: %s", err)) } // Invoke the callback with all the unmarshalled arguments err = w.Handler.GetHistory(ctx, params) return err } // ChangeCurrency converts echo context to params. func (w *ServerInterfaceWrapper) ChangeCurrency(ctx echo.Context) error { var err error ctx.Set(BearerScopes, []string{""}) // Invoke the callback with all the unmarshalled arguments err = w.Handler.ChangeCurrency(ctx) return err } // RequestMoney converts echo context to params. func (w *ServerInterfaceWrapper) RequestMoney(ctx echo.Context) error { var err error ctx.Set(BearerScopes, []string{""}) // Invoke the callback with all the unmarshalled arguments err = w.Handler.RequestMoney(ctx) return err } // This is a simple interface which specifies echo.Route addition functions which // are present on both echo.Echo and echo.Group, since we want to allow using // either of them for path registration type EchoRouter interface { CONNECT(path string, h echo.HandlerFunc, m ...echo.MiddlewareFunc) *echo.Route DELETE(path string, h echo.HandlerFunc, m ...echo.MiddlewareFunc) *echo.Route GET(path string, h echo.HandlerFunc, m ...echo.MiddlewareFunc) *echo.Route HEAD(path string, h echo.HandlerFunc, m ...echo.MiddlewareFunc) *echo.Route OPTIONS(path string, h echo.HandlerFunc, m ...echo.MiddlewareFunc) *echo.Route PATCH(path string, h echo.HandlerFunc, m ...echo.MiddlewareFunc) *echo.Route POST(path string, h echo.HandlerFunc, m ...echo.MiddlewareFunc) *echo.Route PUT(path string, h echo.HandlerFunc, m ...echo.MiddlewareFunc) *echo.Route TRACE(path string, h echo.HandlerFunc, m ...echo.MiddlewareFunc) *echo.Route } // RegisterHandlers adds each server route to the EchoRouter. func RegisterHandlers(router EchoRouter, si ServerInterface) { RegisterHandlersWithBaseURL(router, si, "") } // Registers handlers, and prepends BaseURL to the paths, so that the paths // can be served under a prefix. func RegisterHandlersWithBaseURL(router EchoRouter, si ServerInterface, baseURL string) { wrapper := ServerInterfaceWrapper{ Handler: si, } router.DELETE(baseURL+"/account", wrapper.DeleteAccount) router.GET(baseURL+"/account", wrapper.GetAccount) router.PATCH(baseURL+"/account", wrapper.ChangeAccount) router.POST(baseURL+"/account", wrapper.AddAccount) router.DELETE(baseURL+"/account/:userId", wrapper.DeleteDirectAccount) router.GET(baseURL+"/account/:userId", wrapper.GetDirectAccount) router.PATCH(baseURL+"/account/:userId", wrapper.SetAccountVerificationStatus) router.GET(baseURL+"/accounts", wrapper.PaginationAccounts) router.DELETE(baseURL+"/cart", wrapper.RemoveFromCart) router.PATCH(baseURL+"/cart", wrapper.Add2cart) router.POST(baseURL+"/cart/pay", wrapper.PayCart) router.GET(baseURL+"/currencies", wrapper.GetCurrencies) router.PUT(baseURL+"/currencies", wrapper.UpdateCurrencies) router.GET(baseURL+"/history", wrapper.GetHistory) router.PATCH(baseURL+"/wallet", wrapper.ChangeCurrency) router.POST(baseURL+"/wallet", wrapper.RequestMoney) } // Base64 encoded, gzipped, json marshaled Swagger object var swaggerSpec = []string{ "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", "aPw7AAD//x8jBLeBRgAA", } // GetSwagger returns the content of the embedded swagger specification file // or error if failed to decode func decodeSpec() ([]byte, error) { zipped, err := base64.StdEncoding.DecodeString(strings.Join(swaggerSpec, "")) if err != nil { return nil, fmt.Errorf("error base64 decoding spec: %s", err) } zr, err := gzip.NewReader(bytes.NewReader(zipped)) if err != nil { return nil, fmt.Errorf("error decompressing spec: %s", err) } var buf bytes.Buffer _, err = buf.ReadFrom(zr) if err != nil { return nil, fmt.Errorf("error decompressing spec: %s", err) } return buf.Bytes(), nil } var rawSpec = decodeSpecCached() // a naive cached of a decoded swagger spec func decodeSpecCached() func() ([]byte, error) { data, err := decodeSpec() return func() ([]byte, error) { return data, err } } // Constructs a synthetic filesystem for resolving external references when loading openapi specifications. func PathToRawSpec(pathToFile string) map[string]func() ([]byte, error) { var res = make(map[string]func() ([]byte, error)) if len(pathToFile) > 0 { res[pathToFile] = rawSpec } return res } // GetSwagger returns the Swagger specification corresponding to the generated code // in this file. The external references of Swagger specification are resolved. // The logic of resolving external references is tightly connected to "import-mapping" feature. // Externally referenced files must be embedded in the corresponding golang packages. // Urls can be supported but this task was out of the scope. func GetSwagger() (swagger *openapi3.T, err error) { var resolvePath = PathToRawSpec("") loader := openapi3.NewLoader() loader.IsExternalRefsAllowed = true loader.ReadFromURIFunc = func(loader *openapi3.Loader, url *url.URL) ([]byte, error) { var pathToFile = url.String() pathToFile = path.Clean(pathToFile) getSpec, ok := resolvePath[pathToFile] if !ok { err1 := fmt.Errorf("path not found: %s", pathToFile) return nil, err1 } return getSpec() } var specData []byte specData, err = rawSpec() if err != nil { return } swagger, err = loader.LoadFromData(specData) if err != nil { return } return }