1 package Koha::REST::V1::ArticleRequests;
3 # This file is part of Koha.
5 # Koha is free software; you can redistribute it and/or modify it
6 # under the terms of the GNU General Public License as published by
7 # the Free Software Foundation; either version 3 of the License, or
8 # (at your option) any later version.
10 # Koha is distributed in the hope that it will be useful, but
11 # WITHOUT ANY WARRANTY; without even the implied warranty of
12 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 # GNU General Public License for more details.
15 # You should have received a copy of the GNU General Public License
16 # along with Koha; if not, see <http://www.gnu.org/licenses>.
20 use Mojo::Base 'Mojolicious::Controller';
23 use Koha::ArticleRequests;
25 use Scalar::Util qw( blessed );
26 use Try::Tiny qw( catch try );
30 Koha::REST::V1::ArticleRequests
38 Controller function that handles cancelling a Koha::ArticleRequest object
43 my $c = shift->openapi->valid_input or return;
45 my $article_request = Koha::ArticleRequests->find( $c->validation->param('article_request_id') );
47 unless ( $article_request ) {
50 openapi => { error => "Article request not found" }
54 my $reason = $c->validation->param('cancellation_reason');
55 my $notes = $c->validation->param('notes');
59 $article_request->cancel($reason, $notes);
65 $c->unhandled_exception($_);
69 =head3 patron_cancel (public route)
71 Controller function that handles cancelling a patron's Koha::ArticleRequest object
76 my $c = shift->openapi->valid_input or return;
78 my $patron = Koha::Patrons->find( $c->validation->param('patron_id') );
83 openapi => { error => "Patron not found" }
87 # patron_id has been validated by the allow-owner check, so the following call to related
88 # article requests covers the case of article requests not belonging to the patron
89 my $article_request = $patron->article_requests->find( $c->validation->param('article_request_id') );
91 unless ( $article_request ) {
94 openapi => { error => "Article request not found" }
98 my $reason = $c->validation->param('cancellation_reason');
99 my $notes = $c->validation->param('notes');
103 $article_request->cancel( $reason, $notes );
110 $c->unhandled_exception($_);