/api-insights-openapi-rulesets

API Insights analyzers liniting ruleset.

Primary LanguageJavaScriptApache License 2.0Apache-2.0

api-insights-openapi-rulesets

The API Insights OpenAPI ruleset is a project to programatically check conformance of API specification against REST API Guidelines. These guidelines are developed and supported as part of API Insights.

This module implements a set of lintable REST API best practices, linters can be used validate API Specs in Swagger2 or OAS3 format. The project implements 2 linter rulesets.

  1. REST Guidelines : Lintable REST API best practices related to API Design, API implementation, API testing and developer experience. For details refer rest-guidelines.md
  2. Doc Completeness: set of rules provided to ensure the end user document generated from API specs are of good quality. It includes rules and examples are included for every schema, description provided for every attribute, etc. For details refer to doc-completeness.md

These custom rulesets are implemented using Spectral open source linter.

Note: In addition to the above rulesets API Insights also includes an "Inclusive Language" analyzer. cisco-open/inclusive-language project is a collection of tools and resources for working on eliminating biased language.

Installation

npm install @cisco-developer/api-insights-openapi-rulesets

Usage

There are two rulesets in this repo, you can choose one of them:

api-insights-openapi-ruleset.js
completeness.js
  • If you installed spectral cli globally refer to spectral-cli, you can run:
spectral lint -r node_modules/@cisco-developer/api-insights-openapi-rulesets/api-insights-openapi-ruleset.js your-spec.json/yaml
  • Run with locally installed cli:
npx spectral lint -r node_modules/@cisco-developer/api-insights-openapi-rulesets/api-insights-openapi-ruleset.js your-spec.json/yaml

Also you can refer to use npm, define your .spectral.yaml like this:

extends:
  - "@cisco-developer/api-insights-openapi-rulesets"
  - "@cisco-developer/api-insights-openapi-rulesets/api-insights-openapi-ruleset.js"
  - "@cisco-developer/api-insights-openapi-rulesets/completeness.js"

Contributing

If you are interested in this project, check out CONTRIBUTING.md.

License

Apache License 2.0