Custom OpenAPI Templates
This directory contains custom mustache templates used by the OpenAPI code generator. The original templates were extracted by running:
openapi-generator author template -g go
NOTE: This command extracts a copy of every template used by the generator, but we only track templates that we've modified here. The generator can handle sourcing templates from multiple locations.
What have we changed?
api.mustache
- Add
GetX()methods for each request parameterX, for use in unit tests - Add checks for
isByteArrayto generate[]byterequest fields instead of*string - Add checks for
isBinaryto generateio.ReadCloserrequest fields instead of**os.File - Update creation of
GenericOpenAPIErrorto track sub-error models by reference - Add checks for
isResponseBinaryto directly return the raw*http.Response, instead of pulling the entire body into memory and transforming it into an*os.File - GUnzip non-binary response bodies before unmarshalling when
Content-Encoding: gzipis set - Remove
*http.Responses from the return values of generatedExecuteoperations & provide a separate methodExecuteWithHttpInfofor returning the*http.Responseif needed. The standardExecuteoperation should normally be used unless specific header values or response codes need to be examined with theExecuteWithHttpInfo. The response body cannot be read from the*http.Reponsereturned fromExecuteWithHttpInfoas it will have already have been read and closed; access to the response body content should be achieved through the returned response model if applicable
client.mustache
- Removed use of
golang.org/x/oauth2to avoid its heavy dependencies - Fixed error strings to be idiomatic according to staticcheck (lowercase, no punctuation)
- Use
strings.EqualFoldinstead of comparing twostrings.ToLowercalls - Update the
GenericOpenAPIErrortype to enforce that error response models implement theerrorinterface - Update
setBodyto avoid buffering data in memory when the request body is already anio.ReadCloser
configuration.mustache
- Deleted
ContextOAuth2key to match modification in client - Fixed error strings to be idiomatic according to staticcheck (lowercase, no punctuation)
model_enum.mustache
- Add a function to build and return a slice of the valid values for the enum, named <enum_name>Values
model_oneof.mustache
- Fixed error strings to be idiomatic according to staticcheck (lowercase, no punctuation)
model_simple.mustache
- Added
yaml:tags to all model fields to support unmarshalling camelCase - Added support for
x-go-field-typevendor extension, to explicitly override the type generated for model fields