Jonathan Druart
238fabc4ab
The purpose of this script was to load the relevant Koha lib for the different scripts (installation, cronjob, CLI, etc.) However it is not used consistently and we prefer to rely on PERL5LIB. From bug 28617 comment 6 from Galen: """ Time marches on, and one of the motivations for having kohalib.pl - making it possible to install Koha without setting a single environment variable - has been obviated by the vast improvements in the ease of installing Koha. Consequently, I think kohalib.pl can go away. """ Test plan: confirm that the changes make sense and that kohalib.pl can be removed safely. Signed-off-by: Marcel de Rooy <m.de.rooy@rijksmuseum.nl> Signed-off-by: Martin Renvoize <martin.renvoize@ptfs-europe.com> Signed-off-by: Fridolin Somers <fridolin.somers@biblibre.com>
127 lines
4.2 KiB
Perl
Executable file
127 lines
4.2 KiB
Perl
Executable file
#!/usr/bin/perl
|
|
|
|
#-----------------------------------
|
|
# Copyright 2013 ByWater Solutions
|
|
#
|
|
# This file is part of Koha.
|
|
#
|
|
# Koha is free software; you can redistribute it and/or modify it
|
|
# under the terms of the GNU General Public License as published by
|
|
# the Free Software Foundation; either version 3 of the License, or
|
|
# (at your option) any later version.
|
|
#
|
|
# Koha is distributed in the hope that it will be useful, but
|
|
# WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
# GNU General Public License for more details.
|
|
#
|
|
# You should have received a copy of the GNU General Public License
|
|
# along with Koha; if not, see <http://www.gnu.org/licenses>.
|
|
#-----------------------------------
|
|
|
|
use Modern::Perl;
|
|
|
|
binmode( STDOUT, ":encoding(UTF-8)" );
|
|
|
|
use Getopt::Long qw( GetOptions );
|
|
use Pod::Usage qw( pod2usage );
|
|
use Koha::Script -cron;
|
|
use C4::Biblio qw( DelBiblio );
|
|
use Koha::Database;
|
|
use Koha::Biblios;
|
|
use Koha::Biblio::Metadatas;
|
|
use Koha::Items;
|
|
|
|
my $delete_items;
|
|
my $confirm;
|
|
my $test;
|
|
my $verbose;
|
|
my $help;
|
|
|
|
GetOptions(
|
|
'i|di|delete-items' => \$delete_items,
|
|
'c|confirm' => \$confirm,
|
|
't|test' => \$test,
|
|
'v|verbose' => \$verbose,
|
|
'h|help' => \$help,
|
|
);
|
|
|
|
pod2usage(q|--test and --confirm cannot be specified together|) if $test and $confirm;
|
|
|
|
unless ( $confirm or $test ) {
|
|
warn "Running in test mode as --confirm is not passed\n";
|
|
$test = 1;
|
|
}
|
|
|
|
if ( $help ) {
|
|
say qq{
|
|
delete_records_via_leader.pl - Attempt to delete any MARC records where the leader character 5 equals 'd'
|
|
usage: delete_records_via_leader.pl --confirm --verbose [--test]
|
|
This script has the following parameters :
|
|
-h --help: Prints this message
|
|
-c --confirm: Script will do nothing without this parameter
|
|
-v --verbose: Be verbose
|
|
-t --test: Test mode, does not delete records.
|
|
Test mode cannot determine if a record/item will be deleted successfully,
|
|
it will only tell you what records and items the script will attempt to delete.
|
|
-i --delete-items: Try deleting items before deleting record.
|
|
Records with items cannot be deleted.
|
|
};
|
|
exit();
|
|
}
|
|
|
|
my @metadatas = # Should be replaced by a call to C4::Search on zebra index
|
|
# Record-status when bug 15537 will be pushed
|
|
Koha::Biblio::Metadatas->search( { format => 'marcxml', schema => C4::Context->preference('marcflavour'), metadata => { LIKE => '%<leader>_____d%' } } );
|
|
|
|
my $total_records_count = @metadatas;
|
|
my $deleted_records_count = 0;
|
|
my $total_items_count = 0;
|
|
my $deleted_items_count = 0;
|
|
foreach my $m (@metadatas) {
|
|
my $biblionumber = $m->get_column('biblionumber');
|
|
|
|
say "RECORD: $biblionumber" if $verbose;
|
|
|
|
if ($delete_items) {
|
|
my $deleted_count = 0;
|
|
my $biblio = Koha::Biblios->find( $biblionumber );
|
|
my @items = Koha::Items->search( { biblionumber => $biblionumber } );
|
|
foreach my $item ( @items ) {
|
|
my $itemnumber = $item->itemnumber;
|
|
|
|
if( $test ){
|
|
my $result = $item->safe_to_delete;
|
|
if ( $result eq "1") {
|
|
say "TEST MODE: Item $itemnumber would have been deleted";
|
|
} else {
|
|
say "TEST MODE: ERROR DELETING ITEM $itemnumber: $result";
|
|
}
|
|
} else {
|
|
my $result = $item->safe_delete;
|
|
if ( ref $result eq "Koha::Item" ){
|
|
say "DELETED ITEM $itemnumber" if $verbose;
|
|
$deleted_items_count++;
|
|
} else {
|
|
say "ERROR DELETING ITEM $itemnumber: $result";
|
|
}
|
|
}
|
|
$total_items_count++;
|
|
}
|
|
}
|
|
|
|
my $error = $test ? q{Test mode enabled} : DelBiblio($biblionumber);
|
|
if ( $error ) {
|
|
say "ERROR DELETING BIBLIO $biblionumber: $error";
|
|
} else {
|
|
say "DELETED BIBLIO $biblionumber" if $verbose;
|
|
$deleted_records_count++;
|
|
}
|
|
|
|
say q{};
|
|
}
|
|
|
|
if ( $verbose ) {
|
|
say "DELETED $deleted_records_count OF $total_records_count RECORDS";
|
|
say "DELETED $deleted_items_count OF $total_items_count ITEMS" if $delete_items;
|
|
}
|