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 return $self->SUPER::store;
66 my $checkout = Koha::Checkouts->find( $self->issue_id )
67 || Koha::Old::Checkouts->find( $self->issue_id );
79 my $borrower = $self->_result->borrowernumber;
80 return Koha::Patron->_new_from_dbic( $borrower ) if $borrower;
87 resolution => $resolution,
88 resolved_by => $patron_id,
90 new_lost_status => $status, ]
99 my ( $self, $params ) = @_;
101 my @mandatory = ( 'resolution', 'resolved_by' );
102 for my $param (@mandatory) {
103 unless ( defined( $params->{$param} ) ) {
104 Koha::Exceptions::MissingParameter->throw( error => "The $param parameter is mandatory" );
108 $self->_result->result_source->schema->txn_do(
111 { resolution => $params->{resolution},
112 resolved_by => $params->{resolved_by},
113 resolved_on => $params->{resolved_on} // \'NOW()',
114 updated_by => $params->{resolved_by}
118 if ( defined $params->{new_lost_status} ) {
119 $self->checkout->item->itemlost( $params->{new_lost_status} )->store;
127 =head3 to_api_mapping
129 This method returns the mapping for representing a Koha::Checkouts::ReturnClaim object
137 itemnumber => 'item_id',
138 borrowernumber => 'patron_id',
142 =head2 Internal methods
149 return 'ReturnClaim';
154 Kyle M Hall <kyle@bywatersolutions.com>