Documentation ¶
Index ¶
- Constants
- type Api
- type ApiGroup
- type ApiRoot
- type ApiRouter
- type Contact
- type ExternalDocs
- type Header
- type Info
- type Items
- type JSONLink
- type JSONMedia
- type JSONSchema
- type JSONType
- type License
- type OAuth2FlowType
- type Operation
- type ParamInType
- type Parameter
- type Path
- type RawDefine
- type RawDefineDic
- type Response
- type Root
- func (r *Root) AddSecurityAPIKey(name, desc string, in SecurityInType) ApiRoot
- func (r *Root) AddSecurityBasic(name, desc string) ApiRoot
- func (r *Root) AddSecurityOAuth2(name, desc string, flow OAuth2FlowType, authorizationUrl, tokenUrl string, ...) ApiRoot
- func (r *Root) DELETE(path string, h echo.HandlerFunc, m ...echo.MiddlewareFunc) Api
- func (r *Root) Echo() *echo.Echo
- func (r *Root) GET(path string, h echo.HandlerFunc, m ...echo.MiddlewareFunc) Api
- func (r *Root) GetRaw() *Swagger
- func (r *Root) GetSpec(c echo.Context, docPath string) (Swagger, error)
- func (r *Root) Group(name, prefix string, m ...echo.MiddlewareFunc) ApiGroup
- func (r *Root) HEAD(path string, h echo.HandlerFunc, m ...echo.MiddlewareFunc) Api
- func (r *Root) OPTIONS(path string, h echo.HandlerFunc, m ...echo.MiddlewareFunc) Api
- func (r *Root) PATCH(path string, h echo.HandlerFunc, m ...echo.MiddlewareFunc) Api
- func (r *Root) POST(path string, h echo.HandlerFunc, m ...echo.MiddlewareFunc) Api
- func (r *Root) PUT(path string, h echo.HandlerFunc, m ...echo.MiddlewareFunc) Api
- func (r *Root) SetExternalDocs(desc, url string) ApiRoot
- func (r *Root) SetRaw(s *Swagger) ApiRoot
- func (r *Root) SetRequestContentType(types ...string) ApiRoot
- func (r *Root) SetResponseContentType(types ...string) ApiRoot
- func (r *Root) SetScheme(schemes ...string) ApiRoot
- func (r *Root) SetUI(ui UISetting) ApiRoot
- type Scope
- type SecurityDefinition
- type SecurityInType
- type SecurityType
- type Swagger
- type Tag
- type UISetting
- type XMLSchema
Constants ¶
const ( DefPrefix = "#/definitions/" SwaggerVersion = "2.0" SpecName = "swagger.json" )
const DefaultCDN = "https://cdn.jsdelivr.net/npm/swagger-ui-dist@3.22.1"
CDN refer to https://www.jsdelivr.com/package/npm/swagger-ui-dist
const SwaggerUIContent = `` /* 2257-byte string literal not displayed */
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type Api ¶
type Api interface { // AddParamPath adds path parameter. AddParamPath(p interface{}, name, desc string) Api // AddParamPathNested adds path parameters nested in p. // P must be struct type. AddParamPathNested(p interface{}) Api // AddParamQuery adds query parameter. AddParamQuery(p interface{}, name, desc string, required bool) Api // AddParamQueryNested adds query parameters nested in p. // P must be struct type. AddParamQueryNested(p interface{}) Api // AddParamForm adds formData parameter. AddParamForm(p interface{}, name, desc string, required bool) Api // AddParamFormNested adds formData parameters nested in p. // P must be struct type. AddParamFormNested(p interface{}) Api // AddParamHeader adds header parameter. AddParamHeader(p interface{}, name, desc string, required bool) Api // AddParamHeaderNested adds header parameters nested in p. // P must be struct type. AddParamHeaderNested(p interface{}) Api // AddParamBody adds body parameter. AddParamBody(p interface{}, name, desc string, required bool) Api // AddParamFile adds file parameter. AddParamFile(name, desc string, required bool) Api // AddResponse adds response for Api. // Header must be struct type. AddResponse(code int, desc string, schema interface{}, header interface{}) Api // SetRequestContentType sets request content types. SetRequestContentType(types ...string) Api // SetResponseContentType sets response content types. SetResponseContentType(types ...string) Api // SetOperationId sets operationId SetOperationId(id string) Api // SetDeprecated marks Api as deprecated. SetDeprecated() Api // SetDescription sets description. SetDescription(desc string) Api // SetExternalDocs sets external docs. SetExternalDocs(desc, url string) Api // SetSummary sets summary. SetSummary(summary string) Api // SetSecurity sets Security which names are reigistered // by AddSecurity... functions. SetSecurity(names ...string) Api // SetSecurityWithScope sets Security for Api which names are // reigistered by AddSecurity... functions. // Should only use when Security type is oauth2. SetSecurityWithScope(s map[string][]string) Api // Route returns the embedded `echo.Route` instance. Route() *echo.Route }
type ApiGroup ¶
type ApiGroup interface { ApiRouter // SetDescription sets description for ApiGroup. SetDescription(desc string) ApiGroup // SetExternalDocs sets external docs for ApiGroup. SetExternalDocs(desc, url string) ApiGroup // SetSecurity sets Security for all operations within the ApiGroup // which names are reigistered by AddSecurity... functions. SetSecurity(names ...string) ApiGroup // SetSecurityWithScope sets Security with scopes for all operations // within the ApiGroup which names are reigistered // by AddSecurity... functions. // Should only use when Security type is oauth2. SetSecurityWithScope(s map[string][]string) ApiGroup // EchoGroup returns the embedded `echo.Group` instance. EchoGroup() *echo.Group }
type ApiRoot ¶
type ApiRoot interface { ApiRouter // Group overrides `Echo#Group()` and creates ApiGroup. Group(name, prefix string, m ...echo.MiddlewareFunc) ApiGroup // SetRequestContentType sets request content types. SetRequestContentType(types ...string) ApiRoot // SetResponseContentType sets response content types. SetResponseContentType(types ...string) ApiRoot // SetExternalDocs sets external docs. SetExternalDocs(desc, url string) ApiRoot // AddSecurityBasic adds `SecurityDefinition` with type basic. AddSecurityBasic(name, desc string) ApiRoot // AddSecurityAPIKey adds `SecurityDefinition` with type apikey. AddSecurityAPIKey(name, desc string, in SecurityInType) ApiRoot // AddSecurityOAuth2 adds `SecurityDefinition` with type oauth2. AddSecurityOAuth2(name, desc string, flow OAuth2FlowType, authorizationUrl, tokenUrl string, scopes map[string]string) ApiRoot // SetUI sets UI setting. // If DetachSpec is false, HideTop will not take effect SetUI(ui UISetting) ApiRoot // SetScheme sets available protocol schemes. SetScheme(schemes ...string) ApiRoot // GetRaw returns raw `Swagger`. Only special case should use. GetRaw() *Swagger // SetRaw sets raw `Swagger` to ApiRoot. Only special case should use. SetRaw(s *Swagger) ApiRoot // Echo returns the embedded Echo instance Echo() *echo.Echo }
type ApiRouter ¶
type ApiRouter interface { // GET overrides `Echo#GET()` and creates Api. GET(path string, h echo.HandlerFunc, m ...echo.MiddlewareFunc) Api // POST overrides `Echo#POST()` and creates Api. POST(path string, h echo.HandlerFunc, m ...echo.MiddlewareFunc) Api // PUT overrides `Echo#PUT()` and creates Api. PUT(path string, h echo.HandlerFunc, m ...echo.MiddlewareFunc) Api // DELETE overrides `Echo#DELETE()` and creates Api. DELETE(path string, h echo.HandlerFunc, m ...echo.MiddlewareFunc) Api // OPTIONS overrides `Echo#OPTIONS()` and creates Api. OPTIONS(path string, h echo.HandlerFunc, m ...echo.MiddlewareFunc) Api // HEAD overrides `Echo#HEAD()` and creates Api. HEAD(path string, h echo.HandlerFunc, m ...echo.MiddlewareFunc) Api // PATCH overrides `Echo#PATCH()` and creates Api. PATCH(path string, h echo.HandlerFunc, m ...echo.MiddlewareFunc) Api }
type Contact ¶
type Contact struct { // Name of the contact person/organization Name string `json:"name,omitempty"` // Email address of the contact person/organization Email string `json:"email,omitempty"` // URL pointing to the contact information URL string `json:"url,omitempty"` }
Contact contains the API contact information.
type ExternalDocs ¶
type ExternalDocs struct { // Description is a short description of the target documentation. // GFM syntax can be used for rich text representation. Description string `json:"description,omitempty"` // URL for the target documentation. URL string `json:"url"` }
ExternalDocs allows referencing an external resource for extended documentation.
type Header ¶
type Header struct { // Description is`a brief description of the parameter. // GFM syntax can be used for rich text representation. Description string `json:"description,omitempty"` // Type of the header. it is limited to simple types (that is, not an object). Type string `json:"type,omitempty"` // Format is the extending format for the previously mentioned type. Format string `json:"format,omitempty"` // Items describes the type of items in the array if type is "array". Items *Items `json:"items,omitempty"` // CollectionFormat determines the format of the array if type array is used. // Possible values are csv, ssv, tsv, pipes and multi. CollectionFormat string `json:"collectionFormat,omitempty"` // Default declares the value of the parameter that the server will use if none is // provided, for example a "count" to control the number of results per page might // default to 100 if not supplied by the client in the request. Default interface{} `json:"default,omitempty"` Maximum *float64 `json:"maximum,omitempty"` ExclusiveMaximum bool `json:"exclusiveMaximum,omitempty"` Minimum *float64 `json:"minimum,omitempty"` ExclusiveMinimum bool `json:"exclusiveMinimum,omitempty"` MaxLength *int `json:"maxLength,omitempty"` MinLength *int `json:"minLength,omitempty"` Pattern string `json:"pattern,omitempty"` MaxItems *int `json:"maxItems,omitempty"` MinItems *int `json:"minItems,omitempty"` UniqueItems bool `json:"uniqueItems,omitempty"` Enum []interface{} `json:"enum,omitempty"` MultipleOf float64 `json:"multipleOf,omitempty"` }
Header represents a header parameter.
type Info ¶
type Info struct { Title string `json:"title,omitempty"` Description string `json:"description,omitempty"` TermsOfService string `json:"termsOfService,omitempty"` Contact *Contact `json:"contact,omitempty"` License *License `json:"license,omitempty"` Version string `json:"version"` Extensions map[string]interface{} `json:"-"` }
Info provides metadata about the API. The metadata can be used by the clients if needed, and can be presented in the Swagger-UI for convenience.
type Items ¶
type Items struct { // Type of the items. it is limited to simple types (that is, not an object). Type string `json:"type,omitempty"` // Format is the extending format for the previously mentioned type. Format string `json:"format,omitempty"` // Items describes the type of items in the array if type is "array". Items *Items `json:"items,omitempty"` // CollectionFormat determines the format of the array if type array is used. // Possible values are csv, ssv, tsv, pipes and multi. CollectionFormat string `json:"collectionFormat,omitempty"` // Default declares the value of the parameter that the server will use if none is // provided, for example a "count" to control the number of results per page might // default to 100 if not supplied by the client in the request. Default interface{} `json:"default,omitempty"` Maximum *float64 `json:"maximum,omitempty"` ExclusiveMaximum bool `json:"exclusiveMaximum,omitempty"` Minimum *float64 `json:"minimum,omitempty"` ExclusiveMinimum bool `json:"exclusiveMinimum,omitempty"` MaxLength *int `json:"maxLength,omitempty"` MinLength *int `json:"minLength,omitempty"` Pattern string `json:"pattern,omitempty"` MaxItems *int `json:"maxItems,omitempty"` MinItems *int `json:"minItems,omitempty"` UniqueItems bool `json:"uniqueItems,omitempty"` Enum []interface{} `json:"enum,omitempty"` MultipleOf float64 `json:"multipleOf,omitempty"` }
Items is a limited subset of JSON-Schema's items object. It is used by parameter definitions that are not located in "body".
type JSONLink ¶
type JSONLink struct { Title string `json:"title,omitempty"` Description string `json:"description,omitempty"` Rel string `json:"rel,omitempty"` Href string `json:"href,omitempty"` Method string `json:"method,omitempty"` Schema *JSONSchema `json:"schema,omitempty"` TargetSchema *JSONSchema `json:"targetSchema,omitempty"` MediaType string `json:"mediaType,omitempty"` EncType string `json:"encType,omitempty"` }
JSONLink represents a "link" field in a JSON hyper schema.
type JSONMedia ¶
type JSONMedia struct { BinaryEncoding string `json:"binaryEncoding,omitempty"` Type string `json:"type,omitempty"` }
JSONMedia represents a "media" field in a JSON hyper schema.
type JSONSchema ¶
type JSONSchema struct { Schema string `json:"$schema,omitempty"` // Core schema ID string `json:"id,omitempty"` Title string `json:"title,omitempty"` Type JSONType `json:"type,omitempty"` Items *JSONSchema `json:"items,omitempty"` Properties map[string]*JSONSchema `json:"properties,omitempty"` Definitions map[string]*JSONSchema `json:"definitions,omitempty"` Description string `json:"description,omitempty"` DefaultValue interface{} `json:"default,omitempty"` Example interface{} `json:"example,omitempty"` // Hyper schema Media *JSONMedia `json:"media,omitempty"` ReadOnly bool `json:"readOnly,omitempty"` Ref string `json:"$ref,omitempty"` XML *XMLSchema `json:"xml,omitempty"` // Validation Enum []interface{} `json:"enum,omitempty"` Format string `json:"format,omitempty"` Pattern string `json:"pattern,omitempty"` Minimum *float64 `json:"minimum,omitempty"` Maximum *float64 `json:"maximum,omitempty"` MinLength *int `json:"minLength,omitempty"` MaxLength *int `json:"maxLength,omitempty"` Required []string `json:"required,omitempty"` AdditionalProperties *JSONSchema `json:"additionalProperties,omitempty"` // Union AnyOf []*JSONSchema `json:"anyOf,omitempty"` }
type License ¶
type License struct { // Name of license used for the API Name string `json:"name,omitempty"` // URL to the license used for the API URL string `json:"url,omitempty"` }
License contains the license information for the API.
type OAuth2FlowType ¶
type OAuth2FlowType string
const ( OAuth2FlowImplicit OAuth2FlowType = "implicit" OAuth2FlowPassword OAuth2FlowType = "password" OAuth2FlowApplication OAuth2FlowType = "application" OAuth2FlowAccessCode OAuth2FlowType = "accessCode" )
type Operation ¶
type Operation struct { // Tags is a list of tags for API documentation control. Tags can be used for // logical grouping of operations by resources or any other qualifier. Tags []string `json:"tags,omitempty"` // Summary is a short summary of what the operation does. For maximum readability // in the swagger-ui, this field should be less than 120 characters. Summary string `json:"summary,omitempty"` // Description is a verbose explanation of the operation behavior. // GFM syntax can be used for rich text representation. Description string `json:"description,omitempty"` // ExternalDocs points to additional external documentation for this operation. ExternalDocs *ExternalDocs `json:"externalDocs,omitempty"` // OperationID is a unique string used to identify the operation. OperationID string `json:"operationId,omitempty"` // Consumes is a list of MIME types the operation can consume. Consumes []string `json:"consumes,omitempty"` // Produces is a list of MIME types the operation can produce. Produces []string `json:"produces,omitempty"` // Parameters is a list of parameters that are applicable for this operation. Parameters []*Parameter `json:"parameters,omitempty"` // Responses is the list of possible responses as they are returned from executing // this operation. Responses map[string]*Response `json:"responses,omitempty"` // Schemes is the transfer protocol for the operation. Schemes []string `json:"schemes,omitempty"` // Deprecated declares this operation to be deprecated. Deprecated bool `json:"deprecated,omitempty"` // Secury is a declaration of which security schemes are applied for this operation. Security []map[string][]string `json:"security,omitempty"` // Extensions defines the swagger extensions. Extensions map[string]interface{} `json:"-"` }
Operation describes a single API operation on a path.
type ParamInType ¶
type ParamInType string
const ( ParamInQuery ParamInType = "query" ParamInHeader ParamInType = "header" ParamInPath ParamInType = "path" ParamInFormData ParamInType = "formData" ParamInBody ParamInType = "body" )
type Parameter ¶
type Parameter struct { // Name of the parameter. Parameter names are case sensitive. Name string `json:"name"` // In is the location of the parameter. // Possible values are "query", "header", "path", "formData" or "body". In string `json:"in"` // Description is`a brief description of the parameter. // GFM syntax can be used for rich text representation. Description string `json:"description,omitempty"` // Required determines whether this parameter is mandatory. Required bool `json:"required"` // Schema defining the type used for the body parameter, only if "in" is body Schema *JSONSchema `json:"schema,omitempty"` // Type of the parameter. Since the parameter is not located at the request body, // it is limited to simple types (that is, not an object). Type string `json:"type,omitempty"` // Format is the extending format for the previously mentioned type. Format string `json:"format,omitempty"` // AllowEmptyValue sets the ability to pass empty-valued parameters. // This is valid only for either query or formData parameters and allows you to // send a parameter with a name only or an empty value. Default value is false. AllowEmptyValue bool `json:"allowEmptyValue,omitempty"` // Items describes the type of items in the array if type is "array". Items *Items `json:"items,omitempty"` // CollectionFormat determines the format of the array if type array is used. // Possible values are csv, ssv, tsv, pipes and multi. CollectionFormat string `json:"collectionFormat,omitempty"` // Default declares the value of the parameter that the server will use if none is // provided, for example a "count" to control the number of results per page might // default to 100 if not supplied by the client in the request. Default interface{} `json:"default,omitempty"` Maximum *float64 `json:"maximum,omitempty"` ExclusiveMaximum bool `json:"exclusiveMaximum,omitempty"` Minimum *float64 `json:"minimum,omitempty"` ExclusiveMinimum bool `json:"exclusiveMinimum,omitempty"` MaxLength *int `json:"maxLength,omitempty"` MinLength *int `json:"minLength,omitempty"` Pattern string `json:"pattern,omitempty"` MaxItems *int `json:"maxItems,omitempty"` MinItems *int `json:"minItems,omitempty"` UniqueItems bool `json:"uniqueItems,omitempty"` Enum []interface{} `json:"enum,omitempty"` MultipleOf float64 `json:"multipleOf,omitempty"` // Extensions defines the swagger extensions. Extensions map[string]interface{} `json:"-"` }
Parameter describes a single operation parameter.
type Path ¶
type Path struct { // Ref allows for an external definition of this path item. Ref string `json:"$ref,omitempty"` // Get defines a GET operation on this path. Get *Operation `json:"get,omitempty"` // Put defines a PUT operation on this path. Put *Operation `json:"put,omitempty"` // Post defines a POST operation on this path. Post *Operation `json:"post,omitempty"` // Delete defines a DELETE operation on this path. Delete *Operation `json:"delete,omitempty"` // Options defines a OPTIONS operation on this path. Options *Operation `json:"options,omitempty"` // Head defines a HEAD operation on this path. Head *Operation `json:"head,omitempty"` // Patch defines a PATCH operation on this path. Patch *Operation `json:"patch,omitempty"` // Parameters is the list of parameters that are applicable for all the operations // described under this path. Parameters []*Parameter `json:"parameters,omitempty"` // Extensions defines the swagger extensions. Extensions map[string]interface{} `json:"-"` }
Path holds the relative paths to the individual endpoints.
type RawDefine ¶
type RawDefine struct { Value reflect.Value Schema *JSONSchema }
type RawDefineDic ¶
type Response ¶
type Response struct { // Description of the response. GFM syntax can be used for rich text representation. Description string `json:"description,omitempty"` // Schema is a definition of the response structure. It can be a primitive, // an array or an object. If this field does not exist, it means no content is // returned as part of the response. As an extension to the Schema Object, its root // type value may also be "file". Schema *JSONSchema `json:"schema,omitempty"` // Headers is a list of headers that are sent with the response. Headers map[string]*Header `json:"headers,omitempty"` // Ref references a global API response. // This field is exclusive with the other fields of Response. Ref string `json:"$ref,omitempty"` // Extensions defines the swagger extensions. Extensions map[string]interface{} `json:"-"` }
Response describes an operation response.
type Root ¶
type Root struct {
// contains filtered or unexported fields
}
func (*Root) AddSecurityAPIKey ¶
func (r *Root) AddSecurityAPIKey(name, desc string, in SecurityInType) ApiRoot
func (*Root) AddSecurityBasic ¶
func (*Root) AddSecurityOAuth2 ¶
func (*Root) SetExternalDocs ¶
func (*Root) SetRequestContentType ¶
func (*Root) SetResponseContentType ¶
type Scope ¶
type Scope struct { // Description for scope Description string `json:"description,omitempty"` }
Scope corresponds to an available scope for an OAuth2 security scheme.
type SecurityDefinition ¶
type SecurityDefinition struct { // Type of the security scheme. Valid values are "basic", "apiKey" or "oauth2". Type string `json:"type"` // Description for security scheme Description string `json:"description,omitempty"` // Name of the header or query parameter to be used when type is "apiKey". Name string `json:"name,omitempty"` // In is the location of the API key when type is "apiKey". // Valid values are "query" or "header". In string `json:"in,omitempty"` // Flow is the flow used by the OAuth2 security scheme when type is "oauth2" // Valid values are "implicit", "password", "application" or "accessCode". Flow string `json:"flow,omitempty"` // The oauth2 authorization URL to be used for this flow. AuthorizationURL string `json:"authorizationUrl,omitempty"` // TokenURL is the token URL to be used for this flow. TokenURL string `json:"tokenUrl,omitempty"` // Scopes list the available scopes for the OAuth2 security scheme. Scopes map[string]string `json:"scopes,omitempty"` // Extensions defines the swagger extensions. Extensions map[string]interface{} `json:"-"` }
SecurityDefinition allows the definition of a security scheme that can be used by the operations. Supported schemes are basic authentication, an API key (either as a header or as a query parameter) and OAuth2's common flows (implicit, password, application and access code).
type SecurityInType ¶
type SecurityInType string
const ( SecurityInQuery SecurityInType = "query" SecurityInHeader SecurityInType = "header" )
type SecurityType ¶
type SecurityType string
const ( SecurityBasic SecurityType = "basic" SecurityOAuth2 SecurityType = "oauth2" SecurityAPIKey SecurityType = "apiKey" )
type Swagger ¶
type Swagger struct { Swagger string `json:"swagger,omitempty"` Info *Info `json:"info,omitempty"` Host string `json:"host,omitempty"` BasePath string `json:"basePath,omitempty"` Schemes []string `json:"schemes,omitempty"` Consumes []string `json:"consumes,omitempty"` Produces []string `json:"produces,omitempty"` Paths map[string]interface{} `json:"paths"` Definitions map[string]*JSONSchema `json:"definitions,omitempty"` Parameters map[string]*Parameter `json:"parameters,omitempty"` Responses map[string]*Response `json:"responses,omitempty"` SecurityDefinitions map[string]*SecurityDefinition `json:"securityDefinitions,omitempty"` Tags []*Tag `json:"tags,omitempty"` ExternalDocs *ExternalDocs `json:"externalDocs,omitempty"` }
Swagger represents an instance of a swagger object. See https://swagger.io/specification/
type Tag ¶
type Tag struct { // Name of the tag. Name string `json:"name,omitempty"` // Description is a short description of the tag. // GFM syntax can be used for rich text representation. Description string `json:"description,omitempty"` // ExternalDocs is additional external documentation for this tag. ExternalDocs *ExternalDocs `json:"externalDocs,omitempty"` // Extensions defines the swagger extensions. Extensions map[string]interface{} `json:"-"` }
Tag allows adding meta data to a single tag that is used by the Operation Object. It is not mandatory to have a Tag Object per tag used there.