3 # Copyright ByWater Solutions 2014
4 # Copyright PTFS Europe 2016
6 # This file is part of Koha.
8 # Koha is free software; you can redistribute it and/or modify it under the
9 # terms of the GNU General Public License as published by the Free Software
10 # Foundation; either version 3 of the License, or (at your option) any later
13 # Koha is distributed in the hope that it will be useful, but WITHOUT ANY
14 # WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
15 # A PARTICULAR PURPOSE. See the GNU General Public License for more details.
17 # You should have received a copy of the GNU General Public License along
18 # with Koha; if not, write to the Free Software Foundation, Inc.,
19 # 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
32 use Koha
::Patron
::Categories
;
33 use Koha
::Patron
::Images
;
36 use base
qw(Koha::Object);
40 Koha::Patron - Koha Patron Object class
50 Returns a Koha::Patron object for this patron's guarantor
57 return unless $self->guarantorid();
59 return Koha
::Patrons
->find( $self->guarantorid() );
65 return Koha
::Patron
::Images
->find( $self->borrowernumber )
70 Returns the guarantees (list of Koha::Patron) of this patron
77 return Koha
::Patrons
->search( { guarantorid
=> $self->borrowernumber } );
82 Returns the siblings of this patron.
89 my $guarantor = $self->guarantor;
91 return unless $guarantor;
93 return Koha
::Patrons
->search(
97 '=' => $guarantor->id,
100 '!=' => $self->borrowernumber,
106 =head3 wants_check_for_previous_checkout
108 $wants_check = $patron->wants_check_for_previous_checkout;
110 Return 1 if Koha needs to perform PrevIssue checking, else 0.
114 sub wants_check_for_previous_checkout
{
116 my $syspref = C4
::Context
->preference("checkPrevCheckout");
119 ## Hard syspref trumps all
120 return 1 if ($syspref eq 'hardyes');
121 return 0 if ($syspref eq 'hardno');
122 ## Now, patron pref trumps all
123 return 1 if ($self->checkprevcheckout eq 'yes');
124 return 0 if ($self->checkprevcheckout eq 'no');
126 # More complex: patron inherits -> determine category preference
127 my $checkPrevCheckoutByCat = Koha
::Patron
::Categories
128 ->find($self->categorycode)->checkprevcheckout;
129 return 1 if ($checkPrevCheckoutByCat eq 'yes');
130 return 0 if ($checkPrevCheckoutByCat eq 'no');
132 # Finally: category preference is inherit, default to 0
133 if ($syspref eq 'softyes') {
140 =head3 do_check_for_previous_checkout
142 $do_check = $patron->do_check_for_previous_checkout($item);
144 Return 1 if the bib associated with $ITEM has previously been checked out to
145 $PATRON, 0 otherwise.
149 sub do_check_for_previous_checkout
{
150 my ( $self, $item ) = @_;
152 # Find all items for bib and extract item numbers.
153 my @items = Koha
::Items
->search({biblionumber
=> $item->{biblionumber
}});
155 foreach my $item (@items) {
156 push @item_nos, $item->itemnumber;
159 # Create (old)issues search criteria
161 borrowernumber
=> $self->borrowernumber,
162 itemnumber
=> \
@item_nos,
165 # Check current issues table
166 my $issues = Koha
::Issues
->search($criteria);
167 return 1 if $issues->count; # 0 || N
169 # Check old issues table
170 my $old_issues = Koha
::OldIssues
->search($criteria);
171 return $old_issues->count; # 0 || N
176 my $debarment_expiration = $patron->is_debarred;
178 Returns the date a patron debarment will expire, or undef if the patron is not
186 return unless $self->debarred;
187 return $self->debarred
188 if $self->debarred =~ '^9999'
189 or dt_from_string
( $self->debarred ) > dt_from_string
;
193 =head2 update_password
195 my $updated = $patron->update_password( $userid, $password );
197 Update the userid and the password of a patron.
198 If the userid already exists, returns and let DBIx::Class warns
199 This will add an entry to action_logs if BorrowersLog is set.
203 sub update_password
{
204 my ( $self, $userid, $password ) = @_;
205 eval { $self->userid($userid)->store; };
206 return if $@
; # Make sure the userid is not already in used by another patron
207 $self->password($password)->store;
208 logaction
( "MEMBERS", "CHANGE PASS", $self->borrowernumber, "" ) if C4
::Context
->preference("BorrowersLog");
214 my $new_expiry_date = $patron->renew_account
216 Extending the subscription to the expiry date.
224 C4
::Context
->preference('BorrowerRenewalPeriodBase') eq 'dateexpiry'
225 ? dt_from_string
( $self->dateexpiry )
227 my $patron_category = Koha
::Patron
::Categories
->find( $self->categorycode ); # FIXME Should be $self->category
228 my $expiry_date = $patron_category->get_expiry_date($date);
230 $self->dateexpiry($expiry_date)->store;
232 C4
::Members
::AddEnrolmentFeeIfNeeded
( $self->categorycode, $self->borrowernumber );
234 logaction
( "MEMBERS", "RENEW", $self->borrowernumber, "Membership renewed" ) if C4
::Context
->preference("BorrowersLog");
235 return dt_from_string
( $expiry_date )->truncate( to
=> 'day' );
240 my $has_overdues = $patron->has_overdues;
242 Returns the number of patron's overdues
248 my $dtf = Koha
::Database
->new->schema->storage->datetime_parser;
249 return $self->_result->issues->search({ date_due
=> { '<' => $dtf->format_datetime( dt_from_string
() ) } })->count;
262 Kyle M Hall <kyle@bywatersolutions.com>
263 Alex Sassmannshausen <alex.sassmannshausen@ptfs-europe.com>