zepgram / module-json-schema
Json Schema Validation for Magento 2
Installs: 15 661
Dependents: 1
Suggesters: 0
Security: 0
Stars: 1
Watchers: 1
Forks: 0
Open Issues: 0
Type:magento2-module
Requires
- justinrainbow/json-schema: ~5.2.11
- magento/framework: ^103.0.4
This package is auto-updated.
Last update: 2024-11-29 06:35:52 UTC
README
A Magento implementation for validating JSON Structures against a given Schema with support for Schemas of Draft-3 or Draft-4.
Based on https://github.com/justinrainbow/json-schema json schema.
For more information about json schema: http://json-schema.org/
Installation
composer require zepgram/module-json-schema
bin/magento module:enable Zepgram_JsonSchema
bin/magento setup:upgrade
Guideline
- Add the formatted json-schema in your module, where webservice will be implemented under
/etc/schema
directory. - Create a Virtual Class of type
Zepgram\JsonSchema\Model\Validator
and adaptfileName
andmoduleName
parameters.
Example
/etc/di.xml
<virtualType name="HelloWorldValidator" type="Zepgram\JsonSchema\Model\Validator"> <arguments> <argument name="fileName" xsi:type="string">schema/hello-world-service.json</argument> <argument name="moduleName" xsi:type="string">Zepgram_HelloWorld</argument> </arguments> </virtualType>
/etc/schema/hello-world-service.json
{ "type":"array", "items":{ "type":"object", "required":[ "helloId", "helloContact" ], "properties":{ "helloId":{ "type":"string", "description":"Hello Id" }, "helloContact":{ "type":"array", "items":{ "type":"object", "required":[ "age", "fullName" ], "properties":{ "age":{ "type":"integer", "format":"int32", "description":"contact age", "minimum":-2147483648, "maximum":2147483647 }, "fullName":{ "type":"object", "required":[ "firstname", "lastname" ], "properties":{ "firstname":{ "type":"string", "description":"contact firstname" }, "lastname":{ "type":"string", "description":"contact lastname" } } } } } } } }, "$schema":"http://json-schema.org/draft-04/schema#" }
Open API V3
If your architecture is using open API-V3 to describe web service usage you can convert it to json schema.
- Install the node utility: https://github.com/mikunn/openapi2schema
- Convert the open api yaml file into JSON:
openapi2schema -i my-custom-service.yaml | python -m json.tool | jq '."%end_point%".post.body' > my-custom-service.json
where%endpoint%
must be replaced by your api endpoint described in yaml file (e.g.: /v1/customEndPoint)
Issues
If you encountered an issue during installation or with usage, please report it on this github repository.