Important: This documentation covers Yarn 1 (Classic).
For Yarn 2+ docs and migration guide, see yarnpkg.com.

Package detail

zod-package-json

velut145.7kMIT1.1.0TypeScript support: included

Zod schema for the package.json file format

zod, schema, package, json, typescript, npm

readme

zod-package-json

Build status Coverage jsDocs.io Language npm License

Zod schema for the package.json file format.

This package exports a zod schema (and a TypeScript type) named PackageJson that can parse most well-formed package.json files.

The schema includes all currently supported properties listed in the npm docs as well as additional well-known properties specific to TypeScript and Node.js.

The schema also preserves unknown properties, which can be accessed by indexing the parsed data with the desired string keys.

The schema only validates the listed properties against the expected type but does not do any additional normalization such as merging similar properties. If necessary, that can be done by extending the schema with zod methods such as .transform() or .refine().

Useful resources

Install

Using npm:

npm add zod-package-json

Using yarn:

yarn add zod-package-json

Using pnpm:

pnpm add zod-package-json

Using bun:

bun add zod-package-json

Usage examples

import { PackageJson } from "zod-package-json";

// Parse data from a `package.json` file.
const packageJson = PackageJson.parse({
    name: "foo",
    version: "1.0.0",
    unknownProp: "who knows",
});

// Access a known property.
packageJson.name; // "foo"

// Access an unknown property.
packageJson["unknownProp"]; // "who knows"

License

MIT

Copyright (c) 2025 Edoardo Scibona

See LICENSE file.

changelog

Changelog

All notable changes to this project will be documented in this file.

The format is based on Keep a Changelog, and this project adheres to Semantic Versioning.

Unreleased

  • None

1.1.0 - 2025-01-20

Changed

  • Upgraded dependencies

1.0.3 - 2024-06-12

Changed

1.0.2 - 2024-04-23

Changed

1.0.1 - 2024-04-21

Fixed

  • Add booleans to the browser object values (a1de691)
  • Widen config object values to unknown (95224f9)