Koha/cataloguing/value_builder/marc21_field_008.pl
Jonathan Druart bfdf896111 Bug 21053: Encode URI characters in plugin 008
A # (or &) at any position in 008 field of a bib record causes
all subsequent data in field to be overwritten with default values when
record is saved.

These characters need to be correctly encoded before being passed as
parameters of the url

To reproduce:
1. Find and edit a bib record which has an 008 which differs from the
default values for the MARC framework
2. Choose 008 helper
3. Add # in any position before the end of the field noting the current
values of the data
4. Save record
5. Edit record and select 008 helper
6. Review characters after #

Signed-off-by: Maryse Simard <maryse.simard@inlibro.com>
Followed the test plan and it works.

Signed-off-by: Katrin Fischer <katrin.fischer.83@web.de>

Signed-off-by: Nick Clemens <nick@bywatersolutions.com>
2018-07-19 16:23:16 +00:00

174 lines
5.9 KiB
Perl
Executable file

#!/usr/bin/perl
# Converted to new plugin style (Bug 13437)
# Copyright 2000-2002 Katipo Communications
#
# 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 C4::Auth;
use CGI qw ( -utf8 );
use C4::Context;
use C4::Search;
use C4::Output;
use XML::LibXML;
use Koha::Util::FrameworkPlugin qw|date_entered|;
my $builder = sub {
my ( $params ) = @_;
my $lang = C4::Context->preference('DefaultLanguageField008' );
$lang = "eng" unless $lang;
$lang = pack("A3", $lang);
my $country = C4::Context->preference('DefaultCountryField008') // "xxu";
$country = pack("A3", $country);
my $function_name = $params->{id};
my $dateentered = date_entered();
my $res = "
<script type=\"text/javascript\">
//<![CDATA[
function Focus$function_name(event) {
if ( document.getElementById(event.data.id).value ) {
}
else {
document.getElementById(event.data.id).value='$dateentered' + 'b $country||||| |||| 00| 0 $lang d';
}
return 1;
}
function Click$function_name(event) {
defaultvalue=document.getElementById(event.data.id).value;
//Retrieve full leader string and pass it to the 008 tag editor
var leader_value = \$(\"input[id^='tag_000']\").val();
var leader_parameter = \"\";
if (leader_value){
//Only add the parameter to the URL if there is a value to add
leader_parameter = \"&leader=\"+leader_value;
}
newin=window.open(\"../cataloguing/plugin_launcher.pl?plugin_name=marc21_field_008.pl&index=\"+ event.data.id +\"&result=\"+encodeURIComponent(defaultvalue)+leader_parameter,\"tag_editor\",'width=1000,height=600,toolbar=false,scrollbars=yes');
}
//]]>
</script>
";
return $res;
};
my $launcher = sub {
my ( $params ) = @_;
my $input = $params->{cgi};
my $lang = C4::Context->preference('DefaultLanguageField008' );
$lang = "eng" unless $lang;
$lang = pack("A3", $lang);
my $country = C4::Context->preference('DefaultCountryField008') // "xxu";
$country = pack("A3", $country);
my $index = $input->param('index');
my $result = $input->param('result');
my $leader = $input->param('leader');
my $material_configuration;
if ($leader && length($leader) == '24') {
#MARC 21 Material Type Configuration
#Field 008/18-34 Configuration
#If Leader/06 = a and Leader/07 = a, c, d, or m: Books
#If Leader/06 = a and Leader/07 = b, i, or s: Continuing Resources
#If Leader/06 = t: Books
#If Leader/06 = c, d, i, or j: Music
#If Leader/06 = e, or f: Maps
#If Leader/06 = g, k, o, or r: Visual Materials
#If Leader/06 = m: Computer Files
#If Leader/06 = p: Mixed Materials
#http://www.loc.gov/marc/bibliographic/bdleader.html
my $material_configuration_mapping = {
a => {
a => 'BKS',
c => 'BKS',
d => 'BKS',
m => 'BKS',
b => 'CR',
i => 'CR',
s => 'CR',
},
t => 'BKS',
c => 'MU',
d => 'MU',
i => 'MU',
j => 'MU',
e => 'MP',
f => 'MP',
g => 'VM',
k => 'VM',
o => 'VM',
r => 'VM',
m => 'CF',
p => 'MX',
};
my $leader06 = substr($leader, 6, 1);
my $leader07 = substr($leader, 7, 1);
#Retrieve material type using leader06
$material_configuration = $material_configuration_mapping->{$leader06};
#If the value returned is a ref (i.e. leader06 is 'a'), then use leader07 to get the actual material type
if ( ($material_configuration) && (ref($material_configuration) eq 'HASH') ){
$material_configuration = $material_configuration->{$leader07};
}
}
my $dbh = C4::Context->dbh;
my ($template, $loggedinuser, $cookie) = get_template_and_user(
{ template_name => "cataloguing/value_builder/marc21_field_008.tt",
query => $input,
type => "intranet",
authnotrequired => 0,
flagsrequired => { editcatalogue => '*' },
debug => 1,
}
);
my $dateentered = date_entered();
$result = "$dateentered" . "b $country||||| |||| 00| 0 $lang d" unless $result;
my $errorXml = '';
# Check if the xml, xsd exists and is validated
my $dir = C4::Context->config('intrahtdocs') . '/prog/' . $template->{lang} . '/data/';
if (-r $dir . 'marc21_field_008.xml') {
my $doc = XML::LibXML->new->parse_file($dir . 'marc21_field_008.xml');
if (-r $dir . 'marc21_field_CF.xsd') {
my $xmlschema = XML::LibXML::Schema->new(location => $dir . 'marc21_field_CF.xsd');
eval {
$xmlschema->validate( $doc );
};
$errorXml = 'Can\'t validate the xml data from ' . $dir . 'marc21_field_008.xml' if ($@);
}
} else {
$errorXml = 'Can\'t read the xml file ' . $dir . 'marc21_field_008.xml';
}
$template->param(tagfield => '008',
index => $index,
result => $result,
errorXml => $errorXml,
material_configuration => $material_configuration,
);
output_html_with_http_headers $input, $cookie, $template->output;
};
return { builder => $builder, launcher => $launcher };