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 # if issue_id is not found in issues or old_issues, set to null
57 $self->issue_id(undef) unless ( !$self->issue_id
58 || Koha::Checkouts->find( $self->issue_id )
59 || Koha::Old::Checkouts->find( $self->issue_id ) );
61 return $self->SUPER::store;
71 my $checkout_rs = $self->_result->checkout;
72 return unless $checkout_rs;
73 return Koha::Checkout->_new_from_dbic($checkout_rs);
83 my $old_checkout_rs = $self->_result->old_checkout;
84 return unless $old_checkout_rs;
85 return Koha::Old::Checkout->_new_from_dbic($old_checkout_rs);
95 my $borrower = $self->_result->borrowernumber;
96 return Koha::Patron->_new_from_dbic( $borrower ) if $borrower;
101 my $item = $claim->item;
103 Return the return claim item
109 my $item_rs = $self->_result->item;
110 return Koha::Item->_new_from_dbic( $item_rs );
117 resolution => $resolution,
118 resolved_by => $patron_id,
120 new_lost_status => $status, ]
129 my ( $self, $params ) = @_;
131 my @mandatory = ( 'resolution', 'resolved_by' );
132 for my $param (@mandatory) {
133 unless ( defined( $params->{$param} ) ) {
134 Koha::Exceptions::MissingParameter->throw( error => "The $param parameter is mandatory" );
138 $self->_result->result_source->schema->txn_do(
141 { resolution => $params->{resolution},
142 resolved_by => $params->{resolved_by},
143 resolved_on => $params->{resolved_on} // \'NOW()',
144 updated_by => $params->{resolved_by}
148 if ( defined $params->{new_lost_status} ) {
149 $self->item->itemlost( $params->{new_lost_status} )->store;
157 =head3 to_api_mapping
159 This method returns the mapping for representing a Koha::Checkouts::ReturnClaim object
167 itemnumber => 'item_id',
168 borrowernumber => 'patron_id',
172 =head2 Internal methods
179 return 'ReturnClaim';
184 Kyle M Hall <kyle@bywatersolutions.com>