X-Git-Url: https://git.camperquake.de/gitweb.cgi?a=blobdiff_plain;f=xmlrtorrent%2FHTTPTalker.pm;h=d8b9340519a1ec446c0d5dba8fa3f41f25853da3;hb=04b77099c1d5e26a81651245b5949dee2c8e6bf6;hp=bab2209017aa5857c292639fe69aa23cac8fa062;hpb=f53811070671adc7647202740c5921bc6ae8340d;p=xmlrtorrent.git diff --git a/xmlrtorrent/HTTPTalker.pm b/xmlrtorrent/HTTPTalker.pm index bab2209..d8b9340 100644 --- a/xmlrtorrent/HTTPTalker.pm +++ b/xmlrtorrent/HTTPTalker.pm @@ -8,7 +8,7 @@ use xmlrtorrent::TalkerBase; @ISA = qw(xmlrtorrent::TalkerBase); use Data::Dumper; - +use RPC::XML::Client; use strict; sub new { @@ -17,6 +17,12 @@ sub new { $self->{'NAME'} = 'http'; $self->{'DESC'} = 'talker using RPC over HTTP'; + $self->{'_PARAMS'} = { + 'XMLURL' => ['', 'URL of SCGI script'], + 'USERNAME' => ['', 'username for RPC credentials (optional)'], + 'PASSWORD' => ['', 'password for RPC credentials (optional)'], + }; + $self->{'_LASTXMLURL'} = undef; bless($self, $class); @@ -25,4 +31,30 @@ sub new { return $self; } +sub send_request { + my $self = shift; + my @params = @_; + + my $xmlurl = $self->_getval('XMLURL'); + + unless (defined($xmlurl) and $xmlurl ne '') { + return 'http talker: XMLURL not set'; + } + + if ($xmlurl ne $self->{'_LASTXMLURL'}) { + $self->{'_LASTXMLURL'} = $xmlurl; + $self->{'__RPCClient'} = RPC::XML::Client->new($xmlurl); + } + + my $username = $self->_getval('USERNAME'); + my $password = $self->_getval('PASSWORD'); + + if (defined $username and defined $password and $username ne '') { + # mitch: let me guess, the realm must be configurable, too! + $self->{'__RPCClient'}->credentials('', $username, $password); + } + + return $self->{'__RPCClient'}->send_request(@params); +} + 1;