NAME

IO::MUlltiplex::Intermediary - multiplexing with fault tolerance

SYNOPSIS

use IO::Multiplex::Intermediary;

my $intermediary = IO::Multiplex::Intermediary->new;

$intermediary->run;

DESCRIPTION

WARNING! THIS MODULE HAS BEEN DEEMED ALPHA BY THE AUTHOR. THE API MAY CHANGE IN SUBSEQUENT VERSIONS.

This module is for users who want to optimize user experience. It keeps the external connection operations and application operations separate as separate processes, so that if the application crashes.

The core is robust in its simplicity. If the application crashes, the end users on the external side will not be disconnected. When the controller reconnects, they will be welcomed back to the real interaction in any way that the developer who extends this module sees fit.

The intermediary opens two ports: one for end users to connect to, and one for the application to connect to. The intermediary server and client use JSON to communicate with each other. Here is an example of the life cycle of the intermediary and application:

 User land       |  Intermediary      |  Application
                 |                    |
 Connect         |                    |
                 |  Accept user       |
                 |  connection        |
                 |                    |
                 |  Send the          |
                 |  connection        |
                 |  action to         |
                 |   the app          |
                 |                    |  Receive
                 |                    |  connection
                 |                    |
                 |                    |  Track any
                 |                    |  user data
                 |                    |
 User sends      |                    |
 something       |                    |
                 | Read the message   |
                 |                    |
                 | Send the message   |
                 | to the app         |
                 |                    |  Read the message
                 |                    |
                 |                    |  Process the message
                 |                    |  (build_response)
                 |                    |
                 |                    |  Send the response
                 |  Get the response  |
                 |                    |
                 |  Send the response |
                 |  to the appropriate|
                 |  user              |
Disconnect       |                    |
                 |  Send the discon.  |
                 |  message to the    |
                 |  intermediary      |
                 |                    |  Become aware of
                 |                    |  the disconnect
                 |                    |  and act
                 |                    |  accordingly

EXAMPLES

NOTE: Examples are in the examples/ directory supplied with the distribution.

PARAMETERS FOR new

external_port

This is the port that the end users will use to access the application. If it is not specified, the default is 6715.

client_port

This is the port that intermediary will use to communicate internally with the application.

METHODS

send($id, $data)

Sends $data (string format) to the socket that belongs to $id

HOOKS

These methods are NOT for complete overriding. They do important things that involve communication with the client. They are here so that you can hook around these methods in any way you see fit.

client_connect_event

Method called when the client connects to the intermediary

client_input_event

Method called when the client sends data to the intermediary

client_disconnect_event

Method called when the client disconnects from the intermediary

connect_event

Method called when a user connects to the intermediary

input_event

Method called when a user sends data to the intermediary

disconnect_event

Method called when a user disconnects from the intermediary

AUTHOR

Jason May <jason.a.may@gmail.com>

LICENSE

This library is free software and may be distributed under the same terms as perl itself.

1 POD Error

The following errors were encountered while parsing the POD:

Around line 389:

You forgot a '=back' before '=head1'