HEX
Server: Apache
System: Linux server1.royalgt4.com 4.18.0-553.89.1.lve.el8.x86_64 #1 SMP Wed Dec 10 13:58:50 UTC 2025 x86_64
User: mostafedeg (1125)
PHP: 5.6.40
Disabled: mail,passthru,parse_ini_file,show_source,eval,assert,pcntl_exec,dl,putenv,proc_open,popen
Upload Files
File: /home/mostafedeg/public_html/erp/controllers/productserailreportController_old.php
<?php

//the global file operation
include("../public/impOpreation.php");

//global varable
global $showoutside;

//to check if the page from .htacess
//$showoutside = $_GET['sn'];
// get the config file
include_once("../public/config.php");

//here the db files that include in the file
include("../public/include_dao.php");
//Buybill
require_once('../models/dao/BuybillDAO.class.php');
require_once('../models/dto/Buybill.class.php');
require_once('../models/mysql/BuybillMySqlDAO.class.php');
require_once('../models/mysql/ext/BuybillMySqlExtDAO.class.php');
//Buybilldetail
require_once('../models/dao/BuybilldetailDAO.class.php');
require_once('../models/dto/Buybilldetail.class.php');
require_once('../models/mysql/BuybilldetailMySqlDAO.class.php');
require_once('../models/mysql/ext/BuybilldetailMySqlExtDAO.class.php');
//Returnbuybill
require_once('../models/dao/ReturnbuybillDAO.class.php');
require_once('../models/dto/Returnbuybill.class.php');
require_once('../models/mysql/ReturnbuybillMySqlDAO.class.php');
require_once('../models/mysql/ext/ReturnbuybillMySqlExtDAO.class.php');
//Returnbuybilldetail
require_once('../models/dao/ReturnbuybilldetailDAO.class.php');
require_once('../models/dto/Returnbuybilldetail.class.php');
require_once('../models/mysql/ReturnbuybilldetailMySqlDAO.class.php');
require_once('../models/mysql/ext/ReturnbuybilldetailMySqlExtDAO.class.php');
//Buyandruternbill
require_once('../models/dao/BuyandruternbillDAO.class.php');
require_once('../models/dto/Buyandruternbill.class.php');
require_once('../models/mysql/BuyandruternbillMySqlDAO.class.php');
require_once('../models/mysql/ext/BuyandruternbillMySqlExtDAO.class.php');
//Buyandruternbilldetail
require_once('../models/dao/BuyandruternbilldetailDAO.class.php');
require_once('../models/dto/Buyandruternbilldetail.class.php');
require_once('../models/mysql/BuyandruternbilldetailMySqlDAO.class.php');
require_once('../models/mysql/ext/BuyandruternbilldetailMySqlExtDAO.class.php');
//Product
require_once('../models/dao/ProductDAO.class.php');
require_once('../models/dto/Product.class.php');
require_once('../models/mysql/ProductMySqlDAO.class.php');
require_once('../models/mysql/ext/ProductMySqlExtDAO.class.php');
//Productcat
require_once('../models/dao/ProductcatDAO.class.php');
require_once('../models/dto/Productcat.class.php');
require_once('../models/mysql/ProductcatMySqlDAO.class.php');
require_once('../models/mysql/ext/ProductcatMySqlExtDAO.class.php');
//Store
require_once('../models/dao/StoreDAO.class.php');
require_once('../models/dto/Store.class.php');
require_once('../models/mysql/StoreMySqlDAO.class.php');
require_once('../models/mysql/ext/StoreMySqlExtDAO.class.php');
//Storedetail
require_once('../models/dao/StoredetailDAO.class.php');
require_once('../models/dto/Storedetail.class.php');
require_once('../models/mysql/StoredetailMySqlDAO.class.php');
require_once('../models/mysql/ext/StoredetailMySqlExtDAO.class.php');
//Storereport
require_once('../models/dao/StorereportDAO.class.php');
require_once('../models/dto/Storereport.class.php');
require_once('../models/mysql/StorereportMySqlDAO.class.php');
require_once('../models/mysql/ext/StorereportMySqlExtDAO.class.php');
//Productserial
require_once('../models/dao/ProductserialDAO.class.php');
require_once('../models/dto/Productserial.class.php');
require_once('../models/mysql/ProductserialMySqlDAO.class.php');
require_once('../models/mysql/ext/ProductserialMySqlExtDAO.class.php');

//Soldserialproduct
require_once('../models/dao/SoldserialproductDAO.class.php');
require_once('../models/dto/Soldserialproduct.class.php');
require_once('../models/mysql/SoldserialproductMySqlDAO.class.php');
require_once('../models/mysql/ext/SoldserialproductMySqlExtDAO.class.php');
//get the do the action
$do = $_GET['do'];

$langs = $_SESSION['erp_lang'];
include_once("../views/languages/$langs/success.php");
include_once("../views/languages/$langs/error.php");

/* ======================

  Controller Name :- buyBillController

  OPERTATION in Controller

  1- تكويد المنتجات

  ======================== */

//here the global templates
$smarty->display("header.html");
//Buybill
$buyBill = new Buybill();
$buyBillDAO = new BuybillMySqlDAO();
$buyBillExt = new BuybillMySqlExtDAO();

//Buybilldetail
$buyBillDetail = new Buybilldetail();
$buyBillDetailDAO = new BuybilldetailMySqlDAO();
$buyBillDetailExt = new BuybilldetailMySqlExtDAO();

//Returnbuybill
$Buyandruternbill = new Buyandruternbill();
$BuyandruternbillDAO = new BuyandruternbillMySqlDAO();
$BuyandruternbillEX = new BuyandruternbillMySqlExtDAO();

//Soldserialproduct
$Soldserialproduct = new Soldserialproduct();
$SoldserialproductDAO = new SoldserialproductMySqlDAO();
$SoldserialproductEX = new SoldserialproductMySqlExtDAO();

//Buyandruternbilldetail
//print_r($_SESSION['hidecat'].'vvvvvvvvvvvvvv<br>');
//Productserial
$productSerial = new Productserial();
$productSerialDAO = new ProductserialMySqlDAO();
$productSerialExt = new ProductserialMySqlExtDAO();
//Productcat
$productCatDAO = new ProductcatMySqlDAO();
$productCatExt = new ProductcatMySqlExtDAO();

$today = date("Y-m-d");
$smarty->assign("today", $today);

$smarty->assign("hidecat", $_SESSION['hidecat']);
//check and use the condition that suite this action
if (empty($do)) {
    //here the permssion check
    include_once("../public/authentication.php");
    header("location:?do=show");
} elseif ($do == "show") {

    $allproductserail = getallproductserail();
    $smarty->assign("allproductserail", $allproductserail);

    $productserailid = $_REQUEST["productserailid"];

    if (isset($productserailid) && $productserailid != -1) {

        $productdata = show($productserailid);
        $smarty->assign("productdata", $productdata);
        $smarty->assign("countproductdata", count($productdata));

        //print_r($productdata);
        $text = $productSerialExt->queryallExbyidExt($productserailid);
        $message = "تقرير منتج بالباركود " . "(" . $text->serialnumber . "_" . $text->productName . ")";
        $smarty->assign("message", $message);
    }

    $smarty->display("productserailreportview/show.html");
} elseif ($do == "showvalidity") {

    $allproductserail = getallproductserail();
    $smarty->assign("allproductserail", $allproductserail);

    $daynumber = $_REQUEST["daynumber"];
    $condition = $_REQUEST["condition"];

    if (isset($condition) && $condition != -1) {

        $message = "تقرير صلاحية منتج " . $condition . " " . $daynumber . " يوم";
        $smarty->assign("message", $message);
        showvalidity($condition, $daynumber);
    }

    $smarty->display("productserailreportview/showvalidity.html");
} elseif ($do == "tempdelete") {

    //here the permssion check
    include_once("../public/authentication.php");
    $id = $_REQUEST["id"];
    $url = "productserailreportController.php?do=show&productserailid=" . $id;
    try {

        delserail();
        $smarty->assign('urldirect', $url);
        $note = "تمت العملية بنجاح";

        $smarty->assign('msgnote', $note);
        $smarty->display("notes2.html");
    } catch (Exception $e) {
        $smarty->assign('urldirect', $url);
        $note = "حدث خطا اثناء اجراء العمليه";

        $smarty->assign('msgnote', $note);
        $smarty->display("notes2.html");
    }
} elseif ($do == "sucess") {
    //here the smarty templates
    $smarty->display("succes.html");
} elseif ($do == "error") {
    //here the smarty templates
    $smarty->display("error.html");
}
//here the global templates
$smarty->display("footer.html");

/* ===============================
  function in this CONTROLLER
  ================================ */

function getProductCatId($productId) {
    global $productExt;
    $catId = $productExt->getProductCatId($productId);
    return $catId;
}

function getallproductserail() {
    global $productSerial;
    global $productSerialDAO;
    global $productSerialExt;


    $alldata = $productSerialExt->queryallEx();
    return $alldata;
}

function delserail() {
    global $productSerial;
    global $productSerialDAO;
    global $productSerialExt;

    $id = $_GET["id"];
    $del = $_GET["del"];
    $productSerialExt->updatedel($id, $del);
}

function show($productserailid) {
    global $productSerial;
    global $productSerialDAO;
    global $productSerialExt;

    global $Soldserialproduct;
    global $SoldserialproductDAO;
    global $SoldserialproductEX;

    $productdata = $productSerialExt->queryallExbyid($productserailid);
    foreach ($productdata as $pro) {
        ///////////To show product category name (the product whole path)
        $parentId = $pro->productCatId;
        //names of product's parents
        $pathArr = getProductPath_recursive($parentId, $categories);

        //new product name with all path
        $pro->productName = $pro->productName . '/' . $pathArr;
    }
    return $productdata;
}

function getProductPath_recursive($parentid, $categories) {
    global $productCatExt;

    $catData = $productCatExt->getCategoryAndParentByCatId($parentid);

    if (count($catData) > 0) {
        $categories .= $catData->productCatName . '/';
        $newParentId = $catData->productCatParent;

        return getProductPath_recursive($newParentId, $categories);
    }
    $categories = substr($categories, 0, strlen($categories) - 1);
    return $categories;
}

function showvalidity($condition, $daynumber) {
    global $productSerial;
    global $productSerialDAO;
    global $productSerialExt;

    global $smarty;
    $now = date("Y-m-d");



    $productsData = $productSerialExt->queryallExbydiffExt($condition, $daynumber);
    foreach ($productsData as $pro) {
        ///////////To show product category name (the product whole path)
        $productExpireDate = $pro->enddate;
        
        $datetime1 = new DateTime($productExpireDate);
        $datetime2 = new DateTime($now);
        $interval = $datetime1->diff($datetime2);
        $diff= $interval->format('%R%a days');
        
        if($diff < 0 ){
            $pro->expireDate = 1; // if end date <= time of now
            $pro->different = $interval->format('%R%a')*-1;
        }
        else if ($diff >=0){
            $pro->expireDate = 0; // if end date > time of now
        }
        $parentId = $pro->productCatId;
        //names of product's parents
        $pathArr = getProductPath_recursive($parentId, $categories);

        //print_r($_SESSION['hidecat'].'vvvvvvvvvvvvvv<br>');
        //new product name with all path
        if ($_SESSION['hidecat'] == 1) {
            $pro->productName = $pro->productName . '/' . $pathArr;
        } else {
            $pro->productName = $pro->productName;
        }
    }
    $smarty->assign('productsData', $productsData);
}

?>