NAME
IO::Async::JSONStream
- send or receive lines of JSON data in IO::Async
SYNOPSIS
use IO::Async::JSONStream;
use IO::Async::Loop;
my $loop = IO::Async::Loop->new;
my $jsonstream = IO::Async::JSONStream->new;
$loop->add( $jsonstream );
$jsonstream->connect(
host => "my.server",
service => 12345,
)->then( sub {
$jsonstream->write_json( [ data => { goes => "here" } ] );
$jsonstream->read_json
})->on_done( sub {
my ( $data ) = @_;
print "Received the data $data\n";
})->get;
DESCRIPTION
This subclass of IO::Async::Stream implements a simple JSON-encoded data stream, sending and receiving Perl data structures by JSON-encoded lines of text.
EVENTS
The following events are invoked, either using subclass methods or CODE references in parameters:
on_json $data
Invoked when a line of JSON-encoded data is received. It is passed the decoded data as a regular Perl data structure.
on_json_error $error, $line
Invoked when a line is received but JSON decoding fails. It is passed the failure exception from the JSON decoder and the line on which decoding failed.
PARAMETERS
The following named parameters may be passed to new
or configure
:
- on_json => CODE
- on_json_error => CODE
-
CODE references for event handlers.
- eol => STRING
-
Optional. Sets the string used for the line ending on the stream. Defaults to
\n
if not given.
METHODS
$jsonstream->write_json( $data, %args )
Writes a new line of JSON-encoded data from the given Perl data structure.
Other arguments are passed to the write
method. Returns a Future
which will complete when the line is flushed.
$jsonstream->read_json ==> $data
Returns a Future that will yield the next line of JSON-encoded data to be read from the stream. This takes place instead of the on_json
event.
If a JSON decoding error occurs it will result in a failed Future with the operation name json
and the line on which decoding failed as its argument.
TODO
Consider a true streaming mode, using
JSON
's incremental parsing ability.
AUTHOR
Paul Evans <leonerd@leonerd.org.uk>