use vars qw (%allowed);
-%allowed = qw(call 1 fname 1 name 1 addr2 1 state 1 country 1 lat 1 lon 1 county 1 moddate 1 qslmgr 1 grid 1 );
+%allowed = qw(call 1 fname 1 name 1 addr2 1 state 1 country 1 lat 1 lon 1 county 1 moddate 1 qslmgr 1 grid 1 Error 1 );
sub _send
{
dbg("qrz: $state $msg") if isdbg('qrz');
if ($state eq 'blank') {
- if ($msg =~ /^<Callsign>/) {
+ if ($msg =~ /^\s*<Callsign>/) {
$conn->{state} = 'go';
- } elsif ($msg =~ /^<Error>/) {
+ } elsif ($msg =~ /^\s*<Error>/) {
_send($conn, $msg, $dxchan);
}
} elsif ($state eq 'go') {
my $target = $Internet::qrz_url || 'xmldata.qrz.com';
my $port = 80;
my $path = qq{/xml/current/?callsign=$line;username=$Internet::qrz_uid;password=$Internet::qrz_pw;agent=dxspider};
- dbg("qrz: $path") if isdbg('qrz');
+ dbg("qrz: $target:$port$path") if isdbg('qrz');
Log('call', "$call: show/qrz \U$line");
my $conn = AsyncMsg->get($self, $target, $port, $path, filter=>\&filter, prefix=>'qrz> ', on_disc=>\&_on_disc);
my $conn = shift;
my $msg = shift;
- my $state = $conn->{state};
+ my $state = $conn->{_asstate};
- dbg("asyncmsg: $msg") if isdbg('async');
+ dbg("asyncmsg: $state $msg") if isdbg('async');
# no point in going on if there is no-one wanting the output anymore
my $dxchan = DXChannel::get($conn->{caller});
my ($http, $code, $ascii) = $msg =~ m|(HTTP/\d\.\d)\s+(\d+)\s+(.*)|;
if ($code == 200) {
# success
- $conn->{state} = 'waitblank';
+ $conn->{_asstate} = 'waitblank';
} elsif ($code == 302) {
# redirect
- $conn->{state} = 'waitlocation';
+ $conn->{_asstate} = 'waitlocation';
} else {
$dxchan->send("$code $ascii");
$conn->disconnect;
} elsif ($state eq 'waitlocation') {
my ($path) = $msg =~ m|Location:\s*(.*)|;
if ($path) {
+ my $newconn;
my @uri = split m|/+|, $path;
if ($uri[0] eq 'http:') {
shift @uri;
my $host = shift @uri;
my $newpath = '/' . join('/', @uri);
$newpath .= '/' if $path =~ m|/$|;
- _getpost(ref $conn, $conn->{asyncsort}, $conn->{caller}, $host, 80, $newpath, @{$conn->{asyncargs}});
+ $newconn = _getpost(ref $conn, $conn->{_assort}, $conn->{caller}, $host, 80, $newpath, @{$conn->{_asargs}});
} elsif ($path =~ m|^/|) {
- _getpost(ref $conn, $conn->{asyncsort}, $conn->{caller}, $conn->{peerhost}, $conn->{peerport}, $path,
- @{$conn->{asyncargs}});
+ $newconn = _getpost(ref $conn, $conn->{_assort}, $conn->{caller}, $conn->{peerhost}, $conn->{peerport}, $path, @{$conn->{_asargs}});
+ }
+ if ($newconn) {
+ # copy over any elements in $conn that are not in $newconn
+ while (my ($k,$v) = each %$conn) {
+ dbg("async: $state copying over $k -> \$newconn") if isdbg('async');
+ $newconn{$k} = $v unless exists $newconn{$k};
+ }
}
delete $conn->{on_disconnect};
$conn->disconnect;
}
} elsif ($state eq 'waitblank') {
unless ($msg) {
- $conn->{state} = 'indata';
+ $conn->{_asstate} = 'indata';
}
- } elsif ($conn->{state} eq 'indata') {
- if (my $filter = $conn->{filter}) {
+ } elsif ($conn->{_asstate} eq 'indata') {
+ if (my $filter = $conn->{_asfilter}) {
no strict 'refs';
# this will crash if the command has been redefined and the filter is a
# function defined there whilst the request is in flight,
my $conn = $pkg->new($call, \&handle_get);
- $conn->{asyncargs} = [@_];
- $conn->{state} = 'waitreply';
- $conn->{filter} = delete $args{filter} if exists $args{filter};
+ $conn->{_asargs} = [@_];
+ $conn->{_asstate} = 'waitreply';
+ $conn->{_asfilter} = delete $args{filter} if exists $args{filter};
$conn->{prefix} = delete $args{prefix} if exists $args{prefix};
$conn->{on_disconnect} = delete $args{on_disc} || delete $args{on_disconnect};
$conn->{path} = $path;
- $conn->{asyncsort} = $sort;
+ $conn->{_assort} = $sort;
$r = $conn->connect($host, $port);
if ($r) {