The Ivory JSON builder allows you to build your JSON through the Symfony2 PropertyAccess component while keeping the control of the value escaping.
To build some JSON, you will need to instanciate a builder:
use Ivory\JsonBuilder\JsonBuilder;
$builder = new JsonBuilder();
To set your values on the builder, you can either use setValues
or setValue
but be aware they don't behave same.
Basically, setValues
allows you to append a set of values in the builder without escaping control whereas setValue
allows you to append one value in the builder but with escaping control.
To append a set of values in the builder, just use setValues
and pass your values as first argument:
$builder->setValues(array('foo' => array('bar')));
Additionally, this method takes as second argument a path prefix (Symfony2 PropertyAccess component syntax) which allows you to append your values where you want in the builder graph. So, the next sample is basically the equivalent of the precedent:
$builder->setValues(array('bar'), '[foo]');
To append one value in the builder, just use setValue
and pass the path as first argument and the value as second one:
$builder->setValue('[foo][0]','bar');
If you want to keep control of the value escaping, this part is for you :) Basically, just pass false
as third
argument:
$builder->setValue('[foo][0]','bar', false);
By default, the JSON builder uses the native json_encode
options. To override it, you can use:
$builder->setJsonEncodeOptions(JSON_FORCE_OBJECT);
$jsonEncodeOptions = $builder->getJsonEncodeOptions();
Once your builder is well configured, you can build your JSON:
$json = $builder->build();
Because the builder is statefull (keep a track of every values), you need to reset it if you want to restart a json build:
$builder->reset();
If you still don't understand, a concrete example :)
use Ivory\JsonBuilder\JsonBuilder;
$builder = new JsonBuilder();
// {"0":"foo","1":bar}
echo $builder
->setJsonEncodeOptions(JSON_FORCE_OBJECT)
->setValues(array('foo'))
->setValue('[1]', 'bar', false)
->build();
// {"foo":["bar"],"baz":bat}
echo $builder
->reset()
->setValues(array('foo' => array('bar')))
->setValue('[baz]', 'bat', false)
->build();