1 package Koha::BackgroundJob::BatchDeleteAuthority;
4 use JSON qw( encode_json decode_json );
6 use Koha::DateUtils qw( dt_from_string );
7 use C4::AuthoritiesMarc;
9 use base 'Koha::BackgroundJob';
12 return 'batch_authority_record_deletion';
16 my ( $self, $args ) = @_;
18 if ( $self->status eq 'cancelled' ) {
22 # FIXME If the job has already been started, but started again (worker has been restart for instance)
23 # Then we will start from scratch and so double delete the same records
26 $self->started_on(dt_from_string)
27 ->progress($job_progress)
31 my $mmtid = $args->{mmtid};
32 my @record_ids = @{ $args->{record_ids} };
35 total_records => scalar @record_ids,
39 my $schema = Koha::Database->new->schema;
40 RECORD_IDS: for my $record_id ( sort { $a <=> $b } @record_ids ) {
42 last if $self->get_from_storage->status eq 'cancelled';
44 next unless $record_id;
46 $schema->storage->txn_begin;
48 my $authid = $record_id;
49 eval { C4::AuthoritiesMarc::DelAuthority({ authid => $authid }) };
53 code => 'authority_not_deleted',
57 $schema->storage->txn_rollback;
62 code => 'authority_deleted',
65 $report->{total_success}++;
66 $schema->storage->txn_commit;
69 $self->progress( ++$job_progress )->store;
72 my $job_data = decode_json $self->data;
73 $job_data->{messages} = \@messages;
74 $job_data->{report} = $report;
76 $self->ended_on(dt_from_string)
77 ->data(encode_json $job_data);
78 $self->status('finished') if $self->status ne 'cancelled';
83 my ( $self, $args) = @_;
85 # TODO Raise exception instead
86 return unless exists $args->{record_ids};
88 my @record_ids = @{ $args->{record_ids} };
90 $self->SUPER::enqueue({
91 job_size => scalar @record_ids,
92 job_args => {record_ids => \@record_ids,},
93 queue => 'long_tasks',