toc | ||
---|---|---|
|
- Fixed an issue where running the
preview
command failed because one of its dependencies could not be resolved. The issue occurred when Realm was not installed in thenode_modules
of the project. - Updated @redocly/openapi-core to v1.27.1.
- Added the ability to override default problem messages for built-in rules.
- Fixed an issue where
apis
' root inredocly.yaml
was not resolved properly when the value ofroot
was a URL. - Updated the Redocly CLI command
redocly build-docs
to usestdout
instead ofstderr
for simple logs. - Updated @redocly/openapi-core to v1.27.0.
- Fixed an issue where an API alias's root path might be resolved incorrectly for configuration files located outside the root folder.
- Updated @redocly/openapi-core to v1.26.1.
- Introduced the
struct
rule and deprecated thespec
rule. Added thespec
ruleset, which enforces compliance with the specifications.
- Fixed an issue where the CLI would fail to run on Windows due to a breaking change in the Node.js API.
- Fixed an issue where
join
would throw an error when a glob pattern was provided. - Updated
sourceDescriptions
to enforce a valid type field, ensuring compliance with the Arazzo specification. - Updated @redocly/openapi-core to v1.26.0.
- Clarified usage of the
--output
option in thebundle
command. - Updated @redocly/openapi-core to v1.25.15.
- Resolved an issue where overrides for the severity of configurable rules were ignored.
- Updated @redocly/openapi-core to v1.25.14.
- Added the possibility to skip configurable rules using the
--skip-rule
option. - Updated @redocly/openapi-core to v1.25.13.
- Fixed an issue where valid Redocly tokens were not recognized.
- Updated @redocly/openapi-core to v1.25.12.
- Fixed an issue with the
remove-x-internal
decorator where bundling API descirptions containing discriminators could fail when using Node.js v17 or earlier. - Fixed API descriptions bundling. Previously, schemas containing nulls in examples were causing failures.
- Updated @redocly/openapi-core to v1.25.11.
- Fixed
component-name-unique
problems to include correct location. - Fixed the
remove-x-internal
decorator, which was not removing the reference in the corresponding discriminator mapping while removing the original$ref
. - Updated @redocly/openapi-core to v1.25.10.
- Updated @redocly/openapi-core to v1.25.9.
- Added the
REDOCLY_SUPPRESS_UPDATE_NOTICE
environment variable so that users can skip version updates. - Fixed bundling with the
--dereferenced
option. Previously, references to external files were not substituted with references to components, causing them to become invalid. - Fixed an issue where using
externalValue
as a property name was causing the API description validation process to fail. - Updated @redocly/openapi-core to v1.25.8.
- Updated redoc to v2.2.0.
- Removed the support of the
x-inherit
extension for Arazzo description files. - Updated @redocly/openapi-core to v1.25.7.
- Changed the
x-operation
extension in Arazzo, enabling users to make requests with this extension without an API description file. - Removed the support of the
x-parameters
extension for Arazzo description files. - Updated @redocly/openapi-core to v1.25.6.
- Fixed an issue where the bundle command did not resolve links in
externalValue
. - Fixed an issue where the plugins in external NPM packages could not be resolved if the CLI package was installed globally.
- Updated @redocly/openapi-core to v1.25.5.
- Added a warning message to the
push
andpush-status
commands to notify users about upcoming or ongoing resource deprecation. - Updated @redocly/openapi-core to v1.25.4.
- Updated @redocly/openapi-core to v1.25.3.
- Fixed
camelCase
assertion for single-letter values. - Updated @redocly/openapi-core to v1.25.2.
- Added additional checks to
criteria-unique
Arazzo rule. - Updated @redocly/openapi-core to v1.25.1.
- Added a cache for resolved plugins to ensure that plugins are only instantiated once during a single execution.
- Updated @redocly/openapi-core to v1.25.0.
- Added Spot and Arazzo rules:
no-criteria-xpath
,no-actions-type-end
,criteria-unique
.
- Fixed an issue where custom rules were not applied to Arazzo descriptions.
- Updated @redocly/openapi-core to v1.24.0.
- Fixed a bug where bundling multiple API description files specified as CLI arguments, along with the
--output
option, stored the result in a single file instead of a folder. - Updated @redocly/openapi-core to v1.23.1.
- Added support for the
output
option in the per-API configuration so that the destination file can be specified in configuration.
- Fixed the absolute path for importing plugins in Windows.
- Added the ability to run the
eject
command without specifying components, which displays a selectable list of all available components. - Updated @redocly/openapi-core to v1.23.0.
- Updated @redocly/openapi-core to v1.22.1.
- Updated the Arazzo validation types for workflows input, parameter objects, and criteria to match the specification.
- Added Arazzo rulesets so that users can customize their linting rules for this format.
- Updated @redocly/openapi-core to v1.22.0.
- Updated @redocly/openapi-core to v1.21.1.
- Added the
eject
andtranslate
commands for use with the new Reunite-hosted product family.
- Updated @redocly/openapi-core to v1.21.0.
- Get more helpful error messages when there's a problem importing a plugin.
- Updated @redocly/openapi-core to v1.20.1.
- Added support for ESM plugins and importing of plugins directly from npm package:
@vendor/package/plugin.js
instead of./node_modules/@vendor/package/plugin.js
. - Added
info-license-strict
rule as a replacement of theinfo-license-url
to support the OpenAPI 3.1 changes to allow identifier or URL license details. - Changed plugins format to export a function instead of an object for compatibility with other Redocly products. The backwards compatibility with an old format of plugins is maintained.
- Added support for webhooks in stats and fixed a crash that occurred when tags were not included in webhooks.
- Updated @redocly/openapi-core to v1.20.0.
- Added support for AsyncAPI 3.0 description linting.
- Fixed an issue where
patternProperties
incorrectly caused linting errors due to a missingPatternProperties
node. - Updated @redocly/openapi-core to v1.19.0.
- Allowed the
theme.openapi
configuration option to accept settings specific to Redoc 2.x and earlier. - Fixed an issue in the OpenAPI
spec
rule wheredependentSchemas
was parsed as an array. It is now correctly parsed as a map. - Fixed bundling of
$refs
insidepatternProperties
. - Updated AsyncAPI v2 typings to abide by JSON Schema draft-07 specification.
- Updated @redocly/openapi-core to v1.18.1.
- Added support for Arazzo description linting.
- Removed
additionalItems
from OAS 3.0.x typings. This keyword is not supported by the specification. - Updated @redocly/openapi-core to v1.18.0.
- Added JSON Schema draft 2019-09+ validation keyword -
dependentRequired
. - Updated @redocly/openapi-core to v1.17.1.
- Changed resolution process to include extendedTypes and plugins before linting.
- Added support for the
contentSchema
keyword to parse as a schema instance. - Replace path items emoji with 🔀 so the width is consistent.
- Updated @redocly/openapi-core to v1.17.0.
- Users can run the CLI tool behind a proxy by using
HTTP_PROXY
orHTTPS_PROXY
environment variables to configure the proxy settings.
- Updated @redocly/openapi-core to v1.16.0.
- Made
redocly.yaml
validation consistent with the general Redocly config.
- Updated Redoc to v2.1.5.
- Fixed
no-invalid-media-type-examples
,no-invalid-parameter-examples
, andno-invalid-schema-examples
rules which allowed falsy example values to pass for any schema. - Updated @redocly/openapi-core to v1.15.0.
- Added the ability to exclude some operations or entire paths from the
security-defined
rule.
- Improved error messages.
- Updated @redocly/openapi-core to v1.14.0.
- Added support for the linting command to output markdown format.
- Updated @redocly/openapi-core to v1.13.0.
- Updated @redocly/openapi-core to v1.12.2.
- Updated @redocly/openapi-core to v1.12.1.
- Added return values for the
push
andpush-status
commands.
- Fixed handling of wildcards on Windows (#1521).
- Updated @redocly/openapi-core to v1.12.0.
- Removed additional operations from the
join
command; uselint
and/orbundle
for operations such aslint
anddecorate
. - Removed lint support from the bundle command to support a wider range of use cases. Users should update to run lint and bundle separately.
- Added support for a
github-actions
output format for thelint
command to annotate reported problems on files when used in a GitHub Actions workflow.
- Fixed
no-invalid-media-type-examples
ruleexternalValue
example validation. - Updated @redocly/openapi-core to v1.11.0.
- Added
check-config
command to validate a Redocly configuration file. - Updated @redocly/openapi-core to v1.10.6.
- Updated license text for date and organization naming accuracy.
- Updated @redocly/openapi-core to v1.10.5.
- Fixed a problem with the
preview
command crashing on Windows by adding operating system detection for the correctnpx
executable to use. - Updated @redocly/openapi-core to v1.10.4.
- Reverted "Users can run the CLI tool behind a proxy by using HTTP_PROXY or HTTPS_PROXY environment variables to configure the proxy settings" temporary.
- Updated @redocly/openapi-core to v1.10.3.
- Users can run the CLI tool behind a proxy by using
HTTP_PROXY
orHTTPS_PROXY
environment variables to configure the proxy settings. - Updated @redocly/openapi-core to v1.10.2.
- Updated @redocly/openapi-core to v1.10.1.
- Users can run the CLI tool behind a proxy by using
HTTP_PROXY
orHTTPS_PROXY
environment variables to configure the proxy settings.
- Added inflection to the
join
command so that--prefix-components-with-info-prop
replaces spaces with underscores to create less confusing $refs. - Updated @redocly/openapi-core to v1.10.0.
- Adds support for using logical AND for the security schema so that the
join
command generates the correct schema. - Fixed a bug with resolving $refs to file names that contain the hash symbol.
- Fixed a problem where the
join
command did not process schemas containingnull
values when the--prefix-components-with-info-prop
option was used.' - Updated @redocly/openapi-core to v1.9.1.
-
- Removed descriptions adding for x-tagGroups for the
join
command. Descriptions in x-tagGroups are not supported and cause errors on linting. - Updated
info.title
to be used as a name in x-tagGroups instead of a file name for thejoin
command, so you can now join files with the same names.
- Removed descriptions adding for x-tagGroups for the
- Added new
no-required-schema-properties-undefined
rule to check if each required schema property is defined.
- Fixed an issue where using the
--prefix-components-with-info-prop
option with thejoin
command caused$refs
to include duplicated prefixes. - Fixed an issue where
$ref
s ending in#
(instead of#/
) would break the application. - Updated @redocly/openapi-core to v1.9.0.
- Added markdown format option to stats command for use with GitHub job summaries.
- Fixed an issue with the
push
command, whendestination
option does not work without specifying it inredocly.yaml
. - Updated @redocly/openapi-core to v1.8.2.
- Added git to the docker image, so the push command can use git metadata.
- Updated @redocly/openapi-core to v1.8.1.
- Added a
push
andpush-status
command for use with future Redocly products.
- Updated @redocly/openapi-core to v1.8.0.
- Added a
preview
command that starts a local preview server for Redocly projects that use products that are currently in a pre-release stage.
- Fixed an issue with resolving references after splitting API descriptions written in the json format.
- Added filename extension support for more
x-codeSamples
languages. - Fixed a problem where the linter incorrectly returned an error for valid examples that contain references.
- Updated @redocly/openapi-core to v1.7.0.
- Added the ability to use
$ref
in the Redocly config file. This ability allows users to split up big config files and maintain their constituent parts independently.
- Deprecated
--lint
option in thejoin
command. The options are marked for removal in a future release. Use the lint command separately to lint your APIs. - Updated @redocly/openapi-core to v1.6.0.
- Added new rule
array-parameter-serialization
to require that serialization parametersstyle
andexplode
are present on array parameters.
- Deprecated lint-related options in the
bundle
command. The options are marked for removal in a future release. Use the lint command separately to lint your APIs before bundling. - Updated Redoc to v2.1.3.
- Updated @redocly/openapi-core to v1.5.0.
- Fixed an issue with resolving the
node-fetch
package by explicitly adding the missing dependency. - Updated @redocly/openapi-core to v1.4.1.
- Added
recommended-strict
ruleset which uses the same rules asrecommended
but with the severity level set toerror
for all rules. - Add JSON output support to the
split
andjoin
commands.
- The
--host/-h
argument in thepreview-docs
command is now also used by the WebSocket server for hot reloading. - Updated @redocly/openapi-core to v1.4.0.
- Added the possibility to configure the linting severity level of the configuration file for all CLI commands.
Redocly CLI exits with an error if there are any issues with the configuration file, and the severity is set to
error
.
- Updated @redocly/openapi-core to v1.3.0.
- Fixed an issue with nested refs in the
join
command. - Fixed pattern for no-server-example.com rule to improve detection accuracy.
- Changed the report location for
pattern
andnotPattern
assertions to be more precise. - Updated
unevaluatedItems
type definition to resolve either boolean or object schema per JSON Schema 2019-09 specification. - Updated @redocly/openapi-core to v1.2.1.
- Added support for linting AsyncAPI v2 files, so that a wider range of API descriptions can use the Redocly linting workflow.
- Renamed API definition to API description for consistency.
- Updated @redocly/openapi-core to v1.2.0.
- Added
ignoreCase
option fortags-alphabetical
rule. - Added
join
support for OAS 3.1 descriptions. - Added support for Redoc v2.1.2, and aligned the dependencies for both projects.
- Fixed an issue where the
--remove-unused-components
option removed used components that were referenced as child objects. - Updated Redocly config validation.
- Fixed the location pointer when reporting on the
no-path-trailing-slash
rule. - Updated minimum required version of Node.js to v14.19.0, NPM to v7.0.0, and removed deprecated packages.
- Updated @redocly/openapi-core to v1.1.0.
- No code changes.
- Updated @redocly/openapi-core to v1.0.2.
- Fixed the build-docs command failing when running outside the root folder.
- Updated @redocly/openapi-core to v1.0.1.
This release marks the stable version 1.0. There are no changes from previous releases.
- Fixed issue with publishing to Docker Hub (no code changes).
- Fixed smoke tests in Yarn and Docker environments.
- Added job for testing new version (no code changes).
- Update package publishing process (no code changes).
No code changes.
- Handled aborted request in the docker and removed a redundant call.
- Resolved problem with installation failing in node 14- and yarn due to unresolved peer dependencies.
- Removed the
cdn
option from thebuild-docs
command as it was not functional. - Updated Redocly config validation schemas.
- Added new rule
component-name-unique
to check for unique component names (kudos to @pboos 🎉). - Added docker container to GitHub container registry.
- Fixed an issue when the
--files
option of thepush
command did not upload extra files. - Fixed nullable schema type validation for OAS 3.1.
- Added peer dependencies to fix an issue with styles seen in the build-docs command.
- Additional data masking for the anonymous data collection feature.
- Added fetch request timeout to prevent hanging the tool when executing commands.
- Added product metrics collection.
- Fixed build-docs command not working in Docker.
- Other stability fixes and improvements.
- Streamlined the
push
command interface. The previous syntax also continues to work. - Improved Redocly configuration validation.
- Documentation and messaging corrections.
- Resolve
$ref
s in preprocessors. - Create the
spec-strict-refs
rule to ensure$ref
usage is in accordance with the OpenAPI specification.
- Handle syntax errors from plugins.
- Apply the following regular expression,
^[a-zA-Z0-9\.\-_]+$
, only to fixed fields under components.
- Change the prefix from
assert/
torule/
as a prefix for configurable rules. Theassert/
prefix continues to work with a warning of the deprecated syntax.
- Inform the user if a new version is available.
- Improved messages on wrong schemas.
- Fixed components duplication and self-referencing when bundling.
- Fixed typos.
- Adjusted CLI arguments behavior for array-like options: it's required to specify the option multiple times to add multiple values. For example,
--skip-rule rule1 --skip-rule rule2
instead of--skip-rule rule1 rule2
.
- Added new options for the
join
command:--decorate
and--preprocess
.
- Fixed a bug with OAS (
x-
) specification extensions that contain an array. - Display an error if the API path refers to a folder.
- Fixed the
push
command not recognizing API descriptions with spaces. - Defined default
allowedValues
in theall
ruleset for mime-type rules.
- Display an error if apis or rules for the
lint
command are not provided. - Stopped executing decorators and preprocessors upon the
join
command. - Sort top-level OAS3 keys in
bundle
andjoin
commands.
- Added the required-min-length-string-type-property rule that requires required properties in the API description with type
string
to have aminLength
.
- Fixed an issue with
$ref
in path parameters during thejoin
command. - This release also includes various internal stability fixes and improvements.
- Changed the arguments for assertion custom functions. Now as the third parameter, instead of a
location
object, assertion custom functions include actx
object. See Custom functions.
- Fixed an issue with remote file inside the lint ignore file.
- Fixed the
push
command when organization is provided in theredocly.yaml
configuration file.
- Fixed an issue with the
push
command not working with a validorganizationId
.
- Added custom output file option to the
join
command. - Added an option to include webhooks to operation-4xx-response rule.
- Added a new built-in decorator info-override.
- Added support for
/
as a separator which puts paths into subdirectories for each path segment with the split command.
- Ignored case when inferring file extension from code sample
lang
property.
- Moved and renamed the
features.openapi
andfeatures.mockServer
into thetheme
object with the namesopenapi
andmockServer
.
Before:
features.openapi: {}
features.mockServer: {}
After:
theme:
openapi: {}
mockServer: {}
- Fixed an issue where
$refs
weren't resolved inside specification extensions.
- Fixed an issue where the
spec
rule showed an error forx-logo
properties in the 3.1 OpenAPI description.
- Enabled removing unused components in the config to use within the bundle command.
- Implemented special SpecExtension type
VendorExtension
. - Added an error handler for the case when the API description file or a plugin does not exist.
- Added
media-type-examples-override
decorator.
- Fixed an issue where the rule spec-components-invalid-map-name is not applied for all examples and adjusted the logic behind the rule in general.
- Fixed an issue with scalar assertion failing when an object is of invalid type.
- Added Redoc vendor extensions to supported types.
- Added support for
any
type in assertions.
- Renamed the Docker image on Docker Hub.
- Changed assertions errors grouping.
- Removed orphaned git submodule
public_api_docs
.
- Added a new assertion
notPattern
to the custom rules.
- Removed automatically adding the
recommended
configuration when there is a config defined without anextends
list.
- Fixed an issue with undefined
process.cwd
in browser environment. - Fixed an issue with
$anchors
in OpenAPI documents are not properly parsed. - Fixed an issue with the
spec
rule not reporting onnullable
in Schema object that don't have atype
sibling. - Added missing OAS2 and OAS3 list types.
- Don't show false media type example errors when a discriminator is used with the
allOf
keyword.
- Changed assertions syntax and renamed to custom rules.
- Removed
info-description
rule. - Removed deprecated fields suggestions in Redocly config file.
- Renamed four type names for alignment with the OpenAPI specification.
PathsMap
toPaths
ResponsesMap
toResponses
EncodingsMap
toEncodingMap
SecuritySchemeFlows
toOAuth2Flows
- Added a new option
--keep-url-references
to thebundle
command that disables bundling of absolute URL$ref
-s.
- Improved location of problems produced by
security-defined
rule. - Fixed an issue with
response-contains-header
being case-sensitive. - Fixed an issue with
path-params-defined
rule that was not accounting for params defined on the operation level. - Fixed an issue with
type
not being validated if it is an array. - Fixed an issue with
apis
overrides not picking up some base values from the root config. - Fixed an issue with api not being detected from the
apis
list if used as a file name.
- Added the
build-docs
command which builds Redoc API docs into a zero-dependency HTML file. - Added the ability to upload other files and folders with the
push
command. - Added support for custom assertions as plugins.
- Fixed incorrect behavior for the
no-invalid-media-type-examples
rule in combination with theallOf
keyword.
- Added rfc7807 problem details rule.
- Improved error messages by adding
referenced from
information. - Added the
spec-components-invalid-map-name
rule for component map names validation. - Added a new lint
--format
option:summary
.
- Fixed an issue with multi-line strings in literal mode.
- Fixed an issue with multi-line Markdown with Windows-style new lines.
- Fixed the Header object type to require
content
orschema
. - Fixed a error message for
operation-4xx-response
rule. - Fixed an issue with
paths
not being correctly handled by thejoin
command. - Fixed the
operation-security-defined
rule to check the security on the root and in each operation.
- Renamed 'DefinitionRoot', 'ServerVariableMap', 'PathMap', 'CallbackMap', 'MediaTypeMap', 'ExampleMap', 'EncodingMap', 'HeaderMap', and 'LinkMap' definition node types.
- Removed the
styleguide
object from the configuration file. - Renamed the
operation-security-defined
rule tosecurity-defined
.
- Renamed
no-servers-empty-enum
tono-server-variables-empty-enum
and fixed incorrect docs ofno-empty-enum-servers
.
- Add browser support for
openapi-core
. - Allow accessing
config
field in subclasses extendingBaseResolver
class. - Ability to create config (e.g.
redocly.yaml
) from string or object.
- Fixed docs for
no-server-example.com
. - Incorrect schema description dereferenced.
- Add
allowAdditionalProperties
to built-in rules and markdisallowAdditionalProperties
as deprecated.
- Introduced severity level
off
for assertions.
- Now errors exit with return code
1
.
- Renamed
lint
intostyleguide
in Redocly configuration. - Improved naming consistency.
- Fixed bug with an invalid path to the configuration file causing issues with the ignore file.
- Fixed incorrect boolean filtering in
filter-out
rule. - Fixed bug with tags duplication for the
join
command. - Other internal stability fixes and improvements.
- Added new property
ref
to assertation object. - Added the
--lint-config
option for thelint
command. Use it to validate the configuration file with appropriate severity level. - Added new built-in decorators
filter-in
andfilter-out
.
- Resolved an issue with the
--run-id
option for thepush
command. The--run-id
option renamed to the--batch-id
, added the--batch-size
option. - Improved types for the configuration file.
- The
join
command supports a new option--without-x-tag-groups
. Use it to skip the creation and population ofx-tagGroups
. - Added new property
requireAny
to assertation object. - Updated types. Added
showSecuritySchemeType
anddisableTryItRequestUrlEncoding
configuration options.
- Fixed issue with
additionalItems
array type.
Broken release.
- Fixed types for
Callback
andNamedCallbacks
. - Fixed an issue with the
scalar-property-missing-example
built-in rule that didn't work on examples containing falsy values.
- Added three new built-in rules:
response-contains-header
,response-contains-property
,scalar-property-missing-example
. - The
bundle
command supports a new option--keep-url-references
. Use it to prevent Redocly CLI from resolving external URL references during bundling. - Added
addinionalItems
,minContains
andmaxContains
array types.
- Resolved an issue with escaping symbols in code sample language names (the
lang
value in thex-codeSamples
specification extension).
- Updated types. Added
hideTryItPanel
,schemaDefinitionsTagName
configuration options andx-hideTryItPanel
,x-tags
OpenAPI specification extensions.
- Added the
--public
option to thepush
command. With this option, you can upload OpenAPI descriptions and make them publicly accessible. - Changed assertions syntax to this pattern:
assert/{assert name}
- Fixed an issue with
process.*
in core package that caused crashes in client-side builds. - Fixed
preview-docs
hot reload.
Technical release for changing the package name from @redocly/openapi-cli
to @redocly/cli
.
{% admonition type="warning" name="Product name change" %} The product name has changed from OpenAPI CLI to Redocly CLI.
This change is reflected in all Redocly product documentation, in the npm package name (more on that in the "Deprecated" section), and in the official project GitHub repository.
The change also affects the CLI commands. The legacy name openapi
is supported for now, but we strongly recommend you use the new name redocly
.
(To illustrate, if you previously used openapi lint
, now you should use redocly lint
).
If you encounter any issues and suspect they may be related to this change, let us know by reporting an issue.
{% /admonition %}
- The
lint.extends
section in the Redocly configuration file supports file paths and URLs as values. This means you can define your own lint rulesets in local or remote files, and list those files in theextends
section. The following example shows how to do it:
extends:
- recommended
- ./path/to/local/lint-ruleset.yaml
- https://url-to-remote/lint-ruleset.yaml
The contents of those referenced files must correspond to the standard format used in the rules
object to configure the rules. Here is an example lint-ruleset.yaml
file referenced above:
rules:
tags-alphabetical: error
- The
lint
command supports a new output formatting option calledcodeclimate
that you can use with the--format
argument.
- Fixed an issue with resolvable scalar values not working in assertions.
- Deprecated the
@redocly/openapi-cli
npm package. From this version forward, use@redocly/cli
instead.
- The
lint
command supports usingunevaluatedProperties
as boolean in OAS 3.1.x and no longer reports this as an error. - Internal changes.
- Resolved an issue with the
push
command skipping dependencies.
- Introduced configurable rules - a new, powerful lint feature, which helps you enforce API design standards without coding (named
assertions
at the time of the release). - The
push
command supports a new--skip-decorator
option.
- Resolved an issue with
openapi preview-docs
failing during authorization.
- Added the
--separator
option to thesplit
command. Use it to change the separator character that's used instead of whitespace in file names. The default is_
, which means that after splitting, path file names look like this: "user_login.yaml", "user_logout", etc.
- Resolved an issue with the
bundle
command when handling files with multiple dots in the file name.
- Updated types to support validation of the Redocly configuration file according to the new file structure.
- Internal changes of
redocly.yaml
config structure - add new mock server options toredocly.yaml
schema.
- Fixed crash when there's an empty
redocly.yaml
file.
- Internal changes of
redocly.yaml
config structure.
- Fixed an issue with the
lint
command highlighting the entire file whenservers
are missing in OAS3. Now it highlights only theopenapi
field, indicating an incorrect OpenAPI description. - Fixed an issue with the
lint
command highlighting all parent values when one of the child fields has an empty value instead of highlighting the field itself.
- Fixed an issue with
process.env
assignment that caused crashes in client-side builds. - Fixed an issue with
no-path-parameter
rule reporting false-positives.
- Allowed to name the config file either
.redocly.yaml
(deprecated) orredocly.yaml
.
- The
spec
rule triggers an error when a parameter is missingschema
orcontent
fields.
- Internal improvements
- Fixed an issue with the
lint
command crashing when theservers.url
field is empty in the OpenAPI description. - Fixed an issue with the
lint
command crashing when anenum
value is invalid.
- Added the
webhooks
and x-webhooks support to thesplit
command.
- Removed support for using OpenAPI CLI behind a proxy server.
- Added support for using OpenAPI CLI behind a proxy server.
- Fixed an issue with the
lint
command not reporting errors whensecurityDefinitions.basic
contains the unsupportedadditionalProperty
in OAS2. - Fixed an issue with the
no-invalid-media-type-examples
built-in rule that didn't work on examples containing a$ref
. - Fixed an issue with the
lint
command incorrectly reporting boolean schemas for array items as invalid. - Fixed an issue with
isPathParameter
failing because of an incorrect brace.
- Fixed an issue with date-time conversion in YAML files.
- Fixed an issue with the
oauth2-redirect.html
file being absent when served bypreview-docs
command.
- Fixed the
remove-x-internal
decorator to remove references to removedx-internal
components. - Fixed the
remove-unused-components
decorator that strips remotely referenced components.
- Added the
remove-x-internal
built-in decorator. - Added the
--remove-unused-components
option to thebundle
command.
- Fixed an issue with backslashes in
$refs
to paths with thesplit
command in a Windows environment.
- Exported
mapTypeToComponent
function.
- Added the
--host
option to thepreview-docs
CLI command.
- Fixed an issue with continuous deployment to Docker Hub.
- Fixed an issue with
const
not handled correctly by thelint
command.
- Resolved another backward compatibility issue with older versions of portal.
- Fixed another backward compatibility issue with regions: save old config key to support old portal versions.
- Fixed a backward compatibility issue with
REDOCLY_DOMAIN
in the EU region introduced in the previous release.
- Added support for the region option with the
login
,push
, and other commands. - Added two new built-in rules:
- Fixed an issue with the built-in
paths-kebab-case
rule that disallowed paths with trailing slashes. - Fixed a validation issue with the
example
property when the schema is an array.
- Implemented new
--extends
and--metafile
options for the bundle command.
- Fixed an issue with hot reloading when running a preview of reference docs with
openapi preview-docs
. - Fixed an issue with page refresh when pagination is set to
item
orsection
. - Fixed an issue with inlining external schema when components' names match.
- Fixed an issue with fetching hosted schema on Windows when bundling OpenAPI descriptions.
- Fixed an issue for
no-server-trailing-slash
when server url is a root.
- Added a new built-in rule: operation-4xx-response.
- Added four new built-in rules:
- Fixed an issue with OAS 3.1 meta keywords reported as not expected.
- Fixed an issue with incorrect codeframe for
info-license-url
rule. - Fixed an issue with discriminator mapping not supported in
no-invalid-media-type-examples
. - Fixed an issue with ignore file generated in windows not working on other systems, and in Redocly Workflows.
- Added three built-in decorators -
info-description-override
,tag-description-override
,operation-description-override
- that let you modify your API descriptions during the bundling process. Use these decorators in thelint
section of yourredocly.yaml
file to point OpenAPI CLI to Markdown files with custom content. That custom content replaces any existing content in theinfo.description
field, and intags.description
andoperation.description
fields for specified tag names and operation IDs.
The following examples show how to add the decorators to the redocly.yaml
file:
lint:
decorators:
info-description-override:
filePath: ./my-custom-description.md
lint:
decorators:
tag-description-override:
tagNames:
pet: ./my-custom-description.md
lint:
decorators:
operation-description-override:
operationIds:
updatePet: ./my-custom-description.md
- Improved documentation for the lint command.
- Fixed the the
bundle
command to return a non-zero code when it detects an error when used with the--lint
option.
-
Fixed an issue with the
--format
option not working with thebundle
command. -
Fixed a validation issue with the non-string
openapi
value in API descriptions. Thelint
command now warns if the value is not string instead of crashing.
- Upgraded the
js-yaml
package from v.3 to v.4 with YAML 1.2 support. This resolves issues with parsing timestamps and example strings with leading zeros in YAML.
- Resolved an issue with the
--max-problems
option that was not working with thebundle
command.
- Improved validation of values for the following fields in the Schema Object:
multipleOf, maxLength, minLength, maxItems, minItems, maxProperties, minProperties
.
- Fixed an issue with the
join
command crashing when trying to resolve $ref.
-
Resolved an issue with the
preview-docs
command not working when runningopenapi-cli
in a Docker container. -
Improved the security of local documentation previews by removing query parameters from the request URL.
- Internal improvements to configuration types.
- Simplified the login check query to improve performance.
-
Added a function for linting the
redocly.yaml
configuration file. -
Published the OpenAPI CLI quickstart guide as part of our Google Season of Docs 2021 project.
-
Updated and improved the introductory content and installation instructions for OpenAPI CLI as part of our Google Season of Docs 2021 project.
-
Implemented improvements to the internal CD process.
- Internal changes.
-
Resolved an issue with transitive $ref resolution in the JSON schema validator.
-
If the JSON schema validator crashes, OpenAPI CLI reports the problem in the output instead of crashing itself.
- The
operation-operationId
rule no longer triggers a warning when one or more operations in thecallbacks
object don't haveoperationId
defined.
-
Our official OpenAPI CLI documentation is now open-source! 🥳 You can find the source of all pages published on our website in the
docs
folder of the openapi-cli repository. We invite you to help us improve the documentation and make it more usable for everyone. Please make sure to always follow our Code of conduct in all your contributions. -
Implemented support for OpenAPI 3.1 in
typeExtension
plugins.
-
Resolved a crash caused when processing properties with the
null
value. -
Resolved a "Maximum call stack size exceeded" issue in the JSON schema validator caused by recursive
oneOf
.
- Implemented improvements to the
openapi-cli
package to reduce the size of the browser bundle.
-
Removed unused keywords in OpenAPI 3.1.
-
Resolved an issue with the
openapi bundle
command failing because of the missingjs-yaml
dependency.
- Resolved an issue with the plugin ID being prefixed to all rules, preprocessors and decorators multiple times (for example, when using the
preview-docs
command and changing configuration files).
- The
bundle
command now supports an optional--lint
parameter.
-
Improved the error messages for
kebab-case
and implemented detection ofsnake_case
usage in paths. -
The
join
command does not overwrite an existingx-displayName
of a tag with the tag'sname
property.
- Implemented support for OpenAPI 3.1. You can now lint, validate, and bundle your OAS 3.1 descriptions with OpenAPI CLI.
- Resolved a validation issue for
enum
items with the nullable property. Validation errors are no longer reported whennullable: true
forenum
items that contain anull
value.
- The
browser
field inpackage.json
is now set to simplify usingopenapi-core
in browser-based builds.
- The root API description document is now parsed in all cases, even if it doesn't report the correct MIME type or doesn't use any of the supported file extensions.
- Improved
openapi-core
so that it can be used within our other projects including Redoc, Reference docs, and Developer portal.
- Resolved an issue with the
--dereferenced
CLI option not functioning properly.
- Resolved an issue where transitive $refs that span multiple files would crash the validation in some cases.
- Resolved a hot-reloading issue with the
preview-docs
command. It now automatically reloads the docs in the browser when you make live changes to an OpenAPI description.
- Exported a helper function from
openapi-core
and implemented defaults for some functions to improve integration with the Developer portal.
- Implemented error handling for failed file uploads when using the
push
command. The command now displays success/failure messages in the output.
- Source type was changed from
FILE
toCICD
to support integration with the new CI/CD source in Workflows.
- OpenAPI CLI now has tab completion for global installations. Run
openapi completion
for instructions to set it up in your environment.
- OpenAPI CLI now has an official Docker image! You can get it from Docker Hub.
- You can now use the
--verbose
parameter with thelogin
command to show a detailed error trace (if any). Detailed error output is not displayed by default for this command.
-
The "access token" has been renamed to "API key" in the output of relevant OpenAPI CLI commands (
login
,push
) to make it clearer what information the users must provide. -
For improved security, the API key is now hidden (masked) when the user provides it in the terminal, and it's not logged in the user's history.
- The
bundle
method is now able to acceptDocument
directly in openapi-core.
- OpenAPI CLI now automatically resolves all $refs by default, even in places where they are not allowed by the specification ("incorrect $refs"). This functionality can be disabled for examples by setting
doNotResolveExamples
totrue
inredocly.yaml
.
- Fixed an issue with incorrect base directory when resolving transitive
$refs
.
- Resolved an issue with nested filepaths that caused the
push
command to upload files to the wrong path when used on Windows systems.
- A new command called
push
is now supported by OpenAPI CLI. With this command, you can upload your API descriptions and associated files, and set up your own CI pipeline for updating API descriptions without granting Redocly Workflows access to your repositories.
- Resolved an issue that prevented using the
.
(dot) symbol in version names with thepush
command.
-
Resolved an issue with
assert-node-version
using the wrong path. -
OpenAPI CLI bundles the API description before gathering stats.
-
Resolved issues with tag logic and tag display names for the
join
command. -
Refactored CLI command handlers.
- A new command called
join
is now available in OpenAPI CLI. Use it to combine two or more API description files into one. The resulting file optionally helps distinguish the origin of OpenAPI objects and properties by appending custom prefixes to them. Note that this command is considered experimental; meaning, it's still a work in progress.
- The previously single OpenAPI CLI package has been split into two:
openapi-cli
andopenapi-core
.
- OpenAPI CLI now supports the
split
command, which you can use to create a multi-file structure out of an API description file by extracting referenced parts into standalone, separate files. The command doesn't support OAS 2.
- Resolved an issue with counting operation tags in the
stats
command.
- A new command called
stats
has been implemented. It provides statistics about the structure of one or more API description files, and lets you choose the format in which the statistics are presented.
- Resolved an issue with the
glob
library by installing the missing package.
-
Resolved an issue with the extended regex path which was missing the dot symbol.
-
Added support for non-compatible globbing shells.
- Added the missing label definition for
x-codeSamples
and enabledx-codeSamples
for OAS 2.
-
Fixed the required field name for
openIdConnectUrl
. -
Resolved an issue with detecting duplicated plugin IDs, and added a warning that plugin IDs must be unique.
-
Adedd
engines
andengineStrict
topackage.json
. -
Implemented better handling and error messages for invalid severity values.
- Previously, OpenAPI CLI tried to use
/
instead of\
for file path splitting on Windows machines. The issue has been resolved by implementing platform-specific separator usage.
- Resolved an issue with missing support for external plugins in the bundled version.
-
Fixed a crash that happened when attempting to resolve back-references.
-
The version number of OpenAPI CLI is now printed in the JSON output.
-
The
--format
option now supports JSON as one of the output formats you can choose when using OpenAPI CLI commands. -
Bundling and uploading are now part of the build process.
-
Warnings and errors are now displayed as separate counts in JSON output.
-
All parts of a pointer are now used to generate unique component names when needed.
-
Added support for linting
x-webhooks
, which is a forward-compatibility vendor extension forwebhooks
from OpenAPI 3.1.
-
Removed an extra blank line that was printed when no rules were ignored.
-
Resolved an issue with missing types for
OasDecorator
andOas3Decorator
. -
Resolved a tag syntax error when deploying to Workflows.
-
Relative paths are now used for JSON output.
- Added mime-type handling for remote docs.
-
Fixed the callbacks type definition.
-
Fixed invalid component names for some components.
-
Resolved an issue with bundling local references.
-
Resolved a minor issue where the help message displayed references to the
registry:login
command instead of thelogin
command.
-
Fixed invalid unescape and
decodeURIComponent
. -
Updated the
extends
parameter logic to allow configuration overrides. -
Improved handling logic and error message when the input file is not an OpenAPI document.
-
Resolved an issue with detecting output file extension without an entrypoint.
-
Resolved an issue with the
preview-docs
command failing to automatically select the first description from theapiDefinitions
section of the configuration file when used without arguments. -
Fixed an issue with relative paths for entrypoints from external configuration files.
-
The
default.hbs
file is now copied to the build directory. -
Resolved an issue with the preview functionality failing to access
watcher
.
-
Resolved an issue with the
no-path-trailing-slash
rule showing errors for the wrong location and path. -
Fixed a transitive resolve issue.
First beta release!