- # check for sane parameters
- next if $ver < 5000; # only works with version 5 software
- next if length $call < 3; # min 3 letter callsigns
- DXNode->new($self, $call, $confmode, $here, $ver);
-
- # unbusy and stop and outgoing mail (ie if somehow we receive another PC19 without a disconnect)
- my $mref = DXMsg::get_busy($call);
- $mref->stop_msg($self) if $mref;
-
- # add this station to the user database, if required
- my $user = DXUser->get_current($call);
- $user = DXUser->new($call) if !$user;
- $user->node($call) if !$user->node;
- $user->sort('A');
- $user->put;
- }
-
- # queue up any messages
- DXMsg::queue_msg() if $self->state eq 'normal';
- last SWITCH;
- }
-
- if ($pcno == 20) { # send local configuration
- $self->send_local_config();
- $self->send(pc22());
- $self->state('normal');
-
- # queue mail
- DXMsg::queue_msg();
- return;
- }
-
- if ($pcno == 21) { # delete a cluster from the list
- my $call = uc $field[1];
- if ($call ne $main::mycall) { # don't allow malicious buggers to disconnect me!
- my $ref = DXCluster->get($call);
- $ref->del() if $ref;
- }
- last SWITCH;
- }
-
- if ($pcno == 22) {last SWITCH;}
-
- if ($pcno == 23 || $pcno == 27) { # WWV info
- Geomag::update(@field[1..$#field]);
- last SWITCH;
- }
+ if ($pcno == 20) { # send local configuration
+ $self->send_local_config();
+ $self->send(pc22());
+ $self->state('normal');
+
+ # queue mail
+ DXMsg::queue_msg(0);
+ return;
+ }
+
+ if ($pcno == 21) { # delete a cluster from the list
+ my $call = uc $field[1];
+ if ($call ne $main::mycall) { # don't allow malicious buggers to disconnect me!
+ my $ref = DXCluster->get_exact($call);
+ $ref->del() if $ref;
+ }
+ last SWITCH;
+ }
+
+ if ($pcno == 22) {
+ $self->state('normal');
+
+ # queue mail
+ DXMsg::queue_msg(0);
+ return;
+ }
+
+ if ($pcno == 23 || $pcno == 27) { # WWV info
+ # do some de-duping
+ my $d = cltounix($field[1], sprintf("%02d18Z", $field[2]));
+ my $sfi = unpad($field[3]);
+ my $k = unpad($field[4]);
+ my $i = unpad($field[5]);
+ my $dupkey = "$d.$sfi$k$i";
+ if ($wwvdup{$dupkey}) {
+ dbg('chan', "Dup WWV Spot ignored\n");
+ return;
+ }
+ if ($d > $main::systime + 900 || $field[2] < 0 || $field[2] > 23) {
+ dbg('chan', "WWV Date ($field[1] $field[2]) out of range");
+ return;
+ }
+
+ $wwvdup{$dupkey} = $d;
+ my $wwv = Geomag::update($d, $field[2], $sfi, $k, $i, @field[6..$#field]);
+
+ my $r;
+ eval {
+ $r = Local::wwv2($self, $field[1], $field[2], $sfi, $k, $i, @field[6..$#field]);
+ };
+ dbg('local', "Local::wwv2 error $@") if $@;
+ return if $r;
+
+ # DON'T be silly and send on PC27s!
+ return if $pcno == 27;
+
+ # broadcast to the eager users
+ broadcast_users("WWV de $field[7] <$field[2]>: SFI=$sfi, K=$k, A=$i, $field[6]", 'wwv', $wwv );
+ last SWITCH;
+ }
+
+ if ($pcno == 24) { # set here status
+ my $call = uc $field[1];
+ my $ref = DXCluster->get_exact($call);
+ $ref->here($field[2]) if $ref;
+ last SWITCH;
+ }
+
+ if ($pcno == 25) { # merge request
+ unless ($field[1] eq $main::mycall) {
+ dbg('chan', "merge request to $field[1] from $field[2] ignored");
+ return;
+ }