Skip to content

navarchus/api-insights-openapi-rulesets

 
 

Repository files navigation

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. API Contract: Set of rules provided to ensure the API contract is reliable and complete in terms of API metadata, schema definition, operation status code & responses. For details refer to doc-completeness.md.
  3. API Documentation Completeness: Set of rules provided to ensure the end user document generated from API specs is of good quality. It includes rules like description provided for every attribute, examples are included for every schema, 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
contract.js
documentation.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/api-insights-openapi-ruleset.js"
  - "@cisco-developer/api-insights-openapi-rulesets/contract.js"
  - "@cisco-developer/api-insights-openapi-rulesets/documentation.js"

Contributing

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

License

Apache License 2.0

About

API Insights analyzers liniting ruleset.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • JavaScript 100.0%