// 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 // Получение недавних тарифов // (GET /recent) GetRecent(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 } // 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 } // GetRecent converts echo context to params. func (w *ServerInterfaceWrapper) GetRecent(ctx echo.Context) error { var err error ctx.Set(BearerScopes, []string{}) // Invoke the callback with all the unmarshaled arguments err = w.Handler.GetRecent(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 } // 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.GET(baseURL+"/recent", wrapper.GetRecent) router.POST(baseURL+"/sendReport", wrapper.SendReport) 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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", } // 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 }