Bug 23403: Remove cardnumber from SIP
[koha.git] / C4 / SIP / ILS / Transaction / Renew.pm
blob7a21c89144baa138b99dbf1c7dc2dcf7dd454f08
2 # Status of a Renew Transaction
5 package C4::SIP::ILS::Transaction::Renew;
7 use warnings;
8 use strict;
10 use C4::Circulation;
11 use Koha::Patrons;
12 use Koha::DateUtils;
14 use parent qw(C4::SIP::ILS::Transaction);
16 my %fields = (
17 renewal_ok => 0,
20 sub new {
21 my $class = shift;
22 my $self = $class->SUPER::new();
24 foreach my $element (keys %fields) {
25 $self->{_permitted}->{$element} = $fields{$element};
28 @{$self}{keys %fields} = values %fields; # overkill?
29 return bless $self, $class;
32 sub do_renew_for {
33 my $self = shift;
34 my $borrower = shift;
35 my ($renewokay,$renewerror) = CanBookBeRenewed($borrower->{borrowernumber},$self->{item}->{itemnumber});
36 if ($renewokay) { # ok so far check charges
37 my ($fee, undef) = GetIssuingCharges($self->{item}->{itemnumber}, $self->{patron}->{borrowernumber});
38 if ($fee > 0) {
39 $self->{sip_fee_type} = '06';
40 $self->{fee_amount} = sprintf '%.2f',$fee;
41 if ($self->{fee_ack} eq 'N') {
42 $renewokay = 0;
47 if ($renewokay){
48 my $issue = AddIssue( $borrower, $self->{item}->id, undef, 0 );
49 $self->{due} = $self->duedatefromissue($issue, $self->{item}->{itemnumber});
50 $self->renewal_ok(1);
51 } else {
52 $renewerror=~s/on_reserve/Item unavailable due to outstanding holds/;
53 $renewerror=~s/too_many/Item has reached maximum renewals/;
54 $renewerror=~s/item_denied_renewal/Item renewal is not allowed/;
55 $self->screen_msg($renewerror);
56 $self->renewal_ok(0);
58 $self->ok(1);
59 return;
62 sub do_renew {
63 my $self = shift;
64 my $patron = Koha::Patrons->find( $self->{patron}->borrowernumber );
65 $patron or return; # FIXME we should log that
66 return $self->do_renew_for($patron->unblessed);