NAME
POEx::ProxySession::Server - Hosts published sessions and routes proxy message
VERSION
version 1.102750
SYNOPSIS
class Flarg { with 'POEx::Role::SessionInstantiation';
after _start(@args) is Event
{
POEx::ProxySession::Server->new
(
listen_ip => '127.0.0.1',
listen_port => 56789,
alias => 'Server',
options => { trace => 1, debug => 1 },
);
}
}
DESCRIPTION
POEx::ProxySession::Server is a lightweight network server that handles storage and listing of published sessions, and routing of proxied messages between connected clients.
PROTECTED_ATTRIBUTES
sessions
This attribute is used to store the published sessions.
Access these sessions through the following methods:
The stored structure looks like the following:
Session =>
{
name => isa SessionAlias,
methods => isa HashRef,
id => isa WheelID,
}
delivered_store
delivered_store holds the wheel ids that are awaiting a response from some other client.
Access to these ids is provided through the following methods:
handles =>
{
get_delivered => 'get',
set_delivered => 'set',
delete_delivered => 'delete',
count_delivereds => 'count',
all_delivered_keys => 'keys',
all_delivered_values => 'values',
has_delivered => 'exists',
}
PROTECTED_METHODS
handle_inbound_data
(ProxyMessage $data, WheelID $id) is Event
Our implementation of handle_inbound_data expects a ProxyMessage as data. Here is where the handling and routing of messages lives. The following types of messages are handled here: publish, rescind, listing, subscribe, deliver, and result.
rescind_session
(ProxyMessage $data, WheelID $id) is Event
This handles rescinding of a published session. No payload on success.
publish_session
(ProxyMessage $data, WheelID $id) is Event
This method handles session publication. Payload on success is the session alias
subscribe_session
(ProxyMessage $data, WheelID $id) is Event
This method handles subscription requests. Payload on success is a hashref:
Payload =>
{
session => isa SessionAlias,
methods => HashRef,
}
deliver_message
(ProxyMessage $data, WheelID $id) is Event
This method does message delivery by doing a lookup of the alias to the real session name, and rewriting the message header to point to that session, then sends it on to that session's connection. Sets a delivered message.
handle_delivered
(ProxyMessage $data, WheelID $id) is Event
This method handles result messages from delivered messages. All messages that go through the system are expected to return a result message indicating success or failure.
get_listing
(ProxyMessage $data, WheelID $id) is Event
This method handles listing requests from clients. Should always succeed. Payload is an ArrayRef[SessionAlias].
PRIVATE_METHODS
after _start
(@args) is Event
The _start method is advised to hardcode the filter to use as a POE::Filter::Reference instance.
AUTHOR
Nicholas Perez <nperez@cpan.org>
COPYRIGHT AND LICENSE
This software is copyright (c) 2010 by Nicholas Perez.
This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.