3 use base qw(Gearman::Driver::Worker);
6 use Data::Dump qw(dump);
10 with 'APKPM::Gearman::Client';
15 sub prefix { 'DSLAM_' }
18 my ( $self, $orig, $job_name ) = @_;
19 warn "# process_name $orig $job_name\n";
20 return "$orig ($job_name)";
24 my ( $self, $job, $workload ) = @_;
25 warn "# begin ", dump( $workload );
28 sub search : Job : Encode(e_json_encode) {
29 my ( $self, $job, $workload ) = @_;
30 warn "# search ",dump($workload);
34 if ( $workload =~ m/[:=]/ ) {
35 ($field,$value) = split(/[:=]/,$workload,2)
37 return { error => 'invalid workload', expected => 'OPT_82:%' };
40 my $crm_results = $self->do('CRM_search' => $workload);
42 my $crm = $crm_results->[0];
43 warn "ERROR: more than one result from CRM, using first ", dump($crm_results)
44 if $#$crm_results > 0;
46 warn "# crm ",dump $crm;
48 my $time = $self->datetime_now;
50 my $module = 'H1::' . $crm->{TIP_UREDJAJA};
52 warn "# eval $module";
54 eval { $hash = $module->hash( $crm->{IP_UREDAJA}, $crm->{SHELF_SLOT_PORT} ) };
55 return { error => $@ } if $@;
57 $self->do_background_json( 'Store_insert', {
59 ip => $crm->{IP_MANAGEMENT}, # FIXME IP_UREDAJA ?
60 username => $crm->{USERNAME},