Documentation ¶
Index ¶
- type Components
- type Contact
- type DataType
- type Encoding
- type Example
- type ExampleOrRef
- type FieldError
- type Generator
- func (g *Generator) API() *OpenAPI
- func (g *Generator) AddOperation(path, method, tag string, in, out reflect.Type, info *OperationInfo) (*Operation, error)
- func (g *Generator) AddTag(name, desc string)
- func (g *Generator) Errors() []error
- func (g *Generator) OverrideDataType(t reflect.Type, typ, format string) error
- func (g *Generator) OverrideTypeName(t reflect.Type, name string) error
- func (g *Generator) SetInfo(info *Info)
- func (g *Generator) SetSecurity(security *SecurityRequirement)
- func (g *Generator) SetServers(servers []*Server)
- func (g *Generator) SetSortParams(b bool)
- func (g *Generator) SetSortTags(b bool)
- func (g *Generator) UseFullSchemaNames(b bool)
- type Header
- type HeaderOrRef
- type Info
- type InternalDataType
- type License
- type MediaType
- type MediaTypeOrRef
- type OAuthFlow
- type OAuthFlows
- type OpenAPI
- type Operation
- type OperationInfo
- type OperationResponse
- type OverridedDataType
- type Parameter
- type ParameterOrRef
- type PathItem
- type Paths
- type Reference
- type RequestBody
- type Response
- type ResponseHeader
- type ResponseOrRef
- type Responses
- type Schema
- type SchemaOrRef
- type SecurityRequirement
- type SecurityScheme
- type SecuritySchemeOrRef
- type Server
- type ServerVariable
- type SpecGenConfig
- type Tag
- type TypeError
- type Typer
- type XCodeSample
- type XLogo
- type XTagGroup
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type Components ¶
type Components struct { Schemas map[string]*SchemaOrRef `json:"schemas,omitempty" yaml:"schemas,omitempty"` Responses map[string]*ResponseOrRef `json:"responses,omitempty" yaml:"responses,omitempty"` Parameters map[string]*ParameterOrRef `json:"parameters,omitempty" yaml:"parameters,omitempty"` Examples map[string]*ExampleOrRef `json:"examples,omitempty" yaml:"examples,omitempty"` Headers map[string]*HeaderOrRef `json:"headers,omitempty" yaml:"headers,omitempty"` SecuritySchemes map[string]*SecuritySchemeOrRef `json:"securitySchemes,omitempty" yaml:"securitySchemes,omitempty"` }
Components holds a set of reusable objects for different ascpects of the specification.
type Contact ¶
type Contact struct { Name string `json:"name,omitempty" yaml:"name,omitempty"` URL string `json:"url,omitempty" yaml:"url,omitempty"` Email string `json:"email,omitempty" yaml:"email,omitempty"` }
Contact represents the the contact informations exposed for an API.
type DataType ¶
DataType is the interface implemented by types that can describe their OAS3 data type and format.
func DataTypeFromType ¶
DataTypeFromType returns a DataType for the given type.
type Encoding ¶
type Encoding struct { ContentType string `json:"contentType,omitempty" yaml:"contentType,omitempty"` Headers map[string]*HeaderOrRef `json:"headers,omitempty" yaml:"headers,omitempty"` Style string `json:"style,omitempty" yaml:"style,omitempty"` Explode bool `json:"explode,omitempty" yaml:"explode,omitempty"` AllowReserved bool `json:"allowReserved,omitempty" yaml:"allowReserved,omitempty"` }
Encoding represents a single encoding definition applied to a single schema property.
type Example ¶
type Example struct { Summary string `json:"summary,omitempty" yaml:"summary,omitempty"` Description string `json:"description,omitempty" yaml:"description,omitempty"` Value interface{} `json:"value,omitempty" yaml:"value,omitempty"` ExternalValue string `json:"externalValue,omitempty" yaml:"externalValue,omitempty"` }
Example represents the exanple of a media type.
type ExampleOrRef ¶
ExampleOrRef represents an Example that can be inlined or referenced in the API description.
func (*ExampleOrRef) MarshalYAML ¶
func (eor *ExampleOrRef) MarshalYAML() (interface{}, error)
MarshalYAML implements yaml.Marshaler for ExampleOrRef.
type FieldError ¶
type FieldError struct { Name string TypeName string Type reflect.Type Message string ParameterLocation string Parent reflect.Type }
FieldError is the error returned when an error related to a field occurs.
func (*FieldError) Error ¶
func (fe *FieldError) Error() string
Error implements the builtin error interface for FieldError.
type Generator ¶
type Generator struct {
// contains filtered or unexported fields
}
Generator is an OpenAPI 3 generator.
func NewGenerator ¶
func NewGenerator(conf *SpecGenConfig) (*Generator, error)
NewGenerator returns a new OpenAPI generator.
func (*Generator) AddOperation ¶
func (g *Generator) AddOperation(path, method, tag string, in, out reflect.Type, info *OperationInfo) (*Operation, error)
AddOperation add a new operation to the OpenAPI specification using the method and path of the route and the tonic handler informations.
func (*Generator) AddTag ¶
AddTag adds a new tag to the OpenAPI specification. If a tag already exists with the same name, it is overwritten.
func (*Generator) Errors ¶
Errors returns the errors thar occurred during the generation of the specification.
func (*Generator) OverrideDataType ¶
OverrideDataType registers a custom schema type and format for the given type that will overrided the default generation.
func (*Generator) OverrideTypeName ¶
OverrideTypeName registers a custom name for a type that will override the default generation and have precedence over types that implements the Typer interface.
func (*Generator) SetSecurity ¶
func (g *Generator) SetSecurity(security *SecurityRequirement)
SetSecurity sets the security options for the current specification.
func (*Generator) SetServers ¶
SetServers sets the server list for the current specification.
func (*Generator) SetSortParams ¶
SetSortParams controls whether the generator should sort the parameters of an operation by location and name in ascending order.
func (*Generator) SetSortTags ¶
SetSortTags controls whether the generator should sort the global tags sections.
func (*Generator) UseFullSchemaNames ¶
UseFullSchemaNames defines whether the generator should generates a full name for the components using the package name of the type as a prefix. Omitting the package part of the name increases the risks of conflicts. It is the responsibility of the developper to ensure that unique type names are used across all the packages of the application. Default to true.
type Header ¶
type Header struct { Description string `json:"description,omitempty" yaml:"description,omitempty"` Required bool `json:"required,omitempty" yaml:"required,omitempty"` Deprecated bool `json:"deprecated,omitempty" yaml:"deprecated,omitempty"` AllowEmptyValue bool `json:"allowEmptyValue,omitempty" yaml:"allowEmptyValue,omitempty"` Schema *SchemaOrRef `json:"schema,omitempty" yaml:"schema,omitempty"` }
Header represents an HTTP header.
type HeaderOrRef ¶
HeaderOrRef represents a Header that can be inlined or referenced in the API description.
func (*HeaderOrRef) MarshalYAML ¶
func (hor *HeaderOrRef) MarshalYAML() (interface{}, error)
MarshalYAML implements yaml.Marshaler for HeaderOrRef.
type Info ¶
type Info struct { Title string `json:"title" yaml:"title"` Description string `json:"description,omitempty" yaml:"description,omitempty"` TermsOfService string `json:"termsOfService,omitempty" yaml:"termsOfService,omitempty"` Contact *Contact `json:"contact,omitempty" yaml:"contact,omitempty"` License *License `json:"license,omitempty" yaml:"license,omitempty"` Version string `json:"version" yaml:"version"` XLogo *XLogo `json:"x-logo,omitempty" yaml:"x-logo,omitempty"` }
Info represents the metadata of an API.
type InternalDataType ¶
type InternalDataType int
InternalDataType represents an internal type.
const ( TypeInteger InternalDataType = iota TypeLong TypeFloat TypeDouble TypeString TypeByte TypeBinary TypeBoolean TypeDate TypeDateTime TypeDuration TypeIP TypeURL TypePassword TypeAny // TypeComplex represents non-primitive types like // Go struct, for which a schema must be generated. TypeComplex // Imported data types. TypeUUID TypeUnsupported )
Type constants.
func (InternalDataType) Format ¶
func (dt InternalDataType) Format() string
Format returns the format corresponding to the DataType.
func (InternalDataType) String ¶
func (dt InternalDataType) String() string
String implements fmt.Stringer for DataType.
func (InternalDataType) Type ¶
func (dt InternalDataType) Type() string
Type returns the type corresponding to the DataType.
type License ¶
type License struct { Name string `json:"name" yaml:"name"` URL string `json:"url,omitempty" yaml:"url,omitempty"` }
License represents the license informations exposed for an API.
type MediaType ¶
type MediaType struct { Schema *SchemaOrRef `json:"schema" yaml:"schema"` Example interface{} `json:"example,omitempty" yaml:"example,omitempty"` Examples map[string]*ExampleOrRef `json:"examples,omitempty" yaml:"examples,omitempty"` Encoding map[string]*Encoding `json:"encoding,omitempty" yaml:"encoding,omitempty"` }
MediaType represents the type of a media.
type MediaTypeOrRef ¶
MediaTypeOrRef represents a MediaType that can be inlined or referenced in the API description.
func (*MediaTypeOrRef) MarshalYAML ¶
func (mtor *MediaTypeOrRef) MarshalYAML() (interface{}, error)
MarshalYAML implements yaml.Marshaler for MediaTypeOrRef.
type OAuthFlow ¶
type OAuthFlow struct { AuthorizationURL string `json:"authorizationUrl,omitempty" yaml:"authorizationUrl,omitempty"` TokenURL string `json:"tokenUrl,omitempty" yaml:"tokenUrl,omitempty"` RefreshURL string `json:"refreshUrl,omitempty" yaml:"refreshUrl,omitempty"` Scopes map[string]string `json:"scopes,omitempty" yaml:"scopes,omitempty"` }
OAuthFlow represents the data required to define an OAuth security scheme.
type OAuthFlows ¶
type OAuthFlows struct { Implicit *OAuthFlow `json:"implicit,omitempty" yaml:"implicit,omitempty"` Password *OAuthFlow `json:"password,omitempty" yaml:"password,omitempty"` ClientCredentials *OAuthFlow `json:"clientCredentials,omitempty" yaml:"clientCredentials,omitempty"` AuthorizationCode *OAuthFlow `json:"authorizationCode,omitempty" yaml:"authorizationCode,omitempty"` }
OAuthFlows represents all the supported OAuth flows
type OpenAPI ¶
type OpenAPI struct { OpenAPI string `json:"openapi" yaml:"openapi"` Info *Info `json:"info" yaml:"info"` Servers []*Server `json:"servers,omitempty" yaml:"servers,omitempty"` Paths Paths `json:"paths" yaml:"paths"` Components *Components `json:"components,omitempty" yaml:"components,omitempty"` Tags []*Tag `json:"tags,omitempty" yaml:"tags,omitempty"` Security *SecurityRequirement `json:"security,omitempty" yaml:"security,omitempty"` XTagGroups []*XTagGroup `json:"x-tagGroups,omitempty" yaml:"x-tagGroups,omitempty"` }
OpenAPI represents the root document object of an OpenAPI document.
type Operation ¶
type Operation struct { Tags []string `json:"tags,omitempty" yaml:"tags,omitempty"` Summary string `json:"summary,omitempty" yaml:"summary,omitempty"` Description string `json:"description,omitempty" yaml:"description,omitempty"` ID string `json:"operationId,omitempty" yaml:"operationId,omitempty"` Parameters []*ParameterOrRef `json:"parameters,omitempty" yaml:"parameters,omitempty"` RequestBody *RequestBody `json:"requestBody,omitempty" yaml:"requestBody,omitempty"` Responses Responses `json:"responses,omitempty" yaml:"responses,omitempty"` Deprecated bool `json:"deprecated,omitempty" yaml:"deprecated,omitempty"` Servers []*Server `json:"servers,omitempty" yaml:"servers,omitempty"` Security []*SecurityRequirement `json:"security" yaml:"security"` XCodeSamples []*XCodeSample `json:"x-codeSamples,omitempty" yaml:"x-codeSamples,omitempty"` }
Operation describes an API operation on a path.
func (*Operation) MarshalJSON ¶
MarshalJSON excludes empty but non-null SecurityRequirements.
func (*Operation) MarshalYAML ¶
MarshalYAML implements yaml.Marshaler for Operation. Needed to marshall empty but non-null SecurityRequirements.
type OperationInfo ¶
type OperationInfo struct { ID string StatusCode int StatusDescription string Headers []*ResponseHeader Summary string Description string Deprecated bool InputModel interface{} Responses []*OperationResponse Security []*SecurityRequirement XCodeSamples []*XCodeSample }
OperationInfo represents the informations of an operation that will be used when generating the OpenAPI specification.
type OperationResponse ¶
type OperationResponse struct { // The response code can be "default" // according to OAS3 spec. Code string Description string Model interface{} Headers []*ResponseHeader Example interface{} Examples map[string]interface{} }
OperationResponse represents a single response of an API operation.
type OverridedDataType ¶
type OverridedDataType struct {
// contains filtered or unexported fields
}
OverridedDataType represents a data type which details override the default generation.
func (*OverridedDataType) Format ¶
func (dt *OverridedDataType) Format() string
Format implements DataType for OverridedDataType.
func (*OverridedDataType) Type ¶
func (dt *OverridedDataType) Type() string
Type implements DataType for OverridedDataType.
type Parameter ¶
type Parameter struct { Name string `json:"name" yaml:"name"` In string `json:"in" yaml:"in"` Description string `json:"description,omitempty" yaml:"description,omitempty"` Required bool `json:"required,omitempty" yaml:"required,omitempty"` Deprecated bool `json:"deprecated,omitempty" yaml:"deprecated,omitempty"` AllowEmptyValue bool `json:"allowEmptyValue,omitempty" yaml:"allowEmptyValue,omitempty"` Schema *SchemaOrRef `json:"schema,omitempty" yaml:"schema,omitempty"` Style string `json:"style,omitempty" yaml:"style,omitempty"` Explode bool `json:"explode,omitempty" yaml:"explode,omitempty"` }
Parameter describes a single operation parameter.
type ParameterOrRef ¶
ParameterOrRef represents a Parameter that can be inlined or referenced in the API description.
func (*ParameterOrRef) MarshalYAML ¶
func (por *ParameterOrRef) MarshalYAML() (interface{}, error)
MarshalYAML implements yaml.Marshaler for ParameterOrRef.
type PathItem ¶
type PathItem struct { Ref string `json:"$ref,omitempty" yaml:"$ref,omitempty"` Summary string `json:"summary,omitempty" yaml:"summary,omitempty"` Description string `json:"description,omitempty" yaml:"description,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"` TRACE *Operation `json:"trace,omitempty" yaml:"trace,omitempty"` Servers []*Server `json:"servers,omitempty" yaml:"servers,omitempty"` Parameters []*ParameterOrRef `json:"parameters,omitempty" yaml:"parameters,omitempty"` }
PathItem describes the operations available on a single API path.
type Reference ¶
type Reference struct {
Ref string `json:"$ref" yaml:"$ref"`
}
Reference is a simple object to allow referencing other components in the specification, internally and externally.
type RequestBody ¶
type RequestBody struct { Description string `json:"description,omitempty" yaml:"description,omitempty"` Content map[string]*MediaType `json:"content" yaml:"content"` Required bool `json:"required,omitempty" yaml:"required,omitempty"` }
RequestBody represents a request body.
type Response ¶
type Response struct { Description string `json:"description,omitempty" yaml:"description,omitempty"` Headers map[string]*HeaderOrRef `json:"headers,omitempty" yaml:"headers,omitempty"` Content map[string]*MediaTypeOrRef `json:"content,omitempty" yaml:"content,omitempty"` }
Response describes a single response from an API.
type ResponseHeader ¶
ResponseHeader represents a single header that may be returned with an operation response.
type ResponseOrRef ¶
ResponseOrRef represents a Response that can be inlined or referenced in the API description.
func (*ResponseOrRef) MarshalYAML ¶
func (ror *ResponseOrRef) MarshalYAML() (interface{}, error)
MarshalYAML implements yaml.Marshaler for ResponseOrRef.
type Responses ¶
type Responses map[string]*ResponseOrRef
Responses represents a container for the expected responses of an opration. It maps a HTTP response code to the expected response.
type Schema ¶
type Schema struct { // The following properties are taken from the JSON Schema // definition but their definitions were adjusted to the // OpenAPI Specification. Type string `json:"type,omitempty" yaml:"type,omitempty"` AllOf *SchemaOrRef `json:"allOf,omitempty" yaml:"allOf,omitempty"` OneOf *SchemaOrRef `json:"oneOf,omitempty" yaml:"oneOf,omitempty"` AnyOf *SchemaOrRef `json:"anyOf,omitempty" yaml:"anyOf,omitempty"` Items *SchemaOrRef `json:"items,omitempty" yaml:"items,omitempty"` Properties map[string]*SchemaOrRef `json:"properties,omitempty" yaml:"properties,omitempty"` AdditionalProperties *SchemaOrRef `json:"additionalProperties,omitempty" yaml:"additionalProperties,omitempty"` Description string `json:"description,omitempty" yaml:"description,omitempty"` Format string `json:"format,omitempty" yaml:"format,omitempty"` Default interface{} `json:"default,omitempty" yaml:"default,omitempty"` Example interface{} `json:"example,omitempty" yaml:"example,omitempty"` // The following properties are taken directly from the // JSON Schema definition and follow the same specifications Title string `json:"title,omitempty" yaml:"title,omitempty"` MultipleOf int `json:"multipleOf,omitempty" yaml:"multipleOf,omitempty"` Maximum int `json:"maximum,omitempty" yaml:"maximum,omitempty"` ExclusiveMaximum bool `json:"exclusiveMaximum,omitempty" yaml:"exclusiveMaximum,omitempty"` Minimum int `json:"minimum,omitempty" yaml:"minimum,omitempty"` ExclusiveMinimum bool `json:"exclusiveMinimum,omitempty" yaml:"exclusiveMinimum,omitempty"` MaxLength int `json:"maxLength,omitempty" yaml:"maxLength,omitempty"` MinLength int `json:"minLength,omitempty" yaml:"minLength,omitempty"` Pattern string `json:"pattern,omitempty" yaml:"pattern,omitempty"` MaxItems int `json:"maxItems,omitempty" yaml:"maxItems,omitempty"` MinItems int `json:"minItems,omitempty" yaml:"minItems,omitempty"` UniqueItems bool `json:"uniqueItems,omitempty" yaml:"uniqueItems,omitempty"` MaxProperties int `json:"maxProperties,omitempty" yaml:"maxProperties,omitempty"` MinProperties int `json:"minProperties,omitempty" yaml:"minProperties,omitempty"` Required []string `json:"required,omitempty" yaml:"required,omitempty"` Enum []interface{} `json:"enum,omitempty" yaml:"enum,omitempty"` Nullable bool `json:"nullable,omitempty" yaml:"nullable,omitempty"` Deprecated bool `json:"deprecated,omitempty" yaml:"deprecated,omitempty"` }
Schema represents the definition of input and output data types of the API.
type SchemaOrRef ¶
SchemaOrRef represents a Schema that can be inlined or referenced in the API description.
func (*SchemaOrRef) MarshalYAML ¶
func (sor *SchemaOrRef) MarshalYAML() (interface{}, error)
MarshalYAML implements yaml.Marshaler for SchemaOrRef.
type SecurityRequirement ¶
SecurityRequirement represents the security object in the API specification.
type SecurityScheme ¶
type SecurityScheme struct { Type string `json:"type,omitempty" yaml:"type,omitempty"` Scheme string `json:"scheme,omitempty" yaml:"scheme,omitempty"` BearerFormat string `json:"bearerFormat,omitempty" yaml:"bearerFormat,omitempty"` Description string `json:"description,omitempty" yaml:"description,omitempty"` In string `json:"in,omitempty" yaml:"in,omitempty"` Name string `json:"name,omitempty" yaml:"name,omitempty"` OpenIDConnectURL string `json:"openIdConnectUrl,omitempty" yaml:"openIdConnectUrl,omitempty"` Flows *OAuthFlows `json:"flows,omitempty" yaml:"flows,omitempty"` }
SecurityScheme represents how the API is secured
type SecuritySchemeOrRef ¶
type SecuritySchemeOrRef struct { *SecurityScheme *Reference }
SecuritySchemeOrRef represents a SecurityScheme that can be inlined or referenced in the API description.
func (*SecuritySchemeOrRef) MarshalYAML ¶
func (sor *SecuritySchemeOrRef) MarshalYAML() (interface{}, error)
MarshalYAML implements yaml.Marshaler for SecuritySchemeOrRef.
type Server ¶
type Server struct { URL string `json:"url" yaml:"url"` Description string `json:"description,omitempty" yaml:"description,omitempty"` Variables map[string]*ServerVariable `json:"variables,omitempty" yaml:"variables,omitempty"` }
Server represents a server.
type ServerVariable ¶
type ServerVariable struct { Enum []string `json:"enum,omitempty" yaml:"enum,omitempty"` Default string `json:"default" yaml:"default"` Description string `json:"description,omitempty" yaml:"description,omitempty"` }
ServerVariable represents a server variable for server URL template substitution.
type SpecGenConfig ¶
type SpecGenConfig struct { // Name of the tag used by the validator.v8 // package. This is used by the spec generator // to determine if a field is required. ValidatorTag string PathLocationTag string QueryLocationTag string HeaderLocationTag string EnumTag string DefaultTag string }
SpecGenConfig represents the configuration of the spec generator.
type Tag ¶
type Tag struct { Name string `json:"name" yaml:"name"` Description string `json:"description,omitempty" yaml:"description,omitempty"` }
Tag represents the metadata of a single tag.
type TypeError ¶
TypeError is the error returned when the generator encounters an unknow or unsupported type.
type Typer ¶
type Typer interface {
TypeName() string
}
Typer is the interface implemented by the types that can describe themselves.
type XCodeSample ¶
type XCodeSample struct { Lang string `json:"lang,omitempty" yaml:"lang,omitempty"` Label string `json:"label,omitempty" yaml:"label,omitempty"` Source string `json:"source,omitempty" yaml:"source,omitempty"` }
XCodeSample represents the information about the x-codeSample extension See: https://github.com/Redocly/redoc/blob/master/docs/redoc-vendor-extensions.md#x-codesamples
type XLogo ¶
type XLogo struct { URL string `json:"url,omitempty" yaml:"url,omitempty"` BackgroundColor string `json:"backgroundColor,omitempty" yaml:"backgroundColor,omitempty"` AltText string `json:"altText,omitempty" yaml:"altText,omitempty"` Href string `json:"href,omitempty" yaml:"href,omitempty"` }
XLogo represents the information about the x-logo extension See: https://github.com/Redocly/redoc/blob/master/docs/redoc-vendor-extensions.md#x-logo
type XTagGroup ¶
type XTagGroup struct { Name string `json:"name,omitempty" yaml:"name,omitempty"` Tags []string `json:"tags,omitempty" yaml:"tags,omitempty"` }
XTagGroup represents the information about the x-tagGroups extension See: https://github.com/Redocly/redoc/blob/master/docs/redoc-vendor-extensions.md#x-taggroups