X-Git-Url: https://git.camperquake.de/gitweb.cgi?p=xmlrtorrent.git;a=blobdiff_plain;f=xmlrtorrent%2FHTTPTalker.pm;h=1254b2ddd506d1157447dbbfebcc0a490de7e8fb;hp=bab2209017aa5857c292639fe69aa23cac8fa062;hb=HEAD;hpb=f53811070671adc7647202740c5921bc6ae8340d diff --git a/xmlrtorrent/HTTPTalker.pm b/xmlrtorrent/HTTPTalker.pm index bab2209..1254b2d 100644 --- a/xmlrtorrent/HTTPTalker.pm +++ b/xmlrtorrent/HTTPTalker.pm @@ -4,11 +4,11 @@ # licensed under GNU GPL v2 package xmlrtorrent::HTTPTalker; -use xmlrtorrent::TalkerBase; -@ISA = qw(xmlrtorrent::TalkerBase); +use xmlrtorrent::RTorrentTalkerBase; +@ISA = qw(xmlrtorrent::RTorrentTalkerBase); 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;