https://github.com/un-ts/json-schema-migrate-x
Migrate JSON-Schema `draft-04` to `draft-07`, `draft-2019-09` or `draft-2020-12`
https://github.com/un-ts/json-schema-migrate-x
ajv json-schema json-shcema-migrate jsonschema
Last synced: about 2 months ago
JSON representation
Migrate JSON-Schema `draft-04` to `draft-07`, `draft-2019-09` or `draft-2020-12`
- Host: GitHub
- URL: https://github.com/un-ts/json-schema-migrate-x
- Owner: un-ts
- License: mit
- Created: 2025-04-02T12:06:55.000Z (about 2 months ago)
- Default Branch: master
- Last Pushed: 2025-04-03T13:09:29.000Z (about 2 months ago)
- Last Synced: 2025-04-03T14:24:04.174Z (about 2 months ago)
- Topics: ajv, json-schema, json-shcema-migrate, jsonschema
- Language: TypeScript
- Homepage: https://npm.im/json-schema-migrate-x
- Size: 1.49 MB
- Stars: 1
- Watchers: 0
- Forks: 0
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
README
# json-schema-migrate-x
[](https://github.com/un-ts/json-schema-migrate-x/actions/workflows/ci.yml?query=branch%3Amaster)
[](https://codecov.io/gh/un-ts/json-schema-migrate-x)
[](https://github.com/plantain-00/type-coverage)
[](https://coderabbit.ai)
[](https://www.npmjs.com/package/json-schema-migrate-x)
[](https://github.com/un-ts/json-schema-migrate-x/releases)[](https://conventionalcommits.org)
[](https://renovatebot.com)
[](https://standardjs.com)
[](https://github.com/prettier/prettier)This is an actively maintained fork of [`json-schema-migrate`](https://github.com/ajv-validator/json-schema-migrate) which helps migrate JSON-Schema from `draft-04` to `draft-07`, `draft-2019-09` or `draft-2020-12`.
## Install
```sh
# npm
npm install json-schema-migrate-x# yarn
yarn add json-schema-migrate-x# pnpm
pnpm add json-schema-migrate-x# bun
bun add json-schema-migrate-x
```## Usage
```js
import * as migrate from 'json-schema-migrate-x'const schema = {
id: 'my-schema',
minimum: 1,
exclusiveMinimum: true,
}migrate.draft7(schema)
// or migrate.draft2019(schema)
// or migrate.draft2020(schema)console.log(schema)
// {
// $id: 'my-schema',
// exclusiveMinimum: 1
// }
```You can access Ajv instance that is used to migrate schema using `migrate.getAjv` function:
```js
console.log(migrate.getAjv().errorsText(errors))
```## Changes in schemas after migration
- `id` is replaced with `$id`
- `$schema` value becomes `draft-07`, `draft-2019-09` or `draft-2020-12` meta-schema
- `draft-04` boolean form of `exclusiveMaximum/Minimum` is replaced with the current number form
- `enum` with a single allowed value is replaced with `const`
- Non-standard `constant` is replaced with `const`
- empty schema is replaced with `true`
- schema `{"not":{}}` is replaced with `false`
- `draft2019` function additionally replaces:
- `dependencies` with `dependentRequired` and `dependentSchemas`
- `"id": "#foo"` with `"$anchor": "foo"`
- `"id": "schema#foo"` with `"$id": "schema", "$anchor": "foo"`
- `draft2020` function additionally replaces array form of `items` with `prefixItems` (and `additionalItems` with `items`)[](https://github.com/sponsors/JounQin)
## Sponsors
| 1stG | RxTS | UnTS |
| ---------------------------------------------------------------------------------------------------------------------- | ---------------------------------------------------------------------------------------------------------------------- | ---------------------------------------------------------------------------------------------------------------------- |
| [](https://opencollective.com/1stG) | [](https://opencollective.com/rxts) | [](https://opencollective.com/unts) |## Backers
| 1stG | RxTS | UnTS |
| ------------------------------------------------------------------------------------------------------------------- | ------------------------------------------------------------------------------------------------------------------- | ------------------------------------------------------------------------------------------------------------------- |
| [](https://opencollective.com/1stG) | [](https://opencollective.com/rxts) | [](https://opencollective.com/unts) |## Changelog
Detailed changes for each release are documented in [CHANGELOG.md](./CHANGELOG.md).
## License
[MIT][] © [JounQin][]@[1stG.me][]
[1stG.me]: https://www.1stG.me
[JounQin]: https://github.com/JounQin
[MIT]: http://opensource.org/licenses/MIT