NAME
    POE::Component::Server::Inet - a super-server daemon implementation in
    POE

VERSION
    version 0.06

SYNOPSIS
      use strict;
      use warnings;
      use POE qw(Component::Server::Inet);

      $|=1;

      my $inetd = POE::Component::Server::Inet->spawn( options => { trace => 0 } );

      my $echo = $inetd->add_tcp( port => 0, program => \&_echo );

      print "Started echo server on port: $echo\n";

      my $fake = $inetd->add_tcp( port => 0, program => \&_fake );

      print "Started a 'fake' server on $fake\n";

      my $fake2 = $inetd->add_tcp( port => 0, program => \&_fake2 );

      print "Started another 'fake' server on $fake2\n";

      $poe_kernel->run();
      exit 0;

      sub _echo {
        use FileHandle;
        autoflush STDOUT 1;
        while(<STDIN>) {
          print STDOUT $_;
        }
        return;
      }

      sub _fake {
        return;
      }

      sub _fake2 {
        sleep 10000000000;
        return;
      }

DESCRIPTION
    POE::Component::Server::Inet is an Inetd (
    <http://en.wikipedia.org/wiki/Inetd> ) "super-server" implementation in
    POE. It currently only supports TCP based connections.

    You may either specify programs to run or use coderefs.

    The component uses POE::Wheel::Run to do its magic.

CONSTRUCTOR
    spawn
        Starts a POE::Component::Server::Inet session and returns an object.
        Takes a number of optional arguments:

          'alias', an alias to address the component by;
          'options', a hashref of POE::Session options;
          'timeout', a number in seconds to wait before forcefully terminating forked processes, default 30;

METHODS
    session_id
        Takes no arguments. Returns the POE Session ID of the component.

    add_tcp
        Adds a TCP listener to the component. Takes a number of parameters:

          'port', the port to listen on, mandatory ( can be set to 0 if required );
          'program', a program or coderef to execute for each connection, mandatory;
          'programargs', an arrayref of parameters for the program being run;
          'allow', a Net::Netmask object of hosts to allow to connect;
          'deny', a Net::Ntemask object of hosts to deny connections from;
          'user', the UID of a user to switch to;
          'group', the GID of a group to switch to;

        Options "program", "programargs", "user" and "group" are passed
        directly to POE::Wheel::Run's constructor, please check that
        documentation for extra information.

        The method call returns the port that was assigned.

    del_tcp
        Removes a TCP listener. Takes one mandatory parameter:

          'port', the port to remove;

        Any pending connections are dealt with.

    shutdown
        Terminates the component. All connections and wheels are closed.

SEE ALSO
    POE

    <http://en.wikipedia.org/wiki/Inetd>

    POE::Wheel::Run

AUTHOR
    Chris Williams <chris@bingosnet.co.uk>

COPYRIGHT AND LICENSE
    This software is copyright (c) 2014 by Chris Williams.

    This is free software; you can redistribute it and/or modify it under
    the same terms as the Perl 5 programming language system itself.