update Changes
[spider.git] / perl / DXProt.pm
index 99c2ef82a674362f5c1aa34df27d165553c34efa..f72fe8903a37bbe5c1c17a201b99eb936e69b49c 100644 (file)
@@ -654,6 +654,8 @@ sub normal
                                                if ($self->in_filter_route($r)) {
                                                        $ar = $parent->add($call, $ver, $flags);
                                                        push @rout, $ar if $ar;
+                                               } else {
+                                                       next;
                                                }
                                        }
                                        if ($r->version ne $ver || $r->flags != $flags) {
@@ -668,6 +670,8 @@ sub normal
                                    if ($self->in_filter_route($new)) {
                                                my $r = $parent->add($call, $ver, $flags);
                                                push @rout, $r;
+                                       } else {
+                                               next;
                                        }
                                }
 
@@ -785,6 +789,7 @@ sub normal
                        $ref->here($field[2]) if $ref;
                        $ref = Route::User::get($call);
                        $ref->here($field[2]) if $ref;
+                       $ref ||= Route->new($call);
                        
                        # input filter if required
                        return unless $self->in_filter_route($ref);
@@ -927,7 +932,7 @@ sub normal
                        }
                        $user->lastoper($main::systime);   # to cut down on excessive for/opers being generated
                        $user->put;
-                       my $ref = Route::get($call);
+                       my $ref = Route::get($call) || Route->new($call);
 
                        # input filter if required
                        return unless $self->in_filter_route($ref);
@@ -1483,7 +1488,7 @@ sub route
        # always send it down the local interface if available
        my $dxchan = DXChannel->get($call);
        unless ($dxchan) {
-               my $cl = Route::Node::get($call);
+               my $cl = Route::get($call);
                $dxchan = $cl->dxchan if $cl;
                if (ref $dxchan) {
                        if (ref $self && $dxchan eq $self) {