-
Notifications
You must be signed in to change notification settings - Fork 265
/
Copy pathremove_unused_authorities.pl
executable file
·151 lines (126 loc) · 4.61 KB
/
remove_unused_authorities.pl
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
#!/usr/bin/perl
#script to administer Authorities without biblio
# Copyright 2009 BibLibre
# written 2009-05-04 by paul dot poulain at biblibre.com
#
# 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;
use Koha::Script;
use C4::Context;
use C4::AuthoritiesMarc qw( DelAuthority );
use C4::Log qw( cronlogaction );
use Getopt::Long qw( GetOptions );
use Koha::SearchEngine::Search;
my @authtypes;
my ( $confirm, $test, $want_help );
my $command_line_options = join( " ", @ARGV );
GetOptions(
'aut|authtypecode:s' => \@authtypes,
'c|confirm' => \$confirm,
't|test' => \$test,
'h|help' => \$want_help,
);
if ( $want_help || !( $test || $confirm ) ) {
print_usage();
exit 0;
}
cronlogaction( { info => $command_line_options } );
if ($test) {
print "*** Testing only, authorities will not be deleted. ***\n";
}
if (@authtypes) {
print "Restricted to authority type(s) : " . join( ',', @authtypes ) . ".\n";
}
my $searcher = Koha::SearchEngine::Search->new( { index => 'biblios' } );
my $checksearch;
if ( C4::Context->preference("SearchEngine") eq 'Zebra' ) {
# Check server state
my $errZebraConnection = C4::Context->Zconn( "biblioserver", 0 )->errcode();
if ( $errZebraConnection == 10000 ) {
die "Zebra server seems not to be available. This script needs Zebra runs.";
} elsif ($errZebraConnection) {
die "Error from Zebra: $errZebraConnection";
}
$checksearch = q{an,alwaysmatches=''};
} else {
$checksearch = q{an:*};
}
# Check search on authority number as at least one result
my ( $err, $res, $nb ) = $searcher->simple_search_compat( $checksearch, 0, 10 );
unless ( $nb > 0 ) {
die "Searching authority number in biblio records seems not to be available : $checksearch";
}
my $dbh = C4::Context->dbh;
# prepare the request to retrieve all authorities of the requested types
my $rqsql = q{ SELECT authid,authtypecode FROM auth_header };
$rqsql .= q{ WHERE authtypecode IN (} . join( ',', map { '?' } @authtypes ) . ')' if @authtypes;
my $rqselect = $dbh->prepare($rqsql);
$| = 1;
$rqselect->execute(@authtypes);
my $counter = 0;
my $totdeleted = 0;
my $totundeleted = 0;
while ( my $data = $rqselect->fetchrow_hashref ) {
$counter++;
print 'authid=' . $data->{'authid'};
print ' type=' . $data->{'authtypecode'};
my $bibliosearch = 'an:' . $data->{'authid'};
# search for biblios mapped
my ( $err, $res, $used ) = $searcher->simple_search_compat( $bibliosearch, 0, 10 );
if ( defined $err ) {
print "\n";
warn "Error: $err on search for biblios $bibliosearch\n";
next;
}
unless ( $used > 0 ) {
unless ($test) {
DelAuthority( { authid => $data->{'authid'}, skip_merge => 1 } );
print " : deleted";
} else {
print " : can be deleted";
}
$totdeleted++;
} else {
$totundeleted++;
print " : used $used time(s)";
}
print "\n";
}
print "$counter authorities parsed\n";
unless ($test) {
print "$totdeleted deleted because unused\n";
} else {
print "$totdeleted can be deleted because unused\n";
}
print "$totundeleted unchanged because used\n";
sub print_usage {
print <<_USAGE_;
$0: Remove unused authority records
This script removes authority records that do not have any biblio
records attached to them.
If the --aut option is supplied, only authority records of that
particular type will be checked for usage. --aut can be repeated.
If --aut is not supplied, all authority records will be checked.
Use --confirm Confirms you want to really run this script, otherwise prints this help.
Use --test to perform a test run. This script does not ask the
operator to confirm the deletion of each authority record.
parameters
--aut|authtypecode TYPE the list of authtypes to check
--confirm or -c confirm running of script
--test or -t test mode, don't delete really, just count
--help or -h show this message.
_USAGE_
}