#
# Copyright (c) 2001 Dirk Koopman G1TLH
#
-# $Id$
+#
#
package Route::User;
use DXDebug;
use Route;
+use DXUtil;
+use DXJSON;
+use Time::HiRes qw(gettimeofday);
use strict;
-use vars qw($VERSION $BRANCH);
-$VERSION = sprintf( "%d.%03d", q$Revision$ =~ /(\d+)\.(\d+)/ );
-$BRANCH = sprintf( "%d.%03d", q$Revision$ =~ /\d+\.\d+\.(\d+)\.(\d+)/ || (0,0));
-$main::build += $VERSION;
-$main::branch += $BRANCH;
-
use vars qw(%list %valid @ISA $max $filterdef);
@ISA = qw(Route);
-%valid = (
- parent => '0,Parent Calls,parray',
-);
-
$filterdef = $Route::filterdef;
%list = ();
$max = 0;
+our $cachefn = localdata('route_user_cache');
+
sub count
{
my $n = scalar(keys %list);
my $call = uc shift;
my $ncall = uc shift;
my $flags = shift;
+ my $ip = shift;
+
confess "already have $call in $pkg" if $list{$call};
my $self = $pkg->SUPER::new($call);
$self->{parent} = [ $ncall ];
$self->{flags} = $flags || Route::here(1);
+ $self->{ip} = $ip if defined $ip;
$list{$call} = $self;
+ dbg("CLUSTER: user $call added") if isdbg('cluster');
return $self;
}
{
my $self = shift;
my $pref = shift;
+ my $call = $self->{call};
$self->delparent($pref);
unless (@{$self->{parent}}) {
- delete $list{$self->{call}};
+ delete $list{$call};
+ dbg("CLUSTER: user $call deleted") if isdbg('cluster');
return $self;
}
return undef;
return $self->_dellist('parent', @_);
}
+sub TO_JSON { return { %{ shift() } }; }
+
+sub write_cache
+{
+ my $json = DXJSON->new;
+ $json->canonical(isdbg('routecache'));
+
+ my $ta = [ gettimeofday ];
+ my @s;
+ eval {
+ while (my ($k, $v) = each %list) {
+ push @s, "$k:" . $json->encode($v) . "\n";
+ }
+ };
+ if (!$@ && @s) {
+ my $fh = IO::File->new(">$cachefn") or confess("writing $cachefn $!");
+ if (isdbg("routecache")) {
+ $fh->print(sort @s);
+ }
+ else {
+ $fh->print(@s);
+ }
+ $fh->close;
+ } else {
+ dbg("Route::User:Write_cache error '$@'");
+ return;
+ }
+ my $diff = _diffms($ta);
+ dbg("Route::User:WRITE_CACHE time to write: $diff mS");
+}
+
#
# generic AUTOLOAD for accessors
#