Browse Source
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>21.05.x
13 changed files with 404 additions and 18 deletions
@ -0,0 +1,61 @@ |
|||
#!/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); |
Loading…
Reference in new issue