2016-04-11 11:56:43 +08:00
// Copyright 2014 beego Author. All Rights Reserved.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
//
// Swagger™ is a project used to describe and document RESTful APIs.
//
// The Swagger specification defines a set of files required to describe such an API. These files can then be used by the Swagger-UI project to display the API and Swagger-Codegen to generate clients in various languages. Additional utilities can also take advantage of the resulting files, such as testing tools.
// Now in version 2.0, Swagger is more enabling than ever. And it's 100% open source software.
// Package swagger struct definition
package swagger
// Swagger list the resource
type Swagger struct {
2016-09-15 00:15:02 +03:00
SwaggerVersion string ` json:"swagger,omitempty" yaml:"swagger,omitempty" `
Infos Information ` json:"info" yaml:"info" `
Host string ` json:"host,omitempty" yaml:"host,omitempty" `
BasePath string ` json:"basePath,omitempty" yaml:"basePath,omitempty" `
Schemes [ ] string ` json:"schemes,omitempty" yaml:"schemes,omitempty" `
Consumes [ ] string ` json:"consumes,omitempty" yaml:"consumes,omitempty" `
Produces [ ] string ` json:"produces,omitempty" yaml:"produces,omitempty" `
Paths map [ string ] * Item ` json:"paths" yaml:"paths" `
Definitions map [ string ] Schema ` json:"definitions,omitempty" yaml:"definitions,omitempty" `
SecurityDefinitions map [ string ] Security ` json:"securityDefinitions,omitempty" yaml:"securityDefinitions,omitempty" `
Security map [ string ] [ ] string ` json:"security,omitempty" yaml:"security,omitempty" `
Tags [ ] Tag ` json:"tags,omitempty" yaml:"tags,omitempty" `
ExternalDocs * ExternalDocs ` json:"externalDocs,omitempty" yaml:"externalDocs,omitempty" `
2016-04-11 11:56:43 +08:00
}
// Information Provides metadata about the API. The metadata can be used by the clients if needed.
type Information struct {
2016-09-15 00:15:02 +03:00
Title string ` json:"title,omitempty" yaml:"title,omitempty" `
Description string ` json:"description,omitempty" yaml:"description,omitempty" `
Version string ` json:"version,omitempty" yaml:"version,omitempty" `
TermsOfService string ` json:"termsOfService,omitempty" yaml:"termsOfService,omitempty" `
2016-04-11 11:56:43 +08:00
2016-09-15 00:15:02 +03:00
Contact Contact ` json:"contact,omitempty" yaml:"contact,omitempty" `
License * License ` json:"license,omitempty" yaml:"license,omitempty" `
2016-04-11 11:56:43 +08:00
}
// Contact information for the exposed API.
type Contact struct {
2016-09-15 00:15:02 +03:00
Name string ` json:"name,omitempty" yaml:"name,omitempty" `
URL string ` json:"url,omitempty" yaml:"url,omitempty" `
EMail string ` json:"email,omitempty" yaml:"email,omitempty" `
2016-04-11 11:56:43 +08:00
}
// License information for the exposed API.
type License struct {
2016-09-15 00:15:02 +03:00
Name string ` json:"name,omitempty" yaml:"name,omitempty" `
URL string ` json:"url,omitempty" yaml:"url,omitempty" `
2016-04-11 11:56:43 +08:00
}
// Item Describes the operations available on a single path.
type Item struct {
2016-09-15 00:15:02 +03:00
Ref string ` json:"$ref,omitempty" yaml:"$ref,omitempty" `
Get * Operation ` json:"get,omitempty" yaml:"get,omitempty" `
Put * Operation ` json:"put,omitempty" yaml:"put,omitempty" `
Post * Operation ` json:"post,omitempty" yaml:"post,omitempty" `
Delete * Operation ` json:"delete,omitempty" yaml:"delete,omitempty" `
Options * Operation ` json:"options,omitempty" yaml:"options,omitempty" `
Head * Operation ` json:"head,omitempty" yaml:"head,omitempty" `
Patch * Operation ` json:"patch,omitempty" yaml:"patch,omitempty" `
2016-04-11 11:56:43 +08:00
}
// Operation Describes a single API operation on a path.
type Operation struct {
2016-09-15 00:15:02 +03:00
Tags [ ] string ` json:"tags,omitempty" yaml:"tags,omitempty" `
Summary string ` json:"summary,omitempty" yaml:"summary,omitempty" `
Description string ` json:"description,omitempty" yaml:"description,omitempty" `
OperationID string ` json:"operationId,omitempty" yaml:"operationId,omitempty" `
Consumes [ ] string ` json:"consumes,omitempty" yaml:"consumes,omitempty" `
Produces [ ] string ` json:"produces,omitempty" yaml:"produces,omitempty" `
Schemes [ ] string ` json:"schemes,omitempty" yaml:"schemes,omitempty" `
Parameters [ ] Parameter ` json:"parameters,omitempty" yaml:"parameters,omitempty" `
Responses map [ string ] Response ` json:"responses,omitempty" yaml:"responses,omitempty" `
Deprecated bool ` json:"deprecated,omitempty" yaml:"deprecated,omitempty" `
2016-04-11 11:56:43 +08:00
}
// Parameter Describes a single operation parameter.
type Parameter struct {
2016-09-15 00:15:02 +03:00
In string ` json:"in,omitempty" yaml:"in,omitempty" `
Name string ` json:"name,omitempty" yaml:"name,omitempty" `
Description string ` json:"description,omitempty" yaml:"description,omitempty" `
Required bool ` json:"required,omitempty" yaml:"required,omitempty" `
Schema * Schema ` json:"schema,omitempty" yaml:"schema,omitempty" `
Type string ` json:"type,omitempty" yaml:"type,omitempty" `
Format string ` json:"format,omitempty" yaml:"format,omitempty" `
Items * ParameterItems ` json:"items,omitempty" yaml:"items,omitempty" `
2016-10-29 22:33:57 +08:00
Default interface { } ` json:"default,omitempty" yaml:"default,omitempty" `
2016-08-20 11:22:03 +08:00
}
// A limited subset of JSON-Schema's items object. It is used by parameter definitions that are not located in "body".
// http://swagger.io/specification/#itemsObject
type ParameterItems struct {
2016-09-15 00:15:02 +03:00
Type string ` json:"type,omitempty" yaml:"type,omitempty" `
Format string ` json:"format,omitempty" yaml:"format,omitempty" `
Items [ ] * ParameterItems ` json:"items,omitempty" yaml:"items,omitempty" ` //Required if type is "array". Describes the type of items in the array.
CollectionFormat string ` json:"collectionFormat,omitempty" yaml:"collectionFormat,omitempty" `
Default string ` json:"default,omitempty" yaml:"default,omitempty" `
2016-04-11 11:56:43 +08:00
}
// Schema Object allows the definition of input and output data types.
type Schema struct {
2016-09-15 00:15:02 +03:00
Ref string ` json:"$ref,omitempty" yaml:"$ref,omitempty" `
Title string ` json:"title,omitempty" yaml:"title,omitempty" `
Format string ` json:"format,omitempty" yaml:"format,omitempty" `
Description string ` json:"description,omitempty" yaml:"description,omitempty" `
Required [ ] string ` json:"required,omitempty" yaml:"required,omitempty" `
Type string ` json:"type,omitempty" yaml:"type,omitempty" `
Items * Schema ` json:"items,omitempty" yaml:"items,omitempty" `
Properties map [ string ] Propertie ` json:"properties,omitempty" yaml:"properties,omitempty" `
2016-04-11 11:56:43 +08:00
}
// Propertie are taken from the JSON Schema definition but their definitions were adjusted to the Swagger Specification
type Propertie struct {
2016-09-15 00:15:02 +03:00
Ref string ` json:"$ref,omitempty" yaml:"$ref,omitempty" `
Title string ` json:"title,omitempty" yaml:"title,omitempty" `
Description string ` json:"description,omitempty" yaml:"description,omitempty" `
2016-10-08 11:28:47 +03:00
Default interface { } ` json:"default,omitempty" yaml:"default,omitempty" `
2016-09-15 00:15:02 +03:00
Type string ` json:"type,omitempty" yaml:"type,omitempty" `
Example string ` json:"example,omitempty" yaml:"example,omitempty" `
Required [ ] string ` json:"required,omitempty" yaml:"required,omitempty" `
Format string ` json:"format,omitempty" yaml:"format,omitempty" `
ReadOnly bool ` json:"readOnly,omitempty" yaml:"readOnly,omitempty" `
Properties map [ string ] Propertie ` json:"properties,omitempty" yaml:"properties,omitempty" `
Items * Propertie ` json:"items,omitempty" yaml:"items,omitempty" `
AdditionalProperties * Propertie ` json:"additionalProperties,omitempty" yaml:"additionalProperties,omitempty" `
2016-04-11 11:56:43 +08:00
}
// Response as they are returned from executing this operation.
type Response struct {
2016-09-15 00:15:02 +03:00
Description string ` json:"description,omitempty" yaml:"description,omitempty" `
Schema * Schema ` json:"schema,omitempty" yaml:"schema,omitempty" `
Ref string ` json:"$ref,omitempty" yaml:"$ref,omitempty" `
2016-04-11 11:56:43 +08:00
}
2016-09-14 23:36:38 +03:00
// Security Allows the definition of a security scheme that can be used by the operations
type Security struct {
2016-09-15 00:15:02 +03:00
Type string ` json:"type,omitempty" yaml:"type,omitempty" ` // Valid values are "basic", "apiKey" or "oauth2".
Description string ` json:"description,omitempty" yaml:"description,omitempty" `
Name string ` json:"name,omitempty" yaml:"name,omitempty" `
In string ` json:"in,omitempty" yaml:"in,omitempty" ` // Valid values are "query" or "header".
Flow string ` json:"flow,omitempty" yaml:"flow,omitempty" ` // Valid values are "implicit", "password", "application" or "accessCode".
AuthorizationURL string ` json:"authorizationUrl,omitempty" yaml:"authorizationUrl,omitempty" `
TokenURL string ` json:"tokenUrl,omitempty" yaml:"tokenUrl,omitempty" `
Scopes map [ string ] string ` json:"scopes,omitempty" yaml:"scopes,omitempty" ` // The available scopes for the OAuth2 security scheme.
2016-04-11 11:56:43 +08:00
}
// Tag Allows adding meta data to a single tag that is used by the Operation Object
type Tag struct {
2016-09-15 00:15:02 +03:00
Name string ` json:"name,omitempty" yaml:"name,omitempty" `
Description string ` json:"description,omitempty" yaml:"description,omitempty" `
ExternalDocs * ExternalDocs ` json:"externalDocs,omitempty" yaml:"externalDocs,omitempty" `
2016-04-11 11:56:43 +08:00
}
// ExternalDocs include Additional external documentation
type ExternalDocs struct {
2016-09-15 00:15:02 +03:00
Description string ` json:"description,omitempty" yaml:"description,omitempty" `
URL string ` json:"url,omitempty" yaml:"url,omitempty" `
2016-04-11 11:56:43 +08:00
}