swaggest / json-schema-maker
Instance to JSON schema and back
Installs: 27 918
Dependents: 3
Suggesters: 0
Security: 0
Stars: 10
Watchers: 1
Forks: 0
Open Issues: 0
Requires
- php: >=5.6.0
- ext-json: *
- swaggest/json-schema: ^0.12.27
Requires (Dev)
- phpunit/phpunit: ^5
README
Create JSON Schema from instance values and vice versa.
Installation
composer require swaggest/json-schema-maker
Usage
CLI
v1.7.8 json-cli build-schema
JSON CLI tool, https://github.com/swaggest/json-cli
Usage:
json-cli build-schema <data> [schema]
data Path to data (JSON/YAML)
schema Path to parent schema
Options:
--ptr-in-schema <ptrInSchema> JSON pointer to structure in root schema, default #
--ptr-in-data <ptrInData> JSON pointer to structure in data, default #
--jsonl Data is a stream of JSON Lines
--use-nullable Use `nullable: true` instead of `type: null`, OAS 3.0 compatibility
--use-xnullable Use `x-nullable: true` instead of `type: null`, Swagger 2.0 compatibility
--defs-ptr <defsPtr> Location to put new definitions. default: "#/definitions/"
--collect-examples Collect scalar values example
--heuristic-required Mark properties that are available in all samples as `required`.
--additional-data <additionalData...> Additional paths to data
--pretty Pretty-print result JSON
--output <output> Path to output result, default STDOUT
--to-yaml Output in YAML format
--to-serialized Output in PHP serialized format
Basic example:
json-cli build-schema tests/assets/original.json
{"properties":{"key1":{"items":{"type":"integer"},"type":"array"},"key2":{"type":"integer"},"key3":{"$ref":"#/definitions/key3"},"key4":{"items":{"$ref":"#/definitions/key4.element"},"type":"array"}},"type":"object","definitions":{"key3":{"properties":{"sub0":{"type":"integer"},"sub1":{"type":"string"},"sub2":{"type":"string"}},"type":"object"},"key4.element":{"properties":{"a":{"type":"integer"},"b":{"type":"boolean"}},"type":"object"}}}
Advanced example:
json-cli build-schema dump-responses.jsonl ./acme-service/swagger.json --ptr-in-schema "#/definitions/Orders" --jsonl --ptr-in-data "#/responseValue" --pretty --output swagger.json
Updates swagger.json
with actual response samples provided in dump-responses.jsonl
.
Generating JSON schema based on instance values
$instanceValue = json_decode(file_get_contents(__DIR__ . '/../resources/github-example.json')); $schema = new \Swaggest\JsonSchema\Schema(); $f = new \Swaggest\JsonSchemaMaker\SchemaMaker($schema); $f->options->upgradeIntToNumber = true; // Use `type: number` instead of `type: [integer, number]`. $f->addInstanceValue($instanceValue); $schemaJson = json_encode(\Swaggest\JsonSchema\Schema::export($schema)); // With object schemas extracted as definitions. $schemaJsonInline = json_encode($schema); // With inline object schemas.
See available options.
See example schemas.
Generating fake instance value based on JSON schema
mt_srand(1); // Optionally seed random generator for reproducible results. $schema = \Swaggest\JsonSchema\Schema::import(json_decode(file_get_contents(__DIR__ . '/../resources/github-example-schema-with-examples.json'))); $instanceFaker = new \Swaggest\JsonSchemaMaker\InstanceFaker($schema); $value = $instanceFaker->makeValue(); $anotherValue = $instanceFaker->makeValue();
See available options.
See example value.