devlabs91 / php-code-builder
Swaggest JSON-schema enabled PHP code builder
v0.2.10
2019-01-10 02:45 UTC
Requires
- php: >=5.5.0
- ext-json: *
- devlabs91/code-builder: ^0.3.1
- devlabs91/json-schema: ^0.12.0
Requires (Dev)
- phpunit/phpunit: 4.8.36
README
This library generates PHP mapping structures defined by JSON schema
using swaggest/json-schema
.
Example
You need to add swaggest/json-schema
to your dependencies.
<?php require_once __DIR__ . '/vendor/autoload.php'; $schemaData = json_decode(<<<'JSON' { "type": "object", "properties": { "id": {"type": "integer"}, "name": {"type": "string"}, "parent": {"$ref": "#"}, "children": {"type": "array", "items": {"$ref": "#"}}, "info": {"$ref": "#/definitions/info"} }, "definitions": { "info": { "type": "object", "properties": { "lastName": {"type": "string"}, "birthDate": {"type": "string", "format": "date-time"}, "options": {"$ref": "#/definitions/options"} } }, "options": { "type": "object", "properties": { "rememberSession": {"type": "boolean"}, "allowNotifications": {"type": "boolean"} } } } } JSON ); $swaggerSchema = \Swaggest\JsonSchema\Schema::import($schemaData); $appPath = realpath(__DIR__ . '/tests/src/Tmp') . '/Example'; $appNs = 'Swaggest\PhpCodeBuilder\Tests\Tmp\Example'; $app = new \Swaggest\PhpCodeBuilder\App\PhpApp(); $app->setNamespaceRoot($appNs, '.'); $builder = new \Swaggest\PhpCodeBuilder\JsonSchema\PhpBuilder(); $builder->buildSetters = true; $builder->makeEnumConstants = true; $builder->classCreatedHook = new \Swaggest\PhpCodeBuilder\JsonSchema\ClassHookCallback( function (\Swaggest\PhpCodeBuilder\PhpClass $class, $path, $schema) use ($app, $appNs) { $desc = ''; if ($schema->title) { $desc = $schema->title; } if ($schema->description) { $desc .= "\n" . $schema->description; } if ($fromRefs = $schema->getFromRefs()) { $desc .= "\nBuilt from " . implode("\n" . ' <- ', $fromRefs); } $class->setDescription(trim($desc)); $class->setNamespace($appNs); if ('#' === $path) { $class->setName('User'); // Class name for root schema } elseif (strpos($path, '#/definitions/') === 0)) { $class->setName(\Swaggest\PhpCodeBuilder\PhpCode::makePhpClassName( substr($path, strlen('#/definitions/')))); } $app->addClass($class); } ); $builder->getType($swaggerSchema); $app->clearOldFiles($appPath); $app->store($appPath);
Creating and exporting an instance
$user = new \Swaggest\PhpCodeBuilder\Tests\Tmp\Example\User(); $user->name = "John"; $user->info = (new \Swaggest\PhpCodeBuilder\Tests\Tmp\Example\Info()) ->setLastName("Doe") ->setBirthDate("1980-01-01") ->setOptions( (new \Swaggest\PhpCodeBuilder\Tests\Tmp\Example\Options()) ->setRememberSession(true) ->setAllowNotifications(false) ); // No exception on exporting valid data $jsonData = \Swaggest\PhpCodeBuilder\Tests\Tmp\Example\User::export($user); // {"name":"John","info":{"lastName":"Doe","birthDate":"1980-01-01","options":{"rememberSession":true,"allowNotifications":false}}} echo json_encode($jsonData); // Setting invalid value (integer instead of string) $user->name = 123; // Exception: String expected, 123 received at #->$ref[#]->properties:name $jsonData = \Swaggest\PhpCodeBuilder\Tests\Tmp\Example\User::export($user);
Creating class instance from raw data
// Importing raw data to entity class instance will do validation and mapping $user = \Swaggest\PhpCodeBuilder\Tests\Tmp\Example\User::import( json_decode('{"name":"John","info":{"lastName":"Doe","birthDate":"1980-01-01","options":{"rememberSession":true,"allowNotifications":false}}}') ); var_dump($user->info->options->allowNotifications); // bool(false)