- $t->open(Host => "qrz.com",
- Port => 80,
- Timeout => 5);
- if ($t) {
- $t->print("GET /database?callsign=$l HTTP/1.0\n\n");
- Log('call', "$call: show/qrz $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.,;:-]+)(?:<br>)?$/) {
- my $line = $1;
- unless ($line =~ /^\s+$/) {
- push @out, $line;
- $state = 'inaddr' unless $state eq 'inaddr';
- }
- } else {
- $state = 'runout' if $state eq 'inaddr';
- }
+ 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 = "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 =~ /^<Callsign>/i) {
+ $state = 'go';
+ } elsif ($state eq 'go') {
+ next if $result =~ m|<user>|;
+ next if $result =~ m|<u_views>|;
+ next if $result =~ m|<locref>|;
+ next if $result =~ m|<ccode>|;
+ next if $result =~ m|<dxcc>|;
+ last if $result =~ m|</Callsign>|;
+ my ($tag, $data) = $result =~ m|^\s*<(\w+)>(.*)</|;
+ push @out, sprintf "%10s: $data", $tag;