json-raw-encoder icon indicating copy to clipboard operation
json-raw-encoder copied to clipboard

Use this package to encode arrays to JSON with raw JS objects (eg. callbacks) in them.

Moved to GitLab

Warning: This project has been moved to GitLab: https://gitlab.com/balping/json-raw-encoder


Json Raw Encoder

Use this package to encode arrays to JSON with raw JS objects (eg. callbacks) in them.

Installation

composer require balping/json-raw-encoder

Usage

Suppose you need to pass a callback to a JSON object.

<?php
    $array = [
        'type' => 'cat',
        'count' => 42,
        'callback' => 'function(a){alert(a);}'
    ];
?>

<scrtip>
    let bar = <?php echo $json_encode($array); ?>
    bar.callback('hello'); //error
</script>

However, the above array will be encoded as

{"type":"cat","count":42,"callback":"function(a){alert(a);}"}

On this object, you cannot call callback(), as callback is a string and not a function.

To get around this problem, use Raw objects provided by this package:

<?php
    use Balping\JsonRaw\Raw;
    use Balping\JsonRaw\Encoder;

    $array = [
        'type' => 'cat',
        'count' => 42,
        'callback' => new Raw('function(a){alert(a);}')
    ];
?>

<scrtip>
    let bar = <?php echo Encoder::encode($array); ?>
    bar.callback('hello'); //prints hello
</script>

Now, the encoded JSON looks like this. Notice, that there are no parentheses around the function.

{"type":"cat","count":42,"callback":function(a){alert(a);}}

Calling bar.callback() now works, as callback is a function and not a string.

Using with third party libraries

It is possible that the serialisation is done by a library (eg. Fractal), and not by your code, i.e. you cannot replace json_encode with Encoder::encode().

In this case, you can still pass callbacks to JSON, by passing the encoded json and an array of all raw objects to Replacer::replace():


use Balping\JsonRaw\Raw;
use Balping\JsonRaw\Replacer;

$rawObjects = [];

$array = [
    'type' => 'cat',
    'count' => 42,
    'callback' => $rawObjects[] = new Raw('function(a){alert(a);}')
];

// you cannot alter the behaviour of a third party encoder
$encoded = $thirdParty->jsonEncode($array);

echo Replacer::replace($encoded, $rawObjects);

Result:

{"type":"cat","count":42,"callback":function(a){alert(a);}}

License

This package is licensed under GPLv3.