php-extended/php-json-schema-generator-object
最新稳定版本:8.0.9
Composer 安装命令:
composer require php-extended/php-json-schema-generator-object
包简介
A library that implements the php-extended/php-json-schema-generator-interface library
README 文档
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).
统计信息
- 总下载量: 510
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 0
- 点击次数: 0
- 依赖项目数: 1
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2023-09-20