Skip to content

Latest commit

 

History

History
202 lines (154 loc) · 11.7 KB

RELEASE_NOTES.md

File metadata and controls

202 lines (154 loc) · 11.7 KB

Release Notes

v3.0.0 (TBD)

  • OpenAPI v3.x support (Issue #128)
  • API Changes
    • Path.api -> Path.apiDefinition
    • SwaggerApi -> ApiDefinition

v2.0.4 (2018-08-31)

  • Another attempt at fixing the TypeScript definitions

v2.0.3 (2018-08-26)

  • Fix TypeScript definitions

v2.0.2 (2018-08-08)

  • Fix TypeScript definitions

v2.0.1 (2018-08-04)

  • Fix bug where non-plain objects passed to Operation#validateRequest, Operation#validateResponse, Parameter#getValue and Response#validateResponse failed input validation (Issue #35)
  • Upgrade path-laoder (via json-refs) to upgrade superagent to avoid NSP warnings (Issue #155)

v2.0.0 (2018-07-18)

  • Added support for performing custom request/response validation by passing in an options object as the optional second parameter to Operation#validateRequest, Operation#validateResponse and Response#validateResponse with a customValidators property containing an Array of Function objects (Issue #171)
    • The previously-mentioned APIs were updated to move the optional strictMode argument to be a property within the options object. (Please review the API documentation for more details.)
  • Added support for registering custom format generators via options.customFormatGenerators when creating the SwaggerApi object and/or calling SwaggerApi#registerFormatGenerator (Issue #100)
  • Added support for registering custom format validators via options.customFormats when creating the SwaggerApi object and/or calling SwaggerApi#registerFormat (Issue #74)
  • Added support for strict request/response validation (Issue #94)
    • Operation#validateRequest, Operation#validateResponse and Response#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 and query 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 and SwaggerApi#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 and PUT 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 and Response#getSample for type: file failed (Issue #159)
  • Fix bug where Path#getOperation by operationId returned the matching Path instead of Operation (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 and Response#validateResponse to no longer validate Content-Type headers when there is no body (Issue #164)
  • Updated ParameterValue to provide better errors for empty values when allowEmptyValue is false (Issue #88)
  • Updated Sway#getPath and Parameter#getValue to work with request objects containing originalUrl (Issue #156)
  • Updated Sway#getPath to better handle multiple matches for http.ClientRequest (or similar) (Issue #76)
  • Updated Sway#getPath to work with characters special to RegExp/path-to-regexp in path definitions for http.ClientRequest (or similar) (Issue #79)
  • Updated Sway#getOperation and Path#getOperation to work with an operationId (Issue #152)

v1.0.0 (2016-04-04)

  • 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 overwrite Operation.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 to Sway
  • Changed the definition property for Operation, Parameter, Path and Response to now be definitionFullyResolved and now the definition 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 relative options.definition did not take options.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 the Response type except Operation#validateResponse (Issue #44)
    • API Additions
      • Operation#getResponse
      • Operation#getResponses
    • API Changes
      • Operation#getResponseExample -> Response#getExample
      • Operation#getResponseSample -> Response#getSample
  • 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 set Operation.parameters to include all parameter definitions, even ones defined at the path level. This could be confusing. Operation.parameterObjects, Operation#getParameters and Operation#getParameter already solve the need to have a composite view for operation parameters.)
  • Removed Parameter#getSchema and Parameter.computedSchema in favor of using Parameter.schema for consistency
  • Removed SwaggerApi.resolved in favor of SwaggerApi.definitionFullyResolved (Object containing the Swagger with all references fully resolved)
  • Updated Operation#validateRequest, Operation#validateResponse, Parameter#getValue and Response#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 not undefined (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)

v0.6.0 (2015-11-25)

  • Remove logic to do type coercion when the expected type is unknown (We use to assume that a missing type was of type object. This is wrong per JSON Schema which allows a missing type and handles it specially.)

v0.5.4 (2015-11-25)

  • Fixed bug in error reporting when Buffer was converted to a String and failed type conversion

v0.5.3 (2015-11-25)

  • Fixed a bug with String->Object conversion resulting in unexpected response validation errors (Issue #46)

v0.5.2 (2015-11-11)

  • Added validator for empty path parameter declarations (Issue #40)
  • Fixed a bug with validating strings that were not date or date-time format (Issue #41)
  • Fixed a bug where passing a Buffer to Operation#validateResposne could result in unexpected schema validation failure (Issue #42)

v0.5.1 (2015-11-03)

  • Updated Operation#validateResponse to use the default response when validating a response code that isn't defined

v0.5.0 (2015-11-02)

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 an Error but instead to put the error details in the response structure

v0.4.0 (2015-11-02)

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 and Operation#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 and SwaggerApi#getLastWarnings in favor of SwaggerApi#validate returning the validation results. This will make all of the validation APIs consistent in how they work.

v0.3.3 (2015-10-23)

  • 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 an http.ClientRequest) (Issue #35)
  • Updated json-refs to fix a bug with remote reference errors (Issue #36)

v0.3.2 (2015-10-14)

  • Fixed sub-schema validation of properties with special names (PR 30)
  • Updated Swagger 2.0 JSON Schema (PR 31)

v0.3.1 (2015-09-30)

  • 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 or oneOf validation fails (Issue #15)
  • Update json-refs to work with options.jsonRefs.location having a hash (Issue #24)

v0.3.0 (2015-09-18)

  • Updated json-refs for service/web worker support (Issues #22)
  • Updated z-schema to avoid throwing runtime errors on unknown formats (Issues #20)

v0.2.3 (2015-08-31)

  • Updated json-refs to fix a big bug in local reference resolution for remote documents (See json-refs/issues/30)

v0.2.2 (2015-08-31)

  • Fix a bug where missing securityDefinitions could result in a runtime error

v0.2.1 (2015-08-26)

  • Fix bug with loading relative references (Issue #17)
  • Fix bug with loading YAML references (Issue #17)
  • Make errors in SwaggerApi#create handleable (Issue #16)

v0.2.0 (2015-08-25)

  • Added Path object, SwaggerApi#getPath(reqOrPath) and SwaggerApi#getPaths()

v0.1.0 (2015-08-12)

  • Initial release