Product
Socket Now Supports uv.lock Files
Socket now supports uv.lock files to ensure consistent, secure dependency resolution for Python projects and enhance supply chain security.
@opensystemslab/digital-planning-data-schemas
Advanced tools
This repository contains data specifications to describe Digital Planning services developed by Open Digital Planning. Each specification is communicated via a JSON Schema document.
Our initial specification defines data structures, rules, and validation logic for planning applications - including Lawful Development Certificate, Prior Approval, and Planning Permission services - that are being designed and submitted via PlanX.
Digital Planning Data schemas aim to encourage more interoperability and consistency between systems by offering a central, version controlled specification for documenting and validating planning data.
Going forward, we hope that this repository will expand beyond applications to further describe planning reference numbers, site notices, consultations, and more.
There's two main options for integrating with Digital Planning Data schemas:
Reference a hosted schema file directly:
https://theopensystemslab.github.io/digital-planning-data-schemas/<VERSION>/schemas/<SCHEMA>.json
Clone this repository and reference the local schema files programmatically in your own code using tools that support JSON Schema validation
For more detailed info on integrating and validating schemas, please refer to the examples and tests in this repo.
/examples
: Examples of valid payloads for each application type supported by the specifications encoded in this repository.
/schemas
: The main JSON Schema files. The main
branch of this repo will reflect the @next
version, while historic versions are documented and released on the dist
branch.
/types
: TypeScript interfaces used to generate the JSON Schemas.
/tests
: Test suites to ensure that the generated schema and example payloads are valid, accurate, and capable of handling different scenarios.
Assumes PNPM is available globally.
pnpm i
The JSON Schemas are defined using TypeScript interfaces and then generated using the ts-json-schema-generator
library.
To make changes, update /types
and then run pnpm build
to automatically generate the output JSON file under /schemas
.
Types should be annotated using JSDocs, which will then be read during schema generation.
Please see the JSON schema docs for a full list of references for various types.
Add a TypeScript file to /examples/<SCHEMA>/data
with at least one exported variable representing an example payload definition.
Run pnpm build:examples
to automatically generate a corresponding JSON file per example payload in the root of /examples
.
Run pnpm test
to confirm your example payload can be successfully validated against the Digital Planning Data schema.
To publish a new version, open a pull request against main
which increments the package.json
version.
On merge, the publish.yml GitHub Action will update the dist
branch, create a release, and publish the new version via GitHub pages at http://theopensystemslab.github.io/digital-planning-data-schemas/<VERSION>/schemas/<SCHEMA>.json
The latest schema is also viewable at https://theopensystemslab.github.io/digital-planning-data-schemas-docs/.
We welcome feedback, bug reports, and contributions to help improve and grow the Digital Planning Data schemas via GitHub Issues and Pull Requests.
Distributed under the Mozilla Public License Version 2.0. See LICENSE.txt
for more information.
FAQs
Digital Planning Data schemas
The npm package @opensystemslab/digital-planning-data-schemas receives a total of 58 weekly downloads. As such, @opensystemslab/digital-planning-data-schemas popularity was classified as not popular.
We found that @opensystemslab/digital-planning-data-schemas 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.
Product
Socket now supports uv.lock files to ensure consistent, secure dependency resolution for Python projects and enhance supply chain security.
Research
Security News
Socket researchers have discovered multiple malicious npm packages targeting Solana private keys, abusing Gmail to exfiltrate the data and drain Solana wallets.
Security News
PEP 770 proposes adding SBOM support to Python packages to improve transparency and catch hidden non-Python dependencies that security tools often miss.