Generating a Model¶
This library provided a PHP console application to generate the Model, you can use it by executing the following command at the root of your project:
php vendor/bin/jane generate
This command will try to read a config file named .jane
located on the current working directory. However, you can name it as you
like and use the --config-file
option to specify its location and name:
php vendor/bin/jane generate --config-file=jane-configuration.php
Note
No others options can be passed to this command. Having a config file ensure that a team working on the project always use the same set of parameters and, when it changes, give vision of the new option used to generate the code.
Configuration file¶
The configuration file consists of a simple PHP script returning an array:
<?php
return [
'json-schema-file' => __DIR__ . '/json-schema.json',
'root-class' => 'MyModel',
'namespace' => 'Vendor\Library\Generated',
'directory' => __DIR__ . '/generated',
];
This example shows the minimum configuration required to generate a Model:
json-schema-file
: Specify the location of your json schema file, it can be a local file or a remote onehttps://my.domain.com/my-schema.json
root-class
: The root class of the root object defined in your json schema, if there is no property on the root object it will not be usednamespace
: Root namespace of all of your generated codedirectory
: Directory where the code will be generated at
Given this configuration you will need to add the following configuration to composer, in order to load the generated files:
"autoload": {
"psr-4": {
"Vendor\\Library\\Generated\\": "generated/"
}
}
Options¶
Other options are available to customize the generated code:
reference
: A boolean which indicate to add the support for JSON Reference into the generated code.date-format
: A date format to specify how the generated code should encode and decode\DateTime
object to stringuse-fixer
: A boolean which indicate if we make a first cs-fix after code generationfixer-config-file
: A string to specify where to find the custom configuration for the cs-fixer after code generationuse-cacheable-supports-method
: A boolean which indicate if we useCacheableSupportsMethodInterface
interface to improve caching performances when used with Symfony Serializer.
Multi schemas¶
Jane JsonSchema can also generate multiple schemas at the same time with different namespaces and directories, allowing to handle JSON References on others schemas.
See Multi schemas generation for more information