use Data::Dump qw(dump);
use Regexp::Common qw(net);
+use Redis;
use lib 'lib';
use H1::ZTEDSLAM;
+use H1::ZTEMSAN;
+
+my $variant = $ARGV[0] || 'ZTEDSLAM';
+warn "variant: $variant\n";
my $driver = Gearman::Driver->new(
server => 'localhost:4730',
my $w1 = 'Cog';
my $worker = $w1->new();
-warn "CRM_search";
-my $crm = $worker->do( 'CRM_search' => "TIP_UREDJAJA:ZTEDSLAM" );
+
+my $crm = $worker->do( 'CRM_search' => "TIP_UREDJAJA:$variant" );
+
my $poll;
foreach my $ip ( keys %$poll ) {
- my $method = "ZTEDSLAM_$ip";
+ my $method = $variant . '_' . $ip;
- my $zte = H1::ZTEDSLAM->new( ip => $ip );
+ my $module = 'H1::' . $variant;
+ my $zte = $module->new( ip => $ip );
$driver->add_job({
max_processes => 1, # FIXME increase?
methods => [
{
decode => 'd_json',
- encode => 'e_json',
+# encode => 'e_json',
name => $method,
body => sub {
my ( $self, $job, $crm ) = @_;
+
+ if ( exists $crm->{logout} ) {
+ $zte->logout;
+ return;
+ }
+
my $hash;
eval { $hash = $zte->hash( $crm->{SHELF_SLOT_PORT} ) };
- return { error => $@ } if $@;
+ my $redis = Redis->new;
+
+ if ( $@ ) {
+ $redis->sadd("$variant.error" => $@);
+ return { error => $@ };
+ } else {
+ $redis->sadd("$variant.ok" => $crm->{USERNAME});
+ }
$self->do_background_json( 'Store_insert', {
_table => 'dslam_h',
max_processes => 1,
min_processes => 1,
worker => $worker,
+ name => "poll_$variant",
methods => [ {
- name => 'poll_ZTEDSLAM',
+ name => "poll_$variant",
body => sub {
my ( $self, $job, $workload ) = @_;
- my $crm = $self->do( 'CRM_search' => "TIP_UREDJAJA:ZTEDSLAM" );
+ my $crm = $self->do( 'CRM_search' => "TIP_UREDJAJA:$variant" );
warn "# crm $crm";
- my $taskset = $worker->gc->new_task_set;
+ my $gc = Gearman::Client->new;
+ $gc->job_servers( $self->server || 'localhost:4730' );
+ my $taskset = $gc->new_task_set;
my $seen;
+ my $redis = Redis->new;
+ $redis->del( $_ ) foreach $redis->keys("$variant.*");
+
+ $redis->set( "$variant.start" => $self->datetime_now );
+
foreach my $user ( @$crm ) {
- my $ip = $user->{IP_UREDAJA};
- next unless $ip =~ /$RE{net}{IPv4}/;
- my $name = 'ZTEDSLAM_' . $ip;
+ my $ip = $user->{IP_UREDAJA};
+ my $port = $user->{SHELF_SLOT_PORT};
+
+ if ( $ip !~ /$RE{net}{IPv4}/ ) {
+ $redis->sadd("$variant.invalid.IP_UREDAJA" => $ip);
+ next;
+ } elsif ( $port !~ m{\d+(/\d+)+} ) {
+ $redis->sadd("$variant.invalid.PORT" => $port);
+ next;
+ } elsif ( $seen->{ $ip }->{ $port }++ ) {
+ $redis->sadd("$variant.invalid.duplicate" => "$ip $port");
+ next;
+ }
+ $redis->sadd("$variant.queued" => "$ip $port");
+ $redis->incr("$variant.ip.$ip");
+
+ my $name = $variant . '_' . $ip;
$taskset->add_task( $name, $self->e_json( $user ), {
- on_complete => sub { "# $name done", $/ }
+ on_complete => sub { $redis->sadd("$variant.complete", "$ip $port") },
+ on_fail => sub { $redis->sadd("$variant.fail", "$ip $port") },
} )
- if ! $seen->{ $user->{IP_UREDAJA} }->{ $user->{SHELF_SLOT_PORT} }++;
}
+
+ warn "# queue logouts";
+ foreach my $ip ( keys %$seen ) {
+ $taskset->add_task( $variant . '_' . $ip, $self->e_json( { logout => 1 } ) );
+ }
+
warn "# wait";
$taskset->wait;
+ $redis->set( "$variant.finish" => $self->datetime_now );
warn "# seen ", dump($seen);
- return; # body end
+ my $ips = scalar keys %$seen;
+ return "polled $ips IPs"; # body end
}
} ],
});