###################################################################### AOLserver::CtrlPort 0.02 ###################################################################### NAME AOLserver::CtrlPort - Execute Commands on AOLserver's Control Port SYNOPSIS use AOLserver::CtrlPort; my $conn = AOLserver::CtrlPort->new( Host => 'myhost', Port => 3456, User => 'username', Password => 'password', ); my $out = $conn->send_cmds(<<EOT); info tclversion EOT print $out, "\n"; DESCRIPTION "AOLserver::CtrlPort" uses "Net::Telnet" to connect to a running AOLserver's control port, issues commands there and returns the output. It is useful for creating test suites for AOLserver applications which can be controlled via the control port. To configure AOLserver's control port, use settings similar to the following ones: ns_section "ns/server/${servername}/module/nscp" ns_param address myhostname ns_param port 3334 ns_param echopassword 1 ns_param cpcmdlogging 1 ns_section "ns/server/${servername}/module/nscp/users" ns_param user "username:3G5/H31peci.o:" # That's "username:password" ns_section "ns/server/${servername}/modules" ns_param nscp ${bindir}/nscp.so This lets AOLserver enable the control port on server "myhostname" on port 3334. Authentication is on, the username is "username" and the password is "password" (hashed to "3G5/H31peci.o" with a program like "htpasswd"). METHODS AOLserver::CtrlPort->new(...) Creates a new control port client object. The following options are available to the constructor: Port The port AOLserver is listening to for control port commands. Host The control port "address" as defined in the configuration. Timeout Number of seconds after which the client will time out if the server doesn't send a response. User User name for control port login defaults to the empty string for non-protected control ports. Password Password for control port login defaults to the empty string for non-protected control ports. $conn->send_cmds("$cmd1\ncmd2\n...") Send one or more commands, separated by newlines, AOLserver's control port. The method will return the server's response as a string. Typically, this will look like $out = $conn->send_cmds(<<EOT); info tclversion info commands EOT and return the newline-separated response as a single string. Debugging AOLserver::CtrlPort is Log4perl enabled. If your scripts don't do what you want and you need to find out which messages are being sent back and forth, you can easily bump up AOLserver::CtrlPort's internal debugging level by saying something like use Log::Log4perl qw(:easy); Log::Log4perl->easy_init($DEBUG); in your test script before any AOLserver::CtrlPort commands are called. Please check out the Log::Log4perl documentation for details. AUTHOR Mike Schilli, 2004, m@perlmeister.com