Skip to content

Enlumop/json2object

Repository files navigation

Json2Object Conventer

Easy to use Json 2 Object of class conventer.

Installation

Composer:

composer require enlumop/json2obj

Usage

First map JSON properties in your class:

<?php use Enlumop\JsonMapper\Attribute\JsonMap; class MyDtoClass { // If you need set base type then declarate type in mapper // You can use eg. string, int, integer, bool, boolean, float #[JsonMap(type: 'string')] public string $name; // Sometimes json property name is diffrent. Then you can use other json property name to map class property. #[JsonMap(type: 'string', jsonPropertyName: 'shortlyUserName')] public string $shortName; #[JsonMap(type: 'int')] public int $age; // If property is the same as json property then you don't need to set a type #[JsonMap()] public bool $isFine; // Mapping is also working with a private and protected properties #[JsonMap()] private bool $isPrivate; // If structure of JSON is more complex then as type use classname #[JsonMap(type: OtherDto::class)] public OtherDto $other; /**  * For array we need type of the values  * @var array<string>  */ #[JsonMap(type: 'array<string>')] public array $stringArray; /**  * For type of values array you can use clasename  * @var array<OtherDto>  */ #[JsonMap(type: 'array<' . OtherDto::class . '>')] public array $objectsArray; }

That class has mapping for this json:

{ "name": "foo bar baz", "shortlyUserName": "bar", "age": "111", "isFine": true, "isPrivate": true, "other": { "anotherProperty": "another value" }, "stringArray": [ "foo", "bar", "baz" ], "objectsArray": [ { "anotherProperty": "other another value" }, { "anotherProperty": "any other another value" } ] }

Then, if you have a JSON and Mapping in your class then just convert that:

<?php use function Enlumop\JsonMapper\json2Obj; // Get some json data $json = "GIVE ME SOME JSON IN HERE"; // Convert json to object of MyDtoClass $myObj = json2Obj(MyDtoClass::class, $json);

and done! You have object of MyDtoClass!