NAME
FUSE::Server - Perl-FUSE server
SYNOPSIS
use FUSE::Server;
$s = FUSE::Server->new({
Port=>35008,
MaxClients=>5000,
Quiet=>1,
});
$status = $s->start();
print "Server started: $status";
$s->addCallback('BROADCASTALL',\&msg_broadcast);
$s->addCallback('client_start',\&msg_client_start);
$s->defaultCallback(\&unknown_command);
$SIG{INT} = $SIG{TERM} = $SIG{HUP} = sub{$s->die();};
$s->run();
sub msg_broadcast{
my ($userid,$msg,$params) = @_;
my @a = split /\//,$params;
$server->sendAll($a[1],$a[2]);
}
sub msg_client_start{
my ($userid,$msg,$params) = @_;
$server->send($sock,'SECRET_KEY','123 456 789');
}
sub unknown_command{
my ($userid,$msg,$params) = @_;
print "Unknown command $msg\n";
}
DESCRIPTION
The FUSE::Server
module will create a TCP FUSE server and dispatch messages to registered event handlers.
The external interface to FUSE::Server
is:
- $s = FUSE::Server->new( [%options] );
-
The object constructor takes the following arguments:
- $s->start;
-
This method starts the server listening on it's port and returns the IP which it is listening on.
- $s->addCallback( $message, $coderef );
-
This method registers the referenced subroutine as a handler for the specified message. When the server receives that message from the client, it checks it's handler hash and dispatches the decoded message to the sub. The sub should handle the following arguments:
( $userid, $msg, $params )
$userid contains the internal connection id for the client session. You can use this id to associate logins with clients. The $msg parameter contains the message the client sent. This allows one routine to handle more than one message. Messages from clients are typically uppercase, with lowercase messages being reserved for internal server events, such as client connect/disconnect. The available internal messages are:
client_start This message is sent when a client first connects. It is typically used to issue a SECRET_KEY message to the client.
client_stop This message is sent when a client disconnects.
- $s->defaultCallback( $coderef );
-
For all messages without an assigned handler, the default handler (if set) is sent the message. If you'd like to handle all messages internally, then setup
defaultCallback
without setting up any normaladdCallback
's. - $s->die;
-
This method shuts down the server gracefully. Since the
run
method loops, thedie
method is generally set up to run on signal. - $s->run;
-
This method invokes the server's internal message pump. This loop can only be broken by a signal.
AUTHOR
Cal Henderson, <cal@iamcal.com>