installer: command-line scripts improve finding C4 modules
[koha.git] / misc / fines-sanop.pl
1 #!/usr/bin/perl
2
3 #  This script loops through each overdue item, determines the fine,
4 #  and updates the total amount of fines due by each user.  It relies on
5 #  the existence of /tmp/fines, which is created by ???
6 # Doesnt really rely on it, it relys on being able to write to /tmp/
7 # It creates the fines file
8 #
9 #  This script is meant to be run nightly out of cron.
10
11 # Copyright 2000-2002 Katipo Communications
12 #
13 # This file is part of Koha.
14 #
15 # Koha is free software; you can redistribute it and/or modify it under the
16 # terms of the GNU General Public License as published by the Free Software
17 # Foundation; either version 2 of the License, or (at your option) any later
18 # version.
19 #
20 # Koha is distributed in the hope that it will be useful, but WITHOUT ANY
21 # WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
22 # A PARTICULAR PURPOSE.  See the GNU General Public License for more details.
23 #
24 # You should have received a copy of the GNU General Public License along with
25 # Koha; if not, write to the Free Software Foundation, Inc., 59 Temple Place,
26 # Suite 330, Boston, MA  02111-1307 USA
27
28
29 use strict;
30 BEGIN {
31     # find Koha's Perl modules
32     # test carefully before changing this
33     use FindBin;
34     eval { require "$FindBin::Bin/kohalib.pl" };
35 }
36 use C4::Context;
37 use C4::Circulation;
38 use C4::Overdues;
39 use Date::Manip qw/Date_DaysSince1BC/;
40 use C4::Biblio;
41
42 open (FILE,'>/tmp/fines') || die;
43 # FIXME
44 # it looks like $count is just a counter, would it be
45 # better to rely on the length of the array @$data and turn the
46 # for loop below into a foreach loop?
47 #
48 my $DEBUG =1;
49 my $data=Getoverdues();
50 # warn "Overdues : = ".scalar(@$data)." => ".Data::Dumper::Dumper($data);
51 my $overdueItemsCounted=0 if $DEBUG;
52 # FIXME - There's got to be a better way to figure out what day
53 # today is.
54 my ($sec,$min,$hour,$mday,$mon,$year,$wday,$yday,$isdst) =localtime(time);
55 $mon++;
56 $year=$year+1900;
57 my $date=Date_DaysSince1BC($mon,$mday,$year);
58 # print "DATE : ".$date if $DEBUG;
59 if ($mon < '10'  ){
60 $mon="0".$mon;
61 }
62 if ($mday < '10'  ){
63 $mday="0".$mday;
64 }
65 my $reference = $year."".$mon;
66 my $borrowernumber;
67
68 for (my $i=0;$i<scalar(@$data);$i++){
69   my @dates=split('-',$data->[$i]->{'date_due'});
70   my $date2=Date_DaysSince1BC($dates[1],$dates[2],$dates[0]);
71   my $datedue=$data->[$i]->{'date_due'};
72   my $due="$dates[2]/$dates[1]/$dates[0]";
73   my $borrower=BorType($data->[$i]->{'borrowernumber'});
74   my $starter;
75       
76  if ($date2 <= $date){
77     $overdueItemsCounted++ if $DEBUG;
78     my $difference=$date-$date2;
79     my ($amount,$type,$printout,$daycounttotal,$daycount)=
80     CalcFine($data->[$i]->{'itemnumber'},
81         $borrower->{'categorycode'},
82         $difference,
83         $datedue);
84     
85     my ($delays1,$delays2,$delays3)=GetOverdueDelays($borrower->{'categorycode'});
86     my $issuingrules=GetIssuingRules($data->[$i]->{'itemnumber'},$borrower->{'categorycode'});
87
88 # warn "$delays1  and $delays2  and $delays3";
89 if($delays1  and $delays2  and $delays3)  {
90     
91     my $debarredstatus=CheckBorrowerDebarred($borrower->{'borrowernumber'});
92      
93     if (($issuingrules->{'fine'} > 0) || ($issuingrules->{'fine'} ne '' )){
94
95         #DELAYS 1##########################################
96 #         warn "$amount > 0 && $daycount >= $delays1 && $daycount < $delays2";
97         if ($amount > 0 && $daycount >= $delays1 && $daycount < $delays2){
98             # FIXME : already in GetIssuingRules ?
99             my $debarred1=GetOverduerules($borrower->{'categorycode'},1);
100             (UpdateBorrowerDebarred($borrower->{'borrowernumber'}))if(($debarred1 eq '1' ) and ($debarredstatus eq '0'));
101             # save fine
102             UpdateFine($data->[$i]->{'itemnumber'},$data->[$i]->{'borrowernumber'},$amount,$type,$due);
103             # is there an open "dossier" for this date & borrower
104             my $getnotifyid=CheckExistantNotifyid($borrower->{'borrowernumber'},$datedue);
105         
106             my $update=CheckAccountLineLevelInfo($borrower->{'borrowernumber'},$data->[$i]->{'itemnumber'},1,$datedue);
107                 if ($update eq '0'){
108                     if ($getnotifyid eq '0'){
109                         $starter=GetNextIdNotify($reference,$borrower->{'borrowernumber'});
110
111                     }
112                     else{
113                         $starter=$getnotifyid;
114                     }
115         
116                 }
117             UpdateAccountLines($starter,1,$borrower->{'borrowernumber'},$data->[$i]->{'itemnumber'});
118         }
119         ###############################################
120         #SANOP specific
121         if ($daycount>=$delays2) {
122     
123             $amount=$issuingrules->{'fine'} * ($delays2);
124             UpdateFine($data->[$i]->{'itemnumber'},$data->[$i]->{'borrowernumber'},$amount,$type,$due);
125     
126         }
127     
128         #DELAYS 2#################################
129     
130         if ($daycount >= $delays2 && $daycount < $delays3){
131         my $debarred2=GetOverduerules($borrower->{'categorycode'},2);
132         (UpdateBorrowerDebarred($borrower->{'borrowernumber'}))if(($debarred2 eq '1' ) and ($debarredstatus eq '0'));
133        my $update=CheckAccountLineLevelInfo($borrower->{'borrowernumber'},$data->[$i]->{'itemnumber'},2,$datedue);
134         if ($update eq '0'){
135         UpdateAccountLines(undef,2,$borrower->{'borrowernumber'},$data->[$i]->{'itemnumber'});
136         }
137         }
138         ###############################################
139     
140         #DELAYS 3###################################
141         if ($daycount >= $delays3  ){
142             my $debarred3=GetOverduerules($borrower->{'categorycode'},3);
143             (UpdateBorrowerDebarred($borrower->{'borrowernumber'}))if(($debarred3 eq '1' ) and ($debarredstatus eq '0'));
144             my $update=CheckAccountLineLevelInfo($borrower->{'borrowernumber'},$data->[$i]->{'itemnumber'},3,$datedue);
145             if ($update eq '0'){
146                     UpdateAccountLines(undef,3,$borrower->{'borrowernumber'},$data->[$i]->{'itemnumber'});
147             }
148             my $items=GetItems($data->[$i]->{'itemnumber'});
149             my $todaydate=$year."-".$mon."-".$mday;
150             # add item price, the item is considered as lost.
151             my $description="Item Price";
152             my $typeaccount="IP";
153             my $level="3";
154             my $notifyid=GetNotifyId($borrower->{'borrowernumber'},$data->[$i]->{'itemnumber'});
155             my $timestamp=$todaydate." ".$hour."\:".$min."\:".$sec;
156             my $create=CheckAccountLineItemInfo($borrower->{'borrowernumber'},$data->[$i]->{'itemnumber'},$typeaccount,$notifyid);
157             if ($create eq '0'){
158     
159             CreateItemAccountLine($borrower->{'borrowernumber'},$data->[$i]->{'itemnumber'},$todaydate,$items->{'price'},$description,$typeaccount,
160             $items->{'price'},$timestamp,$notifyid,$level);
161             }
162         }
163         ###############################################
164     }
165 }
166
167
168
169 if ($borrower->{'category_type'} eq 'C'){  
170         my $query=qq|    SELECT *
171                 FROM borrowers
172                 WHERE borrowernumber=?|;
173         my $dbh = C4::Context->dbh;
174         my $sth=$dbh->prepare($query);
175         $sth->execute($borrower->{'guarantorid'});
176         my $tdata=$sth->fetchrow_hashref;
177         $sth->finish;
178         $borrower->{'phone'}=$tdata->{'phone'};
179        }
180  print "$printout\t$borrower->{'cardnumber'}\t$borrower->{'category_type'}\t$borrower->{'firstname'}\t$borrower->{'surname'}\t$data->[$i]->{'date_due'}\t$type\t$difference\t$borrower->{'email'}\t$borrower->{'phone'}\t$borrower->{'address'}\t$borrower->{'city'}\t$amount\n";
181  }
182 }
183
184 my $numOverdueItems=scalar(@$data);
185 if ($DEBUG) {
186    print <<EOM
187
188 Number of Overdue Items counted $overdueItemsCounted
189 Number of Overdue Items reported $numOverdueItems
190
191 EOM
192 }
193
194 close FILE;