Bug 16719: (follow-up) Update check on password mapping
[koha.git] / svc / checkout_notes
blob5ad972c99a0c0fb17748881fabf57a1d4ce8623c
1 #!/usr/bin/perl
3 # This file is part of Koha.
5 # Copyright 2017 Aleisha Amohia <aleisha@catalyst.net.nz>
7 # Koha is free software; you can redistribute it and/or modify it
8 # under the terms of the GNU General Public License as published by
9 # the Free Software Foundation; either version 3 of the License, or
10 # (at your option) any later version.
12 # Koha is distributed in the hope that it will be useful, but
13 # WITHOUT ANY WARRANTY; without even the implied warranty of
14 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 # GNU General Public License for more details.
17 # You should have received a copy of the GNU General Public License
18 # along with Koha; if not, see <http://www.gnu.org/licenses>.
20 use Modern::Perl;
22 use JSON qw( to_json );
23 use CGI;
24 use C4::Service;
25 use C4::Auth qw /check_cookie_auth/;
26 use C4::Output qw(:DEFAULT :ajax);
27 use Koha::Checkouts;
29 =head1 NAME
31 svc/checkout_notes - Web service for managing patron notes set on issues
33 =head1 DESCRIPTION
35 =cut
37 # AJAX requests
38 my $is_ajax = is_ajax();
39 my $query = new CGI;
40 my ( $auth_status, $sessionID ) = check_cookie_auth( $query->cookie('CGISESSID'), { circulate => 'manage_checkout_notes' } );
41 if ( $auth_status ne "ok" ) {
42 exit 0;
44 if ($is_ajax) {
45 my $issue_id = $query->param('issue_id');
46 my $issue = Koha::Checkouts->find($issue_id);
47 my $action = $query->param('action');
48 my $status = 'success';
49 if ($action eq 'seen'){
50 $issue->set({ noteseen => 1 })->store;
51 if ( $issue->noteseen != 1 ) {
52 $status = 'failure';
54 } elsif ($action eq 'notseen'){
55 $issue->set({ noteseen => 0 })->store;
56 if ( $issue->noteseen != 0 ) {
57 $status = 'failure';
60 my $json = to_json ( { status => $status } );
61 output_with_http_headers $query, undef, $json, 'js';
62 exit;