cleanup in memberentry,categories.
[koha.git] / misc / fines-sanop.pl
blobf1d0a770ba7287f1426d3663fec1c034aa61fb0b
1 #!/usr/bin/perl
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
9 # This script is meant to be run nightly out of cron.
11 # Copyright 2000-2002 Katipo Communications
13 # This file is part of Koha.
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.
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.
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
29 use C4::Context;
30 use C4::Circulation;
31 use C4::Overdues;
32 use Date::Manip qw/Date_DaysSince1BC/;
33 use C4::Biblio;
34 use strict;
36 open (FILE,'>/tmp/fines') || die;
37 # FIXME
38 # it looks like $count is just a counter, would it be
39 # better to rely on the length of the array @$data and turn the
40 # for loop below into a foreach loop?
42 my $DEBUG =1;
43 my $data=Getoverdues();
44 # warn "Overdues : = ".scalar(@$data)." => ".Data::Dumper::Dumper($data);
45 my $overdueItemsCounted=0 if $DEBUG;
46 # FIXME - There's got to be a better way to figure out what day
47 # today is.
48 my ($sec,$min,$hour,$mday,$mon,$year,$wday,$yday,$isdst) =localtime(time);
49 $mon++;
50 $year=$year+1900;
51 my $date=Date_DaysSince1BC($mon,$mday,$year);
52 # print "DATE : ".$date if $DEBUG;
53 if ($mon < '10' ){
54 $mon="0".$mon;
56 if ($mday < '10' ){
57 $mday="0".$mday;
59 my $reference = $year."".$mon;
60 my $borrowernumber;
62 for (my $i=0;$i<scalar(@$data);$i++){
63 my @dates=split('-',$data->[$i]->{'date_due'});
64 my $date2=Date_DaysSince1BC($dates[1],$dates[2],$dates[0]);
65 my $datedue=$data->[$i]->{'date_due'};
66 my $due="$dates[2]/$dates[1]/$dates[0]";
67 my $borrower=BorType($data->[$i]->{'borrowernumber'});
68 my $starter;
70 if ($date2 <= $date){
71 $overdueItemsCounted++ if $DEBUG;
72 my $difference=$date-$date2;
73 my ($amount,$type,$printout,$daycounttotal,$daycount)=
74 CalcFine($data->[$i]->{'itemnumber'},
75 $borrower->{'categorycode'},
76 $difference,
77 $datedue);
79 my ($delays1,$delays2,$delays3)=GetOverdueDelays($borrower->{'categorycode'});
80 my $issuingrules=GetIssuingRules($data->[$i]->{'itemnumber'},$borrower->{'categorycode'});
82 # warn "$delays1 and $delays2 and $delays3";
83 if($delays1 and $delays2 and $delays3) {
85 my $debarredstatus=CheckBorrowerDebarred($borrower->{'borrowernumber'});
87 if (($issuingrules->{'fine'} > 0) || ($issuingrules->{'fine'} ne '' )){
89 #DELAYS 1##########################################
90 # warn "$amount > 0 && $daycount >= $delays1 && $daycount < $delays2";
91 if ($amount > 0 && $daycount >= $delays1 && $daycount < $delays2){
92 # FIXME : already in GetIssuingRules ?
93 my $debarred1=GetOverduerules($borrower->{'categorycode'},1);
94 (UpdateBorrowerDebarred($borrower->{'borrowernumber'}))if(($debarred1 eq '1' ) and ($debarredstatus eq '0'));
95 # save fine
96 UpdateFine($data->[$i]->{'itemnumber'},$data->[$i]->{'borrowernumber'},$amount,$type,$due);
97 # is there an open "dossier" for this date & borrower
98 my $getnotifyid=CheckExistantNotifyid($borrower->{'borrowernumber'},$datedue);
100 my $update=CheckAccountLineLevelInfo($borrower->{'borrowernumber'},$data->[$i]->{'itemnumber'},1,$datedue);
101 if ($update eq '0'){
102 if ($getnotifyid eq '0'){
103 $starter=GetNextIdNotify($reference,$borrower->{'borrowernumber'});
106 else{
107 $starter=$getnotifyid;
111 UpdateAccountLines($starter,1,$borrower->{'borrowernumber'},$data->[$i]->{'itemnumber'});
113 ###############################################
114 #SANOP specific
115 if ($daycount>=$delays2) {
117 $amount=$issuingrules->{'fine'} * ($delays2);
118 UpdateFine($data->[$i]->{'itemnumber'},$data->[$i]->{'borrowernumber'},$amount,$type,$due);
122 #DELAYS 2#################################
124 if ($daycount >= $delays2 && $daycount < $delays3){
125 my $debarred2=GetOverduerules($borrower->{'categorycode'},2);
126 (UpdateBorrowerDebarred($borrower->{'borrowernumber'}))if(($debarred2 eq '1' ) and ($debarredstatus eq '0'));
127 my $update=CheckAccountLineLevelInfo($borrower->{'borrowernumber'},$data->[$i]->{'itemnumber'},2,$datedue);
128 if ($update eq '0'){
129 UpdateAccountLines(undef,2,$borrower->{'borrowernumber'},$data->[$i]->{'itemnumber'});
132 ###############################################
134 #DELAYS 3###################################
135 if ($daycount >= $delays3 ){
136 my $debarred3=GetOverduerules($borrower->{'categorycode'},3);
137 (UpdateBorrowerDebarred($borrower->{'borrowernumber'}))if(($debarred3 eq '1' ) and ($debarredstatus eq '0'));
138 my $update=CheckAccountLineLevelInfo($borrower->{'borrowernumber'},$data->[$i]->{'itemnumber'},3,$datedue);
139 if ($update eq '0'){
140 UpdateAccountLines(undef,3,$borrower->{'borrowernumber'},$data->[$i]->{'itemnumber'});
142 my $items=GetItems($data->[$i]->{'itemnumber'});
143 my $todaydate=$year."-".$mon."-".$mday;
144 # add item price, the item is considered as lost.
145 my $description="Item Price";
146 my $typeaccount="IP";
147 my $level="3";
148 my $notifyid=GetNotifyId($borrower->{'borrowernumber'},$data->[$i]->{'itemnumber'});
149 my $timestamp=$todaydate." ".$hour."\:".$min."\:".$sec;
150 my $create=CheckAccountLineItemInfo($borrower->{'borrowernumber'},$data->[$i]->{'itemnumber'},$typeaccount,$notifyid);
151 if ($create eq '0'){
153 CreateItemAccountLine($borrower->{'borrowernumber'},$data->[$i]->{'itemnumber'},$todaydate,$items->{'price'},$description,$typeaccount,
154 $items->{'price'},$timestamp,$notifyid,$level);
157 ###############################################
163 if ($borrower->{'category_type'} eq 'C'){
164 my $query=qq| SELECT *
165 FROM borrowers
166 WHERE borrowernumber=?|;
167 my $dbh = C4::Context->dbh;
168 my $sth=$dbh->prepare($query);
169 $sth->execute($borrower->{'guarantorid'});
170 my $tdata=$sth->fetchrow_hashref;
171 $sth->finish;
172 $borrower->{'phone'}=$tdata->{'phone'};
174 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";
178 my $numOverdueItems=scalar(@$data);
179 if ($DEBUG) {
180 print <<EOM
182 Number of Overdue Items counted $overdueItemsCounted
183 Number of Overdue Items reported $numOverdueItems
188 close FILE;