1 package Koha::BackgroundJob::UpdateElasticIndex;
3 # This file is part of Koha.
5 # Koha is free software; you can redistribute it and/or modify it
6 # under the terms of the GNU General Public License as published by
7 # the Free Software Foundation; either version 3 of the License, or
8 # (at your option) any later version.
10 # Koha is distributed in the hope that it will be useful, but
11 # WITHOUT ANY WARRANTY; without even the implied warranty of
12 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 # GNU General Public License for more details.
15 # You should have received a copy of the GNU General Public License
16 # along with Koha; if not, see <http://www.gnu.org/licenses>.
19 use JSON qw( encode_json decode_json );
21 use Koha::BackgroundJobs;
22 use Koha::DateUtils qw( dt_from_string );
24 use C4::MarcModificationTemplates;
26 use base 'Koha::BackgroundJob';
30 Koha::BackgroundJob::UpdateElasticIndex - Update Elastic index
32 This is a subclass of Koha::BackgroundJob.
40 Define the job type of this job: update_elastic_index
45 return 'update_elastic_index';
50 Process the modification.
55 my ( $self, $args ) = @_;
57 my $job = Koha::BackgroundJobs->find( $args->{job_id} );
59 if ( !exists $args->{job_id} || !$job || $job->status eq 'cancelled' ) {
63 # FIXME If the job has already been started, but started again (worker has been restart for instance)
64 # Then we will start from scratch and so double process the same records
67 $job->started_on(dt_from_string)
68 ->progress($job_progress)
72 my @record_ids = @{ $args->{record_ids} };
73 my $record_server = $args->{record_server};
76 total_records => scalar @record_ids,
83 $record_server eq "authorityserver"
84 ? $Koha::SearchEngine::AUTHORITIES_INDEX
85 : $Koha::SearchEngine::BIBLIOS_INDEX;
86 my $indexer = Koha::SearchEngine::Indexer->new({ index => $es_index });
87 $indexer->update_index(\@record_ids);
92 code => 'index_error',
97 # FIXME This is not correct if some record_ids have been skipped
98 $report->{total_success} = scalar @record_ids;
101 my $job_data = decode_json $job->data;
102 $job_data->{messages} = \@messages;
103 $job_data->{report} = $report;
105 $job->ended_on(dt_from_string)
106 ->data(encode_json $job_data);
107 $job->status('finished') if $job->status ne 'cancelled';
118 my ( $self, $args) = @_;
120 return unless exists $args->{record_server};
121 return unless exists $args->{record_ids};
123 my $record_server = $args->{record_server};
124 my @record_ids = @{ $args->{record_ids} };
126 $self->SUPER::enqueue({
127 job_size => scalar @record_ids,
128 job_args => {record_server => $record_server, record_ids => \@record_ids},