Files
BE_IBL/application/controllers/tools/regonline/Demolabku_upload.php
2026-04-15 15:23:57 +07:00

1304 lines
42 KiB
PHP

<?php
class Demolabku_upload extends MY_Controller
{
public function __construct()
{
parent::__construct();
$this->debug = false;
$this->ONLINE_USER_ID = 1500;
$this->SENDER_DOCTOR_ID = 0;
$this->SENDER_ADDRESS_ID = 0;
$this->PJ_DOCTOR_ID = 0;
$this->KASIR_ONLINE_USER = 1500;
$this->url = "https://sasmobile.aplikasi.web.id/one_api_coba/tools/regonline/r_download/";
}
public function now()
{
return Date("Y-m-d H:i:s");
}
public function get_branch_default()
{
$sql =
"select * from m_branch where M_BranchIsDefault = 'Y' and M_BranchIsActive = 'Y'";
$qry = $this->db->query($sql);
if (!$qry) {
echo "{$this->now()} ERR : {$this->db->error()["message"]}\n";
exit();
}
$rows = $qry->result_array();
if (count($rows) == 0) {
echo "{$this->now()} ERR Get Default Branch: {$this->db->error()["message"]}\n";
exit();
}
$branchKelurahanID = $rows[0]["M_BranchM_KelurahanID"];
$this->SENDER_DOCTOR_ID = $rows[0]["M_BranchM_DoctorID"];
$this->SENDER_ADDRESS_ID = $rows[0]["M_BranchM_DoctorAddressID"];
$sql =
"select * from m_doctorpj where M_DoctorPjIsActive = 'Y' and M_DoctorPjIsDefaultPJ='Y'";
$qry = $this->db->query($sql);
if (!$qry) {
echo "{$this->now()} ERR : {$this->db->error()["message"]}\n";
exit();
}
$rows = $qry->result_array();
if (count($rows) == 0) {
echo "{$this->now()} ERR Get Default PJ: {$this->db->error()["message"]}\n";
exit();
}
$this->PJ_DOCTOR_ID = $rows[0]["M_DoctorPjM_DoctorID"];
return [$branchKelurahanID];
}
public function get_promise_by_px($pxID, $headerDate)
{
$sql = "select
date(
case
when M_ScheduleFlagAtTime = 'Y' then
concat( date( ? + interval M_ScheduleMonth * 4 day + interval 7 * M_ScheduleWeek day + interval M_ScheduleDay day) , ' ',
M_ScheduleAtTime , ':00')
else
? + interval M_ScheduleMonth * 4 day + interval 7 * M_ScheduleWeek day + interval M_ScheduleDay day +
interval M_ScheduleHour Hour + interval M_ScheduleMinute minute
end
)
promiseDate,
max(
case
when M_ScheduleFlagAtTime = 'Y' then
concat( date( ? + interval M_ScheduleMonth * 4 day + interval 7 * M_ScheduleWeek day + interval M_ScheduleDay day) , ' ',
M_ScheduleAtTime , ':00')
else
? + interval M_ScheduleMonth * 4 day + interval 7 * M_ScheduleWeek day + interval M_ScheduleDay day +
interval M_ScheduleHour Hour + interval M_ScheduleMinute minute
end
)
promiseDateTime
from
t_test
join m_schedulegrouptest on T_TestNat_TestID = M_ScheduleGroupTestNat_TestID
and M_ScheduleGroupTestIsActive = 'Y'
join m_schedule on M_ScheduleM_ScheduleGroupID = M_ScheduleGroupTestM_ScheduleGroupID
and M_ScheduleIsActive = 'Y'
and M_ScheduleDayOfWeek = dayofweek(?)
and date_format(?, '%H:%i') >= M_ScheduleStartHourMinute
and date_format(?, '%H:%i') <= M_ScheduleEndHourMinute
and T_TestID in ( $pxID )
group by promiseDate";
$qry = $this->db->query($sql, [
$headerDate,
$headerDate,
$headerDate,
$headerDate,
$headerDate,
$headerDate,
$headerDate,
]);
if (!$qry) {
//echo "{$this->now()} ERR Promise Reguler : {$this->db->error()['message']} | {$this->db->last_query()}\n";
return ["", ""];
}
$rows = $qry->result_array();
if (count($rows) == 0) {
//echo "{$this->now()} ERR Promise Reguler : Not Found \n";
return ["", ""];
}
//ambil yg pertama
$promiseDate = $rows[0]["promiseDate"];
$promiseDateTime = $rows[0]["promiseDateTime"];
return [$promiseDate, $promiseDateTime];
}
public function status_order()
{
echo "{$this->now()} Start Order Create Status\n";
list($branchKelurahanID) = $this->get_branch_default();
$db_msg = "";
$this->db->trans_begin();
//1. Get Branch
$sql = "select
M_BranchName, M_BranchAddress
from m_branch
where M_BranchIsActive = 'Y' and M_BranchIsDefault = 'Y'";
$qry = $this->db->query($sql);
if (!$qry) {
echo "{$this->now()} ERR : {$this->db->error()["message"]}\n";
exit();
}
$rows = $qry->result_array();
if (count($rows) == 0) {
echo "{$this->now()} ERR Update Status - Branch : {$this->db->error()["message"]}\n";
exit();
}
$branchName = $rows[0]["M_BranchName"];
$branchAddress = $rows[0]["M_BranchAddress"];
//1. Order Creation
$sql = "select T_OnlineTxOrgID, T_OnlineOrderT_OrderID, T_OnlineOrderID,
T_OrderHeaderLabNumberExt, T_OrderHeaderDate, T_OrderHeaderID
from t_onlineorder
join t_onlinetx on T_OnlineOrderT_OnlineTxID = T_OnlineTxID
join t_orderheader on T_OrderHeaderID = T_OnlineOrderT_OrderHeaderID
where T_OnlineOrderUploaded is null";
$qry = $this->db->query($sql);
if (!$qry) {
echo "{$this->now()} ERR : {$this->db->error()["message"]}\n";
exit();
}
$rows = $qry->result_array();
$counter = 0;
$status = [];
$headerDate = date("Y-m-d H:i:s");
foreach ($rows as $r) {
$msg =
"Nomor Registrasi\t: " . $r["T_OrderHeaderLabNumberExt"] . "\n";
$msg .= "Lab. Sima $branchName\n$branchAddress\n";
$msg .= "Jadwal\t: " . $this->get_hari_id($r["T_OrderHeaderDate"]);
$resp = $this->get_promise_by_px(
$r["T_OrderHeaderID"],
$r["T_OrderHeaderDate"]
);
if ($resp["status"] != "OK") {
$db_msg .= "|Err Promise Info : {$resp["message"]}";
} else {
$msg .= "\n" . $resp["message"];
}
$status[] = [
"T_TxMessageT_TransactionID" => $r["T_OnlineTxOrgID"],
"T_TxMessageT_OrderID" => $r["T_OnlineOrderT_OrderID"],
"T_TxMessageNote" => $msg,
"T_TxMessageCode" => "ORDER",
];
$counter++;
$headerDate = $r["T_OrderHeaderDate"];
$sql = "update t_onlineorder set T_OnlineOrderUploaded=?
where T_OnlineOrderID = ?";
$qry = $this->db->query($sql, [$headerDate, $r["T_OnlineOrderID"]]);
if (!$qry) {
echo "{$this->now()} ERR Update Uploaded: {$this->db->error()["message"]}\n";
exit();
}
}
if (count($status) > 0) {
//upload
$url = $this->url . "status";
$param = ["status" => $status];
$z_param = gzdeflate(json_encode($param), 9);
$resp = $this->post($url, $z_param);
if ($resp["status"] == "OK") {
$this->db->trans_commit();
echo "{$this->now()} Upload Status Creation : $counter\n";
} else {
$this->db->trans_rollback();
echo "{$this->now()} ERR {$resp["message"]}\n";
}
} else {
echo "{$this->now()} Upload Status Creation : $counter | 0 Status \n";
$this->db->trans_commit();
}
}
public function status_validasi()
{
echo "{$this->now()} Start Validasi Status\n";
$this->db->trans_begin();
$sql = "select
T_OrderHeaderID, T_OrderHeaderLabNumberExt,
T_OnlineOrderID, T_OnlineOrderT_OrderID, T_OnlineTxOrgID,
max(T_OrderDetailValDate) maxDate
from
t_onlineorder
join t_onlinetx on T_OnlineOrderT_OnlineTxID = T_OnlineTxID
and T_OnlineOrderIsActive = 'Y'
and T_OnlineTxIsActive = 'Y'
join t_orderheader
on T_OnlineOrderT_OrderHeaderID = T_OrderHeaderID
and T_OnlineOrderUploaded is not null
join pb_upload on pbUploadCode = 'VALIDASI'
join t_orderheaderaddon
on T_OrderHeaderID = T_OrderHeaderAddOnT_OrderHeaderID
and T_OrderHeaderAddOnIsActive = 'Y'
and T_OrderHeaderAddOnValidationDone <> 'N'
and T_OrderHeaderAddOnLastUpdated > pbUploadExecuted
join t_orderdetail on T_OrderDetailT_OrderHeaderID = T_OrderHeaderID
and T_OrderDetailIsActive = 'Y'
and T_OrderDetailValidation = 'Y'
group by T_OrderHeaderID";
$qry = $this->db->query($sql);
if (!$qry) {
echo "{$this->now()} ERR Status Validasi : {$this->db->error()["message"]}\n";
return;
}
$rows = $qry->result_array();
if (count($rows) == 0) {
echo "{$this->now()} No Status Validation\n";
return;
}
$sql = "update pb_upload set pbUploadExecuted=now()
where pbUploadCode = 'VALIDASI'";
$qry = $this->db->query($sql);
if (!$qry) {
echo "{$this->now()} ERR Update Uploaded: {$this->db->error()["message"]}\n";
return;
}
$status = [];
$counter = 0;
foreach ($rows as $r) {
$headerID = $r["T_OrderHeaderID"];
$maxDate = $r["maxDate"];
$staffName = $this->get_validation_staff($headerID, $maxDate);
$msg =
"Nomor Registrasi : " . $r["T_OrderHeaderLabNumberExt"] . "\n";
$msg .=
"Sudah di validasi oleh $staffName pada " .
$this->get_hari_id($maxDate);
$status[] = [
"T_TxMessageT_TransactionID" => $r["T_OnlineTxOrgID"],
"T_TxMessageT_OrderID" => $r["T_OnlineOrderT_OrderID"],
"T_TxMessageNote" => $msg,
"T_TxMessageCode" => "VALIDATION",
];
$counter++;
}
if (count($status) > 0) {
//upload
$url = $this->url . "status";
$param = ["status" => $status];
$z_param = gzdeflate(json_encode($param), 9);
$resp = $this->post($url, $z_param);
if ($resp["status"] == "OK") {
$this->db->trans_commit();
echo "{$this->now()} Upload Status Validation : $counter\n";
} else {
$this->db->trans_rollback();
echo "{$this->now()} ERR {$resp["message"]}\n";
}
} else {
echo "{$this->now()} Upload Status Validasi : $counter\n";
$this->db->trans_commit();
}
}
public function get_validation_staff($headerID, $maxDate)
{
$sql = "select M_StaffName
from
t_orderdetail
join m_user
on T_OrderDetailT_OrderHeaderID = ?
and T_OrderDetailIsActive = 'Y'
and T_OrderDetailValidation = 'Y'
and T_OrderDetailValDate = ?
and T_OrderDetailValUserID = M_UserID
join m_staff on M_UserM_StaffID = M_StaffID";
$qry = $this->db->query($sql, [$headerID, $maxDate]);
if (!$qry) {
echo "{$this->now()} ERR Status Validasi : {$this->db->error()["message"]}\n";
return "";
}
$rows = $qry->result_array();
if (count($rows) == 0) {
return "";
}
return $rows[0]["M_StaffName"];
}
public function status_report($debug = "N")
{
echo "{$this->now()} Start Report Status\n";
$this->db->trans_begin();
$sql = "select
M_BranchCode
from m_branch
where M_BranchIsActive = 'Y' and M_BranchIsDefault = 'Y'";
$qry = $this->db->query($sql);
if (!$qry) {
echo "{$this->now()} ERR : {$this->db->error()["message"]}\n";
exit();
}
$rows = $qry->result_array();
if (count($rows) == 0) {
echo "{$this->now()} ERR Update Status - Branch : {$this->db->error()["message"]}\n";
exit();
}
$branchCode = $rows[0]["M_BranchCode"];
$or_debug = "";
/*
if ($debug == "Y") {
$or_debug =
" or date(Result_ProcessToOfficeLastUpdated) >= date(now()) ";
}
*/
$sql = "select T_OrderHeaderLabNumber,
T_OrderHeaderLabNumberExt, T_OrderHeaderID,
T_OnlineOrderID, T_OnlineOrderT_OrderID,
T_OnlineTxOrgID, max(Result_ProcessToOfficeLastUpdated) maxDate ,
max(T_OrderHeaderAddonReadyPrintDate) maxPrintDate,
T_OrderHeaderM_PatientID
from t_onlineorder
join t_onlinetx on T_OnlineOrderT_OnlineTxID = T_OnlineTxID
and T_OnlineOrderIsActive = 'Y'
and T_OnlineTxIsActive = 'Y'
and T_OnlineOrderUploaded is not null
join t_orderheader
on T_OnlineOrderT_OrderHeaderID = T_OrderHeaderID
and date(T_OrderHeaderDate) >= '2021-12-13'
join t_orderheaderaddon on T_OrderHeaderID = T_OrderHeaderAddOnT_OrderHeaderID
join pb_upload
on pbUploadCode = 'RESULT'
join result_processtooffice on
Result_ProcessToOfficeT_OrderHeaderID = T_OrderHeaderID
and Result_ProcessToOfficeIsActive = 'Y'
and (
Result_ProcessToOfficeLastUpdated > pbUploadExecuted
-- or
-- T_OrderHeaderAddonReadyPrintDate > pbUploadExecuted
)
group by T_OrderHeaderID
";
$qry = $this->db->query($sql);
if (!$qry) {
echo "{$this->now()} ERR Status Report : {$this->db->error()["message"]} | {$this->db->last_query()}\n";
exit();
}
$rows = $qry->result_array();
$tot_row = count($rows);
if ($tot_row == 0) {
echo "{$this->now()} No Status Report : $tot_row \n";
$sql = "update pb_upload set pbUploadExecuted=now()
where pbUploadCode='RESULT'";
$qry = $this->db->query($sql);
$this->db->trans_commit();
return;
}
$s_patientID = "0";
foreach ($rows as $r) {
$s_patientID .= "," . $r["T_OrderHeaderM_PatientID"];
}
//get patient
$sql = "
select M_PatientName,
M_PatientDOB,
M_PatientNoreg,
M_PatientM_SexID,
M_PatientJob,
M_PatientM_IdTypeID,
M_PatientIDNumber,
T_OnlineOrderT_OrderID
from m_patient
join t_onlineorder
on M_PatientID in ($s_patientID)
and T_OnlineOrderM_PatientID = M_PatientID
and T_OnlineOrderIsActive = 'Y'";
$qry = $this->db->query($sql);
if (!$qry) {
echo "{$this->now()} ERR Report : Patient : {$this->db->error()["message"]} | {$this->db->last_query()}\n";
exit();
}
$patients = $qry->result_array();
$status = [];
$counter = 0;
echo "{$this->now()} Upload Status Report : \n";
foreach ($rows as $r) {
$headerID = $r["T_OrderHeaderID"];
$reports = $this->get_report($headerID);
if ($reports == []) {
echo "\t\t" .
$r["T_OrderHeaderLabNumber"] .
" No Report Found\n";
continue;
}
$arr_reports = [];
$idx = 1;
foreach ($reports as $xr) {
if (trim($xr["url_rpt"]) == "-") {
echo "\t {$r['T_OrderHeaderLabNumber']} : {$xr['Group_ResultName']} => Kosong \n";
continue;
}
$rpt_url = "http://localhost/" . $xr["url_rpt"];
$fname =
$r["T_OnlineTxOrgID"] .
"_" .
$r["T_OnlineOrderT_OrderID"] .
"_" .
$xr["Group_ResultName"] .
"_" .
$r["T_OrderHeaderLabNumberExt"] .
".pdf";
$arr_reports[] = [
"name" => $xr["Group_ResultName"],
"branchCode" => $branchCode,
"fname" => $fname,
"content" => base64_encode(file_get_contents($rpt_url)),
];
$idx++;
echo "\t {$r['T_OrderHeaderLabNumber']} => $fname : $rpt_url\n";
}
$msg =
"Nomor Registrasi : " . $r["T_OrderHeaderLabNumberExt"] . "\n";
$msg .= "Sudah selesai.";
$status[] = [
"T_TxMessageT_TransactionID" => $r["T_OnlineTxOrgID"],
"T_TxMessageT_OrderID" => $r["T_OnlineOrderT_OrderID"],
"T_TxMessageNote" => $msg,
"reports" => $arr_reports,
"T_TxMessageCode" => "RESULT",
];
$counter++;
}
if (count($status) > 0) {
$url = $this->url . "status";
$param = ["status" => $status, "patients" => $patients];
$z_param = gzdeflate(json_encode($param), 9);
$resp = $this->post($url, $z_param);
if ($resp["status"] == "OK") {
$this->db->trans_commit();
echo "{$this->now()} Upload Status Report : $counter\n{$resp["message"]}\n";
foreach ($status["report"] as $r) {
echo "{$this->now()} => $fname \n";
}
} else {
$this->db->trans_rollback();
echo "{$this->now()} ERR {$resp["message"]}\n";
}
} else {
echo "{$this->now()} Upload Status Report : $counter\n";
$this->db->trans_commit();
}
$this->status_report_hs();
//update pb_upload
$sql = "update pb_upload set pbUploadExecuted=now()
where pbUploadCode='RESULT'";
$qry = $this->db->query($sql);
if (!$qry) {
echo "{$this->now()} ERR Update Uploaded: {$this->db->error()["message"]}\n";
exit();
}
}
public function status_report_hs($debug = "N")
{
echo "{$this->now()} Start Report Status HS\n";
$sql = "select
M_BranchCode
from m_branch
where M_BranchIsActive = 'Y' and M_BranchIsDefault = 'Y'";
$qry = $this->db->query($sql);
if (!$qry) {
echo "{$this->now()} ERR : {$this->db->error()["message"]}\n";
exit();
}
$rows = $qry->result_array();
if (count($rows) == 0) {
echo "{$this->now()} ERR Update Status - Branch : {$this->db->error()["message"]}\n";
exit();
}
$branchCode = $rows[0]["M_BranchCode"];
$or_debug = "";
$sql = "select T_OrderHeaderLabNumber,
T_OrderHeaderLabNumberExt, T_OrderHeaderID,
T_OrderOldID T_OnlineOrderT_OrderID,
T_OrderT_TransactionOldID T_OnlineTxOrgID,
max(Result_ProcessToOfficeLastUpdated) maxDate ,
max(T_OrderHeaderAddonReadyPrintDate) maxPrintDate,
T_OrderHeaderM_PatientID
from one_hs.t_order
join t_orderheader
on T_OrderT_OrderHeaderID = T_OrderHeaderID
and date(T_OrderHeaderDate) >= '2021-12-13'
join t_orderheaderaddon on T_OrderHeaderID = T_OrderHeaderAddOnT_OrderHeaderID
join pb_upload
on pbUploadCode = 'RESULT'
join result_processtooffice on
Result_ProcessToOfficeT_OrderHeaderID = T_OrderHeaderID
and Result_ProcessToOfficeIsActive = 'Y'
and (
Result_ProcessToOfficeLastUpdated > pbUploadExecuted
-- or
-- T_OrderHeaderAddonReadyPrintDate > pbUploadExecuted
)
group by T_OrderHeaderID
";
$qry = $this->db->query($sql);
if (!$qry) {
echo "{$this->now()} ERR Status Report : {$this->db->error()["message"]} | {$this->db->last_query()}\n";
exit();
}
$rows = $qry->result_array();
$tot_row = count($rows);
if ($tot_row == 0) {
echo "{$this->now()} No Status Report HS : $tot_row \n";
return;
}
$s_patientID = "0";
foreach ($rows as $r) {
$s_patientID .= "," . $r["T_OrderHeaderM_PatientID"];
}
//get patient
$sql = "
select M_PatientName,
M_PatientDOB,
M_PatientNoreg,
M_PatientM_SexID,
M_PatientJob,
M_PatientM_IdTypeID,
M_PatientIDNumber,
T_OnlineOrderT_OrderID
from m_patient
join t_onlineorder
on M_PatientID in ($s_patientID)
and T_OnlineOrderM_PatientID = M_PatientID
and T_OnlineOrderIsActive = 'Y'";
$qry = $this->db->query($sql);
if (!$qry) {
echo "{$this->now()} ERR Report : Patient HS : {$this->db->error()["message"]} | {$this->db->last_query()}\n";
exit();
}
$patients = $qry->result_array();
$status = [];
$counter = 0;
echo "{$this->now()} Upload Status Report HS : \n";
foreach ($rows as $r) {
$headerID = $r["T_OrderHeaderID"];
$reports = $this->get_report($headerID);
if ($reports == []) {
echo "\t\t" .
$r["T_OrderHeaderLabNumber"] .
" No Report Found\n";
continue;
}
$arr_reports = [];
$idx = 1;
foreach ($reports as $xr) {
if (trim($xr["url_rpt"]) == "-") {
echo "\t {$r['T_OrderHeaderLabNumber']} : {$xr['Group_ResultName']} => Kosong \n";
continue;
}
$rpt_url = "http://localhost/" . $xr["url_rpt"];
$fname =
$r["T_OnlineTxOrgID"] .
"_" .
$r["T_OnlineOrderT_OrderID"] .
"_" .
$xr["Group_ResultName"] .
"_" .
$r["T_OrderHeaderLabNumberExt"] .
".pdf";
$arr_reports[] = [
"name" => $xr["Group_ResultName"],
"branchCode" => $branchCode,
"fname" => $fname,
"content" => base64_encode(file_get_contents($rpt_url)),
];
$idx++;
echo "\t {$r['T_OrderHeaderLabNumber']} => $fname : $rpt_url\n";
}
$msg =
"Nomor Registrasi : " . $r["T_OrderHeaderLabNumberExt"] . "\n";
$msg .= "Sudah selesai.";
$status[] = [
"T_TxMessageT_TransactionID" => $r["T_OnlineTxOrgID"],
"T_TxMessageT_OrderID" => $r["T_OnlineOrderT_OrderID"],
"T_TxMessageNote" => $msg,
"reports" => $arr_reports,
"T_TxMessageCode" => "RESULT",
];
$counter++;
}
if (count($status) > 0) {
$url = $this->url . "status";
$param = ["status" => $status, "patients" => $patients];
$z_param = gzdeflate(json_encode($param), 9);
$resp = $this->post($url, $z_param);
if ($resp["status"] == "OK") {
echo "{$this->now()} Upload Status Report : $counter\n{$resp["message"]}\n";
foreach ($status["report"] as $r) {
echo "{$this->now()} => $fname \n";
}
} else {
echo "{$this->now()} ERR {$resp["message"]}\n";
}
} else {
echo "{$this->now()} Upload Status Report : $counter\n";
}
//update pb_upload
}
function force_report_hs($headerID)
{
echo "<pre>{$this->now()} Start Force HS Report Status\n";
$sql = "select
M_BranchCode
from m_branch
where M_BranchIsActive = 'Y' and M_BranchIsDefault = 'Y'";
$qry = $this->db->query($sql);
if (!$qry) {
echo "{$this->now()} ERR : {$this->db->error()["message"]}\n";
exit();
}
$rows = $qry->result_array();
if (count($rows) == 0) {
echo "{$this->now()} ERR Update Status - Branch : {$this->db->error()["message"]}\n";
exit();
}
$branchCode = $rows[0]["M_BranchCode"];
//patients
$sql = "select T_OrderHeaderLabNumber,
T_OrderHeaderLabNumberExt, T_OrderHeaderID,
T_OrderOldID T_OnlineOrderT_OrderID,
T_OrderT_TransactionOldID T_OnlineTxOrgID,
max(Result_ProcessToOfficeLastUpdated) maxDate ,
max(T_OrderHeaderAddonReadyPrintDate) maxPrintDate,
T_OrderHeaderM_PatientID
from one_hs.t_order
join t_orderheader
on T_OrderT_OrderHeaderID = T_OrderHeaderID
and date(T_OrderHeaderDate) >= '2021-12-13'
and T_OrderHeaderID = ?
join t_orderheaderaddon on T_OrderHeaderID = T_OrderHeaderAddOnT_OrderHeaderID
join pb_upload
on pbUploadCode = 'RESULT'
join result_processtooffice on
Result_ProcessToOfficeT_OrderHeaderID = T_OrderHeaderID
and Result_ProcessToOfficeIsActive = 'Y'
group by T_OrderHeaderID
";
$qry = $this->db->query($sql, [$headerID]);
if (!$qry) {
echo "{$this->now()} ERR Status Report : {$this->db->error()["message"]} | {$this->db->last_query()}\n";
exit();
}
$rows = $qry->result_array();
if (count($rows) == 0) {
echo "Report not ready";
return;
}
$r = $rows[0];
$reports = $this->get_report($headerID);
if ($reports == []) {
echo "\t\t" . $headerID . " No Report Found\n";
return;
}
print_r($reports); exit;
$arr_reports = [];
$idx = 1;
foreach ($reports as $xr) {
if (trim($xr["url_rpt"]) == "-") {
echo "\t {$xr['Group_ResultName']} => Kosong \n";
continue;
}
$rpt_url = "http://localhost/" . $xr["url_rpt"];
$fname =
$r["T_OnlineTxOrgID"] .
"_" .
$r["T_OnlineOrderT_OrderID"] .
"_" .
$xr["Group_ResultName"] .
"_" .
$r["T_OrderHeaderLabNumberExt"] .
".pdf";
$arr_reports[] = [
"name" => $xr["Group_ResultName"],
"branchCode" => $branchCode,
"fname" => $fname,
"content" => base64_encode(file_get_contents($rpt_url)),
];
$idx++;
echo "\t {$r['T_OrderHeaderLabNumber']} => $fname : $rpt_url\n";
}
$msg =
"Nomor Registrasi : " . $r["T_OrderHeaderLabNumberExt"] . "\n";
$msg .= "Sudah selesai.";
$status[] = [
"T_TxMessageT_TransactionID" => $r["T_OnlineTxOrgID"],
"T_TxMessageT_OrderID" => $r["T_OnlineOrderT_OrderID"],
"T_TxMessageNote" => $msg,
"reports" => $arr_reports,
"T_TxMessageCode" => "RESULT",
];
if (count($status) > 0) {
//upload
$url = $this->url . "status";
$param = ["status" => $status];
$z_param = gzdeflate(json_encode($param), 9);
$resp = $this->post($url, $z_param);
if ($resp["status"] == "OK") {
echo "{$this->now()} Upload Status Creation \n";
} else {
echo "{$this->now()} ERR {$resp["message"]}\n";
}
} else {
echo "{$this->now()} Upload Status Creation \n";
}
}
function force_report($headerID)
{
echo "<pre>{$this->now()} Start Force Report Status\n";
$sql = "select
M_BranchCode
from m_branch
where M_BranchIsActive = 'Y' and M_BranchIsDefault = 'Y'";
$qry = $this->db->query($sql);
if (!$qry) {
echo "{$this->now()} ERR : {$this->db->error()["message"]}\n";
exit();
}
$rows = $qry->result_array();
if (count($rows) == 0) {
echo "{$this->now()} ERR Update Status - Branch : {$this->db->error()["message"]}\n";
exit();
}
$branchCode = $rows[0]["M_BranchCode"];
//patients
$sql = "select T_OrderHeaderLabNumber,
T_OrderHeaderLabNumberExt, T_OrderHeaderID,
T_OnlineOrderID, T_OnlineOrderT_OrderID,
T_OnlineTxOrgID, max(Result_ProcessToOfficeLastUpdated) maxDate ,
max(T_OrderHeaderAddonReadyPrintDate) maxPrintDate,
T_OrderHeaderM_PatientID
from t_onlineorder
join t_onlinetx on T_OnlineOrderT_OnlineTxID = T_OnlineTxID
and T_OnlineOrderIsActive = 'Y'
and T_OnlineTxIsActive = 'Y'
and T_OnlineOrderUploaded is not null
join t_orderheader
on T_OnlineOrderT_OrderHeaderID = T_OrderHeaderID
and date(T_OrderHeaderDate) >= '2021-12-13'
and T_OrderHeaderID = ?
join t_orderheaderaddon on T_OrderHeaderID = T_OrderHeaderAddOnT_OrderHeaderID
join pb_upload
on pbUploadCode = 'RESULT'
join result_processtooffice on
Result_ProcessToOfficeT_OrderHeaderID = T_OrderHeaderID
and Result_ProcessToOfficeIsActive = 'Y'
group by T_OrderHeaderID
";
$qry = $this->db->query($sql, [$headerID]);
if (!$qry) {
echo "{$this->now()} ERR Status Report : {$this->db->error()["message"]} | {$this->db->last_query()}\n";
exit();
}
$rows = $qry->result_array();
if (count($rows) == 0) {
echo "Report not ready";
return;
}
$r = $rows[0];
$reports = $this->get_report($headerID);
if ($reports == []) {
echo "\t\t" . $headerID . " No Report Found\n";
return;
}
$arr_reports = [];
$idx = 1;
foreach ($reports as $xr) {
if (trim($xr["url_rpt"]) == "-") {
echo "\t {$xr['Group_ResultName']} => Kosong \n";
continue;
}
$rpt_url = "http://localhost/" . $xr["url_rpt"];
$fname =
$r["T_OnlineTxOrgID"] .
"_" .
$r["T_OnlineOrderT_OrderID"] .
"_" .
$xr["Group_ResultName"] .
"_" .
$r["T_OrderHeaderLabNumberExt"] .
".pdf";
$arr_reports[] = [
"name" => $xr["Group_ResultName"],
"branchCode" => $branchCode,
"fname" => $fname,
"content" => base64_encode(file_get_contents($rpt_url)),
];
$idx++;
echo "\t {$r['T_OrderHeaderLabNumber']} => $fname : $rpt_url\n";
}
$msg =
"Nomor Registrasi : " . $r["T_OrderHeaderLabNumberExt"] . "\n";
$msg .= "Sudah selesai.";
$status[] = [
"T_TxMessageT_TransactionID" => $r["T_OnlineTxOrgID"],
"T_TxMessageT_OrderID" => $r["T_OnlineOrderT_OrderID"],
"T_TxMessageNote" => $msg,
"reports" => $arr_reports,
"T_TxMessageCode" => "RESULT",
];
if (count($status) > 0) {
//upload
$url = $this->url . "status";
$param = ["status" => $status];
$z_param = gzdeflate(json_encode($param), 9);
$resp = $this->post($url, $z_param);
if ($resp["status"] == "OK") {
echo "{$this->now()} Upload Status Creation \n";
} else {
echo "{$this->now()} ERR {$resp["message"]}\n";
}
} else {
echo "{$this->now()} Upload Status Creation \n";
}
}
function get_report($headerID, $debug = "")
{
$sql = "select distinct
Group_ResultID,Group_ResultName,
Group_ResultFlagNonLab,IFNULL(T_EmailNonLabUrl,'-') EmailNonLabUrl,
IF(T_EmailNonLabUrl IS NULL AND Group_ResultFlagNonLab = 'Y',' [Belum Pilih Format Hasil]','') temail
from
t_orderdetail
join group_resultdetail
on Group_ResultDetailT_TestID = T_OrderDetailT_TestID
and T_OrderDetailIsActive = 'Y' and Group_ResultDetailIsActive = 'Y'
and T_OrderDetailT_OrderHeaderID = ?
join group_result
on Group_ResultDetailGroup_ResultID = Group_ResultID
and Group_ResultIsActive = 'Y'
LEFT JOIN t_email_nonlab ON T_EmailNonLabT_OrderHeaderID = T_OrderDetailT_OrderHeaderID AND
T_EmailNonLabType LIKE CONCAT('%',REPLACE(Group_ResultName, 'Elektromedik', 'electromedis'),'%')
group by Group_ResultID";
$qry = $this->db->query($sql, [$headerID]);
if (!$qry) {
echo "{$this->now()} Error Ger Report : " .
$this->db->error()["message"] .
"|\n" .
$this->db->last_query() .
" \n";
return [];
}
$rows = $qry->result_array();
$ts = "&ts=" . date("Ymdhis");
$id = $headerID;
$result = [];
foreach ($rows as $r) {
$xname = $r["Group_ResultName"];
$name = $this->escape_fname($xname);
$gid = $r["Group_ResultID"];
$temail = $r["temail"];
$isnonlab = $r["Group_ResultFlagNonLab"];
$emailnonlaburl = str_replace(" ", "", $r["EmailNonLabUrl"]);
if (strpos($emailnonlaburl, "fisik") > 0) {
echo "Hasil Fisik : $name - $xname $emailnonlaburl \n";
continue;
}
$report = "";
switch ($gid) {
case 1:
$report =
"/birt/frameset?__report=report/onelab/lab/rpt_test_email.rptdesign&__format=pdf&username=admin&PID=" .
$id .
$ts;
break;
case 2:
$report =
"/birt/frameset?__report=report/onelab/lab/rpt_hasil_papsmear_email.rptdesign&__format=pdf&username=admin&PID=" .
$id .
$ts;
break;
case 3:
$report =
"/birt/frameset?__report=report/onelab/lab/rpt_hasil_fna_email.rptdesign&__format=pdf&username=admin&PID=" .
$id .
$ts;
break;
case 4:
$report = $emailnonlaburl;
break;
case 5:
$report = $emailnonlaburl;
break;
case 6:
$report = $emailnonlaburl;
break;
case 7:
$report = $emailnonlaburl;
break;
case 8:
$report = $emailnonlaburl;
break;
case 9:
$report = $emailnonlaburl;
break;
case 10:
$report = $emailnonlaburl;
break;
case 11:
$report = $emailnonlaburl;
break;
case 12:
$report =
"/birt/frameset?__report=report/onelab/lab/rpt_hasil_lcprep_email.rptdesign&__format=pdf&username=admin&PID=" .
$id .
$ts;
break;
case 13:
$report =
"/birt/frameset?__report=report/onelab/lab/rpt_test_mikro_email.rptdesign&__format=pdf&username=admin&PID=" .
$id .
$ts;
break;
case 14:
$report =
"/birt/frameset?__report=report/onelab/lab/rpt_hasil_cytologi_email.rptdesign&__format=pdf&username=admin&PID=" .
$id .
$ts;
break;
case 15:
$report = $emailnonlaburl;
break;
case 16:
$report = $emailnonlaburl;
break;
case 17:
$report = $emailnonlaburl;
break;
}
$result[] = ["Group_ResultName" => $xname, "url_rpt" => $report];
}
if ($debug != "") {
echo "<pre>";
print_r($result);
}
return $result;
}
public function get_report_v1($headerID)
{
$sql = "SELECT
distinct
Group_ResultName,
CASE
WHEN Group_ResultID = 1 THEN
CONCAT('/birt/frameset?__report=report/onelab/lab/rpt_test_email.rptdesign&__format=pdf&username=','regonline','&PID=',T_OrderHeaderID,'&ts=',UNIX_TIMESTAMP())
WHEN Group_ResultID = 2 THEN
CONCAT('/birt/frameset?__report=report/onelab/lab/rpt_hasil_papsmear_email.rptdesign&__format=pdf&username=','regonline','&PID=',T_OrderHeaderID,'&ts=',UNIX_TIMESTAMP())
WHEN Group_ResultID = 3 THEN
CONCAT('/birt/frameset?__report=report/onelab/lab/rpt_hasil_fna_email.rptdesign&__format=pdf&username=','regonline','&PID=',T_OrderHeaderID,'&ts=',UNIX_TIMESTAMP())
WHEN Group_ResultID = 12 THEN
CONCAT('/birt/frameset?__report=report/onelab/lab/rpt_hasil_lcprep_email.rptdesign&__format=pdf&username=','regonline','&PID=',T_OrderHeaderID,'&ts=',UNIX_TIMESTAMP())
WHEN Group_ResultID = 13 THEN
CONCAT('/birt/frameset?__report=report/onelab/lab/rpt_test_mikro_email.rptdesign&__format=pdf&username=','regonline','&PID=',T_OrderHeaderID,'&ts=',UNIX_TIMESTAMP())
WHEN Group_ResultID = 14 THEN
CONCAT('/birt/frameset?__report=report/onelab/lab/rpt_hasil_cytologi_email.rptdesign&__format=pdf&username=','regonline','&PID=',T_OrderHeaderID,'&ts=',UNIX_TIMESTAMP())
END as url_rpt
FROM t_orderheader
JOIN t_orderdetail
ON T_OrderHeaderID = ?
AND T_OrderDetailT_OrderHeaderID = T_OrderHeaderID
AND T_OrderDetailIsActive = 'Y'
JOIN t_test
ON T_OrderDetailT_TestID = T_TestID
JOIN group_resultdetail
ON Group_ResultDetailT_TestID = T_TestID
JOIN group_result
ON Group_ResultDetailGroup_ResultID = Group_ResultID
AND Group_ResultFlagNonLab = 'N'
";
$qry = $this->db->query($sql, [$headerID]);
if (!$qry) {
echo "{$this->now()} ERR Get Report : {$this->db->error()["message"]}\n";
exit();
}
$rows = $qry->result_array();
if (count($rows) == 0) {
return [];
}
return $rows;
}
public function status_patient()
{
$sql = "select
T_OnlineOrderT_OrderID,
M_PatientID,
M_PatientName
M_PatientDOB,
M_PatientM_SexID,
M_PatientJob,
M_PatientM_IdTypeID,
M_PatientIDNumber,
M_PatientUserID
from t_onlineorder
join pb_upload
on pbUploadCode = 'PATIENT'
join m_patient on T_OnlineOrderM_PatientID = M_PatientID
and M_PatientIsActive = 'Y'
and M_PatientLastUpdated > pbUploadExecuted
";
$qry = $this->db->query($sql);
if (!$qry) {
echo "{$this->now()} ERR Status Report : {$this->db->error()["message"]} | {$this->db->last_query()}\n";
exit();
}
$rows = $qry->result_array();
if (count($rows) == 0) {
echo "{$this->now()} No Status Report\n";
$sql = "update pb_upload set pbUploadExecuted=now()
where pbUploadCode='RESULT'";
$qry = $this->db->query($sql);
$this->db->trans_commit();
return;
}
//update pb_upload
$sql = "update pb_upload set pbUploadExecuted=now()
where pbUploadCode = 'PASIEN'";
$qry = $this->db->query($sql);
if (!$qry) {
echo "{$this->now()} ERR Update Uploaded: {$this->db->error()["message"]}\n";
exit();
}
$status = [];
$counter = 0;
}
public function get_hari_id($orderDate)
{
$bulan = [
1 => "Januari",
"Februari",
"Maret",
"April",
"Mei",
"Juni",
"Juli",
"Agustus",
"September",
"Oktober",
"November",
"Desember",
];
$tanggal = date("Y-m-d", strtotime($orderDate));
$split = explode("-", $tanggal);
$hari = $split[2] . " " . $bulan[(int) $split[1]] . " " . $split[0];
$dow = date("l", strtotime($orderDate));
switch ($dow) {
case "Sunday":
$dow = "Minggu";
break;
case "Monday":
$dow = "Senin";
break;
case "Tuesday":
$dow = "Selasa";
break;
case "Wednesday":
$dow = "Rabu";
break;
case "Thursday":
$dow = "Kamis";
break;
case "Friday":
$dow = "Jumat";
break;
case "Saturday":
$dow = "Sabtu";
break;
}
$result = "";
if ($dow != "") {
$result .= $dow . ", ";
}
$result .= $hari . " jam " . date("H:i", strtotime($orderDate));
return $result;
}
public function strip_unicode($inp)
{
$result = mb_convert_encoding($inp, "US-ASCII", "UTF-8");
return $result;
}
public function index()
{
$this->status_order();
sleep(5);
$this->status_validasi();
sleep(5);
$this->status_report();
sleep(5);
$this->status_lunas();
}
function status_lunas()
{
echo "{$this->now()} Start Pelunasan Bayar di Tempat\n";
$sql = "select pbUploadExecuted from pb_upload where pbUploadCode = 'LUNAS'";
$qry = $this->db->query($sql);
if (!$qry) {
echo "{$this->now()} ERR : {$this->db->error()["message"]}\n";
exit();
}
$rows = $qry->result_array();
if (count($rows) == 0) {
$sql = "insert into pb_upload(pbUploadCode,pbUploadExecuted) values('LUNAS',now())";
$qry = $this->db->query($sql);
if (!$qry) {
echo "{$this->now()} ERR Init pb Upload Pelunasan bayar di tempat: {$this->db->error()["message"]}\n";
exit();
}
$last_updated = "2021-11-01 00:00:01";
} else {
$last_updated = $rows[0]["pbUploadExecuted"];
}
echo "\t\tLast Updated : $last_updated\n";
$sql = "select distinct T_OnlineTxOrgID, T_OnlineTxNumbering, T_OnlineTxBookingName
from t_onlinetx
join t_onlineorder on T_OnlineTxID = T_OnlineOrderT_OnlineTxID
and T_OnlineTxIsLunas = 'Y'
and T_OnlineTxLastUpdated > ?
join t_orderheader on T_OrderHeaderID = T_OnlineOrderT_OrderHeaderID
join f_payment on F_PaymentT_OrderHeaderID = T_OrderHeaderID
join f_payment_orderheader on F_PaymentID = F_Payment_OrderHeaderF_PaymentID
and F_Payment_OrderHeaderIsLunas = 'Y'
join f_paymentdetail on F_PaymentID = F_PaymentDetailF_PaymentID
and F_PaymentDetailM_PaymentTypeID <> 1000
";
$qry = $this->db->query($sql, [$last_updated]);
if (!$qry) {
echo "{$this->now()} ERR Get TxOnineID: {$this->db->error()["message"]}\n";
exit();
}
$rows = $qry->result_array();
if (count($rows) == 0) {
echo "\t No Upload data\n";
exit;
}
$url = $this->url . "status_lunas";
$param = ["data" => $rows];
$z_param = gzdeflate(json_encode($param), 9);
$resp = $this->post($url, $z_param);
if ($resp["status"] == "OK") {
$counter = count($rows);
$sql = "update pb_upload set pbUploadExecuted = now() where pbUploadCode = 'LUNAS'";
$qry = $this->db->query($sql);
if (!$qry) {
echo "Error update pb_upload : " . $this->db->error()["message"] . "\n";
return;
} else {
$this->db->trans_commit();
}
echo "{$this->now()} Upload Pelunasan bayar di tempat : $counter\n";
} else {
echo "{$this->now()} ERR Upload Pelunasan bayar di tempat : {$resp["message"]}\n";
}
$this->status_lunas_hs($last_updated);
}
function status_lunas_hs($last_updated = "")
{
if ($last_updated = "") {
$last_updated = date("Y-m-d 00:00:00");
}
echo "{$this->now()} Start Pelunasan HS Bayar di Tempat\n";
$sql = "select distinct
T_TransactionOldID T_OnlineTxOrgID,
T_TransactionNumbering T_OnlineTxNumbering,
'' T_OnlineTxBookingName
from one_hs.t_transaction
where T_TransactionLastUpdated > ?
and T_TransactionTotalPaid = 0
and T_TransactionOldID > 0
";
$qry = $this->db->query($sql, [$last_updated]);
if (!$qry) {
echo "{$this->now()} ERR Get TxOnineID: {$this->db->error()["message"]}\n";
exit();
}
$rows = $qry->result_array();
$url = $this->url . "status_lunas";
if (count($rows) == 0) {
echo "\t No Upload data\n";
exit;
}
$url = $this->url . "status_lunas";
$param = ["data" => $rows];
$z_param = gzdeflate(json_encode($param), 9);
$resp = $this->post($url, $z_param);
if ($resp["status"] == "OK") {
$counter = count($rows);
echo "{$this->now()} Upload Pelunasan HS bayar di tempat : $counter\n";
} else {
echo "{$this->now()} ERR Upload Pelunasan HS bayar di tempat : {$resp["message"]}\n";
}
}
public function post($url, $data)
{
echo "{$this->now()} DEBUG : $url\n";
$ch = curl_init($url);
curl_setopt($ch, CURLOPT_CUSTOMREQUEST, "POST");
curl_setopt($ch, CURLOPT_POSTFIELDS, $data);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 5);
curl_setopt($ch, CURLOPT_TIMEOUT, 120);
curl_setopt($ch, CURLOPT_HTTPHEADER, [
"Content-Type: application/json",
"Content-Length: " . strlen($data),
]);
$z_result = curl_exec($ch);
if (curl_errno($ch) > 0) {
return [
"status" => "ERR",
"message" => curl_error($ch),
];
}
$httpCode = curl_getinfo($ch, CURLINFO_HTTP_CODE);
if ($httpCode != 200) {
return [
"status" => "ERR",
"message" => "Http Response : $httpCode | $z_result",
];
}
$result = gzinflate($z_result);
$j_result = json_decode($result, true);
if (!$j_result) {
return [
"status" => "ERR",
"message" => "JSON invalid: $z_result",
];
}
return $j_result;
}
function escape_fname($xname)
{
$find = [" ", "&", '\r\n', '\n', "+", ","];
$xname = str_replace($find, "-", $xname);
//delete and replace rest of special chars
$find = ["/[^a-zA-Z0-9\-<>]/", "/[\-]+/", "/<[^>]*>/"];
$repl = ["", "-", ""];
$xname = preg_replace($find, $repl, $xname);
return $xname;
}
}