11de340639
add authority type in the form to create the missing authority. when authority was found, the 600$9 field have the authid. Testing scenario (Creating an authority record for a failed automatic link) : 1 - In your system preferences set: AutoCreateAuthorities: Don't generate BiblioAddsAuthorities: Allow 2 - Go to the Cataloging -> New record (koha/cataloguing/addbiblio.pl) Ensure you are using the basic editor 3 - Click the "Link authorities automatically" button. A message should appear, telling the user "No authority link was changed." 4 - Add random informations in field 600$a of the biblio record. 5 - Click the "Link authorities automatically" button. the message box should now show "600 - No matching authority found.". the 9 subfield is red Above the 9 subfield is a red X with a blue plus next to it Hover on the plus, see it is titled 'Create authority' 6 - Click the 'Create authority' link 7 - A new authroity form pops up, the info from the cataloging editor is prefilled Click the 100 field heading to expand and confirm info is transferred 8 - Fill in necessary fields and save the new authority 9 - The cataloging screen now has the 9 subfield populated and is green 10 - Click "Link authorities automatically" again Dialog says "No authority link was changed" 11 - In another tab go to System preferences and set AutoCreateAuthorities to 'Generate' 12 - Add random information to the 650 field 13 - Click 'Link authorities' button 14 - Dialog says:650 - No matching authority found. A new authority was created automatically. 15 - The subfield 9 is green and has the id of the new authority record 16 - In another tab search authorities and find an existing subject heading 17 - Add a new 650 with the info from the existing record 18 - Click 'Link authorities' 19 - The new field is correctly linked to existing authority Signed-off-by: Katrin Fischer <katrin.fischer.83@web.de> https://bugs.koha-community.org/show_bug.cgi?id=12299 Signed-off-by: Michal Denar <black23@gmail.com> Signed-off-by: Nick Clemens <nick@bywatersolutions.com> Signed-off-by: Michal Denar <black23@gmail.com> Signed-off-by: Jonathan Druart <jonathan.druart@bugs.koha-community.org>
61 lines
1.9 KiB
Perl
Executable file
61 lines
1.9 KiB
Perl
Executable file
#!/usr/bin/perl
|
|
|
|
# Bouzid Fergani, 2020 - inLibro
|
|
#
|
|
# 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, write to the Free Software Foundation, Inc.,
|
|
# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
|
|
|
use Modern::Perl;
|
|
use CGI;
|
|
use CGI::Cookie;
|
|
use JSON;
|
|
use C4::Auth;
|
|
use C4::Biblio;
|
|
use C4::Context;
|
|
|
|
my $input = new CGI;
|
|
print $input->header('application/json');
|
|
|
|
# Check the user's permissions
|
|
my %cookies = CGI::Cookie->fetch;
|
|
my $sessid = $cookies{'CGISESSID'}->value || $input->param('CGISESSID');
|
|
my ( $auth_status, $auth_sessid ) =
|
|
C4::Auth::check_cookie_auth( $sessid, { editauthorities => 1, editcatalogue => 1 } );
|
|
if ( $auth_status ne "ok" ) {
|
|
print to_json( { status => 'UNAUTHORIZED' } );
|
|
exit 0;
|
|
}
|
|
|
|
# Link the biblio headings to authorities and return a json containing the status of all the links.
|
|
# Example : {"status":"OK","links":[{"authid":"123","status":"LINK_CHANGED","tag":"650"}]}
|
|
#
|
|
# tag = the tag number of the field
|
|
# authid = the value of the $9 subfield for this tag
|
|
# status = The status of the link (LOCAL_FOUND, NONE_FOUND, MULTIPLE_MATCH, UNCHANGED, CREATED)
|
|
|
|
my $json;
|
|
|
|
my $record = TransformHtmlToMarc($input,1);
|
|
|
|
my ( $headings_changed, $results ) = BiblioAutoLink (
|
|
$record,
|
|
$input->param('frameworkcode'),
|
|
1
|
|
);
|
|
|
|
$json->{status} = 'OK';
|
|
$json->{links} = $results->{details} || '';
|
|
|
|
print to_json($json);
|