Skip to content

pyrech-forks/janephp

 
 

Repository files navigation

Jane

Latest Version Software License Build Status Code Coverage Quality Score Total Downloads

Jane is a library to generate, in PHP, a model and a serializer from a JSON Schema.

Disclaimer

The generated code may contain bug or incorrect behavior, use it as a base for your application but you should never trust it as is.

Usage

# jane [schema-path] [root name] [namespace] [destination]
php vendor/bin/jane generate json-schema.json Classname Namespace\\Prefix src/Namespace/Prefix

This will generate, in the src/Namespace/Prefix, a Model and a Normalizer directory.

Model directory will contain a Namespace\Prefix\Model\Classname, which correspond to the root Schema of the json schema file, and all the subclasses discovered through the parsing of the Schema.

Normalizer directory will contain a normalizer service class for each of the model class generated.

Using a config file

For more control over how your library should be generated you can use a config file, just create a file .jane at the root of your repository which will return an array of options:

<?php

return [
    'json-schema-file' => __DIR__ . '/json-schema.json', // Location of our JSON Schema
    'root-class' => 'Classname', // root classname of the root object of your JSON Schema
    'namespace' => 'Namespace\Prefix', // namespace of the generated code
    'directory' => __DIR__ . '/src/Namespace/Prefix', // directory where the code will be output
    'date-format' => \DateTime::RFC3339, // format of the date that your use (you should not change it unless you have to deal with a non compliant specification)
    'reference' => true, // Add the JSON Reference specification to the generated library (so your data can use reference like described in https://tools.ietf.org/html/draft-pbryan-zyp-json-ref-03)
]

Installation

Use composer for installation

composer require jane/jane

Recommended workflow

Here is a recommended workflow when dealing with the generated code:

  1. Start from a clean revision on your project (no modified files);
  2. Update your Json Schema file (edit or download new version);
  3. Generate the new code;
  4. Check the generated code with a diff tool: git diff for example;
  5. If all is well commit modifications.

An optional and recommanded practice is to separate the generated code in a specific directory like creating a generated directory in your project and using jane inside. This allows other developers to be aware that this part of the project is generated and must not be updated manually.

See this library (jane-swagger) for an example on how to achieve that.

Internal

Here is a quick presentation on how this library transforms a Json Schema file into models and normalizers:

  1. First step is to read and parse the Json Schema file;
  2. Second step is to guess classes and their associated properties and types;
  3. Once all things are guessed, classes and their properties are transformed into an AST (by using the PHP-Parser library from nikic);
  4. Then the AST is written into PHP files.

Sponsor

JoliCode

Open Source time sponsored by JoliCode

Credits

License

View the LICENSE file attach to this project.

About

Master repository, containing all jane libs

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • PHP 100.0%