Documentation ¶
Overview ¶
Package chioas - Go package for building OAS (OpenApi Specs) for Chi APIs
Index ¶
- Variables
- func SourceComment(comments ...string) string
- type Additional
- type ApplyMiddlewares
- type CommonParameter
- type CommonParameters
- type CommonRequests
- type CommonResponses
- type Components
- type Constraints
- type Contact
- type ContentType
- type ContentTypes
- type Definition
- type DocOptions
- type Extensions
- type ExternalDocs
- type FromOptions
- type GetHandler
- type Handlers
- type Info
- type License
- type Method
- type Methods
- type OperationIdentifier
- type Path
- type PathMiddlewares
- type PathParam
- type PathParams
- type Paths
- type Properties
- type Property
- type QueryParam
- type QueryParams
- type RedocArrow
- type RedocBreakpoints
- type RedocCode
- type RedocColors
- type RedocFab
- type RedocGroupItems
- type RedocHeadings
- type RedocLevel1Items
- type RedocLinks
- type RedocLogo
- type RedocOptions
- type RedocRightPanel
- type RedocRightPanelServers
- type RedocRightPanelServersOverlay
- type RedocRightPanelServersUrl
- type RedocSidebar
- type RedocSpacing
- type RedocTheme
- type RedocTypography
- type Request
- type Response
- type Responses
- type Schema
- type SchemaConverter
- type SchemaWriter
- type Schemas
- type SecurityScheme
- type SecuritySchemes
- type Server
- type Servers
- type SupportFiles
- type Tag
- type Tags
Constants ¶
This section is empty.
Variables ¶
var MethodsOrder = []string{ http.MethodGet, http.MethodHead, http.MethodOptions, http.MethodPost, http.MethodPut, http.MethodPatch, http.MethodDelete, }
MethodsOrder defines the order in which methods appear in docs
var OasVersion = "3.0.3"
Functions ¶
func SourceComment ¶ added in v1.6.0
SourceComment is a utility function that can be used to place a comment in the spec yaml informing where, in the source code, a particular spec item was defined. Example:
var myApi = chioas.Definition{ Comment: chioas.SourceComment("this is a static comment"), ...
Types ¶
type Additional ¶
Additional is an interface that can be supplied to many parts of the definition to write additional yaml to the OAS
type ApplyMiddlewares ¶ added in v1.1.2
type ApplyMiddlewares func(thisApi any) chi.Middlewares
type CommonParameter ¶ added in v1.5.0
type CommonParameter struct { // Name is the name of the param Name string // Description is the OAS description Description string // Required is the OAS required flag Required bool // In is the OAS field defining whether the param is a "query", "header", "path" or "cookie" param // // Defaults to "query" In string // Example is the OAS example for the param Example any // Schema is the optional OAS Schema Schema *Schema // SchemaRef is the OAS schema reference // // Only used if value is a non-empty string - if both Schema is nil and SchemaRef is empty string, then an // empty object schema is written to the spec yaml, e.g. // schema: // type: "object" // // If the value does not contain a path (i.e. does not contain any "/") then the ref // path will be the value prefixed with components schemas path. For example, specifying "foo" // will result in a schema ref: // schema: // $ref: "#/components/schemas/foo" SchemaRef string // Extensions is extension OAS yaml properties Extensions Extensions // Additional is any additional OAS spec yaml to be written Additional Additional // Comment is any comment(s) to appear in the OAS spec yaml Comment string }
CommonParameter represents the OAS definition of a reusable parameter (as used by Components.Parameters)
type CommonParameters ¶ added in v1.5.0
type CommonParameters map[string]CommonParameter
CommonParameters is a map of CommonParameter, where the key is the name (that can be referenced by PathParam.Ref or QueryParam.Ref)
type CommonRequests ¶ added in v1.4.0
CommonRequests is a map of Request, where the key is the name (that can be referenced by Request.Ref)
type CommonResponses ¶ added in v1.4.0
CommonResponses is a map of Response, where the key is the name (that can be referenced by Response.Ref)
type Components ¶
type Components struct { // Schemas is the OAS reusable schemas Schemas Schemas // Requests is the OAS reusable requests // // To reference one of these, use Method.Request.Ref with the name Requests CommonRequests // Responses is the OAS reusable responses // // To reference one of these, use Method.Responses.Ref with the name Responses CommonResponses // Parameters is the OAS reusable parameters Parameters CommonParameters // SecuritySchemes is the OAS security schemes SecuritySchemes SecuritySchemes // Extensions is extension OAS yaml properties Extensions Extensions // Additional is any additional OAS spec yaml to be written Additional Additional // Comment is any comment(s) to appear in the OAS spec yaml Comment string }
Components represents the OAS components
type Constraints ¶ added in v1.7.0
type Constraints struct { Pattern string Maximum json.Number Minimum json.Number ExclusiveMaximum bool ExclusiveMinimum bool Nullable bool MultipleOf uint MaxLength uint MinLength uint MaxItems uint MinItems uint UniqueItems bool MaxProperties uint MinProperties uint // Additional is any other OAS constraints for a property (that are not currently defined in Constraints) Additional map[string]any }
Constraints defines the constraints for an OAS property
type Contact ¶
type Contact struct { Name string Url string Email string // Extensions is extension OAS yaml properties Extensions Extensions // Comment is any comment(s) to appear in the OAS spec yaml Comment string }
Contact represents the OAS contact section of the info
type ContentType ¶ added in v1.7.0
type ContentType struct { // Schema is the optional OAS Schema // // Only used if the value is non-nil - otherwise uses SchemaRef is used // // The value can be any of the following: // // * chioas.Schema (or *chioas.Schema) // // * a chioas.SchemaConverter // // * a chioas.SchemaWriter // // * a struct or ptr to struct (schema written is determined by examining struct fields) // // * a slice of structs (items schema written is determined by examining struct fields) Schema any // SchemaRef is the OAS schema reference // // Only used if value is a non-empty string - if both Schema is nil and SchemaRef is empty string, then an // empty object schema is written to the spec yaml, e.g. // schema: // type: "object" // // If the value does not contain a path (i.e. does not contain any "/") then the ref // path will be the value prefixed with components schemas path. For example, specifying "foo" // will result in a schema ref: // schema: // $ref: "#/components/schemas/foo" SchemaRef string // IsArray indicates that request is an array of items IsArray bool }
type ContentTypes ¶ added in v1.7.0
type ContentTypes map[string]ContentType
ContentTypes is used by Response.AlternativeContentTypes and Request.AlternativeContentTypes to denote alternative content types
The key is a media type - e.g. "application/json"
type Definition ¶
type Definition struct { // DocOptions is the documentation options for the spec DocOptions DocOptions // AutoHeadMethods when set to true, automatically adds HEAD methods for GET methods (where HEAD method not explicitly specified) AutoHeadMethods bool // Info is the OAS info for the spec Info Info // Servers is the OAS servers for the spec Servers Servers // Tags is the OAS tags for the spec Tags Tags // Methods is any methods on the root api Methods Methods // Middlewares is any chi.Middlewares for api root Middlewares chi.Middlewares // ApplyMiddlewares is an optional function that returns chi.Middlewares for api root ApplyMiddlewares ApplyMiddlewares // Paths is the api paths to be setup (each path can have sub-paths) Paths Paths // descendant paths // Components is the OAS components Components *Components // Security is the OAS security for the api Security SecuritySchemes // Extensions is extension OAS yaml properties Extensions Extensions // Additional is any additional OAS spec yaml to be written Additional Additional // Comment is any comment(s) to appear in the OAS spec yaml Comment string }
Definition is the overall definition of an api
func FromJson ¶ added in v1.8.0
func FromJson(r io.Reader, opts *FromOptions) (result *Definition, err error)
FromJson builds a Definition from an existing OAS spec JSON
where all methods in the spec must have a `x-handler` property, e.g.
"paths": { "/": { "get": { "x-handler": "getRoot" ...
where the key "getRoot" must be provided in the handlers arg
or...
"paths": { "/": { "get": { "x-handler": ".GetRoot" ...
where the "GetRoot" must be a http.HandlerFunc method on the supplied api arg
func FromYaml ¶ added in v1.8.0
func FromYaml(r io.Reader, opts *FromOptions) (result *Definition, err error)
FromYaml builds a Definition from an existing OAS spec YAML
where all methods in the spec must have a `x-handler` tag, e.g.
paths: "/": get: x-handler: "getRoot"
where the key "getRoot" must be provided in the handlers arg
or...
paths: "/": get: x-handler: ".GetRoot"
where the "GetRoot" must be a http.HandlerFunc method on the supplied api arg
func (*Definition) AsJson ¶ added in v1.6.1
func (d *Definition) AsJson() (data []byte, err error)
func (*Definition) AsYaml ¶
func (d *Definition) AsYaml() ([]byte, error)
func (*Definition) SetupRoutes ¶
func (d *Definition) SetupRoutes(router chi.Router, thisApi any) error
SetupRoutes sets up the API routes on the supplied chi.Router
Pass the thisApi arg if any of the methods use method by name
type DocOptions ¶
type DocOptions struct { // ServeDocs whether to serve api docs ServeDocs bool // Context is the optional path prefix for all paths in OAS spec Context string // NoCache if set to true, docs page and spec aren't cached (and built on each call) NoCache bool // AsJson if set to true, serves the spec as JSON AsJson bool // Path the path on which to serve api docs page and spec (defaults to "/docs") Path string // DocIndexPage the name of the docs index page (defaults to "index.html") DocIndexPage string // SupportFiles is an optional handler that is used for other files under "/docs" path // // see _examples/swagger_ui for example usage SupportFiles http.Handler // Title the title in the docs index page (defaults to "API Documentation") Title string // RedocOptions redoc options to be used (see https://github.com/Redocly/redoc#redoc-options-object) // // use map[string]any or &RedocOptions (or anything that can be marshalled and then unmarshalled to map[string]any) RedocOptions any // SpecName the name of the OAS spec (defaults to "spec.yaml") SpecName string // DocTemplate template for the docs page (defaults to internal template if an empty string) DocTemplate string // StylesOverride css styling overrides (injected into docs index page) StylesOverride string // RedocJsUrl is the URL for the Redoc JS // // defaults to: // https://cdn.jsdelivr.net/npm/redoc@2.0.0-rc.77/bundles/redoc.standalone.min.js RedocJsUrl string // TryJsUrl is the URL for the Try Redoc JS // // defaults to: // https://cdn.jsdelivr.net/gh/wll8/redoc-try@1.4.7/dist/try.js TryJsUrl string // DefaultResponses is the default responses for methods that don't have any responses defined // // is a map of http status code and response DefaultResponses Responses // HideHeadMethods indicates that all HEAD methods should be hidden from docs HideHeadMethods bool // OperationIdentifier is an optional function called by Method to generate `operationId` tag value OperationIdentifier OperationIdentifier // contains filtered or unexported fields }
DocOptions determines whether/how the api will serve interactive docs page
type Extensions ¶ added in v1.3.0
Extensions can be added to many OAS items and are written as `x-` yaml properties
type ExternalDocs ¶
type ExternalDocs struct { Description string Url string // Extensions is extension OAS yaml properties Extensions Extensions // Comment is any comment(s) to appear in the OAS spec yaml Comment string }
ExternalDocs represents the OAS external docs for a spec
type FromOptions ¶ added in v1.8.0
type FromOptions struct { // DocOptions is the optional doc options for the generated Definition DocOptions *DocOptions // Api is the optional api object that provides methods where `x-handler` is specified as ".HandlerMethodName" Api any // Handlers is the optional look for handlers specified by `x-handler` Handlers Handlers // Strict when set, causes the FromJson / FromYaml to error if no `x-handler` tag is specified Strict bool // PathMiddlewares is an optional func that sets middlewares on paths found in the from spec PathMiddlewares PathMiddlewares }
FromOptions is used by FromJson and FromYaml to control how the definition is built from a pre-existing OAS spec
type GetHandler ¶ added in v1.3.0
GetHandler is a function that can be set on Method.Handler - and is called to obtain the http.HandlerFunc
type Handlers ¶ added in v1.8.0
type Handlers map[string]http.HandlerFunc
Handlers is a lookup, by name, used by FromJson or FromYaml
type Info ¶
type Info struct { // Title is the OAS title Title string // Description is the OAS description Description string // Version is the OAS version (of the api) Version string // TermsOfService is the OAS terms of service TermsOfService string // Contact is the optional OAS contact info Contact *Contact // License is the optional OAS license info License *License // Extensions is extension OAS yaml properties Extensions Extensions // Additional is any additional OAS spec yaml to be written Additional Additional // ExternalDocs is the optional eternal docs (for the entire spec) ExternalDocs *ExternalDocs // Comment is any comment(s) to appear in the OAS spec yaml Comment string }
Info represents the OAS info section of the spec
type License ¶
type License struct { Name string Url string // Extensions is extension OAS yaml properties Extensions Extensions // Comment is any comment(s) to appear in the OAS spec yaml Comment string }
License represents the OAS license section of the info
type Method ¶
type Method struct { // Description is the OAS description of the method Description string // Summary is the OAS summary of the method Summary string // Handler is the http.HandlerFunc to be used by Chi // // Can also be specified as a string - which must be a public method on the interface passed to Definition.SetupRoutes // // Can also be specified as a GetHandler func - which is called to acquire the http.HandlerFunc Handler any // OperationId is the OAS operation id of the method // // This can be overridden by providing a DocOptions.OperationIdentifier OperationId string // Tag is the OAS tag of the method // // If this is an empty string and any ancestor Path.Tag is set then that ancestor tag is used Tag string // QueryParams is the OAS query params for the method // // Can also be used to specify header params (see QueryParam.In) QueryParams QueryParams // Request is the optional OAS request body for the method Request *Request // Responses is the OAS responses for the method // // If no responses are specified, the DocOptions.DefaultResponses is used // // If there are no DocOptions.DefaultResponses specified, then a http.StatusOK response is used Responses Responses // Deprecated is the OAS deprecated flag for the method Deprecated bool // Security is the OAS security schemes used by the method Security SecuritySchemes // OptionalSecurity if set to true, adds an entry to the OAS method security e.g. // security: // - {} OptionalSecurity bool // Extensions is extension OAS yaml properties Extensions Extensions // Additional is any additional OAS spec yaml to be written Additional Additional // Comment is any comment(s) to appear in the OAS spec yaml Comment string // HideDocs if set to true, hides this method from the OAS docs HideDocs bool }
Method represents the definition of a method (as used by Path and, for root methods, Definition)
type OperationIdentifier ¶ added in v1.1.3
type OperationIdentifier func(method Method, methodName string, path string, parentTag string) string
OperationIdentifier is a function that can be provided to DocOptions
type Path ¶
type Path struct { // Methods is the methods on the path Methods Methods // Paths is the sub-paths of the path Paths Paths // Middlewares is any chi.Middlewares for the path Middlewares chi.Middlewares // ApplyMiddlewares is an optional function that returns chi.Middlewares for the path ApplyMiddlewares ApplyMiddlewares // Tag is the OAS tag of the path // // If this is an empty string and any ancestor Path.Tag is set then that ancestor tag is used // // The final tag is used by Method Tag string // PathParams is the OAS information about path params on this path // // Any path params introduced in the path are descended down the sub-paths and methods - any // path params that are not documented will still be seen in the OAS spec for methods PathParams PathParams // HideDocs if set to true, hides this path (and descendants) from docs HideDocs bool // Extensions is extension OAS yaml properties Extensions Extensions // Additional is any additional OAS spec yaml to be written Additional Additional // Comment is any comment(s) to appear in the OAS spec yaml Comment string }
Path represents a path for both the router and the OAS spec
type PathMiddlewares ¶ added in v1.8.0
type PathMiddlewares func(path string) chi.Middlewares
type PathParam ¶
type PathParam struct { // Description is the OAS description Description string // Example is the OAS example Example any // Extensions is extension OAS yaml properties Extensions Extensions // Additional is any additional OAS spec yaml to be written Additional Additional // Comment is any comment(s) to appear in the OAS spec yaml (not used with Ref) Comment string // Schema is the optional OAS Schema Schema *Schema // SchemaRef is the OAS schema reference // // Only used if value is a non-empty string - if both Schema is nil and SchemaRef is empty string, then an // empty object schema is written to the spec yaml, e.g. // schema: // type: "string" // // If the value does not contain a path (i.e. does not contain any "/") then the ref // path will be the value prefixed with components schemas path. For example, specifying "foo" // will result in a schema ref: // schema: // $ref: "#/components/schemas/foo" SchemaRef string // Ref is the OAS $ref name for the parameter // // If this is a non-empty string, then a $ref to "#/components/parameters/" is used Ref string }
PathParam represents the OAS definition of a path param
type PathParams ¶
PathParams is a map of PathParam where the key is the param name
type Properties ¶ added in v1.4.0
type Properties []Property
Properties is an ordered collection of Property
type Property ¶
type Property struct { // Name is the OAS name of the property Name string // Description is the OAS description of the property Description string // Type is the OAS type of the property // // Should be one of "string", "object", "array", "boolean", "integer", "number" or "null" Type string // ItemType is the OAS type of array items // // only used if Type = "array" ItemType string // Properties is the ordered collection of sub-properties // // Only used if Type == "object" (or Type == "array" and ItemType == "object" Properties Properties // Required indicates the property is required // // see also Schema.RequiredProperties Required bool // Format is the OAS format for the property Format string // Example is the OAS example for the property Example any // Deprecated is the OAS deprecated flag for the property Deprecated bool // Constraints is the OAS constraints for the property Constraints Constraints // SchemaRef is the OAS schema reference // // Only used if value is a non-empty string // // If the value does not contain a path (i.e. does not contain any "/") then the ref // path will be the value prefixed with components schemas path. For example, specifying "foo" // will result in a schema ref: // schema: // $ref: "#/components/schemas/foo" SchemaRef string // Extensions is extension OAS yaml properties Extensions Extensions // Additional is any additional OAS spec yaml to be written Additional Additional // Comment is any comment(s) to appear in the OAS spec yaml Comment string }
Property represents the OAS definition of a property
type QueryParam ¶
type QueryParam struct { // Name is the name of the param Name string // Description is the OAS description Description string // Required is the OAS required flag Required bool // In is the OAS field defining whether the param is a "query" or "header" param // // Defaults to "query" In string // Example is the OAS example for the param Example any // Schema is the optional OAS Schema Schema *Schema // SchemaRef is the OAS schema reference // // Only used if value is a non-empty string - if both Schema is nil and SchemaRef is empty string, then an // empty object schema is written to the spec yaml, e.g. // schema: // type: "string" // // If the value does not contain a path (i.e. does not contain any "/") then the ref // path will be the value prefixed with components schemas path. For example, specifying "foo" // will result in a schema ref: // schema: // $ref: "#/components/schemas/foo" SchemaRef string // Extensions is extension OAS yaml properties Extensions Extensions // Additional is any additional OAS spec yaml to be written Additional Additional // Comment is any comment(s) to appear in the OAS spec yaml (not used with Ref) Comment string // Ref is the OAS $ref name for the parameter // // If this is a non-empty string, then a $ref to "#/components/parameters/" is used Ref string }
QueryParam represents the OAS definition of a query param (or header param)
type QueryParams ¶
type QueryParams []QueryParam
QueryParams represents an ordered collection of QueryParam
type RedocArrow ¶ added in v1.1.1
type RedocBreakpoints ¶ added in v1.1.1
type RedocBreakpoints struct { Small string `json:"small,omitempty"` // '50rem' Medium string `json:"medium,omitempty"` // '85rem' Large string `json:"large"` // '105rem' }
RedocBreakpoints breakpoints for switching three/two and mobile view layouts
type RedocCode ¶ added in v1.1.1
type RedocCode struct { FontSize string `json:"fontSize,omitempty"` // '13px' FontFamily string `json:"fontFamily,omitempty"` // 'Courier, monospace' LineHeight string `json:"lineHeight,omitempty"` // COMPUTED: typography.lineHeight FontWeight string `json:"fontWeight,omitempty"` // COMPUTED: typography.fontWeightRegular Color string `json:"color,omitempty"` // '#e53935' BackgroundColor string `json:"backgroundColor,omitempty"` // 'rgba(38, 50, 56, 0.05)' Wrap bool `json:"wrap,omitempty"` // whether to break word for inline blocks (otherwise they can overflow) }
type RedocColors ¶ added in v1.1.1
type RedocColors struct {
TonalOffset float32 `json:"tonalOffset,omitempty"` // 0.3 # default tonal offset used in computations
}
type RedocGroupItems ¶ added in v1.1.1
type RedocHeadings ¶ added in v1.1.1
type RedocLevel1Items ¶ added in v1.1.1
type RedocLevel1Items struct { ActiveBackgroundColor string `json:"activeBackgroundColor,omitempty"` // COMPUTED: theme.sidebar.backgroundColor ActiveTextColor string `json:"activeTextColor,omitempty"` // COMPUTED: theme.sidebar.activeTextColor TextTransform string `json:"textTransform"` // 'none' }
type RedocLinks ¶ added in v1.1.1
type RedocLinks struct { Color string `json:"color,omitempty"` // COMPUTED: colors.primary.main Visited string `json:"visited,omitempty"` // COMPUTED: typography.links.color Hover string `json:"hover,omitempty"` // COMPUTED: lighten(0.2 typography.links.color) TextDecoration string `json:"textDecoration,omitempty"` // 'auto' HoverTextDecoration string `json:"hoverTextDecoration"` // 'auto' }
type RedocOptions ¶ added in v1.1.1
type RedocOptions struct { DisableSearch bool `json:"disableSearch,omitempty"` // disable search indexing and search box. MinCharacterLengthToInitSearch int `json:"minCharacterLengthToInitSearch,omitempty"` // set minimal characters length to init search, default 3, minimal 1. ExpandDefaultServerVariables bool `json:"expandDefaultServerVariables,omitempty"` // enable expanding default server variables, default false. ExpandResponses string `json:"expandResponses,omitempty"` // specify which responses to expand by default by response codes. Values should be passed as comma-separated list without spaces e.g. expandResponses="200,201". Special value "all" expands all responses by default. Be careful: this option can slow-down documentation rendering time. GeneratedPayloadSamplesMaxDepth int `json:"generatedPayloadSamplesMaxDepth,omitempty"` // set the maximum render depth for JSON payload samples (responses and request body). The default value is 10. MaxDisplayedEnumValues int `json:"maxDisplayedEnumValues,omitempty"` // display only specified number of enum values. hide rest values under spoiler. HideDownloadButton bool `json:"hideDownloadButton,omitempty"` // do not show "Download" spec button. THIS DOESN'T MAKE YOUR SPEC PRIVATE, it just hides the button. DownloadFileName string `json:"downloadFileName,omitempty"` // set a custom file name for the downloaded API definition file. DownloadDefinitionUrl string `json:"downloadDefinitionUrl,omitempty"` // If the 'Download' button is visible in the API reference documentation (hideDownloadButton=false), the URL configured here opens when that button is selected. Provide it as an absolute URL with the full URI scheme. HideHostname bool `json:"hideHostname,omitempty"` // if set, the protocol and hostname is not shown in the operation definition. HideLoading bool `json:"hideLoading,omitempty"` // do not show loading animation. Useful for small docs. HideFab bool `json:"hideFab,omitempty"` // do not show FAB in mobile view. Useful for implementing a custom floating action button. HideSchemaPattern bool `json:"hideSchemaPattern,omitempty"` // if set, the pattern is not shown in the schema. HideSingleRequestSampleTab bool `json:"hideSingleRequestSampleTab,omitempty"` // do not show the request sample tab for requests with only one sample. ShowObjectSchemaExamples bool `json:"showObjectSchemaExamples,omitempty"` // show object schema example in the properties, default false. ExpandSingleSchemaField bool `json:"expandSingleSchemaField,omitempty"` // automatically expand single field in a schema SchemaExpansionLevel any `json:"schemaExpansionLevel,omitempty"` // specifies whether to automatically expand schemas. Special value "all" expands all levels. The default value is 0. JsonSampleExpandLevel any `json:"jsonSampleExpandLevel,omitempty"` // set the default expand level for JSON payload samples (responses and request body). Special value "all" expands all levels. The default value is 2. HideSchemaTitles bool `json:"hideSchemaTitles,omitempty"` // do not display schema title next to the type SimpleOneOfTypeLabel bool `json:"simpleOneOfTypeLabel,omitempty"` // show only unique oneOf types in the label without titles SortEnumValuesAlphabetically bool `json:"sortEnumValuesAlphabetically,omitempty"` // set to true, sorts all enum values in all schemas alphabetically SortOperationsAlphabetically bool `json:"sortOperationsAlphabetically,omitempty"` // set to true, sorts operations in the navigation sidebar and in the middle panel alphabetically SortTagsAlphabetically bool `json:"sortTagsAlphabetically,omitempty"` // set to true, sorts tags in the navigation sidebar and in the middle panel alphabetically MenuToggle bool `json:"menuToggle,omitempty"` // if true, clicking second time on expanded menu item collapses it, default true. NativeScrollbars bool `json:"nativeScrollbars,omitempty"` // use native scrollbar for sidemenu instead of perfect-scroll (scrolling performance optimization for big specs). OnlyRequiredInSamples bool `json:"onlyRequiredInSamples,omitempty"` // shows only required fields in request samples. PathInMiddlePanel bool `json:"pathInMiddlePanel,omitempty"` // show path link and HTTP verb in the middle panel instead of the right one. RequiredPropsFirst bool `json:"requiredPropsFirst,omitempty"` // show required properties first ordered in the same order as in required array. ScrollYOffset any `json:"scrollYOffset,omitempty"` // If set, specifies a vertical scroll-offset. This is often useful when there are fixed positioned elements at the top of the page, such as navbars, headers etc; scrollYOffset can be specified in various ways: ShowExtensions bool `json:"showExtensions,omitempty"` // show vendor extensions ("x-" fields). Extensions used by Redoc are ignored. Can be boolean or an array of string with names of extensions to display. SortPropsAlphabetically bool `json:"sortPropsAlphabetically,omitempty"` // sort properties alphabetically. PayloadSampleIndex int `json:"payloadSampleIdx,omitempty"` // if set, payload sample is inserted at this index or last. Indexes start from 0. Theme *RedocTheme `json:"theme,omitempty"` // Redoc theme UntrustedSpec bool `json:"untrustedSpec,omitempty"` // if set, the spec is considered untrusted and all HTML/markdown is sanitized to prevent XSS. Disabled by default for performance reasons. Enable this option if you work with untrusted user data! Nonce any `json:"nonce,omitempty"` // if set, the provided value is injected in every injected HTML element in the nonce attribute. Useful when using CSP, see https://webpack.js.org/guides/csp/. ShowWebhookVerb bool `json:"showWebhookVerb,omitempty"` // when set to true, shows the HTTP request method for webhooks in operations and in the sidebar. }
RedocOptions for use in DocOptions.RedocOptions (from https://github.com/Redocly/redoc#redoc-options-object)
type RedocRightPanel ¶ added in v1.1.1
type RedocRightPanel struct { BackgroundColor string `json:"backgroundColor,omitempty"` // '#263238' Width string `json:"width,omitempty"` // '40%' TextColor string `json:"textColor,omitempty"` // '#ffffff' Servers *RedocRightPanelServers `json:"servers,omitempty"` }
type RedocRightPanelServers ¶ added in v1.1.5
type RedocRightPanelServers struct { Overlay *RedocRightPanelServersOverlay `json:"overlay,omitempty"` Url *RedocRightPanelServersUrl `json:"url,omitempty"` }
type RedocRightPanelServersOverlay ¶ added in v1.1.5
type RedocRightPanelServersUrl ¶ added in v1.1.5
type RedocRightPanelServersUrl struct {
BackgroundColor string `json:"backgroundColor,omitempty"` // '#fff'
}
type RedocSidebar ¶ added in v1.1.1
type RedocSidebar struct { Width string `json:"width,omitempty"` // '260px' BackgroundColor string `json:"backgroundColor,omitempty"` // '#fafafa' TextColor string `json:"textColor,omitempty"` // '#333333' ActiveTextColor string `json:"activeTextColor"` // COMPUTED: theme.sidebar.textColor (if set by user) or theme.colors.primary.main GroupItems *RedocGroupItems `json:"groupItems,omitempty"` // Group headings Level1Items *RedocLevel1Items `json:"level1Items,omitempty"` // Level 1 items like tags or section 1st level items Arrow *RedocArrow `json:"arrow,omitempty"` // sidebar arrow }
type RedocSpacing ¶ added in v1.1.1
type RedocSpacing struct { Unit int `json:"unit,omitempty"` // 5 # main spacing unit used in autocomputed theme values later SectionHorizontal int `json:"sectionHorizontal,omitempty"` // 40 # Horizontal section padding. COMPUTED: spacing.unit * 8 SectionVertical int `json:"sectionVertical,omitempty"` // 40 # Horizontal section padding. COMPUTED: spacing.unit * 8 }
type RedocTheme ¶ added in v1.1.1
type RedocTheme struct { Spacing *RedocSpacing `json:"spacing,omitempty"` Breakpoints *RedocBreakpoints `json:"breakpoints,omitempty"` Colors *RedocColors `json:"colors,omitempty"` Typography *RedocTypography `json:"typography,omitempty"` Sidebar *RedocSidebar `json:"sidebar,omitempty"` Logo *RedocLogo `json:"logo,omitempty"` RightPanel *RedocRightPanel `json:"rightPanel,omitempty"` Fab *RedocFab `json:"fab,omitempty"` }
type RedocTypography ¶ added in v1.1.1
type RedocTypography struct { FontSize string `json:"fontSize,omitempty"` // '14px' LineHeight string `json:"lineHeight,omitempty"` // '1.5em' FontWeightRegular string `json:"fontWeightRegular,omitempty"` // '400' FontWeightBold string `json:"fontWeightBold,omitempty"` // '600' FontWeightLight string `json:"fontWeightLight,omitempty"` // '300' FontFamily string `json:"fontFamily,omitempty"` // 'Roboto, sans-serif' Smoothing string `json:"smoothing,omitempty"` // 'antialiased' OptimizeSpeed bool `json:"optimizeSpeed"` // true Headings *RedocHeadings `json:"headings,omitempty"` Code *RedocCode `json:"code,omitempty"` Links *RedocLinks `json:"links,omitempty"` }
type Request ¶
type Request struct { // Ref is the OAS $ref name for the request // // If this is a non-empty string and the response is used by Method.Request, then a $ref to "#/components/requestBodies/" is used // // If the Request is used by Components.Requests this value is ignored Ref string // Description is the OAS description Description string // Required is the OAS flag determining if the request is required Required bool // ContentType is the OAS content type // // defaults to "application/json" ContentType string // AlternativeContentTypes is a map of alternative content types (where the key is the media type - e.g. "application/json") AlternativeContentTypes ContentTypes // Schema is the optional OAS Schema // // Only used if the value is non-nil - otherwise uses SchemaRef is used // // The value can be any of the following: // // * chioas.Schema (or *chioas.Schema) // // * a chioas.SchemaConverter // // * a chioas.SchemaWriter // // * a struct or ptr to struct (schema written is determined by examining struct fields) // // * a slice of structs (items schema written is determined by examining struct fields) Schema any // SchemaRef is the OAS schema reference // // Only used if value is a non-empty string - if both Schema is nil and SchemaRef is empty string, then an // empty object schema is written to the spec yaml, e.g. // schema: // type: "object" // // If the value does not contain a path (i.e. does not contain any "/") then the ref // path will be the value prefixed with components schemas path. For example, specifying "foo" // will result in a schema ref: // schema: // $ref: "#/components/schemas/foo" SchemaRef string // IsArray indicates that request is an array of items IsArray bool // Extensions is extension OAS yaml properties Extensions Extensions // Additional is any additional OAS spec yaml to be written Additional Additional // Comment is any comment(s) to appear in the OAS spec yaml (not used with Ref) Comment string }
Request represents the OAS definition of a request
type Response ¶
type Response struct { // Ref is the OAS $ref name for the response // // If this is a non-empty string and the response is used by Method.Responses, then a $ref to "#/components/responses/" is used // // If the Response is used by Components.ResponseBodies this value is ignored Ref string // Description is the OAS description Description string // NoContent indicates that this response has not content // // This does not eed to set this when status code is http.StatusNoContent NoContent bool // ContentType is the OAS content type // // defaults to "application/json" ContentType string // AlternativeContentTypes is a map of alternative content types (where the key is the media type - e.g. "application/json") AlternativeContentTypes ContentTypes // Schema is the optional OAS Schema // // Only used if the value is non-nil - otherwise uses SchemaRef is used // // The value can be any of the following: // // * chioas.Schema (or *chioas.Schema) // // * a chioas.SchemaConverter // // * a chioas.SchemaWriter // // * a struct or ptr to struct (schema written is determined by examining struct fields) // // * a slice of structs (items schema written is determined by examining struct fields) Schema any // SchemaRef is the OAS schema reference // // Only used if value is a non-empty string - if both Schema is nil and SchemaRef is empty string, then an // empty object schema is written to the spec yaml, e.g. // schema: // type: "object" // // If the value does not contain a path (i.e. does not contain any "/") then the ref // path will be the value prefixed with components schemas path. For example, specifying "foo" // will result in a schema ref: // schema: // $ref: "#/components/schemas/foo" SchemaRef string // IsArray indicates that request is an array of items IsArray bool // Extensions is extension OAS yaml properties Extensions Extensions // Additional is any additional OAS spec yaml to be written Additional Additional // Comment is any comment(s) to appear in the OAS spec yaml (not used with Ref) Comment string }
Response is the OAS definition of a response
type Schema ¶
type Schema struct { // Name is the OAS name of the schema Name string // Description is the OAS description Description string // Type is the OAS type // // Should be one of "string", "object", "array", "boolean", "integer", "number" or "null" Type string // RequiredProperties is the ordered collection of required properties // // If any of the items in Properties is also denoted as Property.Required, these are // automatically added to RequiredProperties RequiredProperties []string // Properties is the ordered collection of properties Properties Properties // Default is the OAS default Default any // Example is the OAS example for the schema Example any // Enum is the OAS enum Enum []any // Extensions is extension OAS yaml properties Extensions Extensions // Additional is any additional OAS spec yaml to be written Additional Additional // Comment is any comment(s) to appear in the OAS spec yaml Comment string }
Schema represents the OAS definition of a schema
type SchemaConverter ¶ added in v1.4.0
type SchemaConverter interface {
ToSchema() *Schema
}
type SchemaWriter ¶ added in v1.4.0
type SecurityScheme ¶ added in v1.2.0
type SecurityScheme struct { // Name is the OAS name of the security scheme Name string // Description is the OAS description Description string // Type is the OAS security scheme type // // Valid values are: "apiKey", "http", "mutualTLS", "oauth2", "openIdConnect" // // Defaults to "http" Type string // Scheme is the OAS HTTP Authorization scheme Scheme string // ParamName is the OAS param name (in query, header or cookie) ParamName string // In is the OAS definition of where the API key param is found // // Valid values are: "query", "header" or "cookie" In string // Scopes is the security requirement scopes // // Only used when the SecurityScheme is part of Definition.Security and the // Type is either "oauth2" or "openIdConnect" Scopes []string // Extensions is extension OAS yaml properties Extensions Extensions // Additional is any additional OAS spec yaml to be written Additional Additional // Comment is any comment(s) to appear in the OAS spec yaml Comment string }
SecurityScheme represents the OAS definition of a security scheme
type SecuritySchemes ¶ added in v1.2.0
type SecuritySchemes []SecurityScheme
SecuritySchemes is an ordered collection of SecurityScheme
Used by:
* Components.SecuritySchemes to define the security schemes used by the api
* Definition.Security to define the security requirements across the entire api
* Method.Security to define the security requirement for a particular method
type Server ¶
type Server struct { // Description is the OAS description Description string // Extensions is extension OAS yaml properties Extensions Extensions // Additional is any additional OAS spec yaml to be written Additional Additional // Comment is any comment(s) to appear in the OAS spec yaml Comment string }
Server represents the OAS definition of a server
type SupportFiles ¶ added in v1.8.1
type SupportFiles interface {
ServeHTTP(http.ResponseWriter, *http.Request)
}
type Tag ¶
type Tag struct { // Name is the OAS name of the tag Name string // Description is the OAS description Description string // ExternalDocs is the optional OAS external docs ExternalDocs *ExternalDocs // Extensions is extension OAS yaml properties Extensions Extensions // Additional is any additional OAS spec yaml to be written Additional Additional // Comment is any comment(s) to appear in the OAS spec yaml Comment string }
Tag represents the OAS definition of a tag