Maslosoft Mangan API
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55
<?php
/**
* This software package is licensed under AGPL or Commercial license.
*
* @package maslosoft/mangan
* @licence AGPL or Commercial
* @copyright Copyright (c) Piotr Masełkowski <pmaselkowski@gmail.com>
* @copyright Copyright (c) Maslosoft
* @copyright Copyright (c) Others as mentioned in code
* @link https://maslosoft.com/mangan/
*/
namespace Maslosoft\Mangan\Transformers;
use Maslosoft\Addendum\Interfaces\AnnotatedInterface;
use Maslosoft\Mangan\Exceptions\TransformatorException;
use Maslosoft\Mangan\Interfaces\Transformators\TransformatorInterface;
/**
* JsonString
*
* @author Piotr Maselkowski <pmaselkowski at gmail.com>
*/
class JsonString implements TransformatorInterface
{
/**
* Returns the given object as an associative array
* @param AnnotatedInterface|object $model
* @param string[] $fields Fields to transform
* @param int $options json_encode options
* @return array an associative array of the contents of this object
*/
public static function fromModel(AnnotatedInterface $model, $fields = [], $options = null)
{
return json_encode(JsonArray::fromModel($model, $fields), $options);
}
/**
* Create document from array
*
* @param mixed[] $data
* @param string|object $className
* @param AnnotatedInterface $instance
* @return AnnotatedInterface
* @throws TransformatorException
*/
public static function toModel($data, $className = null, AnnotatedInterface $instance = null)
{
return JsonArray::toModel(json_decode($data, true), $className, $instance);
}
}
API documentation generated by ApiGen