# local databases can chain to remote ones
my $count;
- push @out, $db->print('pre');
+ my $pre = $db->print('pre');
+ push @out, $pre if defined $pre;
# push @out, "@f";
for (@f) {
-# push @out, $db->name . " $_";
+ push @out, $db->name . " $_";
my $value = $db->getkey($_) || "";
- push @out, $db->name . ": $_ :";
+# push @out, $db->name . ": $_ :";
if ($value) {
push @out, split /\n/, $value;
$count++;
}
}
if ($count) {
- push @out, $db->print('post');
+ my $post = $db->print('post');
+ push @out, $post if $post;
# last;
}
}
#
sub process
{
- my ($dxchan, $line) = @_;
-
- # this is periodic processing
- if (!$dxchan || !$line) {
- if ($main::systime - $lastprocesstime >= 60) {
- if (%avail) {
- for (values %avail) {
- if ($main::systime - $_->{accesst} > $opentime) {
- $_->close;
- }
+ if ($main::systime - $lastprocesstime >= 60) {
+ if (%avail) {
+ for (values %avail) {
+ if ($main::systime - $_->{accesst} > $opentime) {
+ $_->close;
}
}
- $lastprocesstime = $main::systime;
}
- return;
+ $lastprocesstime = $main::systime;
}
+}
- my @f = split /\^/, $line;
- my ($pcno) = $f[0] =~ /^PC(\d\d)/; # just get the number
+sub handle_37
+{
- # route out ones that are not for us
- if ($f[1] eq $main::mycall) {
- ;
- } else {
- $dxchan->route($f[1], $line);
- return;
- }
+}
- SWITCH: {
- if ($pcno == 37) { # probably obsolete
- last SWITCH;
- }
+sub handle_44
+{
+ my $self = shift;
- if ($pcno == 44) { # incoming DB Request
- my @in = DXCommandmode::run_cmd($dxchan, "dbshow $f[4] $f[5]");
- sendremote($dxchan, $f[2], $f[3], @in);
- last SWITCH;
- }
+ # incoming DB Request
+ my @in = DXCommandmode::run_cmd($self, "dbshow $_[4] $_[5]");
+ sendremote($self, $_[2], $_[3], @in);
+}
- if ($pcno == 45) { # incoming DB Information
- my $n = getstream($f[3]);
- if ($n) {
- my $mchan = DXChannel->get($n->{call});
- $mchan->send($f[2] . ":$f[4]") if $mchan;
- }
- last SWITCH;
- }
+sub handle_45
+{
+ my $self = shift;
- if ($pcno == 46) { # incoming DB Complete
- delstream($f[3]);
- last SWITCH;
- }
+ # incoming DB Information
+ my $n = getstream($_[3]);
+ if ($n) {
+ my $mchan = DXChannel->get($n->{call});
+ $mchan->send($_[2] . ":$_[4]") if $mchan;
+ }
+}
- if ($pcno == 47) { # incoming DB Update request
- last SWITCH;
- }
+sub handle_46
+{
+ my $self = shift;
- if ($pcno == 48) { # incoming DB Update request
- last SWITCH;
- }
- }
+ # incoming DB Complete
+ delstream($_[3]);
+}
+
+sub handle_47
+{
+}
+
+sub handle_48
+{
}
# send back a trache of data to the remote
wpc16u => 'Allow PC16 from $_[0] disabled',
wpc19s => 'Route PC19 for $_[0] enabled',
wpc19u => 'Route PC19 for $_[0] disabled',
+ wpc90s => 'PC90 for $_[0] enabled',
+ wpc90u => 'PC90 for $_[0] disabled',
wwv1 => '$_[0] is missing or out of range',
wwv2 => 'Duplicate WWV',
wwv3 => 'Date Hour SFI A K Forecast Logger',