9fe4437bda
* Use vendored go-swagger * vendor go-swagger * revert un wanteed change * remove un-needed GO111MODULE * Update Makefile Co-Authored-By: techknowlogick <matti@mdranta.net>
85 lines
3.6 KiB
Go
85 lines
3.6 KiB
Go
// +build !go1.11
|
|
|
|
// Copyright 2015 go-swagger maintainers
|
|
//
|
|
// 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.
|
|
|
|
/*Package scan provides a scanner for go files that produces a swagger spec document.
|
|
|
|
You give it a main file and it will parse all the files that are required by that main
|
|
package to produce a swagger specification.
|
|
|
|
To use you can add a go:generate comment to your main file for example:
|
|
|
|
//go:generate swagger generate spec
|
|
|
|
The following annotations exist:
|
|
|
|
swagger:meta
|
|
|
|
The swagger:meta annotation flags a file as source for metadata about the API.
|
|
This is typically a doc.go file with your package documentation.
|
|
|
|
You can specify a Consumes and Produces key which has a new content type on each line
|
|
Schemes is a tag that is required and allows for a comma separated string composed of:
|
|
http, https, ws or wss
|
|
|
|
Host and BasePath can be specified but those values will be defaults,
|
|
they should get substituted when serving the swagger spec.
|
|
|
|
Default parameters and responses are not supported at this stage, for those you can edit the template json.
|
|
|
|
swagger:strfmt [name]
|
|
|
|
A swagger:strfmt annotation names a type as a string formatter. The name is mandatory and that is
|
|
what will be used as format name for this particular string format.
|
|
String formats should only be used for very well known formats.
|
|
|
|
swagger:model [?model name]
|
|
|
|
A swagger:model annotation optionally gets a model name as extra data on the line.
|
|
when this appears anywhere in a comment for a struct, then that struct becomes a schema
|
|
in the definitions object of swagger.
|
|
|
|
The struct gets analyzed and all the collected models are added to the tree.
|
|
The refs are tracked separately so that they can be renamed later on.
|
|
|
|
When this annotation is found to be on an interface instead of a struct, the properties are provided
|
|
through exported nullary methods.
|
|
|
|
A property of an interface model can have a Discriminator: true annotation to mark that field as
|
|
the field that will contain the discriminator value.
|
|
|
|
swagger:route [method] [path pattern] [operation id] [?tag1 tag2 tag3]
|
|
|
|
A swagger:route annotation links a path to a method.
|
|
This operation gets a unique id, which is used in various places as method name.
|
|
One such usage is in method names for client generation for example.
|
|
|
|
Because there are many routers available, this tool does not try to parse the paths
|
|
you provided to your routing library of choice. So you have to specify your path pattern
|
|
yourself in valid swagger syntax.
|
|
|
|
swagger:params [operationid1 operationid2]
|
|
|
|
Links a struct to one or more operations. The params in the resulting swagger spec can be composed of several structs.
|
|
There are no guarantees given on how property name overlaps are resolved when several structs apply to the same operation.
|
|
This tag works very similarly to the swagger:model tag except that it produces valid parameter objects instead of schema
|
|
objects.
|
|
|
|
swagger:response [?response name]
|
|
|
|
Reads a struct decorated with swagger:response and uses that information to fill up the headers and the schema for a response.
|
|
A swagger:route can specify a response name for a status code and then the matching response will be used for that operation in the swagger definition.
|
|
*/
|
|
package scan
|