Security News
Node.js EOL Versions CVE Dubbed the "Worst CVE of the Year" by Security Experts
Critics call the Node.js EOL CVE a misuse of the system, sparking debate over CVE standards and the growing noise in vulnerability databases.
api-smart-diff
Advanced tools
Generate the diff between two API specifications (OpenAPI, AsyncAPI, JsonSchema)
This package provides utils to compute the diff between two API specifications - online demo
npm install api-smart-diff --save
import { apiDiff } from 'api-smart-diff'
const diffs = apiDiff(oldSpec, newSpec, { rules: "OpenApi3" })
// {
// action: "add" | "remove" | "replace",
// after: 'value in newSpec',
// before: 'value in oldSpec',
// path: ['path, 'in', 'array', 'format'],
// type: "annotation" | "breaking" | "non-breaking" | "unclassified"
// }
const merged = apiMerge(oldSpec, newSpec, { rules: "OpenApi3" })
A browser version of api-smart-diff
is also available via CDN:
<script src="https://cdn.jsdelivr.net/npm/api-smart-diff@latest/browser/api-smart-diff.min.js"></script>
<script src="https://cdn.jsdelivr.net/npm/api-smart-diff@latest/browser/api-smart-diff.js"></script>
Reference api-smart-diff.min.js
in your HTML and use the global variable ApiSmartDiff
.
<script>
var diffs = ApiSmartDiff.apiDiff(oldSpec, newSpec, { rules: "OpenApi3" })
var merged = ApiSmartDiff.apiMerge(oldSpec, newSpec, { rules: "OpenApi3" })
</script>
Package provides the following public functions:
apiDiff (before, after, options?: CompareOptions): Array<Diff>
Calculates the differences between two objects and classify difference in accordinance with specified rules: OpenApi3, AsyncApi2, JsonSchema.
apiMerge (before, after, options?: MergeOptions): object
Merge two objects and inject difference as meta data.
The apiDiff function calculates the difference between two objects.
before: any
- the origin objectafter: any
- the object being compared structurally with the origin object\options: CompareOptions
[optional] - comparison optionstype CompareOptions = {
rules?: Rules | "OpenApi3" | "AsyncApi2" | "JsonSchema"
trimStrings?: boolean
caseSensitive?: boolean
strictArrays?: boolean
externalRefs?: { [key: string]: any }
}
rules
- match and classification rules, custom or predefined.trimString
- ignore spaces in matching, default false
caseSensitive
- ignore case in matching, default false
strictArrays
- use strict match algorithm for array items, default false
externalRegs
- object with external refsFunction returns array of differences:
type Diff = {
action: "add" | "remove" | "replace"
path: Array<string | number>
before?: any
after?: any
type: "breaking" | "non-breaking" | "annotation" | "unclassified"
}
const diffs = apiDiff(before, after, { rules: "OpenApi3" })
if (diffs.length) {
// do something with the changes
}
The apiDiff function calculates the difference between two objects.
before: any
- the origin objectafter: any
- the object being compared structurally with the origin object\options: MergeOptions
[optional] - comparison optionstype MergeOptions<T> = CompareOptions & {
arrayMeta?: boolean
formatMeta?: (diff: Diff) => T
metaKey?: string | symbol
}
Additional to compare options:
arrayMeta
- inject meta to arrays for items changes, default false
metaKey
- key for diff metadata, default $diff
formatMeta
- custom formatting function for metaFunction returns merged object with metadata. Metadata includes merged keys and differences:
type MergedMeta = {
[key: string]: MergedKeyMeta | MergedArrayMeta
}
type MergedKeyMeta = {
type: DiffType
action: ActionType
replaced?: any
}
type MergedArrayMeta = {
array: { [key: number]: MergedArrayMeta }
}
const apiKey = Symbol("diff")
const merged = apiMerge(before, after, { rules: "OpenApi3", apiKey })
// do something with merged object
Custom rules can be defined as object:
type Rules = {
// root property (or array item) rule
"/"?: Rule
// rule for all unspecified properties (or nested array items)
"/*"?: Rule | Rules | (before) => Rules
// rule for specified properties
[key: `/${string}`]?: Rule | Rules | (before) => Rules
// custom match function for object (or array)
"#"?: (before, after) => boolean
}
// Change classifier
type Rule = [
DiffType | (before, after) => DiffType, // add
DiffType | (before, after) => DiffType, // remove
DiffType | (before, after) => DiffType // replace
]
Please check predefined rules in /src/rules
folder to get examples
When contributing, keep in mind that it is an objective of api-smart-diff to have no package dependencies. This may change in the future, but for now, no-dependencies.
Please run the unit tests before submitting your PR: npm test. Hopefully your PR includes additional unit tests to illustrate your change/modification!
MIT
FAQs
Generate the diff between two API specifications (OpenAPI, AsyncAPI, GraphApi, JsonSchema)
The npm package api-smart-diff receives a total of 1,249 weekly downloads. As such, api-smart-diff popularity was classified as popular.
We found that api-smart-diff demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 0 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Critics call the Node.js EOL CVE a misuse of the system, sparking debate over CVE standards and the growing noise in vulnerability databases.
Security News
cURL and Go security teams are publicly rejecting CVSS as flawed for assessing vulnerabilities and are calling for more accurate, context-aware approaches.
Security News
Bun 1.2 enhances its JavaScript runtime with 90% Node.js compatibility, built-in S3 and Postgres support, HTML Imports, and faster, cloud-first performance.