Important: This documentation covers Yarn 1 (Classic).
For Yarn 2+ docs and migration guide, see yarnpkg.com.

Package detail

openapi3-ts

metadevpro6mMIT4.4.0TypeScript support: included

TS Model & utils for OpenAPI 3.x specification.

openapi3, ts, typescript

readme

OpenApi3-TS

TypeScript library to help building OpenAPI 3.x compliant API contracts.

Coverage Status Known Vulnerabilities npm version

NPM

Version 4

Breaking change notice:

Version 4.0 Adds explicit support for OAS 3.0 and OAS 3.1 as separate implementations.

To use version 3.1 import

import { oas31 } from 'openapi3-ts';

Or directly import from subpath:

import { OpenAPIObject, OpenApiBuilder } from 'openapi3-ts/oas31';

To use version 3.0 import

import { oas30 } from 'openapi3-ts';

Or directly import from subpath:

import { OpenAPIObject, OpenApiBuilder } from 'openapi3-ts/oas30';

Includes

  • /src/model TS typed interfaces for helping building a contract.
  • /src/dsl Fluent DSL for building a contract.

Install

Install package via npm:

npm i --save openapi3-ts

Documentation, Versions, and Changelog

References

License

Licensed under the MIT License.

Credits

Contact: Pedro J. Molina | github: pjmolina | twitter: pmolinam

(c) 2017-2024. Pedro J. Molina at Metadev S.L. https://metadev.pro & contributors.

changelog

Changelog: openapi3-ts

Version 4.4.0

2024.08.27

  • Updated libs
  • Updated lo latest eslint (migrated config file)
  • Updated vite config to mts
  • Added basic documentation. Fix #75. PR#139
  • Feat: getSpecAsYaml accepts the same options as yaml.stringify. Fix #143. PR#144 by @urugator

Version 4.3.3

2024.06.10

  • Add mising types definitions. PR #138 by @andreujuanc

Version 4.3.2

2024.05.23

  • Fix #134 exceisve files in distributed package. PR 136 by @RobinTail

Version 4.3.1

2024.04.01

  • Bug fix. const must be of type any. #133 by @RobinTail

Version 4.3.0

2024.04.01

  • Added support for const keyword #132 by @remidewitte
  • Update dependences.

Version 4.2.2

2024.02.22

  • Fixed 131 responses to be optional by @remidewitte

Version 4.2.1

2023.12.21

  • Merged #128 Revert #126 examples typings by @RobinTail

    2023.12.20

  • Added #126 Adding contentEncoding and contentMediaType to 3.1 by @RobinTail

  • Updated dependencies

Version 4.1.2

2023.04.25

  • Fix #113 Fix nullable on 3.0 types by @samchungy
  • Fix #116 Export with .mjs extension by @koooge
  • Fix #117 Support subpath for tsc with moduleResolutin node by @koooge
  • Fix #118 Bump yaml from 2.2.1 to 2.2.2
  • Update dependencies to latest.

Version 4.1.1

2023.04.15

  • Fix #112 Remove nullable & deprecate example in OAS 3.1 by @samchungy.

Version 4.1.0

2023.04.14

  • #111 Improved exports by @koooge

Version 4.0.4

2023.04.10

  • #108 Bug fix: Remove any type from paths by @samchungy.
  • #109 Bug fix: Fixup types example & prefixItems by @samchungy.

Version 4.0.3

2023.03.30

  • Bug fix. Stricter TS compilation. Fix issue #105

Version 4.0.2

2023.03.30

  • PR #104 Fix export for cjs by @RobinTail

Version 4.0.1

2023.03.29

  • Added instructions to README for consuing the library for v. 3.1.0 vs 3.0.0
  • PR #100 Fix typo by @RobinTail
  • PR #99 Fix typo by @RobinTail
  • PR #97 Export type SchemaObjectType by @RobinTail
  • PR #96 Support prefixItems by @samchungy

Version 4.0.0

2023.03.27

  • Breaking change. Adds explicit support for OAS 3.0 and OAS 3.1 as separate implementations.

Version 3.2.0

  • PR #94 Export type SchemaObjectType.
  • PR #95 Export type SchemaObjectFormat. Both contributed by @beautyfree

Version 3.1.2

2022.11.19

  • PR #91 Fix addPath to include merge semantics. Contributed by @MaurerKrisztian

Version 3.1.1

2022.10.10

  • PR #89 Make Webhooks optional (not supportet in OPenAPI 3.0). Contributed by @samchungy

Version 3.1.0

2022.10.06

  • PR #88 Added support to Webhooks. Contributed by @samchungy

Version 3.0.3

2022.10.06

  • PR #87 Enable type array for schema object on OpenAPI 3.1. contributed by @samchungy

Version 3.0.2

2022.08.29

  • PR #85 Enable support for version 3.0.1 and 3.1.0 (Lax typing for exclusiveMinimum and exclusiveMaximum). contributed by @RobinTail

Version 3.0.1

2022.08.16

  • PR #82 Emit helpers for the CJS build. contributed by @RobinTail

Version 3.0.0

2022.08.07

  • PR #80 contributed by @jonluca
    • Updated libs
    • Breaking change: Changed build system to output esm as well as cjs (folders dist/mjs and dist/cjs now respectively, instead of dist for cjs previously).
    • Changed test system to use vite
    • Added stricter extension prefix typing

Version 2.0.2

2022.02.17

  • Updated libs

Version 2.0.1

2020.12.31

  • Updated testing libs
  • Added ESList + Prettier, removed TSList support
  • Refactor to be consistent with ESLint + Prettier code-style rules
  • No functional changes in this version: just end of year house-keeping.

Version 2.0.0

2020.09.18

  • Added Yaml Support and the first dependence to yaml library. Thanks to @DMavani
  • Better typing for type and format properties. Thanks to @xeptore
  • Keeping extensibility on format.

Version 1.4.0

2020.06.06