php-extended / php-json-schema-generator-object
A library that implements the php-extended/php-json-schema-generator-interface library
Installs: 498
Dependents: 1
Suggesters: 0
Security: 0
Stars: 0
Forks: 0
pkg:composer/php-extended/php-json-schema-generator-object
Requires
- php: >=8.1
- php-extended/php-accept-language-object: ^8
- php-extended/php-email-address-object: ^8
- php-extended/php-file-object: ^8
- php-extended/php-http-client-factory-object: ^8
- php-extended/php-json-schema-generator-interface: ^8
- php-extended/php-json-schema-object: ^8.1
- php-extended/php-simple-cache-filesystem: ^8
- php-extended/php-simple-cache-logger: ^8
- php-extended/php-siret-object: ^8
- php-extended/php-uuid-object: ^8
- php-extended/php-version-object: ^8
- psr/http-client: ^1
- psr/simple-cache: ^3
Requires (Dev)
README
A library that implements the php-extended/php-json-schema-generator-interface interface library.
Installation
The installation of this library is made via composer and the autoloading of all classes of this library is made through their autoloader.
- Download
composer.pharfrom their website. - Then run the following command to install this library as dependency :
php composer.phar php-extended/php-json-schema-generator-object ^8
Building the library
To add a new string parsed format, we use the following to build json schemas :
{
"properties": {
"<field_name>": {
"type": "string",
"description": "<description>",
"format": "<new_type_to_be_parsed>"
}
}
}
Then, the new type should be added into the JsonSchemaDefaultVisitor, the JsonSchemaCalculatedVisitor,
the JsonSchemaTypeVisitor, and the JsonSchemaTestUsesVisitor with an adequate test case should be
created for it to pass the 100% coverage.
Actually, the parseable types as strings are as follow :
accept-language-chain: yields aPhpExtended\AcceptLanguage\AcceptLanguageChainInterfacedate: yields a\DateTimeImmutabledate: yields a\DateTimeImmutableemail: yields aPhpExtended\EmailAddress\EmailAddressInterfaceemail-list: yields aPhpExtended\Email\EmailAddressListInterfacemailbox: yields aPhpExtended\Email\MailboxInterfacemailbox-list: yields aPhpExtended\Email\MailboxListInterfacetime: yields a\DateTimeImmutablesiren: yields aPhpExtended\Siret\SirenInterfacesiret: yields aPhpExtended\Siret\SiretInterfaceuri: yields aPsr\Http\Message\UriInterfaceuri-reference: yields aPsr\Http\Message\UriInterfaceuri-template: yields aPsr\Http\Message\UriInterfaceiri: yields aPsr\Http\Message\UriInterfaceiri-reference: yields aPsr\Http\Message\UriInterfaceuuid: yields aPhpExtended\Uri\UriInterfaceversion: yields aPhpExtended\Version\VersionInterface
Basic Usage
This library may be used the following way :
use PhpExtended\JsonSchema\JsonSchemaFileGeneratorPhp74;
use PhpExtended\JsonSchema\JsonSchemaFileWriter;
use PhpExtended\JsonSchema\JsonSchemaProvider;
use PhpExtended\JsonSchema\NamespaceHolder;
/** @var $logger Psr\Logger\LoggerInterface */
$jsonSchemaProvider = new JsonSchemaProvider();
$jsonSchema = $jsonSchemaProvider->provideFromFile('</path/to/file/json-schema.json>');
$namespaces = new NamespaceHolder('NS\\Interfaces', 'NS\\Classes', 'NS\\Tests');
$generator = new JsonSchemaFileGeneratorPhp74($namespaces, 'interface/composer-package-name', 'classes/composer-package-name', 'tests/composer-package-name', $logger);
$fileCollection = $generator->generate($jsonSchema);
$fileWriter = new JsonSchemaFileWriter($logger, '/path/to/interfaces/src', '/path/to/classes/src', '/path/to/tests/src');
$fileWrite->write($fileCollection);
License
MIT (See license file).