1 package Koha::Checkouts::ReturnClaim;
3 # Copyright ByWater Solutions 2019
5 # This file is part of Koha.
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>.
22 use base qw(Koha::Object);
26 use Koha::Exceptions::Checkouts::ReturnClaims;
27 use Koha::Old::Checkouts;
32 Koha::Checkouts::ReturnClaim - Koha ReturnClaim object class
42 my $return_claim = Koha::Checkout::ReturnClaim->new($args)->store;
44 Overloaded I<store> method that validates the attributes and raises relevant
52 unless ( $self->in_storage || $self->created_by ) {
53 Koha::Exceptions::Checkouts::ReturnClaims::NoCreatedBy->throw();
56 unless ( !$self->issue_id
57 || Koha::Checkouts->find( $self->issue_id )
58 || Koha::Old::Checkouts->find( $self->issue_id ) )
60 Koha::Exceptions::Object::FKConstraint->throw(
61 error => 'Broken FK constraint',
62 broken_fk => 'issue_id'
66 return $self->SUPER::store;
76 my $checkout_rs = $self->_result->checkout;
77 return unless $checkout_rs;
78 return Koha::Checkout->_new_from_dbic($checkout_rs);
88 my $old_checkout_rs = $self->_result->old_checkout;
89 return unless $old_checkout_rs;
90 return Koha::Old::Checkout->_new_from_dbic($old_checkout_rs);
100 my $borrower = $self->_result->borrowernumber;
101 return Koha::Patron->_new_from_dbic( $borrower ) if $borrower;
106 my $item = $claim->item;
108 Return the return claim item
114 my $item_rs = $self->_result->item;
115 return Koha::Item->_new_from_dbic( $item_rs );
122 resolution => $resolution,
123 resolved_by => $patron_id,
125 new_lost_status => $status, ]
134 my ( $self, $params ) = @_;
136 my @mandatory = ( 'resolution', 'resolved_by' );
137 for my $param (@mandatory) {
138 unless ( defined( $params->{$param} ) ) {
139 Koha::Exceptions::MissingParameter->throw( error => "The $param parameter is mandatory" );
143 $self->_result->result_source->schema->txn_do(
146 { resolution => $params->{resolution},
147 resolved_by => $params->{resolved_by},
148 resolved_on => $params->{resolved_on} // \'NOW()',
149 updated_by => $params->{resolved_by}
153 if ( defined $params->{new_lost_status} ) {
154 $self->item->itemlost( $params->{new_lost_status} )->store;
162 =head3 to_api_mapping
164 This method returns the mapping for representing a Koha::Checkouts::ReturnClaim object
172 itemnumber => 'item_id',
173 borrowernumber => 'patron_id',
177 =head2 Internal methods
184 return 'ReturnClaim';
189 Kyle M Hall <kyle@bywatersolutions.com>