Documentation ¶
Index ¶
- type APIOperation
- type ApiKeyAuth
- 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) SetAPIKeySecurity()
- func (g *Generator) SetInfo(info *Info)
- 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 OpenAPI
- type Operation
- func (operation *Operation) GetDeprecated() bool
- func (operation *Operation) GetDescription() string
- func (operation *Operation) GetID() string
- func (operation *Operation) GetParameters() []*ParameterOrRef
- func (operation *Operation) GetRequestBody() *RequestBody
- func (operation *Operation) GetResponses() Responses
- func (operation *Operation) GetSecurity() []map[string]interface{}
- func (operation *Operation) GetServers() []*Server
- func (operation *Operation) GetSummary() string
- func (operation *Operation) GetTags() []string
- func (operation *Operation) Marshal() ([]byte, error)
- func (operation *Operation) Unmarshal(data []byte, v interface{}) error
- type OperationInfo
- type OperationReponse
- 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 Server
- type ServerVariable
- type SpecGenConfig
- type Tag
- type TypeError
- type Typer
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type APIOperation ¶
type APIOperation interface { Marshal() ([]byte, error) Unmarshal(data []byte, v interface{}) error GetTags() []string GetSummary() string GetDescription() string GetID() string GetParameters() []*ParameterOrRef GetRequestBody() *RequestBody GetResponses() Responses GetDeprecated() bool GetServers() []*Server GetSecurity() []map[string]interface{} }
type ApiKeyAuth ¶ added in v0.13.7
type Components ¶
type Components struct { Schemas map[string]*SchemaOrRef `json:"schemas,omitempty" yaml:"schemas,omitempty"` SecurityScheme map[string]interface{} `json:"securitySchemes,omitempty" yaml:"securitySchemes,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"` }
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) SetAPIKeySecurity ¶ added in v0.13.7
func (g *Generator) SetAPIKeySecurity()
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"` }
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 // 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 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"` }
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"` Security []map[string]interface{} `json:"security,omitempty" yaml:"security,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"` }
Operation describes an API operation on a path.
func (*Operation) GetDeprecated ¶
func (*Operation) GetDescription ¶
func (*Operation) GetParameters ¶
func (operation *Operation) GetParameters() []*ParameterOrRef
func (*Operation) GetRequestBody ¶
func (operation *Operation) GetRequestBody() *RequestBody
func (*Operation) GetResponses ¶
func (*Operation) GetSecurity ¶ added in v0.13.10
func (*Operation) GetServers ¶
func (*Operation) GetSummary ¶
type OperationInfo ¶
type OperationInfo struct { ID string StatusCode int StatusDescription string Headers []*ResponseHeader Summary string Description string Deprecated bool InputModel interface{} Security []map[string]interface{} Responses []*OperationReponse }
OperationInfo represents the informations of an operation that will be used when generating the OpenAPI specification.
type OperationReponse ¶
type OperationReponse struct { // The response code can be "default" // according to OAS3 spec. Code string Description string Model interface{} Headers []*ResponseHeader }
OperationReponse 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 APIOperation `json:"get,omitempty" yaml:"get,omitempty"` PUT APIOperation `json:"put,omitempty" yaml:"put,omitempty"` POST APIOperation `json:"post,omitempty" yaml:"post,omitempty"` DELETE APIOperation `json:"delete,omitempty" yaml:"delete,omitempty"` OPTIONS APIOperation `json:"options,omitempty" yaml:"options,omitempty"` HEAD APIOperation `json:"head,omitempty" yaml:"head,omitempty"` PATCH APIOperation `json:"patch,omitempty" yaml:"patch,omitempty"` TRACE APIOperation `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"` // 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 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 { Ennum []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.