Bug 22615: Add endpoint for getting one ill backend
[koha.git] / Koha / REST / V1 / Illbackends.pm
1 package Koha::REST::V1::Illbackends;
2
3 # This file is part of Koha.
4 #
5 # Koha is free software; you can redistribute it and/or modify it under the
6 # terms of the GNU General Public License as published by the Free Software
7 # Foundation; either version 3 of the License, or (at your option) any later
8 # version.
9 #
10 # Koha is distributed in the hope that it will be useful, but WITHOUT ANY
11 # WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
12 # A PARTICULAR PURPOSE.  See the GNU General Public License for more details.
13 #
14 # You should have received a copy of the GNU General Public License along
15 # with Koha; if not, write to the Free Software Foundation, Inc.,
16 # 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
17
18 use Modern::Perl;
19
20 use Mojo::Base 'Mojolicious::Controller';
21
22 use Koha::Illrequest::Config;
23 use Koha::Illrequests;
24
25 =head1 NAME
26
27 Koha::REST::V1::Illbackends
28
29 =head2 Operations
30
31 =head3 list
32
33 Return a list of available ILL backends and its capabilities
34
35 =cut
36
37 sub list {
38     my $c = shift->openapi->valid_input;
39
40     my $config = Koha::Illrequest::Config->new;
41     my $backends = $config->available_backends;
42
43     my @data;
44     foreach $b ( @$backends ) {
45         my $backend = Koha::Illrequest->new->load_backend( $b );
46         push @data, {
47             ill_backend_id => $b,
48             capabilities => $backend->capabilities,
49         };
50     }
51     return $c->render( status => 200, openapi => \@data );
52 }
53
54 =head3 get
55
56 Get one backend
57
58 =cut
59
60 sub get {
61     my $c = shift->openapi->valid_input;
62
63     my $backend_id = $c->validation->param('ill_backend_id');
64
65     return try {
66         my $backend = Koha::Illrequest->new->load_backend( $backend_id );
67         return $c->render(
68             status => 200,
69             openapi => {
70                 ill_backend_id => $backend_id,
71                 capabilities => $backend->capabilities
72             }
73         );
74     } catch {
75         return $c->render(
76             status => 404,
77             openapi => { error => "ILL backend does not exist" }
78         );
79     };
80 }
81
82 1;