NAME

POEx::ZMQ3::Sockets - POE ZeroMQ Component

SYNOPSIS

## A 'REQ' client that sends 'PING' to a REP on localhost:5050
use strictures 1;
use POE;
use POEx::ZMQ3::Sockets;

POE::Session->create(
  package_states => [
    main => [ qw/
      _start
      zmqsock_registered
      zmqsock_recv
    / ],
  ]
);

sub _start {
  my ($kern, $heap) = @_[KERNEL, HEAP];
  my $zmq = POEx::ZMQ3::Sockets->new;

  $zmq->start;

  $heap->{zmq} = $zmq;

  $kern->call( $zmq->session_id, 'subscribe', 'all' );
}

sub zmqsock_registered {
  my ($kern, $heap) = @_[KERNEL, HEAP];
  my $zmq = $heap->{zmq};

  $zmq->create( 'pinger', 'REQ' );

  $zmq->connect( 'pinger', 'tcp://127.0.0.1:5050' );

  $zmq->write( 'pinger', 'PING' );
}

sub zmqsock_recv {
  my ($kern, $heap) = @_[KERNEL, HEAP];
  my ($alias, $data) = @_[ARG0 .. $#_];

  if ($data eq 'PONG') {
    ## Got a PONG. Send another PING:
    $zmq->write( 'pinger', 'PING' );
  }
}

$poe_kernel->run;

DESCRIPTION

This is the backend MooX::Role::POE::Emitter session behind POEx::ZMQ3, integrating ZeroMQ (http://www.zeromq.org) with a POE event loop.

Registering Sessions

Your POE::Session should register with the component to receive events:

## Inside a POE::Session
## Get all events from component in $_[HEAP]->{zmq}:
sub my_start {
  my $zmq = $_[HEAP]->{zmq};
  $_[KERNEL]->call( $zmq->session_id, 'subscribe', 'all' );
}

See "POE API" for more on events emitted and accepted by this component.

See MooX::Role::POE::Emitter for more details on event emitters; the documentation regarding event prefixes and session details lives there.

Methods

start

Takes no arguments.

Spawns the MooX::Role::POE::Emitter session that controls ZMQ socket handling. Must be called prior to operating on sockets.

stop

Takes no arguments.

Stops the component, closing out all active sockets.

create

Takes a socket alias and a socket type.

Creates a new ZeroMQ socket. The socket is not initially bound/connected to anything; see "bind", "connect".

The socket type may be either a constant from ZMQ::Constants or a string type:

## Equivalent:

$zmq->create( $alias, 'PUB' );

use ZMQ::Constants 'ZMQ_PUB';
$zmq->create( $alias, ZMQ_PUB );

See the zmq_socket man page for details.

bind

Takes a socket alias and an endpoint to listen for connections on.

The opposite of "bind" is "connect"

connect

Takes a socket alias and a target endpoint to connect to.

Note that ZeroMQ manages its own connections asynchronously. A successful "bind" or "connect" is not necessarily indicative of a positively usable connection.

write

Takes a socket alias, some data (as a scalar), and optional flags to pass to ZeroMQ's zmq_msg_send:

## Write a simple message:
$zmq->write( $alias, 'A message' );

## Write some serialized data:
my $ref  = { things => 'some data' };
my $data = Storable::nfreeze( $ref );
$zmq->write( $alias, $data );

Writes data to the ZMQ socket, when possible.

Also see "write_multipart".

write_multipart

Takes a socket alias and a list of scalar data items to send as a multi-part message:

$zmq->write_multipart( $alias, $header, $content );

See the ZeroMQ documentation for details regarding multi-part messages.

Also see "zmqsock_multipart_recv"

close

Takes a socket alias.

Closes the specified ZMQ socket.

context

Takes no arguments.

Returns the current POEx::ZMQ3::Context object.

get_zmq_socket

Takes a socket alias.

Returns the actual ZMQ::LibZMQ3 socket object.

set_zmq_sockopt

Takes a socket alias and arbitrary flags/options to pass to zmq_setsockopt.

See the man page for zmq_setsockopt.

set_zmq_subscribe

Takes a socket alias and an optional subscription prefix.

Calls "set_zmq_sockopt" to set the ZMQ_SUBSCRIBE flag for the specified socket; this is used by SUB-type sockets to subscribe to messages.

If no subscription prefix is specified, the socket will be subscribed to all messages.

POE API

Emitted Events

zmqsock_bind_added

Emitted when a "bind" has been executed.

$_[ARG0] is the socket's alias.

$_[ARG1] is the endpoint string.

zmqsock_connect_added

Emitted when a "connect" has been executed.

$_[ARG0] is the socket's alias.

$_[ARG1] is the endpoint string.

zmqsock_recv

Emitted when some data has been received on a socket.

$_[ARG0] is the socket's alias.

$_[ARG1] is the raw message data extracted via zmq_msg_data.

zmqsock_multipart_recv

Emitted when multipart data has been received on a socket.

$_[ARG0] is the socket's alias.

$_[ARG1] is an ARRAY containing the raw data extracted from each message part.

zmqsock_created

Emitted when a socket has been created.

$_[ARG0] is the alias that was spawned.

$_[ARG1] is the socket's type, as a ZMQ::Constants constant.

zmqsock_closing

Emitted when a socket is being shut down.

$_[ARG0] is the alias that is closing.

Accepted Events

The following events take the same parameters as their counterparts described in "Methods":

  • create

  • close

  • bind

  • connect

  • write

  • write_multipart

SEE ALSO

POEx::ZMQ3

ZMQ::LibZMQ3

http://www.zeromq.org

AUTHOR

Jon Portnoy <avenj@cobaltirc.org>