Bug 22417: Add Koha::BackgroundJob::BatchUpdateAuthority

This is not ready yet!

Note that this is too close to Koha::BackgroundJob::BatchUpdateBiblio,
we will want to refactor bit of code.

Signed-off-by: Tomas Cohen Arazi <tomascohen@theke.io>

Signed-off-by: David Cook <dcook@prosentient.com.au>

Signed-off-by: Marcel de Rooy <m.de.rooy@rijksmuseum.nl>

Signed-off-by: Kyle M Hall <kyle@bywatersolutions.com>

Signed-off-by: Jonathan Druart <jonathan.druart@bugs.koha-community.org>
This commit is contained in:
Jonathan Druart 2019-02-25 21:43:55 -03:00
parent 0848d46ce6
commit 15beff8f1c

View file

@ -0,0 +1,98 @@
package Koha::BackgroundJob::BatchUpdateAuthority;
use Modern::Perl;
use Koha::BackgroundJobs;
use Koha::DateUtils qw( dt_from_string );
use JSON qw( encode_json decode_json );
use Net::RabbitFoot;
use base 'Koha::BackgroundJob';
our $channel;
sub process {
my ( $self, $args, $channel ) = @_;
my $job_type = $args->{job_type};
return unless exists $args->{job_id};
my $job = Koha::BackgroundJobs->find( $args->{job_id} );
my $job_progress = 0;
$job->started_on(dt_from_string)
->progress($job_progress)
->status('started')
->store;
my $mmtid = $args->{mmtid};
my $record_type = $args->{record_type};
my @record_ids = @{ $args->{record_ids} };
my $report = {
total_records => 0,
total_success => 0,
};
my @messages;
my $dbh = C4::Context->dbh;
$dbh->{RaiseError} = 1;
RECORD_IDS: for my $record_id ( sort { $a <=> $b } @record_ids ) {
$report->{total_records}++;
next unless $record_id;
# Authorities
my $authid = $record_id;
my $error = eval {
my $authority = Koha::MetadataRecord::Authority->get_from_authid( $authid );
my $record = $authority->record;
ModifyRecordWithTemplate( $mmtid, $record );
ModAuthority( $authid, $record, $authority->authtypecode );
};
if ( $error and $error != $authid or $@ ) {
push @messages, {
type => 'error',
code => 'authority_not_modified',
authid => $authid,
error => ($@ ? $@ : 0),
};
} else {
push @messages, {
type => 'success',
code => 'authority_modified',
authid => $authid,
};
$report->{total_success}++;
}
$job->progress( ++$job_progress )->store;
}
my $job_data = decode_json $job->data;
$job_data->{messages} = \@messages;
$job_data->{report} = $report;
$job->ended_on(dt_from_string)
->status('finished')
->data(encode_json $job_data)
->store;
$channel->ack(); # FIXME Is that ok even on failure?
}
sub enqueue {
my ( $self, $args) = @_;
# TODO Raise exception instead
return unless exists $args->{mmtid};
return unless exists $args->{record_type}; #FIXME RMME
return unless exists $args->{record_ids};
my $mmtid = $args->{mmtid};
my $record_type = $args->{record_type};
my @record_ids = @{ $args->{record_ids} };
$self->SUPER::enqueue({
job_type => 'batch_record_modification',
job_size => scalar @record_ids,
job_args => {mmtid => $mmtid, record_type => $record_type, record_ids => \@record_ids,}
});
}
1;