1 package Koha::REST::V1::Illrequests;
3 # This file is part of Koha.
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
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.
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.
20 use Mojo::Base 'Mojolicious::Controller';
22 use Koha::Illrequests;
23 use Koha::Illrequestattributes;
30 Koha::REST::V1::Illrequests
36 Return a list of ILL requests, after applying filters.
41 my $c = shift->openapi->valid_input or return;
43 my $args = $c->req->params->to_hash // {};
45 # Create a hash where all keys are embedded values
46 # Enables easy checking
48 my $args_arr = (ref $args->{embed} eq 'ARRAY') ? $args->{embed} : [ $args->{embed} ];
49 if (defined $args->{embed}) {
50 %embed = map { $_ => 1 } @{$args_arr};
51 delete $args->{embed};
54 my $requests = Koha::Illrequests->unblessed;
56 # Identify patrons & branches that
57 # we're going to need and get them
59 $to_fetch->{patrons} = {} if $embed{patron};
60 $to_fetch->{branches} = {} if $embed{library};
61 $to_fetch->{capabilities} = {} if $embed{capabilities};
62 foreach my $req(@{$requests}) {
63 $to_fetch->{patrons}->{$req->{borrowernumber}} = 1 if $embed{patron};
64 $to_fetch->{branches}->{$req->{branchcode}} = 1 if $embed{library};
65 $to_fetch->{capabilities}->{$req->{backend}} = 1 if $embed{capabilities};
68 # Fetch the patrons we need
71 my @patron_ids = keys %{$to_fetch->{patrons}};
72 if (scalar @patron_ids > 0) {
74 borrowernumber => { -in => \@patron_ids }
76 $patron_arr = Koha::Patrons->search($where)->unblessed;
80 # Fetch the branches we need
82 if ($embed{library}) {
83 my @branchcodes = keys %{$to_fetch->{branches}};
84 if (scalar @branchcodes > 0) {
86 branchcode => { -in => \@branchcodes }
88 $branch_arr = Koha::Libraries->search($where)->unblessed;
92 # Fetch the capabilities we need
93 if ($embed{capabilities}) {
94 my @backends = keys %{$to_fetch->{capabilities}};
95 if (scalar @backends > 0) {
96 foreach my $bc(@backends) {
97 my $backend = Koha::Illrequest->new->load_backend($bc);
98 $to_fetch->{$bc} = $backend->capabilities;
104 # Now we've got all associated users and branches,
105 # we can augment the request objects
106 foreach my $req(@{$requests}) {
107 my $r = Koha::Illrequests->new->find($req->{illrequest_id});
108 $req->{id_prefix} = $r->id_prefix;
109 foreach my $p(@{$patron_arr}) {
110 if ($p->{borrowernumber} == $req->{borrowernumber}) {
112 firstname => $p->{firstname},
113 surname => $p->{surname},
114 cardnumber => $p->{cardnumber}
119 foreach my $b(@{$branch_arr}) {
120 if ($b->{branchcode} eq $req->{branchcode}) {
121 $req->{library} = $b;
125 if ($embed{metadata}) {
126 my $metadata = Koha::Illrequestattributes->search(
127 { illrequest_id => $req->{illrequest_id} },
128 { columns => [qw/type value/] }
131 foreach my $meta(@{$metadata}) {
132 $meta_hash->{$meta->{type}} = $meta->{value};
134 $req->{metadata} = $meta_hash;
136 if ($embed{capabilities}) {
137 $req->{capabilities} = $to_fetch->{$req->{backend}};
141 return $c->render( status => 200, openapi => $requests );