- OpenAPI v3.x support (Issue #128)
- API Changes
Path.api
->Path.apiDefinition
SwaggerApi
->ApiDefinition
- Another attempt at fixing the TypeScript definitions
- Fix TypeScript definitions
- Fix TypeScript definitions
- Fix bug where non-plain objects passed to
Operation#validateRequest
,Operation#validateResponse
,Parameter#getValue
andResponse#validateResponse
failed input validation (Issue #35) - Upgrade
path-laoder
(viajson-refs
) to upgradesuperagent
to avoid NSP warnings (Issue #155)
- Added support for performing custom request/response validation by passing in an
options
object as the optional second parameter toOperation#validateRequest
,Operation#validateResponse
andResponse#validateResponse
with acustomValidators
property containing anArray
ofFunction
objects (Issue #171)- The previously-mentioned APIs were updated to move the optional
strictMode
argument to be a property within theoptions
object. (Please review the API documentation for more details.)
- The previously-mentioned APIs were updated to move the optional
- Added support for registering custom format generators via
options.customFormatGenerators
when creating theSwaggerApi
object and/or callingSwaggerApi#registerFormatGenerator
(Issue #100) - Added support for registering custom format validators via
options.customFormats
when creating theSwaggerApi
object and/or callingSwaggerApi#registerFormat
(Issue #74) - Added support for strict request/response validation (Issue #94)
Operation#validateRequest
,Operation#validateResponse
andResponse#validateResponse
now have an optional second argument (strictMode
) that dictates whether strict mode validation is on/off and to what portion(s) of the request/response needs to be validated (formData
is request only,headers
are request and response andquery
is request only. Please review the API documentation for more details.)
- Added support for unregistering custom formats and custom format generators by calling
SwaggerApi#unregisterFormat
andSwaggerApi#unregisterFormatGenerator
respectively - Fix bug where array values in query parameters contained a single item, it could be coerced inadvertently
- Fix bug where default values for arrays were not used when they should be (Issue #132)
- Fix bug where global security definitions never made it to its
Operation
object (Issue #120) - Fix bug where missing optional file parameters were treated as a validation failure (Issue #129)
- Fix bug where path matching was not case sensitive (Issue #147)
- Fix bug where referenceable objects were were remote documents and references to them were not recorded and resulted
in
UNUSED_DEFINITION
warnings (Issue #179) - Fix bug where references were resolved multiple times (Issue #123)
- Fix bug where request validation only worked for
POST
andPUT
operations (Issue #134) - Fix bug where resolving
consumes
/produces
was failing (Issue #92) - Fix bug where sample generation for
format: date
failed (Issue #99, PR #174) - Fix bug where
Parameter#getSample
andResponse#getSample
fortype: file
failed (Issue #159) - Fix bug where
Path#getOperation
byoperationId
returned the matchingPath
instead ofOperation
(Issue #175) - Performance improvement by lazily initializing
json-schema-faker
(PR #153) - Updated dependencies (Issue #62, #72, #80, #84, #104, #141)
- Update
Operation#validateRequest
,Operation#validateResponse
andResponse#validateResponse
to no longer validateContent-Type
headers when there is no body (Issue #164) - Updated
ParameterValue
to provide better errors for empty values whenallowEmptyValue
isfalse
(Issue #88) - Updated
Sway#getPath
andParameter#getValue
to work with request objects containingoriginalUrl
(Issue #156) - Updated
Sway#getPath
to better handle multiple matches forhttp.ClientRequest
(or similar) (Issue #76) - Updated
Sway#getPath
to work with characters special toRegExp
/path-to-regexp in path definitions forhttp.ClientRequest
(or similar) (Issue #79) - Updated
Sway#getOperation
andPath#getOperation
to work with anoperationId
(Issue #152)
- Added support for nested query parameters, as supported by qs (Issue #39)
- Added
Operation#getParameter(name, [location])
(Issue #56) - Added
Operation#getSecurity
to gather the composite security for an operation (The previous approach was to overwriteOperation.security
with the computed value but this could be confusing) - Added
SwaggerApi.definitionRemotesResolved
(Object containing the Swagger document with all of its remote references resolved) - Changed object exported in the browser from
SwaggerApi
toSway
- Changed the
definition
property forOperation
,Parameter
,Path
andResponse
to now bedefinitionFullyResolved
and now thedefinition
property is the original, non-dereferenced value - Fixed a bug where
date
/date-time
formats were not validated properly (PR #70) - Fixed a bug where
Path#getOperation
did not handle uppercase method - Fixed a bug where
Sway#create
did not properly register custom validators (Issue #53) - Fixed a bug where
Sway#create
with a relativeoptions.definition
did not takeoptions.jsonRefs.relativeBase
into account for the initial load - Fixed a bug where identifying required parameters didn't work in all cases (Issue #60)
- Fixed a bug where we removed
String -> [Array|Object]
coercion to fix issue #46 but shouldn't had (Issue #48)' - Moved all response-specific APIs from
Operation
to theResponse
type exceptOperation#validateResponse
(Issue #44)- API Additions
Operation#getResponse
Operation#getResponses
- API Changes
Operation#getResponseExample
->Response#getExample
Operation#getResponseSample
->Response#getSample
- API Additions
- Removed callback support for
Sway#create
(Issue 51) - Removed plugin support (Issue #55)
- Removed approach that would overwrite
Operation.parameters
with the composite parameters (The previous approach would setOperation.parameters
to include all parameter definitions, even ones defined at the path level. This could be confusing.Operation.parameterObjects
,Operation#getParameters
andOperation#getParameter
already solve the need to have a composite view for operation parameters.) - Removed
Parameter#getSchema
andParameter.computedSchema
in favor of usingParameter.schema
for consistency - Removed
SwaggerApi.resolved
in favor ofSwaggerApi.definitionFullyResolved
(Object containing the Swagger with all references fully resolved) - Updated
Operation#validateRequest
,Operation#validateResponse
,Parameter#getValue
andResponse#validateResponse
to work with mixed-case header names (Issue #67) - Updated
SwaggerApi#validate
to include json-refs warnings as validation warnings - Updated invalid/missing JSON References to be a structural validation errors like z-schema does
- Updated validation errors/warnings to no longer have
params
pruned (Issue #61) - Updated validation errors/warnings to no longer have
schemaId
pruned when its value is notundefined
(Issue #61) - Updated validation to not stop at the first JSON Schema validation error (Issue #63)
- Various changes to all constructors in
lib/types
(Should have no impact since these are technically internal)
- Remove logic to do type coercion when the expected type is unknown (We use to assume that a missing
type
was oftype
object
. This is wrong per JSON Schema which allows a missingtype
and handles it specially.)
- Fixed bug in error reporting when
Buffer
was converted to aString
and failed type conversion
- Fixed a bug with
String
->Object
conversion resulting in unexpected response validation errors (Issue #46)
- Added validator for empty path parameter declarations (Issue #40)
- Fixed a bug with validating strings that were not
date
ordate-time
format (Issue #41) - Fixed a bug where passing a
Buffer
toOperation#validateResposne
could result in unexpected schema validation failure (Issue #42)
- Updated
Operation#validateResponse
to use thedefault
response when validating a response code that isn't defined
Note: This release changes how Operation#validateResponse
works. Instead of throwing an Error
whenver the API
is consumed when providing a status code that is not documented in Swagger, we now provide the error details in the
response structure. (I realize I said I'd do my best to avoid breaking changes but this change was based on user
feedback and the chances of v0.4.0
installations being out there are very small.)
- Updated
Operation#validateResponse
to no longer throw anError
but instead to put the error details in the response structure
Note: This release has a breaking change as documented below. I realize changing APIs should result in a major
version release but I did not want to force an early v1.0.0
release just because of this. The possibility of
breaking API changes prior to v1.0.0
were clearly mentioned on the project home page from day one. While I will
do my best to avoid this happening, this was one of those cases where for API consistency, the change was merited.
- Added
Operation#validateRequest
andOperation#validateResponse
APIs - Fixed issue with valid models being marked as inheriting circularly when an ancestor model has a circular reference (Issue #38)
- (BREAKING) Removed
SwaggerApi#getLastErrors
andSwaggerApi#getLastWarnings
in favor ofSwaggerApi#validate
returning the validation results. This will make all of the validation APIs consistent in how they work.
- Fixed issue with file parameters being marked as invalid (Issue #37)
- Fixed issue with optional parameters being marked as invalid (Issue #34)
- Fixed issue with
Parameter#getValue
not supporting non-plain object *(We need this for when passing in anhttp.ClientRequest
) (Issue #35) - Updated json-refs to fix a bug with remote reference errors (Issue #36)
- Fixed sub-schema validation of properties with special names (PR 30)
- Updated Swagger 2.0 JSON Schema (PR 31)
- Add support for
allowEmptyValue
for parameter value validation (Issue #27) - Better integer validation for parameter values (PR #26)
- More human-readable errors related to JSON Schema validation when
anyOf
oroneOf
validation fails (Issue #15) - Update json-refs to work with
options.jsonRefs.location
having a hash (Issue #24)
- Updated json-refs for service/web worker support (Issues #22)
- Updated z-schema to avoid throwing runtime errors on unknown formats (Issues #20)
- Updated json-refs to fix a big bug in local reference resolution for remote documents (See json-refs/issues/30)
- Fix a bug where missing
securityDefinitions
could result in a runtime error
- Fix bug with loading relative references (Issue #17)
- Fix bug with loading YAML references (Issue #17)
- Make errors in
SwaggerApi#create
handleable (Issue #16)
- Added
Path
object,SwaggerApi#getPath(reqOrPath)
andSwaggerApi#getPaths()
- Initial release