X-Git-Url: http://www.dxcluster.org/gitweb/gitweb.cgi?a=blobdiff_plain;f=cmd%2Fshow%2Fqrz.pl;h=9a3f9c3fc93ed9dd334b64ac259c7e271ac7ae14;hb=99077d96c91df307092394bf1028212adeec4c37;hp=5301c2cd6f72d35c39b562eec5eb3db15664dc4a;hpb=4e913f45fcd752c8a084dfb31f2c8e0da30f59b1;p=spider.git diff --git a/cmd/show/qrz.pl b/cmd/show/qrz.pl index 5301c2cd..9a3f9c3f 100644 --- a/cmd/show/qrz.pl +++ b/cmd/show/qrz.pl @@ -2,8 +2,9 @@ # Query the QRZ Database server for a callsign # # from an idea by Steve Franke K9AN and information from Angel EA7WA +# and finally (!) modified to use the XML interface # -# $Id$ +# Copyright (c) 2001-2009 Dirk Koopman G1TLH # my ($self, $line) = @_; my @list = split /\s+/, $line; # generate a list of callsigns @@ -11,41 +12,54 @@ my $l; my $call = $self->call; my @out; +return (1, $self->msg('e24')) unless $Internet::allow; return (1, "SHOW/QRZ , e.g. SH/QRZ g1tlh") unless @list; +my $target = $Internet::http_proxy || $Internet::qrz_url || 'xml.qrz.com'; +my $port = $Internet::http_proxy_port || 80; +my $url = ''; +$url = 'http://' . ($Internet::qrz_url | 'xml.qrz.com') if $Internet::http_proxy; + use Net::Telnet; my $t = new Net::Telnet; -push @out, $self->msg('call1', "QRZ.com"); foreach $l (@list) { - $t->open(Host => "qrz.com", - Port => 80, - Timeout => 5); - if ($t) { - $t->print("GET /database?callsign=$l HTTP/1.0\n\n"); + eval { + $t->open(Host => $target, + Port => $port, + Timeout => 15); + }; + + if (!$t || $@) { + push @out, $self->msg('e18', 'QRZ.com'); + } else { + my $s = "GET /xml?callsign=$l;username=$Internet::qrz_uid;password=$Internet::qrz_pw;agent=dxspider HTTP/1.0\n\n"; + dbg($s) if isdbg('qrz'); + $t->print($s); Log('call', "$call: show/qrz \U$l"); - my $state = "call"; - while (my $result = $t->getline) { -# print "$state: $result"; - if ($state eq 'call' && $result =~ /$l/i) { - $state = 'getaddr'; - push @out, uc $l; - } elsif ($state eq 'getaddr' || $state eq 'inaddr') { - if ($result =~ /^\s+([\w\s.,;:-]+)(?:
)?$/) { - my $line = $1; - unless ($line =~ /^\s+$/) { - push @out, $line; - $state = 'inaddr' unless $state eq 'inaddr'; - } - } else { - $state = 'runout' if $state eq 'inaddr'; - } + my $state = "blank"; + while (my $result = eval { $t->getline(Timeout => 30) } || $@) { + dbg($result) if isdbg('qrz') && $result; + if ($@) { + push @out, $self->msg('e18', 'QRZ.com'); + last; + } + if ($state eq 'blank' && $result =~ /^/i) { + $state = 'go'; + } elsif ($state eq 'go') { + next if $result =~ m||; + next if $result =~ m||; + next if $result =~ m||; + next if $result =~ m||; + next if $result =~ m||; + last if $result =~ m||; + my ($tag, $data) = $result =~ m|^\s*<(\w+)>(.*)close; - } else { - push @out, $self->msg('e18', 'QRZ.com'); + push @out, $self->msg('e3', 'qrz.com', uc $l) unless @out; } }