From 35e4aabf04559c90ce81c6dda27237addea2b032 Mon Sep 17 00:00:00 2001 From: asansal Date: Wed, 25 Jun 2025 19:49:42 +0700 Subject: [PATCH] Add LogController class for attendance log processing - Implemented methods for database connection, query execution, and attendance record handling. - Added functionality to retrieve attendance logs based on date and process attendance records. - Integrated logic for handling different employee departments and attendance types (IN, OUT, R1, R2). - Included synchronization of attendance records with the attendance list. - Utilized PDO for database interactions to enhance security and performance. --- getdatadevicesbylogs.php | 643 +++++++++------------------- getdatadevicesbylogsbydates.php | 718 ++++++++++++++++++++++++++++++++ 2 files changed, 915 insertions(+), 446 deletions(-) create mode 100644 getdatadevicesbylogsbydates.php diff --git a/getdatadevicesbylogs.php b/getdatadevicesbylogs.php index c74d2de..1ef0e9b 100644 --- a/getdatadevicesbylogs.php +++ b/getdatadevicesbylogs.php @@ -7,7 +7,7 @@ class LogController // $ppHCMTT#2024 public function fn_getconn(){ - $pdo = new PDO("mysql:host=localhost;dbname=dbhcm", "apphcm", "\$ppHCMTT#2024"); + $pdo = new PDO("mysql:host=192.168.1.4;dbname=dbhcm", "apphcm", "\$ppHCMTT#2024"); return $pdo; } public function selectquerySP($sql){ @@ -60,95 +60,37 @@ class LogController return explode(",",$rtn); } - - public function indexold() - { - $ip = "192.168.100.76"; //$row['deviceip']; - $qry="select * from tbl_deviceinfo where isdeleted=0 order by _idx asc"; - #echo $qry; + public function fn_rowisexists($qry){ $rs=$this->selectquerySP($qry); + $rtn=false; if($rs){ + // $rw=$rs->fetch(); + // $rtn=$rw[$fieldname]; while($rw=$rs->fetch()){ - $ip=$rw['deviceip']; - $zk = new ZKLib($ip); - echo "Start time : ".date("Y-m-d H:i:s")."\n"; - echo $ip."\n"; - // die(); - $allData = []; - $connectStatus = $zk->connect(); - - // echo $connectStatus; - if ($connectStatus) { - try { - $zk->disableDevice(); - // $zk->clearAttendance(); - $users = $zk->getUser(); - $getData = $zk->getAttendance(); - // echo json_encode($getData); - $data = []; - foreach ($getData as $att) { - // echo date("Y-m-d", strtotime($att['timestamp'])); - if (date("Y-m-d", strtotime($att['timestamp'])) == date("Y-m-d")) { - // $data[] = [ - // "idUser" => $att['id'], - // "name" => isset($users[$att['id']]) ? $users[$att['id']]['name'] : $att['id'], - // "state" => ZK\Util::getAttState($att['state']), - // "date" => date("Y-m-d", strtotime($att['timestamp'])), - // "time" => date("H:i:s", strtotime($att['timestamp'])), - // "deviceIP" => $ip - // ]; - // echo json_encode($att)."\n"; - $res=$this->fn_setattendance($att, $ip); - $reslog=$this->fn_setattendancelogs($att, $ip); - $data[] = [ - "fingerid" => $att['id'], - "time" => date("Y-m-d H:i:s", strtotime($att['timestamp'])), - "status" => $res - ]; - } - } - $allData = array_merge($allData, $data); - } catch (Exception $e) { - echo $e->getMessage(); - } finally { - $zk->disconnect(); - } - } - echo "End time : ".date("Y-m-d H:i:s")."\n\n"; + $rtn=true; } } - // === Rekon deviceid - $qry="update tbl_attendanceemployee a, tbl_deviceinfo d set a.deviceid=d.deviceid where d.deviceip=a.fingerip and a.deviceid is null or a.deviceid=''"; - $this->executeSP($qry); - - $qry="update tbl_attendanceemployee a, tbl_deviceinfo d set a.deviceidcheckout=d.deviceid where d.deviceip=a.fingerip and a.deviceidcheckout is null or a.deviceidcheckout=''"; - $this->executeSP($qry); - - // header('Content-Type: application/json'); - return json_encode($allData); + return $rtn; } - public function fn_setattendancelogs($data, $ip){ - $rtn=false; - $dates=date("Y-m-d", strtotime($data['timestamp'])); - $times=date("H:i:s", strtotime($data['timestamp'])); - $qry="insert into tbl_attendancelogs - set fingerid='".$data['id']."',username='".$data['id']."',dates='$dates',times='$times',deviceip='$ip',iby='svc',idt=now()"; - $qryexists="select _idx from tbl_attendancelogs - where trim(fingerid)=trim('".$data['id']."') - and dates='$dates' and times='$times' and isdeleted=0 - order by _idx desc limit 1"; - $idx=$this->fn_getfieldvalue("_idx",$qryexists); - if($idx){ - $qry="update tbl_attendancelogs - set udt=now() - where _idx='$idx'"; + + public function index(){ + $argv=$_SERVER['argv']; + // echo $argv[1];return false; + $qry="select * from tbl_attendancelogs + where cast(dates as date)=cast(now() as date) + order by _idx asc"; + $rs=$this->selectquerySP($qry); + if($rs){ + $d=array(); + while($rw=$rs->fetch()){ + $d['timestamp']=date("Y-m-d H:i:s", strtotime($rw['dates'].' '.$rw['times'])); + $d['id']=$rw['fingerid']; + $res=$this->fn_setattendance($d, $rw['deviceip']); + + } } - if($this->executeSP($qry)){ - $rtn=true; - } - return $rtn; } public function fn_setattendance($data, $ip){ @@ -170,6 +112,8 @@ class LogController where e.isdeleted=0 and t.isdeleted=0 and e.fingerid='".$data['id']."' and ('$timestamp'>=t.starttime and '$timestamp'<=t.thresholdtime) order by t._idx asc limit 1"; + // echo $qry;return false; + if($timestamp>2300){ $timestampH=0; $qry="select e._idx idxemployee,e.nik,e.employeename,e.fingerid,t.idxdept,t.deptname,t.attendancename,t.starttimestr,t.starttime, @@ -245,7 +189,7 @@ class LogController // order by t._idx asc limit 1"; $qryshift="select shiftcategory,idxemployee from tbl_callcenterschedule where (cast(dates as date)=cast('$dates' as date) or cast(datesout as date)=cast('$dates' as date)) and idxemployee='$idxemployee' and isdeleted=0"; - + // echo $qryshift;return false; // if($idxemployee==115){ // echo $qryshift."\n"; // } @@ -276,7 +220,7 @@ class LogController where e.isdeleted=0 and t.isdeleted=0 and e.fingerid='".$data['id']."' $swhereshiftcode and ('$timestamp'>=t.starttime and '$timestamp'<=t.thresholdtime) order by t._idx asc limit 1"; - + // echo $qry."\n";return false; if($timestamp>=2300){ $timestampH=0; $qry="select e._idx idxemployee,e.nik,e.employeename,e.fingerid,t.idxdept,t.deptname,t.attendancename,t.starttimestr,t.starttime, @@ -356,6 +300,7 @@ class LogController where s.idxemployee='".$rw['idxemployee']."' and t.attendancename='IN' and cast(s.dates as date)=cast('".date("Y-m-d", strtotime($data['timestamp']))."' as date) and t.shiftcode='".$rw['shiftcode']."' and t.isdeleted=0 and s.isdeleted=0 order by t._idx desc limit 1"; + // echo $qrysc."\n";return false; $endtimecc=$this->fn_getfieldvalue("endtime",$qrysc); $endtimestrcc=$this->fn_getfieldvalue("endtimestr",$qrysc); if($endtimecc){ @@ -472,6 +417,7 @@ class LogController where trim(fingerid)=trim('".$data['id']."') and cast(dates as date)=cast('".date("Y-m-d", strtotime($data['timestamp']))."' as date) and isdeleted=0 and attendancename='".$rw['attendancename']."' and shiftcode='".$rw['shiftcode']."' order by _idx asc limit 1"; + // echo $qryexists."\n";return false; $sp=$this->fn_getfieldsvalues("_idx,deviceid,deviceidcheckout,datestimes",$qryexists); //$idx=$sp[0];$deviceidcheckin=$sp[1];$deviceidcheckout=$sp[2]; $idx=(isset($sp[0]) ? $sp[0] : 0);$deviceidcheckin=(isset($sp[1]) ? $sp[1] : ''); @@ -517,6 +463,7 @@ class LogController $qry="update tbl_attendanceemployee set udt=now(),islates='$islate' where _idx='$idx' and deviceid<>'MANUAL'"; + // echo $qry."\n";return false; } else{ // if(!$deviceidcheckin||is_null($deviceidcheckin)){$deviceidcheckin=$deviceid;} @@ -558,7 +505,10 @@ class LogController // and isdeleted=0"; // //$this->executeSP($qry); // } - $rtn=true; + if($this->attendancelistsync($rw['idxemployee'],$dates)){ + $rtn=true; + } + } } @@ -567,390 +517,191 @@ class LogController return $rtn; } - public function fn_setattendanceold($data, $ip){ + public function attendancelistsync($idxemployee,$dates) + { $rtn=false; - $months=(int)date("m", strtotime($data['timestamp'])); - $years=(int)date("Y", strtotime($data['timestamp'])); - $timestamp=(int)date("Hi", strtotime($data['timestamp'])); - $timestampH=(int)date("H", strtotime($data['timestamp'])); - $timestampstr=date("H:i", strtotime($data['timestamp'])); - $datestimes=date("Y-m-d H:i:s", strtotime($data['timestamp'])); - $dates=date("Y-m-d", strtotime($data['timestamp'])); - $datesadd1=date("Y-m-d", strtotime($data['timestamp'].' +1 day')); - $totallateperemp=0; - $totallateperempr2=0; - $swhereshift=""; - // $qry="select e._idx idxemployee,e.nik,e.employeename,e.fingerid,t.idxdept,t.deptname,t.attendancename,t.starttimestr,t.starttime, - // t.endtimestr,t.endtime,t.thresholdtimestr,t.thresholdtime,t.shiftcode - // from tbl_employee e inner join tbl_attendancethreshold t on e.idxdept=t.idxdept - // where e.isdeleted=0 and t.isdeleted=0 and e.fingerid='".$data['id']."' - // and ('$timestamp'>=t.starttime and '$timestamp'<=t.thresholdtime) - // order by t._idx asc limit 1"; - $qry="select e._idx idxemployee,e.nik,e.employeename,e.fingerid,t.idxdept,t.deptname,t.attendancename,t.starttimestr,t.starttime, - t.endtimestr,t.endtime,t.thresholdtimestr,t.thresholdtime,t.shiftcode - from tbl_employee e inner join tbl_attendancethreshold t on e.idxdept=t.idxdept - where e.isdeleted=0 and t.isdeleted=0 and e.fingerid='".$data['id']."' - and (unix_timestamp(concat('".($timestampH==0 ? $datesadd1 : $dates)."',' ','$timestampstr'))>=unix_timestamp(concat('$dates',' ',t.starttimestr)) - and unix_timestamp(concat('".($timestampH==0 ? $datesadd1 : $dates)."',' ','$timestampstr'))<=unix_timestamp(concat('".($timestampH==0 ? $datesadd1 : $dates)."',' ',t.thresholdtimestr))) - order by t._idx desc limit 1"; - + // $qry="select distinct * from vw_attendanceemployeesync + // where cast(dates as date)=cast(now() as date) + // order by idxemployee,datestimes,sorts asc"; + // $qry="select distinct * from vw_attendanceemployeesync + // where cast(idt as date)=cast(now() as date) + // order by idxemployee,datestimes,sorts asc"; + $qry="select distinct * from vw_attendanceemployeesync + where idxemployee='$idxemployee' and cast(dates as date)=cast('$dates' as date) + order by idxemployee,datestimes,sorts asc"; // echo $qry;return false; - $sp=$this->fn_getfieldsvalues("idxdept,idxemployee,attendancename", $qry); - //$idxdeptemp=$sp[0];$idxemployee=$sp[1]; - $idxdeptemp=(isset($sp[0]) ? $sp[0] : 0);$idxemployee=(isset($sp[1]) ? $sp[1] : 0); - $attendancenameemp=(isset($sp[2]) ? $sp[2] : ''); - if($idxdeptemp==33||$idxdeptemp==34){ - // $sp=$this->fn_getfieldsvalues("shiftcategory,idxemployee","select shiftcategory,idxemployee from tbl_lojaschedule where cast(dates as date)=cast('$dates' as date) and idxemployee='$idxemployee' and isdeleted=0"); - // $shiftcode=(isset($sp[0]) ? $sp[0] : "");$idxemployee=(isset($sp[1]) ? $sp[1] : 0); - // $qry="select e._idx idxemployee,e.nik,e.employeename,e.fingerid,t.idxdept,t.deptname,t.attendancename,t.starttimestr,t.starttime, - // t.endtimestr,t.endtime,t.thresholdtimestr,t.thresholdtime,t.shiftcode - // from tbl_employee e inner join tbl_attendancethreshold t on e.idxdept=t.idxdept - // where e.isdeleted=0 and t.isdeleted=0 and e.fingerid='".$data['id']."' and t.shiftcode='$shiftcode' - // and ('$timestamp'>=t.starttime and '$timestamp'<=t.thresholdtime) - // order by t._idx asc limit 1"; - $qryshift="select shiftcategory,idxemployee from tbl_lojaschedule where cast(dates as date)=cast('$dates' as date) and idxemployee='$idxemployee' and isdeleted=0"; - $rsshift=$this->selectquerySP($qryshift); - $shiftcode="";$limit="limit 1"; - if($rsshift){ - while($rwshift=$rsshift->fetch()){ - $shiftcode.="'".$rwshift['shiftcategory']."',"; - } - if($shiftcode){ - $shiftcode=substr($shiftcode,0,strlen($shiftcode)-1); - } - } - - $swhereshiftcode="and t.shiftcode=''"; - if($shiftcode){ - $swhereshiftcode="and t.shiftcode in($shiftcode)"; - } - - // $qry="select e._idx idxemployee,e.nik,e.employeename,e.fingerid,t.idxdept,t.deptname,t.attendancename,t.starttimestr,t.starttime, - // t.endtimestr,t.endtime,t.thresholdtimestr,t.thresholdtime,t.shiftcode - // from tbl_employee e inner join tbl_attendancethreshold t on e.idxdept=t.idxdept - // where e.isdeleted=0 and t.isdeleted=0 and e.fingerid='".$data['id']."' $swhereshiftcode - // and ('$timestamp'>=t.starttime and '$timestamp'<=t.thresholdtime) - // order by t._idx asc limit 1"; - $qry="select e._idx idxemployee,e.nik,e.employeename,e.fingerid,t.idxdept,t.deptname,t.attendancename,t.starttimestr,t.starttime, - t.endtimestr,t.endtime,t.thresholdtimestr,t.thresholdtime,t.shiftcode - from tbl_employee e inner join tbl_attendancethreshold t on e.idxdept=t.idxdept - where e.isdeleted=0 and t.isdeleted=0 and e.fingerid='".$data['id']."' $swhereshiftcode - and (unix_timestamp(concat('".($timestampH==0 ? $datesadd1 : $dates)."',' ','$timestampstr'))>=unix_timestamp(concat('$dates',' ',t.starttimestr)) - and unix_timestamp(concat('".($timestampH==0 ? $datesadd1 : $dates)."',' ','$timestampstr'))<=unix_timestamp(concat('".($timestampH==0 ? $datesadd1 : $dates)."',' ',t.thresholdtimestr))) - order by t._idx desc limit 1"; - } - - if($idxdeptemp==30){ - // $sp=$this->fn_getfieldsvalues("shiftcategory,idxemployee","select shiftcategory,idxemployee from tbl_callcenterschedule where cast(dates as date)=cast('$dates' as date) and idxemployee='$idxemployee' and isdeleted=0"); - // $shiftcode=(isset($sp[0]) ? $sp[0] : "");$idxemployee=(isset($sp[1]) ? $sp[1] : 0); - // $qry="select e._idx idxemployee,e.nik,e.employeename,e.fingerid,t.idxdept,t.deptname,t.attendancename,t.starttimestr,t.starttime, - // t.endtimestr,t.endtime,t.thresholdtimestr,t.thresholdtime,t.shiftcode - // from tbl_employee e inner join tbl_attendancethreshold t on e.idxdept=t.idxdept - // where e.isdeleted=0 and t.isdeleted=0 and e.fingerid='".$data['id']."' and t.shiftcode='$shiftcode' - // and ('$timestamp'>=t.starttime and '$timestamp'<=t.thresholdtime) - // order by t._idx asc limit 1"; - $qryshift="select shiftcategory,idxemployee from tbl_callcenterschedule - where (cast(dates as date)=cast('$dates' as date) or cast(datesout as date)=cast('$dates' as date)) and idxemployee='$idxemployee' and isdeleted=0"; - - // if($attendancenameemp=='OUT'){ - // $qryshift="select shiftcategory,idxemployee from tbl_callcenterschedule - // where (cast(datesout as date)=cast('$dates' as date)) and idxemployee='$idxemployee' and isdeleted=0"; - - // } - $rsshift=$this->selectquerySP($qryshift); - $shiftcode="";$limit="limit 1"; - if($rsshift){ - while($rwshift=$rsshift->fetch()){ - $shiftcode.="'".$rwshift['shiftcategory']."',"; - } - if($shiftcode){ - $shiftcode=substr($shiftcode,0,strlen($shiftcode)-1); - } - } - - $swhereshiftcode="and t.shiftcode=''"; - if($shiftcode){ - $swhereshiftcode="and t.shiftcode in($shiftcode)"; - } - - // $qry="select e._idx idxemployee,e.nik,e.employeename,e.fingerid,t.idxdept,t.deptname,t.attendancename,t.starttimestr,t.starttime, - // t.endtimestr,t.endtime,t.thresholdtimestr,t.thresholdtime,t.shiftcode - // from tbl_employee e inner join tbl_attendancethreshold t on e.idxdept=t.idxdept - // where e.isdeleted=0 and t.isdeleted=0 and e.fingerid='".$data['id']."' $swhereshiftcode - // and ('$timestamp'>=t.starttime and '$timestamp'<=t.thresholdtime) - // order by t._idx asc limit 1"; - - $qry="select e._idx idxemployee,e.nik,e.employeename,e.fingerid,t.idxdept,t.deptname,t.attendancename,t.starttimestr,t.starttime, - t.endtimestr,t.endtime,t.thresholdtimestr,t.thresholdtime,t.shiftcode - from tbl_employee e inner join tbl_attendancethreshold t on e.idxdept=t.idxdept - where e.isdeleted=0 and t.isdeleted=0 and e.fingerid='".$data['id']."' $swhereshiftcode - and (unix_timestamp(concat('".($timestampH==0 ? $datesadd1 : $dates)."',' ','$timestampstr'))>=unix_timestamp(concat('$dates',' ',t.starttimestr)) - and unix_timestamp(concat('".($timestampH==0 ? $datesadd1 : $dates)."',' ','$timestampstr'))<=unix_timestamp(concat('".($timestampH==0 ? $datesadd1 : $dates)."',' ',t.thresholdtimestr))) - order by t._idx desc limit 1"; - - } - - if($idxdeptemp==22){ - $qryshift="select shiftcategory,idxemployee from tbl_supervisaoschedule where cast(dates as date)=cast('$dates' as date) and idxemployee='$idxemployee' and isdeleted=0"; - $rsshift=$this->selectquerySP($qryshift); - $shiftcode="";$limit="limit 1"; - if($rsshift){ - while($rwshift=$rsshift->fetch()){ - $shiftcode.="'".$rwshift['shiftcategory']."',"; - } - if($shiftcode){ - $shiftcode=substr($shiftcode,0,strlen($shiftcode)-1); - } - } - - $swhereshiftcode="and t.shiftcode=''"; - if($shiftcode){ - $swhereshiftcode="and t.shiftcode in($shiftcode)"; - } - - // $qry="select e._idx idxemployee,e.nik,e.employeename,e.fingerid,t.idxdept,t.deptname,t.attendancename,t.starttimestr,t.starttime, - // t.endtimestr,t.endtime,t.thresholdtimestr,t.thresholdtime,t.shiftcode - // from tbl_employee e inner join tbl_attendancethreshold t on e.idxdept=t.idxdept - // where e.isdeleted=0 and t.isdeleted=0 and e.fingerid='".$data['id']."' $swhereshiftcode - // and ('$timestamp'>=t.starttime and '$timestamp'<=t.thresholdtime) - // order by t._idx asc limit 1"; - $qry="select e._idx idxemployee,e.nik,e.employeename,e.fingerid,t.idxdept,t.deptname,t.attendancename,t.starttimestr,t.starttime, - t.endtimestr,t.endtime,t.thresholdtimestr,t.thresholdtime,t.shiftcode - from tbl_employee e inner join tbl_attendancethreshold t on e.idxdept=t.idxdept - where e.isdeleted=0 and t.isdeleted=0 and e.fingerid='".$data['id']."' $swhereshiftcode - and (unix_timestamp(concat('".($timestampH==0 ? $datesadd1 : $dates)."',' ','$timestampstr'))>=unix_timestamp(concat('$dates',' ',t.starttimestr)) - and unix_timestamp(concat('".($timestampH==0 ? $datesadd1 : $dates)."',' ','$timestampstr'))<=unix_timestamp(concat('".($timestampH==0 ? $datesadd1 : $dates)."',' ',t.thresholdtimestr))) - order by t._idx desc limit 1"; - - } - - // echo $qry."\n\nnndd"; + $qryduration=""; $rs=$this->selectquerySP($qry); if($rs){ + echo "start time : ".date("Y-m-d H:i:s")."\n"; while($rw=$rs->fetch()){ - $islate=0;$shiftcode=$rw['shiftcode']; - // if($rw['idxdept']==30||$rw['idxdept']==22){ - if((int)$rw['idxdept']==30){ - $qrysc="select distinct t.* - from tbl_attendancethreshold t inner join tbl_callcenterschedule s on t.idxshift=s.idxshift and t.idxdept='".$rw['idxdept']."' - where s.idxemployee='".$rw['idxemployee']."' and t.attendancename='IN' - and cast(s.dates as date)=cast('".date("Y-m-d", strtotime($data['timestamp']))."' as date) - and t.shiftcode='".$rw['shiftcode']."' and t.isdeleted=0 and s.isdeleted=0 order by t._idx desc limit 1"; - $endtimecc=$this->fn_getfieldvalue("endtime",$qrysc); - $endtimestrcc=$this->fn_getfieldvalue("endtimestr",$qrysc); - if($endtimecc){ - if((int)$timestamp>(int)$endtimecc&&$rw['attendancename']=='IN'){ - $date1=strtotime($dates." ".$endtimestrcc); - $date2=strtotime($dates." ".$timestampstr); - $totallateperemp=round(abs($date2 - $date1) / 60,2); - // $totallateperemp=(int)$timestamp-(int)$endtimecc; - $islate=1; - } - if((int)$timestamp>(int)$endtimecc&&$rw['attendancename']=='R2'){ - // $totallateperempr2=(int)$timestamp-(int)$endtimecc; - $date1=strtotime($dates." ".$endtimestrcc); - $date2=strtotime($dates." ".$timestampstr); - $totallateperempr2=round(abs($date2 - $date1) / 60,2); - } - } + $swhereshiftcode=""; + if($rw['shiftcode']&&$rw['idxdept']==22){ + $swhereshiftcode="and shiftcode='".$rw['shiftcode']."'"; } - elseif((int)$rw['idxdept']==22){ - $qrysc="select distinct t.* - from tbl_attendancethreshold t inner join tbl_supervisaoschedule s on t.idxshift=s.idxshift and t.idxdept='".$rw['idxdept']."' - where s.idxemployee='".$rw['idxemployee']."' and t.attendancename='IN' - and cast(s.dates as date)=cast('".date("Y-m-d", strtotime($data['timestamp']))."' as date) - and t.shiftcode='".$rw['shiftcode']."' and t.isdeleted=0 and s.isdeleted=0 order by t._idx desc limit 1"; - $endtimecc=$this->fn_getfieldvalue("endtime",$qrysc); - $endtimeccstr=$this->fn_getfieldvalue("endtimestr",$qrysc); - if($endtimecc){ - if((int)$timestamp>(int)$endtimecc&&$rw['attendancename']=='IN'){ - // $totallateperemp=(int)$timestamp-(int)$endtimecc; - $date1=strtotime($dates." ".$endtimeccstr); - $date2=strtotime($dates." ".$timestampstr); - $totallateperemp=round(abs($date2 - $date1) / 60,2); + if($rw['idxdept']==30){ // === only call center department + if($rw['attendancename']=='IN'){ + $qry="insert into tbl_attendancelist + set idxattendance='".$rw['_idx']."',idxemployee='".$rw['idxemployee']."',nik='".$rw['nik']."', + employeename='".$rw['employeename']."',title='".$rw['title']."',levelname='".$rw['levelname']."', + officename='".$rw['officename']."',idxdept='".$rw['idxdept']."',divisiname='".$rw['divisiname']."', + serviconame='".$rw['serviconame']."',dates='".$rw['dates']."',checkin='".$rw['datestimes']."', + islates='".$rw['islates']."',months='".$rw['months']."',years='".$rw['years']."', + shiftcode='".$rw['shiftcode']."',lateperemployee='".$rw['lateperemployee']."',lateperemployeer2='".$rw['lateperemployeer2']."', + deviceidcheckin='".$rw['deviceidcheckin']."', + iby='svc',idt='".$rw['datestimes']."'"; - $islate=1; + $qrychk="select _idx from tbl_attendancelist + where idxemployee='".$rw['idxemployee']."' and cast(dates as date)=cast('".date("Y-m-d",strtotime($rw['dates']))."' as date) + $swhereshiftcode and isdeleted=0 order by _idx desc limit 1"; + if($this->fn_rowisexists($qrychk)){ + $qry=""; } - if((int)$timestamp>(int)$endtimecc&&$rw['attendancename']=='R2'){ - // $totallateperempr2=(int)$timestamp-(int)$endtimecc; - $date1=strtotime($dates." ".$endtimeccstr); - $date2=strtotime($dates." ".$timestampstr); - $totallateperempr2=round(abs($date2 - $date1) / 60,2); + } + elseif($rw['attendancename']=='OUT'){ + // $qrychk="select _idx from tbl_attendancelist + // where idxemployee='".$rw['idxemployee']."' and cast(dates as date)=date_sub('".date("Y-m-d",strtotime($rw['dates']))."', INTERVAL 1 day) and isdeleted=0 order by _idx desc limit 1"; + $qrychk="select _idx from tbl_attendancelist + where idxemployee='".$rw['idxemployee']."' + and cast(checkin as date)=cast('".date("Y-m-d",strtotime($rw['datestimes']))."' as date) + $swhereshiftcode and (checkout is null) + and isdeleted=0 order by _idx desc limit 1"; + // echo $qrychk;//return false; - + $_idx=$this->fn_getfieldvalue("_idx",$qrychk); + if($_idx){ + $qry="update tbl_attendancelist + set checkout='".$rw['datestimes']."',deviceidcheckout='".$rw['deviceidcheckout']."' + where _idx='$_idx' and UNIX_TIMESTAMP('".date("Y-m-d H:i:s",strtotime($rw['datestimes']))."')>UNIX_TIMESTAMP(checkin)"; + $qryduration="update tbl_attendancelist + set duration=SEC_TO_TIME(TIMESTAMPDIFF(SECOND,checkin,checkout)) + where _idx='$_idx'"; + $qrychk="select _idx from tbl_attendancelist + where cast(checkout as date)=cast('".date("Y-m-d",strtotime($rw['datestimes']))."' as date) + $swhereshiftcode and idxemployee='".$rw['idxemployee']."' and isdeleted=0 + order by _idx desc limit 1"; + if($this->fn_rowisexists($qrychk)){ + $qry="";$qryduration=""; + } } + else{ + // $qrychk="select _idx from tbl_attendancelist + // where idxemployee='".$rw['idxemployee']."' and cast(dates as date)=cast('".date("Y-m-d",strtotime($rw['dates']))."' as date) + // and isdeleted=0 order by _idx desc limit 1"; + $qrychk="select _idx from tbl_attendancelist + where idxemployee='".$rw['idxemployee']."' + and cast(checkin as date)=date_sub('".date("Y-m-d",strtotime($rw['datestimes']))."', INTERVAL 1 day) and checkout is null + $swhereshiftcode and isdeleted=0 order by _idx desc limit 1"; + + // echo $qrychk;return false; + $_idx=$this->fn_getfieldvalue("_idx",$qrychk); + if($_idx){ + $qry="update tbl_attendancelist + set checkout='".$rw['datestimes']."',deviceidcheckout='".$rw['deviceidcheckout']."' + where _idx='$_idx' and (UNIX_TIMESTAMP('".date("Y-m-d H:i:s",strtotime($rw['datestimes']))."')>UNIX_TIMESTAMP(checkin)) and checkout is null"; + // $qry="update tbl_attendancelist set checkout='".$rw['datestimes']."' where _idx='$_idx'"; + $qryduration="update tbl_attendancelist + set duration=SEC_TO_TIME(TIMESTAMPDIFF(SECOND,checkin,checkout)) + where _idx='$_idx'"; + $qrychk="select _idx from tbl_attendancelist + where cast(checkout as date)=cast('".date("Y-m-d",strtotime($rw['datestimes']))."' as date) + $swhereshiftcode and idxemployee='".$rw['idxemployee']."' and isdeleted=0 + order by _idx desc limit 1"; + if($this->fn_rowisexists($qrychk)){ + $qry="";$qryduration=""; + } + + } + } + // echo $qry."\n"; + } + else{ + $qry=""; } - } - elseif((int)$rw['idxdept']==33||(int)$rw['idxdept']==34){ - $qrysc="select distinct t.* - from tbl_attendancethreshold t inner join tbl_lojaschedule s on t.idxshift=s.idxshift and t.idxdept='".$rw['idxdept']."' - where s.idxemployee='".$rw['idxemployee']."' and t.attendancename='IN' - and cast(s.dates as date)=cast('".date("Y-m-d", strtotime($data['timestamp']))."' as date) - and t.shiftcode='".$rw['shiftcode']."' and t.isdeleted=0 and s.isdeleted=0 order by t._idx desc limit 1"; - $endtimecc=$this->fn_getfieldvalue("endtime",$qrysc); - $endtimeccstr=$this->fn_getfieldvalue("endtimestr",$qrysc); - if($endtimecc){ - // if($data['id']=='329'){ - // echo (int)$timestamp." ".$endtimecc." ".$rw['attendancename']."\n"; + if($qry){ + $this->executeSP($qry); + if($qryduration){ + // echo $qryduration."\n"; + $this->executeSP($qryduration); + } + // if($rw['attendancename']=='OUT'){ + // $qry="update tbl_attendancelist set duration='".$rw['datestimes']."' where _idx='$_idx'"; // } - if((int)$timestamp>(int)$endtimecc&&$rw['attendancename']=='IN'){ - // $totallateperemp=(int)$timestamp-(int)$endtimecc; - $date1=strtotime($dates." ".$endtimeccstr); - $date2=strtotime($dates." ".$timestampstr); - $totallateperemp=round(abs($date2 - $date1) / 60,2); - - $islate=1; - } - if((int)$timestamp>(int)$endtimecc&&$rw['attendancename']=='R2'){ - // $totallateperempr2=(int)$timestamp-(int)$endtimecc; - $date1=strtotime($dates." ".$endtimeccstr); - $date2=strtotime($dates." ".$timestampstr); - $totallateperempr2=round(abs($date2 - $date1) / 60,2); - - - } } - } - else{ - if((int)$timestamp>(int)$rw['endtime']&&$rw['attendancename']=='IN'){ - // $totallateperemp=(int)$timestamp-(int)$rw['endtime']; - $date1=strtotime($dates." ".$rw['endtimestr']); - $date2=strtotime($dates." ".$timestampstr); - $totallateperemp=round(abs($date2 - $date1) / 60,2); - - - $islate=1; - } - if((int)$timestamp>(int)$rw['endtime']&&$rw['attendancename']=='R2'){ - // $totallateperempr2=(int)$timestamp-(int)$rw['endtime']; - $date1=strtotime($dates." ".$rw['endtimestr']); - $date2=strtotime($dates." ".$timestampstr); - $totallateperempr2=round(abs($date2 - $date1) / 60,2); - - - } - } - // $qryexists="select _idx,deviceid,deviceidcheckout from tbl_attendanceemployee - // where trim(fingerid)=trim('".$data['id']."') and cast(dates as date)=cast('".date("Y-m-d", strtotime($data['timestamp']))."' as date) - // and isdeleted=0 and attendancename='".$rw['attendancename']."' - // order by _idx asc limit 1"; - // $idx=$this->fn_getfieldvalue("_idx",$qryexists); - $qryexists="select _idx,deviceid,deviceidcheckout,datestimes from tbl_attendanceemployee - where trim(fingerid)=trim('".$data['id']."') and cast(dates as date)=cast('".date("Y-m-d", strtotime($data['timestamp']))."' as date) - and isdeleted=0 and attendancename='".$rw['attendancename']."' and shiftcode='".$rw['shiftcode']."' - order by _idx asc limit 1"; - $sp=$this->fn_getfieldsvalues("_idx,deviceid,deviceidcheckout,datestimes",$qryexists); - //$idx=$sp[0];$deviceidcheckin=$sp[1];$deviceidcheckout=$sp[2]; - $idx=(isset($sp[0]) ? $sp[0] : 0);$deviceidcheckin=(isset($sp[1]) ? $sp[1] : ''); - $deviceidcheckout=(isset($sp[2]) ? $sp[2] : ''); - $timesexists=(isset($sp[3]) ? (int)date("Hi",strtotime($sp[3])) : 0); - $timesexistsstr=(isset($sp[3]) ? date("H:i",strtotime($sp[3])) : 0); - // echo $idx." ".$deviceidcheckin." ".$deviceidcheckout."\n";return false; - - // $deviceidcheckin="";$deviceidcheckout=""; - // $qry="select deviceid from tbl_deviceinfo where trim(deviceip)=trim('$ip') and isdeleted=0 order by _idx desc limit 1"; - // $deviceid=$this->fn_getfieldvalue("deviceid",$qry); - - if($idx){ - $islate=0; - if((int)$timesexists>(int)$rw['endtime']&&$rw['attendancename']=='IN'){ - // $totallateperemp=(int)$timesexists-(int)$rw['endtime']; - $date1=strtotime($dates." ".$rw['endtimestr']); - $date2=strtotime($dates." ".$timesexistsstr); - $totallateperemp=round(abs($date2 - $date1) / 60,2); - - $islate=1; - } - if((int)$timesexists>(int)$rw['endtime']&&$rw['attendancename']=='R2'){ - // $totallateperempr2=(int)$timesexists-(int)$rw['endtime']; - $date1=strtotime($dates." ".$rw['endtimestr']); - $date2=strtotime($dates." ".$timesexistsstr); - $totallateperempr2=round(abs($date2 - $date1) / 60,2); - - } - - if(!$totallateperemp){$totallateperemp=0;} - if(!$totallateperempr2){$totallateperempr2=0;} - // $qry="update tbl_attendanceemployee - // set udt=now(),islates='$islate',totallateperemp='$totallateperemp' - // where _idx='$idx' and deviceid<>'MANUAL'"; - $qry="update tbl_attendanceemployee - set udt=now(),islates='$islate',totallateperemp='$totallateperemp',totallateperempr2='$totallateperempr2' - where _idx='$idx' and deviceid<>'MANUAL'"; } - else{ - // if(!$deviceidcheckin||is_null($deviceidcheckin)){$deviceidcheckin=$deviceid;} + else{ // === Non call center dept + if($rw['attendancename']=='IN'){$attfield="checkin='".$rw['datestimes']."',";} + if($rw['attendancename']=='R1'){$attfield="R1='".$rw['datestimes']."',";} + if($rw['attendancename']=='R2'){$attfield="R2='".$rw['datestimes']."',lateperemployeer2='".$rw['lateperemployeer2']."',";} + if($rw['attendancename']=='OUT'){$attfield="checkout='".$rw['datestimes']."',";} - // $swheredeviceid="deviceid='".$deviceid."',"; - // if($rw['attendancename']=='OUT'){ - // if(!$deviceidcheckout||is_null($deviceidcheckout)){$deviceidcheckout=$deviceid;} - // $swheredeviceid="deviceidcheckout='".$deviceidcheckout."',"; - // // ==== Get Device ID Checkin - // $qrygetdevicecheckin="select deviceid from tbl_attendanceemployee - // where idxemployee='".$rw['idxemployee']."' and attendancename='IN' - // and cast(dates as date)=cast('".date("Y-m-d", strtotime($data['timestamp']))."' as date) - // order by _idx desc limit 1"; - // $deviceidcheckin=$this->fn_getfieldvalue("deviceid",$qrygetdevicecheckin); - // } - $swheredeviceid=""; - $qry="insert into tbl_attendanceemployee - set fingerid='".$data['id']."',fingerip='".$ip."',".$swheredeviceid."idxemployee='".$rw['idxemployee']."', - nik='".$rw['nik']."',employeename='".$rw['employeename']."',dates='".date("Y-m-d", strtotime($data['timestamp']))."', - times='".date("H:i:s", strtotime($data['timestamp']))."',datestimes='$datestimes',attendancename='".$rw['attendancename']."',thresholdtime='".$rw['thresholdtime']."', - thresholdtimestr='".$rw['thresholdtimestr']."',endtime='".$rw['endtime']."',shiftcode='".$shiftcode."',totallateperemp='$totallateperemp',months='$months',years='$years',islates='$islate',iby='".$rw['nik']."',idt=now()"; + $qry="insert into tbl_attendancelist + set idxattendance='".$rw['_idx']."',idxemployee='".$rw['idxemployee']."',nik='".$rw['nik']."', + employeename='".$rw['employeename']."',title='".$rw['title']."',levelname='".$rw['levelname']."', + officename='".$rw['officename']."',idxdept='".$rw['idxdept']."',divisiname='".$rw['divisiname']."', + serviconame='".$rw['serviconame']."',dates='".$rw['dates']."',".$attfield." + islates='".$rw['islates']."',months='".$rw['months']."',years='".$rw['years']."', + shiftcode='".$rw['shiftcode']."',lateperemployee='".$rw['lateperemployee']."',lateperemployeer2='".$rw['lateperemployeer2']."', + deviceidcheckin='".$rw['deviceidcheckin']."', + iby='svc',idt='".$rw['datestimes']."'"; + $qrychk="select _idx,checkin,checkout,lateperemployee from tbl_attendancelist + where idxemployee='".$rw['idxemployee']."' and cast(dates as date)=cast('".date("Y-m-d",strtotime($rw['dates']))."' as date) + $swhereshiftcode and isdeleted=0 order by _idx desc limit 1"; + if($this->fn_rowisexists($qrychk)){ + // $_idx=$this->fn_getfieldvalue("_idx",$qrychk); + $sp=$this->fn_getfieldsvalues("_idx,checkin,checkout,lateperemployee", $qrychk); + $_idx=$sp[0];$checkin=$sp[1];$checkout=$sp[2];$lateperemployee=$sp[3]; + $laterperemployeefield=""; + + // if(!$lateperemployee){ + // $laterperemployeefield="lateperemployee='".$rw['lateperemployee']."',"; + // } + + $qry="update tbl_attendancelist + set ".$attfield.$laterperemployeefield."uby='svc',udt='".$rw['datestimes']."' + where _idx='$_idx'"; + if($rw['attendancename']=='IN'&&$checkin!=null){ + $qry="update tbl_attendancelist + set uby='svc',udt='".$rw['datestimes']."' + where _idx='$_idx'"; + } + if($rw['attendancename']=='OUT'){ + $qry="update tbl_attendancelist + set ".$attfield."uby='svc',udt='".$rw['datestimes']."',deviceidcheckout='".$rw['deviceidcheckout']."' + where _idx='$_idx' and UNIX_TIMESTAMP('".date("Y-m-d H:i:s",strtotime($rw['datestimes']))."')>UNIX_TIMESTAMP(checkin)"; + + $idxdept=$rw['idxdept']; + if($idxdept==33||$idxdept==34||$idxdept==30||$idxdept==22){ + $qryduration="update tbl_attendancelist + set duration=SEC_TO_TIME(TIMESTAMPDIFF(SECOND,checkin,checkout)) + where _idx='$_idx'"; + } + else{ + $qryduration="update tbl_attendancelist + set duration=SEC_TO_TIME(TIMESTAMPDIFF(SECOND,checkin,R1)+TIMESTAMPDIFF(SECOND,R2,checkout)) + where _idx='$_idx'"; + + } + } + } + + if($qry){ + $this->executeSP($qry); + if($qryduration){ + // echo $qryduration."\n"; + $this->executeSP($qryduration); + } + } } - // echo $qry."\n"; - // if($deviceid=='172.16.110.251'){ - //echo $qry."\n"; - // } - if($this->executeSP($qry)){ - // if($rw['attendancename']=='OUT'){ - // $qry="update tbl_attendanceemployee set deviceid='$deviceidcheckin',deviceidcheckout='$deviceidcheckout' - // where trim(fingerid)=trim('".$data['id']."') and cast(dates as date)=cast('".date("Y-m-d", strtotime($data['timestamp']))."' as date) - // and isdeleted=0"; - // //$this->executeSP($qry); - // } - $rtn=true; - } - } + + echo "end time : ".date("Y-m-d H:i:s")."\n"; } - + $rtn=true; return $rtn; } - - public function fn_curl() - { - $url="http://localhost/tthcm/getdatadevices.php?isgetdata=1"; - $method="GET"; - $contenttype="application/json"; - // $data=array("") - $ch = curl_init(); - curl_setopt($ch, CURLOPT_URL, $url); - curl_setopt($ch, CURLOPT_USERAGENT, "Mozilla/5.0 (Windows NT 6.1; WOW64; rv:43.0) Gecko/20100101 Firefox/43.0"); - // if($method=='POST')curl_setopt($ch, CURLOPT_POST, true); - if ($method == 'POST' || $method == 'PUT') curl_setopt($ch, CURLOPT_POST, true); - if ($method == 'DELETE') curl_setopt($ch, CURLOPT_CUSTOMREQUEST, 'DELETE'); - if ($method == 'GET') curl_setopt($ch, CURLOPT_CUSTOMREQUEST, 'GET'); - // if($data)curl_setopt($ch, CURLOPT_POSTFIELDS, json_encode($data)); - // curl_setopt($ch, CURLOPT_POSTFIELDS, http_build_query($data)); - // curl_setopt($ch, CURLOPT_POSTFIELDS, json_encode($data)); - curl_setopt($ch, CURLOPT_RETURNTRANSFER, true); - curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, FALSE); - curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, FALSE); - curl_setopt($ch, CURLOPT_HTTPHEADER, array( - 'Content-Type: ' . $contenttype, - 'x-token: ' - )); - - $res = curl_exec($ch); - curl_close($ch); - return $res; - // $arr = json_decode($res, true); - // return $arr; - } } $cl = new LogController(); diff --git a/getdatadevicesbylogsbydates.php b/getdatadevicesbylogsbydates.php new file mode 100644 index 0000000..00cda81 --- /dev/null +++ b/getdatadevicesbylogsbydates.php @@ -0,0 +1,718 @@ + +fn_getconn(); //new PDO("mysql:host=localhost;dbname=dbhcm", "apphcm", "\$pp"); + $q = $pdo->query($sql); + $q->setFetchMode(PDO::FETCH_ASSOC); + return $q; + } + + public function executeSP($qry){ + $rtn=false; + $pdo = $this->fn_getconn(); + $statement = $pdo->prepare($qry); + if($statement->execute()){ + $rtn=true; + } + return $rtn; + } + + public function fn_getfieldvalue($fieldname,$qry){ + $rs=$this->selectquerySP($qry); + $rtn=""; + if($rs){ + // $rw=$rs->fetch(); + // $rtn=$rw[$fieldname]; + while($rw=$rs->fetch()){ + $rtn=$rw[$fieldname]; + } + } + return $rtn; + } + + public function fn_getfieldsvalues($fieldname,$qry){ + $rs=$this->selectquerySP($qry); + $rtn=""; + if($rs){ + // $rw=$rs->fetch(); + // $rtn=$rw[$fieldname]; + while($rw=$rs->fetch()){ + $d=explode(",",$fieldname); + for($i=0;$iselectquerySP($qry); + $rtn=false; + if($rs){ + // $rw=$rs->fetch(); + // $rtn=$rw[$fieldname]; + while($rw=$rs->fetch()){ + $rtn=true; + } + } + return $rtn; + } + + + public function index(){ + $argv=$_SERVER['argv']; + // echo $argv[1];return false; + $qry="select * from tbl_attendancelogs + where cast(dates as date)=cast('".$argv[1]."' as date) + order by _idx asc"; + $rs=$this->selectquerySP($qry); + if($rs){ + $d=array(); + while($rw=$rs->fetch()){ + $d['timestamp']=date("Y-m-d H:i:s", strtotime($rw['dates'].' '.$rw['times'])); + $d['id']=$rw['fingerid']; + $res=$this->fn_setattendance($d, $rw['deviceip']); + + } + } + + } + + public function fn_setattendance($data, $ip){ + $rtn=false; + $months=(int)date("m", strtotime($data['timestamp'])); + $years=(int)date("Y", strtotime($data['timestamp'])); + $timestamp=(int)date("Hi", strtotime($data['timestamp'])); + $timestampH=(int)date("H", strtotime($data['timestamp'])); + $timestampstr=date("H:i", strtotime($data['timestamp'])); + $datestimes=date("Y-m-d H:i:s", strtotime($data['timestamp'])); + $dates=date("Y-m-d", strtotime($data['timestamp'])); + $datesadd1=date("Y-m-d", strtotime($data['timestamp'].' +1 day')); + $totallateperemp=0; + $totallateperempr2=0; + $swhereshift=""; + $qry="select e._idx idxemployee,e.nik,e.employeename,e.fingerid,t.idxdept,t.deptname,t.attendancename,t.starttimestr,t.starttime, + t.endtimestr,t.endtime,t.thresholdtimestr,t.thresholdtime,t.shiftcode + from tbl_employee e inner join tbl_attendancethreshold t on e.idxdept=t.idxdept + where e.isdeleted=0 and t.isdeleted=0 and e.fingerid='".$data['id']."' + and ('$timestamp'>=t.starttime and '$timestamp'<=t.thresholdtime) + order by t._idx asc limit 1"; + // echo $qry;return false; + + if($timestamp>2300){ + $timestampH=0; + $qry="select e._idx idxemployee,e.nik,e.employeename,e.fingerid,t.idxdept,t.deptname,t.attendancename,t.starttimestr,t.starttime, + t.endtimestr,t.endtime,t.thresholdtimestr,t.thresholdtime,t.shiftcode + from tbl_employee e inner join tbl_attendancethreshold t on e.idxdept=t.idxdept + where e.isdeleted=0 and t.isdeleted=0 and e.fingerid='".$data['id']."' + and (unix_timestamp(concat('".$dates."',' ','$timestampstr'))>=unix_timestamp(concat('$dates',' ',t.starttimestr)) + and unix_timestamp(concat('".$dates."',' ','$timestampstr'))<=unix_timestamp(concat('".$datesadd1."',' ',t.thresholdtimestr))) + order by t._idx desc limit 1"; + + } + + // if($data['id']==78){ + // echo $qry."\n\n"; + // } + // echo $qry;return false; + $sp=$this->fn_getfieldsvalues("idxdept,idxemployee,attendancename", $qry); + //$idxdeptemp=$sp[0];$idxemployee=$sp[1]; + $idxdeptemp=(isset($sp[0]) ? $sp[0] : 0);$idxemployee=(isset($sp[1]) ? $sp[1] : 0); + $attendancenameemp=(isset($sp[2]) ? $sp[2] : ''); + if($idxdeptemp==33||$idxdeptemp==34){ + // $sp=$this->fn_getfieldsvalues("shiftcategory,idxemployee","select shiftcategory,idxemployee from tbl_lojaschedule where cast(dates as date)=cast('$dates' as date) and idxemployee='$idxemployee' and isdeleted=0"); + // $shiftcode=(isset($sp[0]) ? $sp[0] : "");$idxemployee=(isset($sp[1]) ? $sp[1] : 0); + // $qry="select e._idx idxemployee,e.nik,e.employeename,e.fingerid,t.idxdept,t.deptname,t.attendancename,t.starttimestr,t.starttime, + // t.endtimestr,t.endtime,t.thresholdtimestr,t.thresholdtime,t.shiftcode + // from tbl_employee e inner join tbl_attendancethreshold t on e.idxdept=t.idxdept + // where e.isdeleted=0 and t.isdeleted=0 and e.fingerid='".$data['id']."' and t.shiftcode='$shiftcode' + // and ('$timestamp'>=t.starttime and '$timestamp'<=t.thresholdtime) + // order by t._idx asc limit 1"; + $qryshift="select shiftcategory,idxemployee from tbl_lojaschedule where cast(dates as date)=cast('$dates' as date) and idxemployee='$idxemployee' and isdeleted=0"; + $rsshift=$this->selectquerySP($qryshift); + $shiftcode="";$limit="limit 1"; + if($rsshift){ + while($rwshift=$rsshift->fetch()){ + $shiftcode.="'".$rwshift['shiftcategory']."',"; + } + if($shiftcode){ + $shiftcode=substr($shiftcode,0,strlen($shiftcode)-1); + } + } + + $swhereshiftcode="and t.shiftcode=''"; + if($shiftcode){ + $swhereshiftcode="and t.shiftcode in($shiftcode)"; + } + + $qry="select e._idx idxemployee,e.nik,e.employeename,e.fingerid,t.idxdept,t.deptname,t.attendancename,t.starttimestr,t.starttime, + t.endtimestr,t.endtime,t.thresholdtimestr,t.thresholdtime,t.shiftcode + from tbl_employee e inner join tbl_attendancethreshold t on e.idxdept=t.idxdept + where e.isdeleted=0 and t.isdeleted=0 and e.fingerid='".$data['id']."' $swhereshiftcode + and ('$timestamp'>=t.starttime and '$timestamp'<=t.thresholdtime) + order by t._idx asc limit 1"; + if($timestamp>=2300){ + $timestampH=0; + $qry="select e._idx idxemployee,e.nik,e.employeename,e.fingerid,t.idxdept,t.deptname,t.attendancename,t.starttimestr,t.starttime, + t.endtimestr,t.endtime,t.thresholdtimestr,t.thresholdtime,t.shiftcode + from tbl_employee e inner join tbl_attendancethreshold t on e.idxdept=t.idxdept + where e.isdeleted=0 and t.isdeleted=0 and e.fingerid='".$data['id']."' $swhereshiftcode + and (unix_timestamp(concat('".$dates."',' ','$timestampstr'))>=unix_timestamp(concat('$dates',' ',t.starttimestr)) + and unix_timestamp(concat('".$dates."',' ','$timestampstr'))<=unix_timestamp(concat('".$datesadd1."',' ',t.thresholdtimestr))) + order by t._idx desc limit 1"; + } + } + + if($idxdeptemp==30){ + // $sp=$this->fn_getfieldsvalues("shiftcategory,idxemployee","select shiftcategory,idxemployee from tbl_callcenterschedule where cast(dates as date)=cast('$dates' as date) and idxemployee='$idxemployee' and isdeleted=0"); + // $shiftcode=(isset($sp[0]) ? $sp[0] : "");$idxemployee=(isset($sp[1]) ? $sp[1] : 0); + // $qry="select e._idx idxemployee,e.nik,e.employeename,e.fingerid,t.idxdept,t.deptname,t.attendancename,t.starttimestr,t.starttime, + // t.endtimestr,t.endtime,t.thresholdtimestr,t.thresholdtime,t.shiftcode + // from tbl_employee e inner join tbl_attendancethreshold t on e.idxdept=t.idxdept + // where e.isdeleted=0 and t.isdeleted=0 and e.fingerid='".$data['id']."' and t.shiftcode='$shiftcode' + // and ('$timestamp'>=t.starttime and '$timestamp'<=t.thresholdtime) + // order by t._idx asc limit 1"; + $qryshift="select shiftcategory,idxemployee from tbl_callcenterschedule + where (cast(dates as date)=cast('$dates' as date) or cast(datesout as date)=cast('$dates' as date)) and idxemployee='$idxemployee' and isdeleted=0"; + // echo $qryshift;return false; + // if($idxemployee==115){ + // echo $qryshift."\n"; + // } + // if($attendancenameemp=='OUT'){ + // $qryshift="select shiftcategory,idxemployee from tbl_callcenterschedule + // where (cast(datesout as date)=cast('$dates' as date)) and idxemployee='$idxemployee' and isdeleted=0"; + + // } + $rsshift=$this->selectquerySP($qryshift); + $shiftcode="";$limit="limit 1"; + if($rsshift){ + while($rwshift=$rsshift->fetch()){ + $shiftcode.="'".$rwshift['shiftcategory']."',"; + } + if($shiftcode){ + $shiftcode=substr($shiftcode,0,strlen($shiftcode)-1); + } + } + + $swhereshiftcode="and t.shiftcode=''"; + if($shiftcode){ + $swhereshiftcode="and t.shiftcode in($shiftcode)"; + } + + $qry="select e._idx idxemployee,e.nik,e.employeename,e.fingerid,t.idxdept,t.deptname,t.attendancename,t.starttimestr,t.starttime, + t.endtimestr,t.endtime,t.thresholdtimestr,t.thresholdtime,t.shiftcode + from tbl_employee e inner join tbl_attendancethreshold t on e.idxdept=t.idxdept + where e.isdeleted=0 and t.isdeleted=0 and e.fingerid='".$data['id']."' $swhereshiftcode + and ('$timestamp'>=t.starttime and '$timestamp'<=t.thresholdtime) + order by t._idx asc limit 1"; + // echo $qry."\n";return false; + if($timestamp>=2300){ + $timestampH=0; + $qry="select e._idx idxemployee,e.nik,e.employeename,e.fingerid,t.idxdept,t.deptname,t.attendancename,t.starttimestr,t.starttime, + t.endtimestr,t.endtime,t.thresholdtimestr,t.thresholdtime,t.shiftcode + from tbl_employee e inner join tbl_attendancethreshold t on e.idxdept=t.idxdept + where e.isdeleted=0 and t.isdeleted=0 and e.fingerid='".$data['id']."' $swhereshiftcode + and (unix_timestamp(concat('".$dates."',' ','$timestampstr'))>=unix_timestamp(concat('$dates',' ',t.starttimestr)) + and unix_timestamp(concat('".$dates."',' ','$timestampstr'))<=unix_timestamp(concat('".$datesadd1."',' ',t.thresholdtimestr))) + + order by t._idx desc limit 1"; + } + + // if($idxemployee==115){ + // echo $qry."\n"; + // } + } + + if($idxdeptemp==22){ + $qryshift="select shiftcategory,idxemployee from tbl_supervisaoschedule where cast(dates as date)=cast('$dates' as date) and idxemployee='$idxemployee' and isdeleted=0"; + $rsshift=$this->selectquerySP($qryshift); + $shiftcode="";$limit="limit 1"; + if($rsshift){ + while($rwshift=$rsshift->fetch()){ + $shiftcode.="'".$rwshift['shiftcategory']."',"; + } + if($shiftcode){ + $shiftcode=substr($shiftcode,0,strlen($shiftcode)-1); + } + } + + $swhereshiftcode="and t.shiftcode=''"; + if($shiftcode){ + $swhereshiftcode="and t.shiftcode in($shiftcode)"; + } + + // $qry="select e._idx idxemployee,e.nik,e.employeename,e.fingerid,t.idxdept,t.deptname,t.attendancename,t.starttimestr,t.starttime, + // t.endtimestr,t.endtime,t.thresholdtimestr,t.thresholdtime,t.shiftcode + // from tbl_employee e inner join tbl_attendancethreshold t on e.idxdept=t.idxdept + // where e.isdeleted=0 and t.isdeleted=0 and e.fingerid='".$data['id']."' $swhereshiftcode + // and ('$timestamp'>=t.starttime and '$timestamp'<=t.thresholdtime) + // order by t._idx asc limit 1"; + $qry="select e._idx idxemployee,e.nik,e.employeename,e.fingerid,t.idxdept,t.deptname,t.attendancename,t.starttimestr,t.starttime, + t.endtimestr,t.endtime,t.thresholdtimestr,t.thresholdtime,t.shiftcode + from tbl_employee e inner join tbl_attendancethreshold t on e.idxdept=t.idxdept + where e.isdeleted=0 and t.isdeleted=0 and e.fingerid='".$data['id']."' $swhereshiftcode + and ('$timestamp'>=t.starttime and '$timestamp'<=t.thresholdtime) + order by t.idxshift desc limit 1"; + if($timestamp>=2300){ + $timestampH=0; + // $qry="select e._idx idxemployee,e.nik,e.employeename,e.fingerid,t.idxdept,t.deptname,t.attendancename,t.starttimestr,t.starttime, + // t.endtimestr,t.endtime,t.thresholdtimestr,t.thresholdtime,t.shiftcode + // from tbl_employee e inner join tbl_attendancethreshold t on e.idxdept=t.idxdept + // where e.isdeleted=0 and t.isdeleted=0 and e.fingerid='".$data['id']."' $swhereshiftcode + // and (unix_timestamp(concat('".$dates."',' ','$timestampstr'))>=unix_timestamp(concat('$dates',' ',t.starttimestr)) + // and unix_timestamp(concat('".$dates."',' ','$timestampstr'))<=unix_timestamp(concat('".$datesadd1."',' ',t.thresholdtimestr))) + // order by t._idx desc limit 1"; + $qry="select e._idx idxemployee,e.nik,e.employeename,e.fingerid,t.idxdept,t.deptname,t.attendancename,t.starttimestr,t.starttime, + t.endtimestr,t.endtime,t.thresholdtimestr,t.thresholdtime,t.shiftcode + from tbl_employee e inner join tbl_attendancethreshold t on e.idxdept=t.idxdept + where e.isdeleted=0 and t.isdeleted=0 and e.fingerid='".$data['id']."' $swhereshiftcode + and (unix_timestamp(concat('".$dates."',' ','$timestampstr'))>=unix_timestamp(concat('$dates',' ',t.starttimestr)) + and unix_timestamp(concat('".$dates."',' ','$timestampstr'))<=unix_timestamp(concat('".$datesadd1."',' ',t.thresholdtimestr))) + order by t.idxshift desc limit 1"; + } + + } + + // echo $qry."\n\nnndd"; + $rs=$this->selectquerySP($qry); + if($rs){ + while($rw=$rs->fetch()){ + $islate=0;$shiftcode=$rw['shiftcode']; + // if($rw['idxdept']==30||$rw['idxdept']==22){ + if((int)$rw['idxdept']==30){ + $qrysc="select distinct t.* + from tbl_attendancethreshold t inner join tbl_callcenterschedule s on t.idxshift=s.idxshift and t.idxdept='".$rw['idxdept']."' + where s.idxemployee='".$rw['idxemployee']."' and t.attendancename='IN' + and cast(s.dates as date)=cast('".date("Y-m-d", strtotime($data['timestamp']))."' as date) + and t.shiftcode='".$rw['shiftcode']."' and t.isdeleted=0 and s.isdeleted=0 order by t._idx desc limit 1"; + // echo $qrysc."\n";return false; + $endtimecc=$this->fn_getfieldvalue("endtime",$qrysc); + $endtimestrcc=$this->fn_getfieldvalue("endtimestr",$qrysc); + if($endtimecc){ + if((int)$timestamp>(int)$endtimecc&&$rw['attendancename']=='IN'){ + $date1=strtotime($dates." ".$endtimestrcc); + $date2=strtotime($dates." ".$timestampstr); + $totallateperemp=round(abs($date2 - $date1) / 60,2); + // $totallateperemp=(int)$timestamp-(int)$endtimecc; + $islate=1; + } + if((int)$timestamp>(int)$endtimecc&&$rw['attendancename']=='R2'){ + // $totallateperempr2=(int)$timestamp-(int)$endtimecc; + $date1=strtotime($dates." ".$endtimestrcc); + $date2=strtotime($dates." ".$timestampstr); + if($date2>$date1){ + $totallateperempr2=round(abs($date2 - $date1) / 60,2); + } + } + } + } + elseif((int)$rw['idxdept']==22){ + // $qrysc="select distinct t.* + // from tbl_attendancethreshold t inner join tbl_supervisaoschedule s on t.idxshift=s.idxshift and t.idxdept='".$rw['idxdept']."' + // where s.idxemployee='".$rw['idxemployee']."' and t.attendancename='".$rw['attendancename']."' + // and cast(s.dates as date)=cast('".date("Y-m-d", strtotime($data['timestamp']))."' as date) + // and t.shiftcode='".$rw['shiftcode']."' and t.isdeleted=0 and s.isdeleted=0 order by t._idx desc limit 1"; + $qrysc="select distinct t.* + from tbl_attendancethreshold t inner join tbl_supervisaoschedule s on t.idxshift=s.idxshift and t.idxdept='".$rw['idxdept']."' + where s.idxemployee='".$rw['idxemployee']."' and t.attendancename='".$rw['attendancename']."' + and cast(s.dates as date)=cast('".date("Y-m-d", strtotime($data['timestamp']))."' as date) + $swhereshiftcode and t.isdeleted=0 and s.isdeleted=0 order by t.idxshift desc limit 1"; + $endtimecc=$this->fn_getfieldvalue("endtime",$qrysc); + $endtimeccstr=$this->fn_getfieldvalue("endtimestr",$qrysc); + if($endtimecc){ + if((int)$timestamp>(int)$endtimecc&&$rw['attendancename']=='IN'){ + // $totallateperemp=(int)$timestamp-(int)$endtimecc; + $date1=strtotime($dates." ".$endtimeccstr); + $date2=strtotime($dates." ".$timestampstr); + if($date2>$date1){ + $totallateperempr2=round(abs($date2 - $date1) / 60,2); + } + + $islate=1; + } + if((int)$timestamp>(int)$endtimecc&&$rw['attendancename']=='R2'){ + // $totallateperempr2=(int)$timestamp-(int)$endtimecc; + $date1=strtotime($dates." ".$endtimeccstr); + $date2=strtotime($dates." ".$timestampstr); + if($date2>$date1){ + $totallateperempr2=round(abs($date2 - $date1) / 60,2); + } + + + } + } + } + elseif((int)$rw['idxdept']==33||(int)$rw['idxdept']==34){ + $qrysc="select distinct t.* + from tbl_attendancethreshold t inner join tbl_lojaschedule s on t.idxshift=s.idxshift and t.idxdept='".$rw['idxdept']."' + where s.idxemployee='".$rw['idxemployee']."' and t.attendancename='IN' + and cast(s.dates as date)=cast('".date("Y-m-d", strtotime($data['timestamp']))."' as date) + and t.shiftcode='".$rw['shiftcode']."' and t.isdeleted=0 and s.isdeleted=0 order by t._idx desc limit 1"; + $endtimecc=$this->fn_getfieldvalue("endtime",$qrysc); + $endtimeccstr=$this->fn_getfieldvalue("endtimestr",$qrysc); + if($endtimecc){ + // if($data['id']=='329'){ + // echo (int)$timestamp." ".$endtimecc." ".$rw['attendancename']."\n"; + // } + if((int)$timestamp>(int)$endtimecc&&$rw['attendancename']=='IN'){ + // $totallateperemp=(int)$timestamp-(int)$endtimecc; + $date1=strtotime($dates." ".$endtimeccstr); + $date2=strtotime($dates." ".$timestampstr); + $totallateperemp=round(abs($date2 - $date1) / 60,2); + + $islate=1; + } + if((int)$timestamp>(int)$endtimecc&&$rw['attendancename']=='R2'){ + // $totallateperempr2=(int)$timestamp-(int)$endtimecc; + $date1=strtotime($dates." ".$endtimeccstr); + $date2=strtotime($dates." ".$timestampstr); + $totallateperempr2=round(abs($date2 - $date1) / 60,2); + + + } + } + } + else{ + if((int)$timestamp>(int)$rw['endtime']&&$rw['attendancename']=='IN'){ + // $totallateperemp=(int)$timestamp-(int)$rw['endtime']; + $date1=strtotime($dates." ".$rw['endtimestr']); + $date2=strtotime($dates." ".$timestampstr); + $totallateperemp=round(abs($date2 - $date1) / 60,2); + + + $islate=1; + } + if((int)$timestamp>(int)$rw['endtime']&&$rw['attendancename']=='R2'){ + // $totallateperempr2=(int)$timestamp-(int)$rw['endtime']; + $date1=strtotime($dates." ".$rw['endtimestr']); + $date2=strtotime($dates." ".$timestampstr); + if($date2>$date1){ + $totallateperempr2=round(abs($date2 - $date1) / 60,2); + } + + + } + } + // $qryexists="select _idx,deviceid,deviceidcheckout from tbl_attendanceemployee + // where trim(fingerid)=trim('".$data['id']."') and cast(dates as date)=cast('".date("Y-m-d", strtotime($data['timestamp']))."' as date) + // and isdeleted=0 and attendancename='".$rw['attendancename']."' + // order by _idx asc limit 1"; + // $idx=$this->fn_getfieldvalue("_idx",$qryexists); + $qryexists="select _idx,deviceid,deviceidcheckout,datestimes from tbl_attendanceemployee + where trim(fingerid)=trim('".$data['id']."') and cast(dates as date)=cast('".date("Y-m-d", strtotime($data['timestamp']))."' as date) + and isdeleted=0 and attendancename='".$rw['attendancename']."' and shiftcode='".$rw['shiftcode']."' + order by _idx asc limit 1"; + // echo $qryexists."\n";return false; + $sp=$this->fn_getfieldsvalues("_idx,deviceid,deviceidcheckout,datestimes",$qryexists); + //$idx=$sp[0];$deviceidcheckin=$sp[1];$deviceidcheckout=$sp[2]; + $idx=(isset($sp[0]) ? $sp[0] : 0);$deviceidcheckin=(isset($sp[1]) ? $sp[1] : ''); + $deviceidcheckout=(isset($sp[2]) ? $sp[2] : ''); + $timesexists=(isset($sp[3]) ? (int)date("Hi",strtotime($sp[3])) : 0); + $timesexistsstr=(isset($sp[3]) ? date("H:i",strtotime($sp[3])) : 0); + // echo $idx." ".$deviceidcheckin." ".$deviceidcheckout."\n";return false; + + // $deviceidcheckin="";$deviceidcheckout=""; + // $qry="select deviceid from tbl_deviceinfo where trim(deviceip)=trim('$ip') and isdeleted=0 order by _idx desc limit 1"; + // $deviceid=$this->fn_getfieldvalue("deviceid",$qry); + + if($idx){ + $islate=0; + if((int)$timesexists>(int)$rw['endtime']&&$rw['attendancename']=='IN'){ + // $totallateperemp=(int)$timesexists-(int)$rw['endtime']; + $date1=strtotime($dates." ".$rw['endtimestr']); + $date2=strtotime($dates." ".$timesexistsstr); + $totallateperemp=round(abs($date2 - $date1) / 60,2); + + $islate=1; + } + if((int)$timesexists>(int)$rw['endtime']&&$rw['attendancename']=='R2'){ + // $totallateperempr2=(int)$timesexists-(int)$rw['endtime']; + $date1=strtotime($dates." ".$rw['endtimestr']); + $date2=strtotime($dates." ".$timesexistsstr); + if($date2>$date1){ + $totallateperempr2=round(abs($date2 - $date1) / 60,2); + } + + + } + + if(!$totallateperemp){$totallateperemp=0;} + if(!$totallateperempr2){$totallateperempr2=0;} + + // $qry="update tbl_attendanceemployee + // set udt=now(),islates='$islate',totallateperemp='$totallateperemp' + // where _idx='$idx' and deviceid<>'MANUAL'"; + // $qry="update tbl_attendanceemployee + // set udt=now(),islates='$islate',totallateperemp='$totallateperemp',totallateperempr2='$totallateperempr2' + // where _idx='$idx' and deviceid<>'MANUAL'"; + $qry="update tbl_attendanceemployee + set udt=now(),islates='$islate' + where _idx='$idx' and deviceid<>'MANUAL'"; + // echo $qry."\n";return false; + } + else{ + // if(!$deviceidcheckin||is_null($deviceidcheckin)){$deviceidcheckin=$deviceid;} + + // $swheredeviceid="deviceid='".$deviceid."',"; + // if($rw['attendancename']=='OUT'){ + // if(!$deviceidcheckout||is_null($deviceidcheckout)){$deviceidcheckout=$deviceid;} + // $swheredeviceid="deviceidcheckout='".$deviceidcheckout."',"; + // // ==== Get Device ID Checkin + // $qrygetdevicecheckin="select deviceid from tbl_attendanceemployee + // where idxemployee='".$rw['idxemployee']."' and attendancename='IN' + // and cast(dates as date)=cast('".date("Y-m-d", strtotime($data['timestamp']))."' as date) + // order by _idx desc limit 1"; + // $deviceidcheckin=$this->fn_getfieldvalue("deviceid",$qrygetdevicecheckin); + // } + $swheredeviceid=""; + // $qry="insert into tbl_attendanceemployee + // set fingerid='".$data['id']."',fingerip='".$ip."',".$swheredeviceid."idxemployee='".$rw['idxemployee']."', + // nik='".$rw['nik']."',employeename='".$rw['employeename']."',dates='".date("Y-m-d", strtotime($data['timestamp']))."', + // times='".date("H:i:s", strtotime($data['timestamp']))."',datestimes='$datestimes',attendancename='".$rw['attendancename']."',thresholdtime='".$rw['thresholdtime']."', + // thresholdtimestr='".$rw['thresholdtimestr']."',endtime='".$rw['endtime']."',shiftcode='".$shiftcode."', + // totallateperemp='$totallateperemp',totallateperempr2='$totallateperempr2',months='$months',years='$years',islates='$islate',iby='".$rw['nik']."',idt=now()"; + $qry="insert into tbl_attendanceemployee + set fingerid='".$data['id']."',fingerip='".$ip."',".$swheredeviceid."idxemployee='".$rw['idxemployee']."', + nik='".$rw['nik']."',idxdept='".$rw['idxdept']."',employeename='".$rw['employeename']."',dates='".date("Y-m-d", strtotime($data['timestamp']))."', + times='".date("H:i:s", strtotime($data['timestamp']))."',datestimes='$datestimes',attendancename='".$rw['attendancename']."',thresholdtime='".$rw['thresholdtime']."', + thresholdtimestr='".$rw['thresholdtimestr']."',endtime='".$rw['endtime']."',shiftcode='".$shiftcode."', + months='$months',years='$years',islates='$islate',iby='".$rw['nik']."',idt=now()"; + + } + // echo $qry."\n"; + // if($deviceid=='172.16.110.251'){ + //echo $qry."\n"; + // } + if($this->executeSP($qry)){ + // if($rw['attendancename']=='OUT'){ + // $qry="update tbl_attendanceemployee set deviceid='$deviceidcheckin',deviceidcheckout='$deviceidcheckout' + // where trim(fingerid)=trim('".$data['id']."') and cast(dates as date)=cast('".date("Y-m-d", strtotime($data['timestamp']))."' as date) + // and isdeleted=0"; + // //$this->executeSP($qry); + // } + if($this->attendancelistsync($rw['idxemployee'],$dates)){ + $rtn=true; + } + + } + + } + } + + return $rtn; + } + + public function attendancelistsync($idxemployee,$dates) + { + $rtn=false; + // $qry="select distinct * from vw_attendanceemployeesync + // where cast(dates as date)=cast(now() as date) + // order by idxemployee,datestimes,sorts asc"; + // $qry="select distinct * from vw_attendanceemployeesync + // where cast(idt as date)=cast(now() as date) + // order by idxemployee,datestimes,sorts asc"; + $qry="select distinct * from vw_attendanceemployeesync + where idxemployee='$idxemployee' and cast(dates as date)=cast('$dates' as date) + order by idxemployee,datestimes,sorts asc"; + // echo $qry;return false; + $qryduration=""; + $rs=$this->selectquerySP($qry); + if($rs){ + echo "start time : ".date("Y-m-d H:i:s")."\n"; + while($rw=$rs->fetch()){ + $swhereshiftcode=""; + if($rw['shiftcode']&&$rw['idxdept']==22){ + $swhereshiftcode="and shiftcode='".$rw['shiftcode']."'"; + } + if($rw['idxdept']==30){ // === only call center department + if($rw['attendancename']=='IN'){ + $qry="insert into tbl_attendancelist + set idxattendance='".$rw['_idx']."',idxemployee='".$rw['idxemployee']."',nik='".$rw['nik']."', + employeename='".$rw['employeename']."',title='".$rw['title']."',levelname='".$rw['levelname']."', + officename='".$rw['officename']."',idxdept='".$rw['idxdept']."',divisiname='".$rw['divisiname']."', + serviconame='".$rw['serviconame']."',dates='".$rw['dates']."',checkin='".$rw['datestimes']."', + islates='".$rw['islates']."',months='".$rw['months']."',years='".$rw['years']."', + shiftcode='".$rw['shiftcode']."',lateperemployee='".$rw['lateperemployee']."',lateperemployeer2='".$rw['lateperemployeer2']."', + deviceidcheckin='".$rw['deviceidcheckin']."', + iby='svc',idt='".$rw['datestimes']."'"; + + $qrychk="select _idx from tbl_attendancelist + where idxemployee='".$rw['idxemployee']."' and cast(dates as date)=cast('".date("Y-m-d",strtotime($rw['dates']))."' as date) + $swhereshiftcode and isdeleted=0 order by _idx desc limit 1"; + if($this->fn_rowisexists($qrychk)){ + $qry=""; + } + } + elseif($rw['attendancename']=='OUT'){ + // $qrychk="select _idx from tbl_attendancelist + // where idxemployee='".$rw['idxemployee']."' and cast(dates as date)=date_sub('".date("Y-m-d",strtotime($rw['dates']))."', INTERVAL 1 day) and isdeleted=0 order by _idx desc limit 1"; + $qrychk="select _idx from tbl_attendancelist + where idxemployee='".$rw['idxemployee']."' + and cast(checkin as date)=cast('".date("Y-m-d",strtotime($rw['datestimes']))."' as date) + $swhereshiftcode and (checkout is null) + and isdeleted=0 order by _idx desc limit 1"; + // echo $qrychk;//return false; + + $_idx=$this->fn_getfieldvalue("_idx",$qrychk); + if($_idx){ + $qry="update tbl_attendancelist + set checkout='".$rw['datestimes']."',deviceidcheckout='".$rw['deviceidcheckout']."' + where _idx='$_idx' and UNIX_TIMESTAMP('".date("Y-m-d H:i:s",strtotime($rw['datestimes']))."')>UNIX_TIMESTAMP(checkin)"; + $qryduration="update tbl_attendancelist + set duration=SEC_TO_TIME(TIMESTAMPDIFF(SECOND,checkin,checkout)) + where _idx='$_idx'"; + $qrychk="select _idx from tbl_attendancelist + where cast(checkout as date)=cast('".date("Y-m-d",strtotime($rw['datestimes']))."' as date) + $swhereshiftcode and idxemployee='".$rw['idxemployee']."' and isdeleted=0 + order by _idx desc limit 1"; + if($this->fn_rowisexists($qrychk)){ + $qry="";$qryduration=""; + } + } + else{ + // $qrychk="select _idx from tbl_attendancelist + // where idxemployee='".$rw['idxemployee']."' and cast(dates as date)=cast('".date("Y-m-d",strtotime($rw['dates']))."' as date) + // and isdeleted=0 order by _idx desc limit 1"; + $qrychk="select _idx from tbl_attendancelist + where idxemployee='".$rw['idxemployee']."' + and cast(checkin as date)=date_sub('".date("Y-m-d",strtotime($rw['datestimes']))."', INTERVAL 1 day) and checkout is null + $swhereshiftcode and isdeleted=0 order by _idx desc limit 1"; + + // echo $qrychk;return false; + $_idx=$this->fn_getfieldvalue("_idx",$qrychk); + if($_idx){ + $qry="update tbl_attendancelist + set checkout='".$rw['datestimes']."',deviceidcheckout='".$rw['deviceidcheckout']."' + where _idx='$_idx' and (UNIX_TIMESTAMP('".date("Y-m-d H:i:s",strtotime($rw['datestimes']))."')>UNIX_TIMESTAMP(checkin)) and checkout is null"; + // $qry="update tbl_attendancelist set checkout='".$rw['datestimes']."' where _idx='$_idx'"; + $qryduration="update tbl_attendancelist + set duration=SEC_TO_TIME(TIMESTAMPDIFF(SECOND,checkin,checkout)) + where _idx='$_idx'"; + $qrychk="select _idx from tbl_attendancelist + where cast(checkout as date)=cast('".date("Y-m-d",strtotime($rw['datestimes']))."' as date) + $swhereshiftcode and idxemployee='".$rw['idxemployee']."' and isdeleted=0 + order by _idx desc limit 1"; + if($this->fn_rowisexists($qrychk)){ + $qry="";$qryduration=""; + } + + } + } + // echo $qry."\n"; + } + else{ + $qry=""; + } + if($qry){ + $this->executeSP($qry); + if($qryduration){ + // echo $qryduration."\n"; + $this->executeSP($qryduration); + } + // if($rw['attendancename']=='OUT'){ + // $qry="update tbl_attendancelist set duration='".$rw['datestimes']."' where _idx='$_idx'"; + // } + } + + } + else{ // === Non call center dept + if($rw['attendancename']=='IN'){$attfield="checkin='".$rw['datestimes']."',";} + if($rw['attendancename']=='R1'){$attfield="R1='".$rw['datestimes']."',";} + if($rw['attendancename']=='R2'){$attfield="R2='".$rw['datestimes']."',lateperemployeer2='".$rw['lateperemployeer2']."',";} + if($rw['attendancename']=='OUT'){$attfield="checkout='".$rw['datestimes']."',";} + + $qry="insert into tbl_attendancelist + set idxattendance='".$rw['_idx']."',idxemployee='".$rw['idxemployee']."',nik='".$rw['nik']."', + employeename='".$rw['employeename']."',title='".$rw['title']."',levelname='".$rw['levelname']."', + officename='".$rw['officename']."',idxdept='".$rw['idxdept']."',divisiname='".$rw['divisiname']."', + serviconame='".$rw['serviconame']."',dates='".$rw['dates']."',".$attfield." + islates='".$rw['islates']."',months='".$rw['months']."',years='".$rw['years']."', + shiftcode='".$rw['shiftcode']."',lateperemployee='".$rw['lateperemployee']."',lateperemployeer2='".$rw['lateperemployeer2']."', + deviceidcheckin='".$rw['deviceidcheckin']."', + iby='svc',idt='".$rw['datestimes']."'"; + + $qrychk="select _idx,checkin,checkout,lateperemployee from tbl_attendancelist + where idxemployee='".$rw['idxemployee']."' and cast(dates as date)=cast('".date("Y-m-d",strtotime($rw['dates']))."' as date) + $swhereshiftcode and isdeleted=0 order by _idx desc limit 1"; + if($this->fn_rowisexists($qrychk)){ + // $_idx=$this->fn_getfieldvalue("_idx",$qrychk); + $sp=$this->fn_getfieldsvalues("_idx,checkin,checkout,lateperemployee", $qrychk); + $_idx=$sp[0];$checkin=$sp[1];$checkout=$sp[2];$lateperemployee=$sp[3]; + $laterperemployeefield=""; + + // if(!$lateperemployee){ + // $laterperemployeefield="lateperemployee='".$rw['lateperemployee']."',"; + // } + + $qry="update tbl_attendancelist + set ".$attfield.$laterperemployeefield."uby='svc',udt='".$rw['datestimes']."' + where _idx='$_idx'"; + if($rw['attendancename']=='IN'&&$checkin!=null){ + $qry="update tbl_attendancelist + set uby='svc',udt='".$rw['datestimes']."' + where _idx='$_idx'"; + } + if($rw['attendancename']=='OUT'){ + $qry="update tbl_attendancelist + set ".$attfield."uby='svc',udt='".$rw['datestimes']."',deviceidcheckout='".$rw['deviceidcheckout']."' + where _idx='$_idx' and UNIX_TIMESTAMP('".date("Y-m-d H:i:s",strtotime($rw['datestimes']))."')>UNIX_TIMESTAMP(checkin)"; + + $idxdept=$rw['idxdept']; + if($idxdept==33||$idxdept==34||$idxdept==30||$idxdept==22){ + $qryduration="update tbl_attendancelist + set duration=SEC_TO_TIME(TIMESTAMPDIFF(SECOND,checkin,checkout)) + where _idx='$_idx'"; + } + else{ + $qryduration="update tbl_attendancelist + set duration=SEC_TO_TIME(TIMESTAMPDIFF(SECOND,checkin,R1)+TIMESTAMPDIFF(SECOND,R2,checkout)) + where _idx='$_idx'"; + + } + } + } + + if($qry){ + $this->executeSP($qry); + if($qryduration){ + // echo $qryduration."\n"; + $this->executeSP($qryduration); + } + } + } + } + + echo "end time : ".date("Y-m-d H:i:s")."\n"; + } + $rtn=true; + return $rtn; + } +} + +$cl = new LogController(); +$rtn =$cl->index(); + +#if(isset($_REQUEST['isgetdata'])){ +# echo "indx"; +# $rtn = $cl->index(); +#} +#else{ +# $rtn = $cl->fn_curl(); +#} + +echo $rtn;