customer/internal/swagger/api.gen.go

504 lines
20 KiB
Go
Raw Normal View History

2023-05-17 03:39:29 +00:00
// Package swagger provides primitives to interact with the openapi HTTP API.
2023-05-16 04:01:55 +00:00
//
// 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
2023-05-17 03:39:29 +00:00
// Создать новый аккаунт
2023-05-16 04:01:55 +00:00
// (POST /account)
AddAccount(ctx echo.Context) error
2023-05-17 03:39:29 +00:00
// Удалить аккаунт по айди
2023-05-17 20:27:09 +00:00
// (DELETE /account/{userId})
DeleteDirectAccount(ctx echo.Context, userId string) error
// Получить аккаунт по ID пользователя системы единой авторизации
// (GET /account/{userId})
GetDirectAccount(ctx echo.Context, userId string) error
2023-05-16 04:01:55 +00:00
// списко аккаунтов с пагинацией
// (GET /accounts)
PaginationAccounts(ctx echo.Context, params PaginationAccountsParams) error
2023-05-17 03:39:29 +00:00
// Удаляем из корзины тариф
2023-05-16 04:01:55 +00:00
// (DELETE /cart)
RemoveFromCart(ctx echo.Context, params RemoveFromCartParams) error
2023-05-17 03:39:29 +00:00
// Добавляем в корзину тариф
// (PATCH /cart)
2023-05-19 09:08:15 +00:00
Add2cart(ctx echo.Context, params Add2cartParams) error
2023-05-16 04:01:55 +00:00
// оплатить козину
// (POST /cart/pay)
PayCart(ctx echo.Context) error
// получить список одобренных валют
// (GET /currencies)
GetCurrencies(ctx echo.Context) error
// обновляет список одобренных валют
2023-05-17 03:39:29 +00:00
// (PUT /currencies)
2023-05-16 04:01:55 +00:00
UpdateCurrencies(ctx echo.Context) error
2023-05-17 03:39:29 +00:00
// Получение лога событий связанных с аккаунтом
2023-05-16 04:01:55 +00:00
// (GET /history)
GetHistory(ctx echo.Context, params GetHistoryParams) error
2023-05-17 03:39:29 +00:00
// Публикация лога в истории
2023-05-16 04:01:55 +00:00
// (POST /history)
Add2history(ctx echo.Context) error
2023-05-17 03:39:29 +00:00
// Запрос на получение ссылки на оплату
// (GET /wallet)
RequestMoney(ctx echo.Context, params RequestMoneyParams) error
// Изменить валюту кошелька
2023-05-16 04:01:55 +00:00
// (PATCH /wallet)
ChangeCurrency(ctx echo.Context) error
2023-05-17 03:39:29 +00:00
// Зачислить деньги на кошелёк
2023-05-16 04:01:55 +00:00
// (POST /wallet)
PutMoney(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
2023-05-17 03:39:29 +00:00
ctx.Set(BearerScopes, []string{""})
2023-05-16 04:01:55 +00:00
// 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
2023-05-17 03:39:29 +00:00
ctx.Set(BearerScopes, []string{""})
2023-05-16 04:01:55 +00:00
// Invoke the callback with all the unmarshalled arguments
err = w.Handler.GetAccount(ctx)
return err
}
// AddAccount converts echo context to params.
func (w *ServerInterfaceWrapper) AddAccount(ctx echo.Context) error {
var err error
2023-05-17 03:39:29 +00:00
ctx.Set(BearerScopes, []string{""})
2023-05-16 04:01:55 +00:00
// 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
2023-05-17 20:27:09 +00:00
// ------------- Path parameter "userId" -------------
var userId string
2023-05-16 04:01:55 +00:00
2023-05-17 20:27:09 +00:00
err = runtime.BindStyledParameterWithLocation("simple", false, "userId", runtime.ParamLocationPath, ctx.Param("userId"), &userId)
2023-05-16 04:01:55 +00:00
if err != nil {
2023-05-17 20:27:09 +00:00
return echo.NewHTTPError(http.StatusBadRequest, fmt.Sprintf("Invalid format for parameter userId: %s", err))
2023-05-16 04:01:55 +00:00
}
2023-05-17 03:39:29 +00:00
ctx.Set(BearerScopes, []string{""})
2023-05-16 04:01:55 +00:00
// Invoke the callback with all the unmarshalled arguments
2023-05-17 20:27:09 +00:00
err = w.Handler.DeleteDirectAccount(ctx, userId)
2023-05-16 04:01:55 +00:00
return err
}
// GetDirectAccount converts echo context to params.
func (w *ServerInterfaceWrapper) GetDirectAccount(ctx echo.Context) error {
var err error
2023-05-17 20:27:09 +00:00
// ------------- Path parameter "userId" -------------
var userId string
2023-05-16 04:01:55 +00:00
2023-05-17 20:27:09 +00:00
err = runtime.BindStyledParameterWithLocation("simple", false, "userId", runtime.ParamLocationPath, ctx.Param("userId"), &userId)
2023-05-16 04:01:55 +00:00
if err != nil {
2023-05-17 20:27:09 +00:00
return echo.NewHTTPError(http.StatusBadRequest, fmt.Sprintf("Invalid format for parameter userId: %s", err))
2023-05-16 04:01:55 +00:00
}
2023-05-17 03:39:29 +00:00
ctx.Set(BearerScopes, []string{""})
2023-05-16 04:01:55 +00:00
// Invoke the callback with all the unmarshalled arguments
2023-05-17 20:27:09 +00:00
err = w.Handler.GetDirectAccount(ctx, userId)
2023-05-16 04:01:55 +00:00
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
2023-05-17 03:39:29 +00:00
// ------------- Optional query parameter "page" -------------
2023-05-16 04:01:55 +00:00
2023-05-17 03:39:29 +00:00
err = runtime.BindQueryParameter("form", false, false, "page", ctx.QueryParams(), &params.Page)
2023-05-16 04:01:55 +00:00
if err != nil {
2023-05-17 03:39:29 +00:00
return echo.NewHTTPError(http.StatusBadRequest, fmt.Sprintf("Invalid format for parameter page: %s", err))
2023-05-16 04:01:55 +00:00
}
2023-05-17 03:39:29 +00:00
// ------------- Optional query parameter "limit" -------------
2023-05-16 04:01:55 +00:00
2023-05-17 03:39:29 +00:00
err = runtime.BindQueryParameter("form", false, false, "limit", ctx.QueryParams(), &params.Limit)
2023-05-16 04:01:55 +00:00
if err != nil {
2023-05-17 03:39:29 +00:00
return echo.NewHTTPError(http.StatusBadRequest, fmt.Sprintf("Invalid format for parameter limit: %s", err))
2023-05-16 04:01:55 +00:00
}
// 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
2023-05-17 03:39:29 +00:00
ctx.Set(BearerScopes, []string{""})
2023-05-16 04:01:55 +00:00
// 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(), &params.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
2023-05-17 03:39:29 +00:00
ctx.Set(BearerScopes, []string{""})
2023-05-19 09:08:15 +00:00
// 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(), &params.Id)
if err != nil {
return echo.NewHTTPError(http.StatusBadRequest, fmt.Sprintf("Invalid format for parameter id: %s", err))
}
2023-05-16 04:01:55 +00:00
// Invoke the callback with all the unmarshalled arguments
2023-05-19 09:08:15 +00:00
err = w.Handler.Add2cart(ctx, params)
2023-05-16 04:01:55 +00:00
return err
}
// PayCart converts echo context to params.
func (w *ServerInterfaceWrapper) PayCart(ctx echo.Context) error {
var err error
2023-05-17 03:39:29 +00:00
ctx.Set(BearerScopes, []string{""})
2023-05-16 04:01:55 +00:00
// 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
2023-05-17 20:27:09 +00:00
ctx.Set(BearerScopes, []string{""})
2023-05-16 04:01:55 +00:00
// 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
2023-05-17 03:39:29 +00:00
ctx.Set(BearerScopes, []string{""})
2023-05-16 04:01:55 +00:00
// Parameter object where we will unmarshal all parameters from the context
var params GetHistoryParams
2023-05-17 20:27:09 +00:00
// ------------- Optional query parameter "page" -------------
2023-05-16 04:01:55 +00:00
2023-05-17 20:27:09 +00:00
err = runtime.BindQueryParameter("form", false, false, "page", ctx.QueryParams(), &params.Page)
2023-05-16 04:01:55 +00:00
if err != nil {
2023-05-17 20:27:09 +00:00
return echo.NewHTTPError(http.StatusBadRequest, fmt.Sprintf("Invalid format for parameter page: %s", err))
2023-05-16 04:01:55 +00:00
}
2023-05-17 20:27:09 +00:00
// ------------- Optional query parameter "limit" -------------
2023-05-16 04:01:55 +00:00
2023-05-17 20:27:09 +00:00
err = runtime.BindQueryParameter("form", false, false, "limit", ctx.QueryParams(), &params.Limit)
2023-05-16 04:01:55 +00:00
if err != nil {
2023-05-17 20:27:09 +00:00
return echo.NewHTTPError(http.StatusBadRequest, fmt.Sprintf("Invalid format for parameter limit: %s", err))
2023-05-16 04:01:55 +00:00
}
// Invoke the callback with all the unmarshalled arguments
err = w.Handler.GetHistory(ctx, params)
return err
}
// Add2history converts echo context to params.
func (w *ServerInterfaceWrapper) Add2history(ctx echo.Context) error {
var err error
// Invoke the callback with all the unmarshalled arguments
err = w.Handler.Add2history(ctx)
return err
}
2023-05-17 03:39:29 +00:00
// RequestMoney converts echo context to params.
func (w *ServerInterfaceWrapper) RequestMoney(ctx echo.Context) error {
2023-05-16 04:01:55 +00:00
var err error
2023-05-17 03:39:29 +00:00
ctx.Set(BearerScopes, []string{""})
// Parameter object where we will unmarshal all parameters from the context
var params RequestMoneyParams
// ------------- Required query parameter "cash" -------------
err = runtime.BindQueryParameter("form", true, true, "cash", ctx.QueryParams(), &params.Cash)
if err != nil {
return echo.NewHTTPError(http.StatusBadRequest, fmt.Sprintf("Invalid format for parameter cash: %s", err))
}
2023-05-16 04:01:55 +00:00
// Invoke the callback with all the unmarshalled arguments
2023-05-17 03:39:29 +00:00
err = w.Handler.RequestMoney(ctx, params)
2023-05-16 04:01:55 +00:00
return err
}
2023-05-17 03:39:29 +00:00
// ChangeCurrency converts echo context to params.
func (w *ServerInterfaceWrapper) ChangeCurrency(ctx echo.Context) error {
2023-05-16 04:01:55 +00:00
var err error
2023-05-17 03:39:29 +00:00
ctx.Set(BearerScopes, []string{""})
2023-05-16 04:01:55 +00:00
// Invoke the callback with all the unmarshalled arguments
2023-05-17 03:39:29 +00:00
err = w.Handler.ChangeCurrency(ctx)
2023-05-16 04:01:55 +00:00
return err
}
// PutMoney converts echo context to params.
func (w *ServerInterfaceWrapper) PutMoney(ctx echo.Context) error {
var err error
2023-05-17 03:39:29 +00:00
ctx.Set(BearerScopes, []string{""})
2023-05-16 04:01:55 +00:00
// Invoke the callback with all the unmarshalled arguments
err = w.Handler.PutMoney(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.POST(baseURL+"/account", wrapper.AddAccount)
2023-05-17 20:27:09 +00:00
router.DELETE(baseURL+"/account/:userId", wrapper.DeleteDirectAccount)
router.GET(baseURL+"/account/:userId", wrapper.GetDirectAccount)
2023-05-16 04:01:55 +00:00
router.GET(baseURL+"/accounts", wrapper.PaginationAccounts)
router.DELETE(baseURL+"/cart", wrapper.RemoveFromCart)
2023-05-17 03:39:29 +00:00
router.PATCH(baseURL+"/cart", wrapper.Add2cart)
2023-05-16 04:01:55 +00:00
router.POST(baseURL+"/cart/pay", wrapper.PayCart)
router.GET(baseURL+"/currencies", wrapper.GetCurrencies)
2023-05-17 03:39:29 +00:00
router.PUT(baseURL+"/currencies", wrapper.UpdateCurrencies)
2023-05-16 04:01:55 +00:00
router.GET(baseURL+"/history", wrapper.GetHistory)
router.POST(baseURL+"/history", wrapper.Add2history)
2023-05-17 03:39:29 +00:00
router.GET(baseURL+"/wallet", wrapper.RequestMoney)
2023-05-16 04:01:55 +00:00
router.PATCH(baseURL+"/wallet", wrapper.ChangeCurrency)
2023-05-17 03:39:29 +00:00
router.POST(baseURL+"/wallet", wrapper.PutMoney)
2023-05-16 04:01:55 +00:00
}
// Base64 encoded, gzipped, json marshaled Swagger object
var swaggerSpec = []string{
2023-05-24 11:20:35 +00:00
"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",
2023-05-16 04:01:55 +00:00
}
// 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
}