Skip to main content

JADN schema tools

Project description

JADN is an information modeling language used to define the information needed by applications and to serialize that information using one or more data formats. It has several purposes, including convenient and expressive definition of data structures, validation of data instances, providing hints for user interfaces working with structured data, and facilitating protocol internationalization. A JADN specification consists of two parts: an Information Model (abstract schema) that is independent of data format, and serialization rules that define how to represent information using a specific data format. A single JADN schema defines protocol data in multiple formats including XML, JSON, and an actually-concise CBOR format. Additional data formats can be defined and applied to any JADN schema.

The software in this package is organized by function:

  • core: Load, validate, and save a JADN schema.

  • codec: Validate, encode, and decode application information using a specified data format:

    • Idiomatic (verbose) JSON

    • Minimized (concise) JSON

    • CBOR*

    • XML*

  • convert: Convert JADN schema between JSON and documentation formats:

    • text-based Interface Definition Language (IDL)

    • html tables

    • markdown tables

    • GraphViz and PlantUML diagrams

  • transform: Process a JADN schema to produce another JADN schema:

    • combine definitions from separate schemas into a single schema

    • split a schema that defines multiple objects into separate schemas for each object

    • remove unused definitions

    • delete or truncate comments

  • translate: Convert a JADN schema into a concrete schema language:

    • JSON Schema

    • XSD*

    • CDDL*

    • Protobuf*

* Planned

Quickstart

The quickstart.py script illustrates how to use these functions:

  • define and validate a schema

  • convert the schema to and from documentation formats

  • truncate comments

  • translate a JADN schema to JSON Schema

  • validate messages and serialize using multiple data formats:

    • JSON

    • Minimized JSON

Make Artifacts

The make_artifacts.py script translates all JADN schemas in a source directory to multiple formats in an output directory.

Input formats are:

  • JADN

  • JADN IDL

  • HTML (with tags produced by this package)

Output formats are:

  • JADN

  • Core JADN (with extensions removed)

  • JADN IDL

  • HTML tables

  • Markdown tables

  • GraphViz diagram

  • PlantUML diagram

  • JSON Schema

Contributors

Jerome Czachor - Massive code cleanup, type hinting, conversion classes, refactor using datatypes

Feedback

Comments on this software can be submitted using GitHub issues and pull requests.

The JADN specification is being developed by the OASIS OpenC2 Technical Committee. OASIS members may participate directly in its development; others may participate indirectly using GitHub issues or the openc2-comment public mail list.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

jadn-0.7.5.tar.gz (70.4 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

jadn-0.7.5-py2.py3-none-any.whl (62.4 kB view details)

Uploaded Python 2Python 3

File details

Details for the file jadn-0.7.5.tar.gz.

File metadata

  • Download URL: jadn-0.7.5.tar.gz
  • Upload date:
  • Size: 70.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.11.9

File hashes

Hashes for jadn-0.7.5.tar.gz
Algorithm Hash digest
SHA256 5a5e0c4cf2fddea9e213e9bea86593180113c0bba0ae277a07ace2e31b9b2ad0
MD5 7f9bddb49b754baa2e6dc401e104e666
BLAKE2b-256 b2e11748710912185848d65775e1a403ac86aa234f6432740b1d47bcc4e267e5

See more details on using hashes here.

File details

Details for the file jadn-0.7.5-py2.py3-none-any.whl.

File metadata

  • Download URL: jadn-0.7.5-py2.py3-none-any.whl
  • Upload date:
  • Size: 62.4 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.11.9

File hashes

Hashes for jadn-0.7.5-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 04df399b3e66c9c8a7bb2bb8212124c8f4d92372146a1778baaf3a4d0522f489
MD5 6fd02e8a367f59a25dab5fdf2c8d2ba4
BLAKE2b-256 453be21f95b9cc4cc85c0b704e65360920da16c55b4ab473162646ad5ca6bbbc

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page