Hyperjump - JSON Schema Bundler
JSON Schema Bundler (JSB) is built on JSON Schema Core.
- Supported JSON Schema Dialects
- draft-04 | draft-06 | draft-07 | Draft 2019-09 | Draft 2020-12
- Schemas can reference other schemas using a different draft
- Load schemas from filesystem (file://), network (http(s)://), or JavaScript
Install
JSB includes support for node.js JavaScript (CommonJS and ES Modules),
TypeScript, and browsers.
Node.js
npm install @hyperjump/json-schema-bundler
Browser
When in a browser context, JSB is designed to use the browser's fetch
implementation instead of a node.js fetch clone. The Webpack bundler does this
properly without any extra configuration, but if you are using the Rollup
bundler you will need to include the browser: true
option in your Rollup
configuration.
plugins: [
resolve({
browser: true
}),
commonjs()
]
Versioning
This project is in beta and there may be breaking changes at any time. When it's
stable enough, I'll publish v1.0.0 and follow semantic versioning from there on
out.
Usage
const Bundler = require("@hyperjump/json-schema-bundler");
Bundler.add({
"$id": "https://json-schema.hyperjump.io/schemas/string",
"$schema": "https://json-schema.org/draft/2020-12/schema",
"type": "string"
});
const main = await Bundler.get(`file://${__dirname}/schemas/main.schema.json`);
const bundle = await Bundler.bundle(main);
TypeScript
Although the package is written in JavaScript, type definitions are included for
TypeScript support. The following example shows the types you might want to
know.
import Bundler from "@hyperjump/json-schema-bundler";
import type { SchemaDocument, Draft202012Schema, InvalidSchemaError } from "@hyperjump/json-schema-bundler";
(async function () {
const schemaJson: Draft202012Schema = {
"$id": "https://json-schema.hyperjump.io/schemas/string",
"$schema": "https://json-schema.org/draft/2020-12/schema",
"type": "string"
};
Bundler.add(schemaJson);
try {
const main: SchemaDocument = await Bundler.get(`file://${__dirname}/schemas/main.schema.json`);
const bundle: Draft202012Schema = await Bundler.bundle(main);
console.log(JSON.stringify(bundle, null, " "));
} catch (error: unknown) {
if (error instanceof InvalidSchemaError) {
console.log(error.output);
} else {
console.log(error);
}
}
}());
API
-
add: (schema: object, url?: URI, schemaVersion?: string) => SDoc
Load a schema. See JSC - $id
and JSC - $schema
for more information.
-
get: (url: URI, contextDoc?: SDoc, recursive: boolean = false) => Promise<SDoc>
Fetch a schema. Schemas can come from an HTTP request, a file, or a schema
that was added with add
.
-
bundle: (schema: SDoc, options: Options) => Promise<SchemaObject>
Create a bundled schema starting with the given schema. External schemas
will be fetched from the filesystem, the network, or internally as needed.
Options:
- alwaysIncludeDialect: boolean (default: false) -- Include dialect even
when it isn't strictly needed
- bundleMode: "flat" | "full" (default: "flat") -- When bundling schemas
that already contain bundled schemas, "flat" mode with remove nested
embedded schemas and put them all in the top level
$defs
. When using
"full" mode, it will keep the already embedded schemas around, which will
result in some embedded schema duplication. - definitionNamingStrategy: "uri" | "uuid" (default: "uri") -- By default
the name used in definitions for embedded schemas will match the
identifier of the embedded schema. This naming is unlikely to collide
with actual definitions, but if you want to be sure, you can use the
"uuid" strategy instead to be sure you get a unique name.
-
setMetaOutputFormat: (outputFormat: OutputFormat = DETAILED) => undefined
Set the output format for meta-validation. Meta-validation output is only
returned if meta-validation results in an error.
-
setShouldMetaValidate: (isEnabled: boolean) => undefined
Enable or disable meta-validation.
-
OutputFormat: [FLAG | BASIC | DETAILED | VERBOSE]
See JSC - Output
for more information on output formats.
Contributing
Tests
Run the tests
npm test
Run the tests with a continuous test runner
npm test -- --watch