// Package swagger provides primitives to interact with the openapi HTTP API. // // Code generated by github.com/deepmap/oapi-codegen/v2 version v2.0.0 DO NOT EDIT. package swagger import ( "bytes" "compress/gzip" "encoding/base64" "fmt" "net/http" "net/url" "path" "strings" "github.com/getkin/kin-openapi/openapi3" "github.com/labstack/echo/v4" "github.com/oapi-codegen/runtime" ) // 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 // Расчет среднего времени жизни платящего клиента (LTV) // (POST /history/ltv) CalculateLTV(ctx echo.Context) error // Получение недавних тарифов // (GET /recent) GetRecentTariffs(ctx echo.Context) error // отправить акт проделанных работ на почту // (POST /sendReport) SendReport(ctx echo.Context) error // Изменить валюту кошелька // (PATCH /wallet) ChangeCurrency(ctx echo.Context) error // Запрос на получение ссылки на оплату // (POST /wallet) RequestMoney(ctx echo.Context) error // Обработка запроса RSPay // (POST /wallet/rspay) PostWalletRspay(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 unmarshaled 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 unmarshaled 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 unmarshaled 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 unmarshaled 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 unmarshaled 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 unmarshaled 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 unmarshaled 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 unmarshaled 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 unmarshaled 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 unmarshaled 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 unmarshaled 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 unmarshaled 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 unmarshaled 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)) } // ------------- Optional query parameter "type" ------------- err = runtime.BindQueryParameter("form", false, false, "type", ctx.QueryParams(), ¶ms.Type) if err != nil { return echo.NewHTTPError(http.StatusBadRequest, fmt.Sprintf("Invalid format for parameter type: %s", err)) } // ------------- Optional query parameter "accountID" ------------- err = runtime.BindQueryParameter("form", false, false, "accountID", ctx.QueryParams(), ¶ms.AccountID) if err != nil { return echo.NewHTTPError(http.StatusBadRequest, fmt.Sprintf("Invalid format for parameter accountID: %s", err)) } // Invoke the callback with all the unmarshaled arguments err = w.Handler.GetHistory(ctx, params) return err } // CalculateLTV converts echo context to params. func (w *ServerInterfaceWrapper) CalculateLTV(ctx echo.Context) error { var err error ctx.Set(BearerScopes, []string{}) // Invoke the callback with all the unmarshaled arguments err = w.Handler.CalculateLTV(ctx) return err } // GetRecentTariffs converts echo context to params. func (w *ServerInterfaceWrapper) GetRecentTariffs(ctx echo.Context) error { var err error ctx.Set(BearerScopes, []string{}) // Invoke the callback with all the unmarshaled arguments err = w.Handler.GetRecentTariffs(ctx) return err } // SendReport converts echo context to params. func (w *ServerInterfaceWrapper) SendReport(ctx echo.Context) error { var err error ctx.Set(BearerScopes, []string{}) // Invoke the callback with all the unmarshaled arguments err = w.Handler.SendReport(ctx) 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 unmarshaled 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 unmarshaled arguments err = w.Handler.RequestMoney(ctx) return err } // PostWalletRspay converts echo context to params. func (w *ServerInterfaceWrapper) PostWalletRspay(ctx echo.Context) error { var err error ctx.Set(BearerScopes, []string{}) // Invoke the callback with all the unmarshaled arguments err = w.Handler.PostWalletRspay(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.POST(baseURL+"/history/ltv", wrapper.CalculateLTV) router.GET(baseURL+"/recent", wrapper.GetRecentTariffs) router.POST(baseURL+"/sendReport", wrapper.SendReport) router.PATCH(baseURL+"/wallet", wrapper.ChangeCurrency) router.POST(baseURL+"/wallet", wrapper.RequestMoney) router.POST(baseURL+"/wallet/rspay", wrapper.PostWalletRspay) } // Base64 encoded, gzipped, json marshaled Swagger object var swaggerSpec = []string{ "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", } // 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: %w", err) } zr, err := gzip.NewReader(bytes.NewReader(zipped)) if err != nil { return nil, fmt.Errorf("error decompressing spec: %w", err) } var buf bytes.Buffer _, err = buf.ReadFrom(zr) if err != nil { return nil, fmt.Errorf("error decompressing spec: %w", 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) { 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) { resolvePath := PathToRawSpec("") loader := openapi3.NewLoader() loader.IsExternalRefsAllowed = true loader.ReadFromURIFunc = func(loader *openapi3.Loader, url *url.URL) ([]byte, error) { 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 }