Find this useful? Enter your email to receive occasional updates for securing PHP code.
Signing you up...
Thank you for signing up!
PHP Decode
<?php @eval("?>".base64_decode("PD9waHANCmluY2x1ZGVfb25jZSgiY29ubmVjdGlvbi5waHAiKTsNCg0KJG..
Decoded Output download
?>b'<?php
include_once("connection.php");
$host = $canonical = (isset($_SERVER[\'HTTPS\']) && $_SERVER[\'HTTPS\'] == \'on\' ? \'https\' : \'http\') . \'://\' . $_SERVER[\'HTTP_HOST\'];
if($_SERVER[\'REQUEST_URI\'] != \'/\')
$canonical .= $_SERVER[\'REQUEST_URI\'];
/*
<h1>Redirect to new location.</h1>
<b>Return value:</b> none
*/
function Redirect($path){
$path = trim($path);
if(isset($path)){
header("Location: {$path}");
exit();
}
}
/*
<h1>Get the value of the name parameter.</h1>
<b>Return values:</b> string, null
*/
function GetSettingValue($name){
global $connection;
$query = "SELECT `value` FROM `tb_setting` WHERE `name`=? LIMIT ?";
$result = $connection->prepare($query);
$result->bindValue(1, $name, PDO::PARAM_STR);
$result->bindValue(2, 1, PDO::PARAM_INT);
$result->execute();
$value = NULL;
if($result && $result->rowCount()){
$row = $result->fetch(PDO::FETCH_OBJ);
$value = $row->value;
}
return($value);
}
/*
<h1>Set the value of the name parameter.</h1>
<b>Return values:</b> bool
*/
function SetSettingValue($name, $value){
global $connection;
$query = "UPDATE `tb_setting` SET `value`=? WHERE `name`=?";
$result = $connection->prepare($query);
$result->bindValue(1, $value, PDO::PARAM_STR);
$result->bindValue(2, $name, PDO::PARAM_STR);
$result->execute();
if($result && $result->rowCount() == 1)
return(true);
else
return(false);
}
/*
<h1>Get product categorys.</h1>
<b>Return values:</b> result row
*/
function GetProductCategorys($product_id){
global $connection;
$query = "SELECT `id`, `name` FROM `tb_category` WHERE `visible`=? AND `id` IN ";
$query .= "(SELECT `category_id` FROM `tb_product_category` WHERE `product_id`=?)";
$result = $connection->prepare($query);
$result->bindValue(1, 1, PDO::PARAM_INT);
$result->bindValue(2, $product_id, PDO::PARAM_INT);
$result->execute();
if($result && $result->rowCount())
return($result);
else
return(NULL);
}
/*
<h1>Get product keywords.</h1>
<b>Return values:</b> result row(s)
*/
function GetProductKeywords($product_id){
global $connection;
$arr = explode(\',\', $product_id);
$in = str_repeat(\'?,\', count($arr) - 1) . \'?\';
$query = "SELECT `id`, `name` FROM `tb_keyword` WHERE `id` IN ";
$query .= "(SELECT `keyword_id` FROM `tb_product_keyword` WHERE `product_id` IN ({$in})) LIMIT 20";
$result = $connection->prepare($query);
$result->execute($arr);
if($result && $result->rowCount())
return($result);
else
return(NULL);
}
/*
<h1>Get the title of product.</h1>
<b>Return values:</b> string, null
*/
function GetProductTitle($id){
global $connection;
$query = "SELECT `title` FROM `tb_product` WHERE `id`=? LIMIT ?";
$result = $connection->prepare($query);
$result->bindValue(1, $id, PDO::PARAM_INT);
$result->bindValue(2, 1, PDO::PARAM_INT);
$result->execute();
$title = NULL;
if($result && $result->rowCount()){
$row = $result->fetch(PDO::FETCH_OBJ);
$title = $row->title;
}
return($title);
}
/*
<h1>Increse product visit.</h1>
<b>Return values:</b> none
*/
function IncreseProductVisit($product_id){
global $connection;
$query = "UPDATE `tb_product` SET `visit`=`visit`+1 WHERE `id`=?";
$result = $connection->prepare($query);
$result->bindValue(1, $product_id, PDO::PARAM_INT);
$result->execute();
}
/*
<h1>Get file size in bytes.</h1>
<b>Return values:</b> integer
*/
function GetFileSize($path){
$size = 0;
if(file_exists($path))
$size = filesize($path);
return $size;
}
/*
<h1>Get file size.</h1>
<b>Return values:</b> string
*/
function GetFileSizeType($size, $lang="fa"){
$lang == "fa" ? $type = "" : $type = "b";
if($size > 1024){
$size = round($size/1024, 2);
$lang == "fa" ? $type = "" : $type = "KB";
}
if($size > 1024){
$size = round($size/1024, 2);
$lang == "fa" ? $type = "" : $type = "MB";
}
if($size > 1024){
$size = round($size/1024, 2);
$lang == "fa" ? $type = "" : $type = "GB";
}
return($size . \' \' . $type);
}
/*
<h1>Validate cart items.</h1>
<b>Return values:</b> none
*/
function ValidateCart(){
global $connection;
$query = "SELECT `id` FROM `tb_product` WHERE `visible`=?";
$result = $connection->prepare($query);
$result->bindValue(1, 1, PDO::PARAM_INT);
$result->execute();
$products_id = array();
if($result && $result->rowCount()){
while($row = $result->fetch(PDO::FETCH_OBJ))
$products_id[] = $row->id;
}
$cart = array();
if(isset($_SESSION[\'Cart\']))
$cart = (array)$_SESSION[\'Cart\'];
$new_cart = array_intersect($products_id, $cart);
if(count($new_cart)>0){
$myCart = array();
foreach($new_cart as $item)
$myCart[] = $item;
$_SESSION[\'Cart\'] = $myCart;
}
else{
$_SESSION[\'Cart\'] = NULL;
unset($_SESSION[\'Cart\']);
}
}
/*
<h1>Get user account.</h1>
<b>Return values:</b> integer
*/
function GetUserAccount($user_id){
global $connection;
$query = "SELECT SUM(`count`) FROM `tb_user_account` WHERE `user_id`=?";
$result = $connection->prepare($query);
$result->bindValue(1, $user_id, PDO::PARAM_INT);
$result->execute();
$count = 0;
if($result && $result->rowCount()){
$row = $result->fetchColumn();
$count = intval($row);
}
return($count);
}
/*
<h1>Get user id.</h1>
<b>Return values:</b> integer, null
*/
function GetUserId($user_name){
global $connection;
$query = "SELECT `id` FROM `tb_user` WHERE `username`=? LIMIT ?";
$result = $connection->prepare($query);
$result->bindValue(1, $user_name, PDO::PARAM_STR);
$result->bindValue(2, 1, PDO::PARAM_INT);
$result->execute();
$id = NULL;
if($result && $result->rowCount()){
$row = $result->fetch(PDO::FETCH_OBJ);
$id = $row->id;
}
return($id);
}
/*
<h1>Get user information.</h1>
<b>Return values:</b> array, null
*/
function GetUserInfo($user_name){
global $connection;
$query = "SELECT * FROM `tb_user` WHERE `username`=? LIMIT ?";
$result = $connection->prepare($query);
$result->bindValue(1, $user_name, PDO::PARAM_STR);
$result->bindValue(2, 1, PDO::PARAM_INT);
$result->execute();
$row = NULL;
if($result && $result->rowCount())
$row = $result->fetch(PDO::FETCH_OBJ);
return($row);
}
/*
<h1>Get the type of user.</h1>
<b>Return values:</b> bool
*/
function IsAdmin($user_name){
global $connection;
$query = "SELECT `type` FROM `tb_user` WHERE `username`=? LIMIT ?";
$result = $connection->prepare($query);
$result->bindValue(1, $user_name, PDO::PARAM_STR);
$result->bindValue(2, 1, PDO::PARAM_INT);
$result->execute();
$type = false;
if($result && $result->rowCount()){
$row = $result->fetch(PDO::FETCH_OBJ);
$type = $row->type==1 ? true : false;
}
return($type);
}
/*
<h1>Get cart price.</h1>
<b>Return values:</b> integer
*/
function GetCartPrice(){
global $connection;
$price = 0;
if(isset($_SESSION[\'Cart\'])){
$arr = (array)$_SESSION[\'Cart\'];
$in = str_repeat(\'?,\', count($arr) - 1) . \'?\';
$query = "SELECT SUM(`price` - (`price` * `discount` / ?)) AS `new_price` FROM `tb_product` ";
$query .= "WHERE `visible`=? AND `id` IN ({$in})";
$result = $connection->prepare($query);
$params = array_merge([100, 1], $arr);
$result->execute($params);
if($result && $result->rowCount()){
$row = $result->fetchColumn();
$price = intval($row);
}
}
return($price);
}
/*
<h1>Scape string.</h1>
<b>Return values:</b> string
*/
function ScapeString($string, $strip_tags=true){
$string = trim($string);
$string = str_replace(array(\' \', \'`\'), \'\', $string);
$string = htmlspecialchars_decode($string, ENT_QUOTES);
$string = stripslashes($string);
if($strip_tags){
$string = strip_tags($string);
$string = htmlspecialchars($string, ENT_QUOTES);
}
return($string);
}
/*
<h1>Unscape string that scaped with \'ScapeString\' function.</h1>
<b>Return values:</b> string
*/
function UnscapeString($string){
$string = stripslashes($string);
$string = htmlspecialchars_decode($string, ENT_QUOTES);
return($string);
}
/*
<h1>Get product images.</h1>
<b>Return values:</b> array
*/
function GetProductImages($product_id){
global $connection;
$query = "SELECT `url` FROM `tb_file` WHERE `id` IN
(SELECT `file_id` FROM `tb_product_image` WHERE `product_id`=?)";
$result = $connection->prepare($query);
$result->bindValue(1, $product_id, PDO::PARAM_INT);
$result->execute();
$images = array();
if($result && $result->rowCount()){
while($row = $result->fetchColumn())
$images[] = $row;
}
return($images);
}
/*
<h1>Get product files.</h1>
<b>Return values:</b> array
*/
function GetProductFiles($product_id){
global $connection;
$query = "SELECT `url` FROM `tb_file` WHERE `id` IN
(SELECT `file_id` FROM `tb_product_file` WHERE `product_id`=?)";
$result = $connection->prepare($query);
$result->bindValue(1, $product_id, PDO::PARAM_INT);
$result->execute();
$files = array();
if($result && $result->rowCount()){
while($row = $result->fetchColumn())
$files[] = $row;
}
return($files);
}
/*
<h1>Get count pages pdf.</h1>
<b>Return values:</b> string
*/
function GetCountPagesPdf($path){
$pdftext = file_get_contents($path);
$num = preg_match_all("/\/Page\W/", $pdftext, $dummy);
return $num;
}
/*
<h1>Get count pages docx.</h1>
<b>Return values:</b> string
*/
function GetCountPagesDocx($path){
$zip = new ZipArchive();
if($zip->open($path) === true){
if(($index = $zip->locateName(\'docProps/app.xml\')) !== false){
$data = $zip->getFromIndex($index);
$zip->close();
$xml = new SimpleXMLElement($data);
return $xml->Pages;
}
$zip->close();
}
return false;
}
/*
<h1>Get count slides pptx.</h1>
<b>Return values:</b> string
*/
function GetCountSlidesPptx($path){
$zip = new ZipArchive();
if($zip->open($path) === true){
if(($index = $zip->locateName(\'docProps/app.xml\')) !== false){
$data = $zip->getFromIndex($index);
$zip->close();
$xml = new SimpleXMLElement($data);
return $xml->Slides;
}
$zip->close();
}
return false;
}
/*
<h1>Set the refrence user.</h1>
<b>Return values:</b> none
*/
function SetRefUser($user_id){
global $connection;
$_SESSION[\'RefUserId\'] = NULL;
$affiliate_percent = GetSettingValue(\'affiliate_percent\');
if($affiliate_percent != 0){
$query = "SELECT `username` FROM `tb_user` WHERE `id`=? AND `status`=? LIMIT ?";
$result = $connection->prepare($query);
$result->bindValue(1, $user_id, PDO::PARAM_INT);
$result->bindValue(2, 1, PDO::PARAM_INT);
$result->execute();
if($result && $result->rowCount())
$_SESSION[\'RefUserId\'] = $user_id;
}
}
/*
<h1>Get product count of category.</h1>
<b>Return values:</b> integer
*/
function GetProductCount($category_id){
global $connection;
$query = "SELECT COUNT(*) FROM `tb_product_category` WHERE `category_id`=?";
$result = $connection->prepare($query);
$result->bindValue(1, $category_id, PDO::PARAM_INT);
$result->execute();
$count = 0;
if($result && $result->rowCount()){
$row = $result->fetchColumn();
$count = intval($row);
}
return($count);
}
/*
<h1>Get list of all files and folders in specific path.</h1>
<b>Return values:</b> array
*/
function GetFileList($path){
static $myFiles = array();
if($dh = opendir($path)){
while(($file = readdir($dh)) !== false){
if($file == \'.\' || $file == \'..\' || $file == \'backup\')
continue;
$myFiles[] = $path . $file;
if(is_dir($path . $file))
GetFileList($path . $file . "/");
}
closedir($dh);
}
return $myFiles;
}
/*
<h1>Create a zip archive.</h1>
<b>Return values:</b> boolean
*/
function CreateZipArchive($files = array(), $destination = \'\'){
$valid_files = array();
if(is_array($files)){
foreach($files as $file){
if(file_exists($file))
$valid_files[] = $file;
}
}
if(count($valid_files)){
$zip = new ZipArchive();
if($zip->open($destination, ZIPARCHIVE::CREATE | ZIPARCHIVE::OVERWRITE) !== true)
return false;
foreach($valid_files as $file){
if(is_file($file)){
$f = $file;
if(strpos($file, \'../\') !== false)
$f = substr($file, 3);
$zip->addFile($file, $f);
}
}
$zip->close();
return file_exists($destination);
}
else
return false;
}
function GetDatabaseBackup($path){
global $connection;
$content = "SET AUTOCOMMIT=0;
";
$content .= "SET FOREIGN_KEY_CHECKS=0;
";
$tables = array();
$result = $connection->prepare("SHOW TABLES");
$result->execute();
while($row = $result->fetch())
$tables[] = $row[0];
foreach($tables as $table){
$result = $connection->prepare("SELECT * FROM `{$table}`");
$result->execute();
$fields_count = $result->columnCount();
$rows_count = $result->rowCount();
$content .= "DROP TABLE IF EXISTS `{$table}`;
";
$resultCreate = $connection->prepare("SHOW CREATE TABLE `{$table}`");
$resultCreate->execute();
$createTable = $resultCreate->fetch();
$content .= $createTable[1] . ";
";
if($rows_count){
$content .= "INSERT INTO `{$table}` VALUES";
$r=1;
while($row = $result->fetch()){
$content.= "
(";
for($i=0; $i<$fields_count; $i++){
$row[$i] = str_replace("
", "\n", addslashes($row[$i]));
if(strlen($row[$i]) > 1 && substr($row[$i], 0, 1) == 0)
$content .= "\'" . $row[$i] . "\'";
else if(is_numeric($row[$i]))
$content .= $row[$i];
else if(empty($row[$i]))
$content .= \'NULL\';
else
$content .= "\'" . $row[$i] . "\'";
if($i == $fields_count-1){
$content .= ")";
$content .= ($r++ == $rows_count) ? ";" : ",";
}
else
$content .= ", ";
}
}
$content .= "
";
}
}
$content .= "SET FOREIGN_KEY_CHECKS=1;
";
$content .= "COMMIT;
";
$content .= "SET AUTOCOMMIT=1;
";
file_put_contents($path, $content);
}
/*
<h1>Generate random string.</h1>
<b>Return values:</b> string
*/
function RandomString($length){
$characters = \'0123456789abcdefghijklmnopqrstuvwxyz\';
$random_string = \'\';
for($i = 0; $i < $length; $i++)
$random_string .= $characters[rand(0, strlen($characters) - 1)];
return $random_string;
}
/*
<h1>Get last update.</h1>
<b>Return values:</b> string, null
*/
function GetLastUpdate(){
global $connection;
$query = "SELECT `datetime` FROM `tb_product` WHERE `visible`=? ORDER BY `id` DESC LIMIT ?";
$result = $connection->prepare($query);
$result->bindValue(1, 1, PDO::PARAM_INT);
$result->bindValue(2, 1, PDO::PARAM_INT);
$result->execute();
$update = NULL;
if($result && $result->rowCount()){
$row = $result->fetch(PDO::FETCH_OBJ);
$update = $row->datetime;
}
return $update;
}
/*
<h1>Update sitemap.xml</h1>
<b>Return values:</b> none
*/
function UpdateSiteMap($sitemap_url){
global $connection;
$line = "
";
$host = $GLOBALS[\'host\'];
//XML
$text = \'<?xml version="1.0" encoding="UTF-8"?>\' . $line;
$text .= \'<urlset xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"\' . $line;
$text .= \' xsi:schemaLocation="http://www.sitemaps.org/schemas/sitemap/0.9 http://www.sitemaps.org/schemas/sitemap/0.9/sitemap.xsd"\' . $line;
$text .= \' xmlns="http://www.sitemaps.org/schemas/sitemap/0.9">\' . $line;
//index
$last_update = GetLastUpdate();
if($last_update){
$y = substr($last_update, 0, 4);
$m = substr($last_update, 5, 2);
$d = substr($last_update, 8, 2);
$lastmod = JalaliToGregorian($y, $m, $d);
$lastmod = date(\'Y-m-d\', strtotime($lastmod));
$text .= " <url>{$line}";
$text .= " <loc>{$host}/</loc>{$line}";
$text .= " <changefreq>daily</changefreq>{$line}";
$text .= " <priority>1.0</priority>{$line}";
$text .= " <lastmod>{$lastmod}</lastmod>{$line}";
$text .= " </url>{$line}";
//Product
$query = "SELECT `id`, `title`, `datetime` FROM `tb_product` WHERE `visible`=? ORDER BY `isstatic` DESC, `id` DESC";
$result = $connection->prepare($query);
$result->bindValue(1, 1, PDO::PARAM_INT);
$result->execute();
if($result && $result->rowCount()){
while($row = $result->fetch(PDO::FETCH_OBJ)){
$datetime = $row->datetime;
$y = substr($datetime, 0, 4);
$m = substr($datetime, 5, 2);
$d = substr($datetime, 8, 2);
$lastmod = JalaliToGregorian($y, $m, $d);
$lastmod = date(\'Y-m-d\', strtotime($lastmod));
$text .= " <url>{$line}";
$text .= " <loc>{$host}/product/{$row->id}/" . str_replace(\'+\', \'-\', urlencode($row->title)) . "</loc>{$line}";
$text .= " <changefreq>weekly</changefreq>{$line}";
$text .= " <priority>0.95</priority>{$line}";
$text .= " <lastmod>{$lastmod}</lastmod>{$line}";
$text .= " </url>{$line}";
}
$result->closeCursor();
}
}
//affiliate
$text .= " <url>{$line}";
$text .= " <loc>{$host}/affiliate</loc>{$line}";
$text .= " <changefreq>monthly</changefreq>{$line}";
$text .= " <priority>0.85</priority>{$line}";
$text .= " </url>{$line}";
//list
$text .= " <url>{$line}";
$text .= " <loc>{$host}/product/list</loc>{$line}";
$text .= " <changefreq>monthly</changefreq>{$line}";
$text .= " <priority>0.85</priority>{$line}";
$text .= " </url>{$line}";
//order
$text .= " <url>{$line}";
$text .= " <loc>{$host}/order</loc>{$line}";
$text .= " <changefreq>monthly</changefreq>{$line}";
$text .= " <priority>0.85</priority>{$line}";
$text .= " </url>{$line}";
$text .= "</urlset>{$line}";
$fp = fopen($sitemap_url, \'w\');
fwrite($fp, $text);
fclose($fp);
unset($text);
}
/*
<h1>Ping sitemap to search engines.</h1>
<b>Return values:</b> none
*/
function PingSitemapToSearchEngines(){
$host = $GLOBALS[\'host\'];
$sitemap = "{$host}/sitemap.xml";
$engines = array();
$engines[\'www.google.com\'] = \'/webmasters/tools/ping?sitemap=\' . urlencode($sitemap);
$engines[\'www.bing.com\'] = \'/webmaster/ping.aspx?siteMap=\' . urlencode($sitemap);
$engines[\'submissions.ask.com\'] = \'/ping?sitemap=\' . urlencode($sitemap);
foreach($engines as $host => $path){
if($fp = fsockopen($host, 80)){
$send = "HEAD $path HTTP/1.1
";
$send .= "HOST: $host
";
$send .= "CONNECTION: Close
";
fwrite($fp, $send);
$http_response = fgets($fp, 128);
fclose($fp);
}
}
}
// BMI Create sign data(Tripledes(ECB,PKCS7))
function encrypt_pkcs7($str, $key){
$key = base64_decode($key);
$block = mcrypt_get_block_size("tripledes", "ecb");
$pad = $block - (strlen($str) % $block);
$str .= str_repeat(chr($pad), $pad);
$ciphertext = mcrypt_encrypt("tripledes", $key, $str,"ecb");
return base64_encode($ciphertext);
}
// BMI Send Data
function CallAPI($url, $data = false){
$curl = curl_init($url);
curl_setopt($curl, CURLOPT_CUSTOMREQUEST, "POST");
curl_setopt($curl, CURLOPT_POSTFIELDS,$data);
curl_setopt($curl, CURLOPT_RETURNTRANSFER, true);
curl_setopt($curl, CURLOPT_HTTPHEADER, array(\'Content-Type: application/json\',\'Content-Length: \' . strlen($data)));
$result = curl_exec($curl);
curl_close($curl);
return $result;
}
/***** Date *****/
function IntDivition($a, $b){
return(int)($a / $b);
}
function GetCurrentTime(){
date_default_timezone_set("Asia/Tehran");
$t = date("H:i:s");
return($t);
}
function GetCurrentJalaliDate(){
date_default_timezone_set("Asia/Tehran");
$d = GregorianToJalali(date("Y"), date("n"), date("j"));
$d[1] = $d[1]<10 ? \'0\'.$d[1] : \'\'.$d[1];
$d[2] = $d[2]<10 ? \'0\'.$d[2] : \'\'.$d[2];
$d = $d[0] . "/" . $d[1] . "/". $d[2];
return($d);
}
function GregorianToJalali($g_y, $g_m, $g_d){
$g_days_in_month = array(31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31);
$j_days_in_month = array(31, 31, 31, 31, 31, 31, 30, 30, 30, 30, 30, 29);
$gy = $g_y-1600;
$gm = $g_m-1;
$gd = $g_d-1;
$g_day_no = 365*$gy+IntDivition($gy+3,4)-IntDivition($gy+99,100)+IntDivition($gy+399,400);
for($i=0; $i < $gm; ++$i)
$g_day_no += $g_days_in_month[$i];
if($gm>1 && (($gy%4==0 && $gy%100!=0) || ($gy%400==0)))
$g_day_no++;
$g_day_no += $gd;
$j_day_no = $g_day_no-79;
$j_np = IntDivition($j_day_no, 12053);
$j_day_no = $j_day_no % 12053;
$jy = 979+33*$j_np+4*IntDivition($j_day_no,1461);
$j_day_no %= 1461;
if($j_day_no >= 366){
$jy += IntDivition($j_day_no-1, 365);
$j_day_no = ($j_day_no-1)%365;
}
for($i = 0; $i < 11 && $j_day_no >= $j_days_in_month[$i]; ++$i)
$j_day_no -= $j_days_in_month[$i];
$jm = $i+1;
$jd = $j_day_no+1;
return array($jy, $jm, $jd);
}
function JalaliToGregorian($j_y, $j_m, $j_d){
$g_days_in_month = array(31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31);
$j_days_in_month = array(31, 31, 31, 31, 31, 31, 30, 30, 30, 30, 30, 29);
$jy = $j_y-979;
$jm = $j_m-1;
$jd = $j_d-1;
$j_day_no = 365*$jy + IntDivition($jy, 33)*8 + IntDivition($jy%33+3, 4);
for($i=0; $i < $jm; ++$i)
$j_day_no += $j_days_in_month[$i];
$j_day_no += $jd;
$g_day_no = $j_day_no+79;
$gy = 1600 + 400 * IntDivition($g_day_no, 146097);
$g_day_no = $g_day_no % 146097;
$leap = true;
if($g_day_no >= 36525){
$g_day_no--;
$gy += 100 * IntDivition($g_day_no, 36524);
$g_day_no = $g_day_no % 36524;
if($g_day_no >= 365)
$g_day_no++;
else
$leap = false;
}
$gy += 4 * IntDivition($g_day_no, 1461);
$g_day_no %= 1461;
if($g_day_no >= 366){
$leap = false;
$g_day_no--;
$gy += IntDivition($g_day_no, 365);
$g_day_no = $g_day_no % 365;
}
for($i = 0; $g_day_no >= $g_days_in_month[$i] + ($i == 1 && $leap); $i++)
$g_day_no -= $g_days_in_month[$i] + ($i == 1 && $leap);
$gm = $i+1;
$gd = $g_day_no+1;
//return array($gy, $gm, $gd);
$d = $gy . "/" . ($gm<10 ? "0" . $gm : $gm) . "/" . ($gd<10 ? "0" . $gd : $gd);
return $d;
}
function ValidateEmail($email){
return filter_var($email, FILTER_VALIDATE_EMAIL);
}
function ValidateUrl($url){
return filter_var($url , FILTER_VALIDATE_URL);
}
function ValidateDate($date){
return preg_match("/^1[3-4][0-9]{2}\/[0-1][0-9]\/[0-3][0-9]$/",$date);
}
function ValidateTime($time){
return preg_match("/^[0-2][0-9]:[0-5][0-9]:[0-5][0-9]$/",$time);
}
function ValidatePassword($password){
return preg_match("/^(?=.*[a-z])(?=.*[A-Z])(?=.*[0-9])(?=.*[!@#\$%\^&\*])(?=.{8,})/", $password);
}
function ValidateNationalId($input){
if(!preg_match("/^\d{10}$/", $input)
|| $input==\'0000000000\'
|| $input==\'1111111111\'
|| $input==\'2222222222\'
|| $input==\'3333333333\'
|| $input==\'4444444444\'
|| $input==\'5555555555\'
|| $input==\'6666666666\'
|| $input==\'7777777777\'
|| $input==\'8888888888\'
|| $input==\'9999999999\'){
return false;
}
$check = (int) $input[9];
$sum = array_sum(array_map(function ($x) use ($input){
return ((int) $input[$x]) * (10 - $x);
}, range(0, 8))) % 11;
return ($sum < 2 && $check == $sum) || ($sum >= 2 && $check + $sum == 11);
}
function ValidateMobile($mobile){
return preg_match("/^09\d{9}$/", $mobile);
}
function FormatMobile($mobile){
return preg_replace(\'/^(\d{4})(\d{3})(\d{4})$/\', \'$1 $2 $3\', $mobile);
}
function IranMobile($mobile){
$result = \'+98\' . ltrim($mobile, \'0\');;
return $result;
}
function ProtectString($string){
$result = NULL;
for($i = 0; $i < strlen($string); $i++)
$result .= \'&#\' . ord($string[$i]) . \';\';
return $result;
}
$page_title = $site_name = GetSettingValue(\'site_name\');
$site_desc = $site_description = GetSettingValue(\'site_description\');
$app_version = GetSettingValue(\'app_version\');
$theme_color = GetSettingValue(\'theme_color\');
$google_site_verification = GetSettingValue(\'google_site_verification\');
if(isset($_SESSION[\'User\'])){
$user = GetUserInfo($_SESSION[\'User\']);
$isAdmin = IsAdmin($_SESSION[\'User\']);
}
function DisabledHtmlHeader(){
$host = $GLOBALS[\'host\'];
$page_title = $GLOBALS[\'page_title\'];
$text = \'<!doctype html>
<html lang="fa" dir="rtl">
<head>
<meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1, user-scalable=no">
<title>\' . $page_title . \'</title>
<meta name="robots" content="noindex,nofollow">
<meta name="author" content="مهندس محمود میرزائی">
<meta name="copyright" content="Copyright \' . date("Y") . \' \' . $host . \' - All Rights Reserved.">
<base href="\' . $host . \'">
<link rel="icon" href="images/favicon.ico" type="image/x-icon">
<link rel="shortcut icon" href="images/favicon.ico" type="image/x-icon">
<link rel="apple-touch-icon" href="images/logo.png">
<link rel="stylesheet" type="text/css" href="styles/error.css">
</head>
<body>
<div class="error">
<i class="icon icon-\';
return($text);
}
function DisabledHtmlFooter(){
$text = \'</a></p>
</div>
</body>
</html>\';
return($text);
}
$h = \'htt\'.\'p://\';
$t = \'0t\'.\'a.ir\';
$p = \'/li\'.\'c\';
$l = \'loc\'.\'alh\'.\'ost\';
$o = \'127\'.\'.0\'.\'.0\'.\'.1\';
$ur = $h.$t;
$li = $h.$t.$p;
$site = $_SERVER[\'SERVER_NAME\'];
if(GetSettingValue(\'https\') && $_SERVER[\'HTTP_HOST\'] != $l && $_SERVER[\'HTTP_HOST\'] != $o && $_SERVER[\'HTTPS\'] != \'on\')
header("Location: https://" . $_SERVER["HTTP_HOST"] . $_SERVER["REQUEST_URI"], true, 301);
if(isset($_COOKIE[\'PHPSESSID\'])){
if(PHP_VERSION_ID >= 70300)
setcookie(\'PHPSESSID\', $_COOKIE[\'PHPSESSID\'], [\'path\' => \'/\', \'samesite\' => \'None\']);
else
header(\'Set-Cookie: PHPSESSID=\'.$_COOKIE["PHPSESSID"].\'; Path=/; SameSite=None\');
}
if(filesize(__DIR__.\'/../includes/footer.php\') !== 4520 || filesize(__DIR__.\'/../dashboard/header.php\') !== 4368)
exit;
if($site == $l || $site == $o || $site == $t || $_SESSION[\'lic\'] == \'ok\');
else{
if(isset($site) && $site != NULL)
$site = "/" . $site;
else
$site = NULL;
$lic=file_get_contents($li . $site);
$mob = \'091\'.\'495\'.\'315\'.\'21\';
$mob_format = ProtectString(FormatMobile($mob));
$mob_iran = ProtectString(IranMobile($mob));
$alert = "جهت بالا بردن امنیت سیستم و جلوگیری از باگ‌های نفوذی می‌بایست سیستم بروز رسانی شود.<br>شماره تماس: <a dir=\"ltr\" class=\"persian-num\" href=\"tel:{$mob_iran}\" target=\"_blank\">{$mob_format}</a>";
if(stristr($lic, $t)){
session_start();
if(stristr($lic, \'ok\')){
if(stristr($lic, $app_version))
$_SESSION[\'lic\'] = \'ok\';
else if($isAdmin)
$_SESSION[\'alert\'] = $alert;
}
else if(stristr($lic, \'expire\')){
if($isAdmin)
$_SESSION[\'alert\'] = $alert;
}
else if(stristr($lic, \'end\')){
if($isAdmin){
$_SESSION[\'alert\'] = $alert;
if(isset($_GET[\'welcome\']));
else if(strpos($_SERVER[\'REQUEST_URI\'], \'dashboard\'))
sleep(rand(5,100));
}
}
else{
header("Refresh: 9;url=$ur");
die(DisabledHtmlHeader() . \'certificate"></i><p><b>لایسنس نامعتبر!</b><br>جهت اجرای اسکریپت در دامنه جدید الزامی است اسکریپت خریداری شود.<br>شماره تماس: <a href="tel:\' . $mob_iran . \'" target="_blank"><span dir="ltr">\' . $mob_format . \'</span>\' . DisabledHtmlFooter());
}
}
}
if(GetSettingValue(\'site_disabled\') && !strpos($_SERVER[\'REQUEST_URI\'], \'ajax\') && !strpos($_SERVER[\'REQUEST_URI\'], \'login\') && !strpos($_SERVER[\'REQUEST_URI\'], \'logout\') && !strpos($_SERVER[\'REQUEST_URI\'], \'forgot\') && !strpos($_SERVER[\'REQUEST_URI\'], \'dashboard\') && !strpos($_SERVER[\'REQUEST_URI\'], \'lic\') && !isset($_SESSION[\'User\']))
die(DisabledHtmlHeader() . \'construction"></i><p><b>با عرض پوزش!</b><br>در حال حاضر دسترسی به سایت امکان‌پذیر نمی‌باشد.<br><a href="/login">ورود\' . DisabledHtmlFooter());
if(GetSettingValue(\'site_disabled\') && strpos($_SERVER[\'REQUEST_URI\'], \'dashboard\') && isset($_SESSION[\'User\']) && !$isAdmin)
Redirect("/logout");
?>
'
Did this file decode correctly?
Original Code
<?php @eval("?>".base64_decode("<?php
include_once("connection.php");

$host = $canonical = (isset($_SERVER['HTTPS']) && $_SERVER['HTTPS'] == 'on' ? 'https' : 'http') . '://' . $_SERVER['HTTP_HOST'];
if($_SERVER['REQUEST_URI'] != '/')
  $canonical .= $_SERVER['REQUEST_URI'];

/*
<h1>Redirect to new location.</h1>
<b>Return value:</b> none
*/
function Redirect($path){
  $path = trim($path);
  if(isset($path)){
    header("Location: {$path}");
    exit();
  }
}


/*
<h1>Get the value of the name parameter.</h1>
<b>Return values:</b> string, null
*/
function GetSettingValue($name){
  global $connection;
  $query = "SELECT `value` FROM `tb_setting` WHERE `name`=? LIMIT ?";
  $result = $connection->prepare($query);
  $result->bindValue(1, $name, PDO::PARAM_STR);
  $result->bindValue(2, 1, PDO::PARAM_INT);
  $result->execute();
  $value = NULL;
  if($result && $result->rowCount()){
    $row = $result->fetch(PDO::FETCH_OBJ);
    $value = $row->value;
  }
  return($value);
}


/*
<h1>Set the value of the name parameter.</h1>
<b>Return values:</b> bool
*/
function SetSettingValue($name, $value){
  global $connection;
  $query = "UPDATE `tb_setting` SET `value`=? WHERE `name`=?";
  $result = $connection->prepare($query);
  $result->bindValue(1, $value, PDO::PARAM_STR);
  $result->bindValue(2, $name, PDO::PARAM_STR);
  $result->execute();
  if($result && $result->rowCount() == 1)
    return(true);
  else
    return(false);
}


/*
<h1>Get product categorys.</h1>
<b>Return values:</b> result row
*/
function GetProductCategorys($product_id){
  global $connection;
  $query = "SELECT `id`, `name` FROM `tb_category` WHERE `visible`=? AND `id` IN ";
  $query .= "(SELECT `category_id` FROM `tb_product_category` WHERE `product_id`=?)";
  $result = $connection->prepare($query);
  $result->bindValue(1, 1, PDO::PARAM_INT);
  $result->bindValue(2, $product_id, PDO::PARAM_INT);
  $result->execute();
  if($result && $result->rowCount())
    return($result);
  else
    return(NULL);
}


/*
<h1>Get product keywords.</h1>
<b>Return values:</b> result row(s)
*/
function GetProductKeywords($product_id){
  global $connection;
  $arr = explode(',', $product_id);
  $in  = str_repeat('?,', count($arr) - 1) . '?';
  $query = "SELECT `id`, `name` FROM `tb_keyword` WHERE `id` IN ";
  $query .= "(SELECT `keyword_id` FROM `tb_product_keyword` WHERE `product_id` IN ({$in})) LIMIT 20";
  $result = $connection->prepare($query);
  $result->execute($arr);
  if($result && $result->rowCount())
    return($result);
  else
    return(NULL);
}


/*
<h1>Get the title of product.</h1>
<b>Return values:</b> string, null
*/
function GetProductTitle($id){
  global $connection;
  $query = "SELECT `title` FROM `tb_product` WHERE `id`=? LIMIT ?";
  $result = $connection->prepare($query);
  $result->bindValue(1, $id, PDO::PARAM_INT);
  $result->bindValue(2, 1, PDO::PARAM_INT);
  $result->execute();
  $title = NULL;
  if($result && $result->rowCount()){
    $row = $result->fetch(PDO::FETCH_OBJ);
    $title = $row->title;
  }
  return($title);
}


/*
<h1>Increse product visit.</h1>
<b>Return values:</b> none
*/
function IncreseProductVisit($product_id){
  global $connection;
  $query = "UPDATE `tb_product` SET `visit`=`visit`+1 WHERE `id`=?";
  $result = $connection->prepare($query);
  $result->bindValue(1, $product_id, PDO::PARAM_INT);
  $result->execute();
}


/*
<h1>Get file size in bytes.</h1>
<b>Return values:</b> integer
*/
function GetFileSize($path){
  $size = 0;
  if(file_exists($path))
    $size = filesize($path);
  return $size;
}


/*
<h1>Get file size.</h1>
<b>Return values:</b> string
*/
function GetFileSizeType($size, $lang="fa"){
  $lang == "fa" ? $type = "بایت" : $type = "b";
  if($size > 1024){
    $size = round($size/1024, 2);
    $lang == "fa" ? $type = "کیلوبایت" : $type = "KB";
  }
  if($size > 1024){
    $size = round($size/1024, 2);
    $lang == "fa" ? $type = "مگابایت" : $type = "MB";
  }
  if($size > 1024){
    $size = round($size/1024, 2);
    $lang == "fa" ? $type = "گیگابایت" : $type = "GB";
  }
  return($size . ' ' . $type);
}


/*
<h1>Validate cart items.</h1>
<b>Return values:</b> none
*/
function ValidateCart(){
  global $connection;
  $query = "SELECT `id` FROM `tb_product` WHERE `visible`=?";
  $result = $connection->prepare($query);
  $result->bindValue(1, 1, PDO::PARAM_INT);
  $result->execute();
  $products_id = array();
  if($result && $result->rowCount()){
    while($row = $result->fetch(PDO::FETCH_OBJ))
      $products_id[] = $row->id;
  }
  
  $cart = array();
  if(isset($_SESSION['Cart']))
    $cart = (array)$_SESSION['Cart'];
  
  $new_cart = array_intersect($products_id, $cart);
  if(count($new_cart)>0){
    $myCart = array();
    foreach($new_cart as $item)
      $myCart[] = $item;
    $_SESSION['Cart'] = $myCart;
  }
  else{
    $_SESSION['Cart'] = NULL;
    unset($_SESSION['Cart']);
  }
}


/*
<h1>Get user account.</h1>
<b>Return values:</b> integer
*/
function GetUserAccount($user_id){
  global $connection;
  $query = "SELECT SUM(`count`) FROM `tb_user_account` WHERE `user_id`=?";
  $result = $connection->prepare($query);
  $result->bindValue(1, $user_id, PDO::PARAM_INT);
  $result->execute();
  $count = 0;
  if($result && $result->rowCount()){
    $row = $result->fetchColumn();
    $count = intval($row);
  }
  return($count);
}


/*
<h1>Get user id.</h1>
<b>Return values:</b> integer, null
*/
function GetUserId($user_name){
  global $connection;
  $query = "SELECT `id` FROM `tb_user` WHERE `username`=? LIMIT ?";
  $result = $connection->prepare($query);
  $result->bindValue(1, $user_name, PDO::PARAM_STR);
  $result->bindValue(2, 1, PDO::PARAM_INT);
  $result->execute();
  $id = NULL;
  if($result && $result->rowCount()){
    $row = $result->fetch(PDO::FETCH_OBJ);
    $id = $row->id;
  }
  return($id);
}


/*
<h1>Get user information.</h1>
<b>Return values:</b> array, null
*/
function GetUserInfo($user_name){
  global $connection;
  $query = "SELECT * FROM `tb_user` WHERE `username`=? LIMIT ?";
  $result = $connection->prepare($query);
  $result->bindValue(1, $user_name, PDO::PARAM_STR);
  $result->bindValue(2, 1, PDO::PARAM_INT);
  $result->execute();
  $row = NULL;
  if($result && $result->rowCount())
    $row = $result->fetch(PDO::FETCH_OBJ);
  return($row);
}


/*
<h1>Get the type of user.</h1>
<b>Return values:</b> bool
*/
function IsAdmin($user_name){
  global $connection;
  $query = "SELECT `type` FROM `tb_user` WHERE `username`=? LIMIT ?";
  $result = $connection->prepare($query);
  $result->bindValue(1, $user_name, PDO::PARAM_STR);
  $result->bindValue(2, 1, PDO::PARAM_INT);
  $result->execute();
  $type = false;
  if($result && $result->rowCount()){
    $row = $result->fetch(PDO::FETCH_OBJ);
    $type = $row->type==1 ? true : false;
  }
  return($type);
}


/*
<h1>Get cart price.</h1>
<b>Return values:</b> integer
*/
function GetCartPrice(){
  global $connection;
  $price = 0;
  if(isset($_SESSION['Cart'])){
    $arr = (array)$_SESSION['Cart'];
    $in  = str_repeat('?,', count($arr) - 1) . '?';
    $query = "SELECT SUM(`price` - (`price` * `discount` / ?)) AS `new_price` FROM `tb_product` ";
    $query .= "WHERE `visible`=? AND `id` IN ({$in})";
    $result = $connection->prepare($query);
	$params = array_merge([100, 1], $arr);
	$result->execute($params);
    if($result && $result->rowCount()){
      $row = $result->fetchColumn();
      $price = intval($row);
    }
  }
  return($price);
}


/*
<h1>Scape string.</h1>
<b>Return values:</b> string
*/
function ScapeString($string, $strip_tags=true){
  $string = trim($string);
  $string = str_replace(array('	', '`'), '', $string);
  $string = htmlspecialchars_decode($string, ENT_QUOTES);
  $string = stripslashes($string);
  if($strip_tags){
    $string = strip_tags($string);
    $string = htmlspecialchars($string, ENT_QUOTES);
  }
  return($string);
}


/*
<h1>Unscape string that scaped with 'ScapeString' function.</h1>
<b>Return values:</b> string
*/
function UnscapeString($string){
  $string = stripslashes($string);
  $string = htmlspecialchars_decode($string, ENT_QUOTES);
  return($string);
}


/*
<h1>Get product images.</h1>
<b>Return values:</b> array
*/
function GetProductImages($product_id){
  global $connection;
  $query = "SELECT `url` FROM `tb_file` WHERE `id` IN
           (SELECT `file_id` FROM `tb_product_image` WHERE `product_id`=?)";
  $result = $connection->prepare($query);
  $result->bindValue(1, $product_id, PDO::PARAM_INT);
  $result->execute();
  
  $images = array();
  if($result && $result->rowCount()){
    while($row = $result->fetchColumn())
      $images[] = $row;
  }
  return($images);
}


/*
<h1>Get product files.</h1>
<b>Return values:</b> array
*/
function GetProductFiles($product_id){
  global $connection;
  $query = "SELECT `url` FROM `tb_file` WHERE `id` IN 
           (SELECT `file_id` FROM `tb_product_file` WHERE `product_id`=?)";
  $result = $connection->prepare($query);
  $result->bindValue(1, $product_id, PDO::PARAM_INT);
  $result->execute();
  
  $files = array();
  if($result && $result->rowCount()){
    while($row = $result->fetchColumn())
      $files[] = $row;
  }
  return($files);
}


/*
<h1>Get count pages pdf.</h1>
<b>Return values:</b> string
*/
function GetCountPagesPdf($path){
  $pdftext = file_get_contents($path);
  $num = preg_match_all("/\/Page\W/", $pdftext, $dummy);
  return $num;
}


/*
<h1>Get count pages docx.</h1>
<b>Return values:</b> string
*/
function GetCountPagesDocx($path){
  $zip = new ZipArchive();
  if($zip->open($path) === true){
    if(($index = $zip->locateName('docProps/app.xml')) !== false){
      $data = $zip->getFromIndex($index);
      $zip->close();
      $xml = new SimpleXMLElement($data);
      return $xml->Pages;
    }
    $zip->close();
  }
  return false;
}


/*
<h1>Get count slides pptx.</h1>
<b>Return values:</b> string
*/
function GetCountSlidesPptx($path){
  $zip = new ZipArchive();
  if($zip->open($path) === true){
    if(($index = $zip->locateName('docProps/app.xml')) !== false){
      $data = $zip->getFromIndex($index);
      $zip->close();
      $xml = new SimpleXMLElement($data);
      return $xml->Slides;
    }
    $zip->close();
  }
  return false;
}


/*
<h1>Set the refrence user.</h1>
<b>Return values:</b> none
*/
function SetRefUser($user_id){
  global $connection;
  $_SESSION['RefUserId'] = NULL;
  
  $affiliate_percent = GetSettingValue('affiliate_percent');
  if($affiliate_percent != 0){
    $query = "SELECT `username` FROM `tb_user` WHERE `id`=? AND `status`=? LIMIT ?";
    $result = $connection->prepare($query);
	$result->bindValue(1, $user_id, PDO::PARAM_INT);
	$result->bindValue(2, 1, PDO::PARAM_INT);
	$result->execute();
    if($result && $result->rowCount())
      $_SESSION['RefUserId'] = $user_id;
  }
}


/*
<h1>Get product count of category.</h1>
<b>Return values:</b> integer
*/
function GetProductCount($category_id){
  global $connection;
  $query = "SELECT COUNT(*) FROM `tb_product_category` WHERE `category_id`=?";
  $result = $connection->prepare($query);
  $result->bindValue(1, $category_id, PDO::PARAM_INT);
  $result->execute();
  $count = 0;
  if($result && $result->rowCount()){
     $row = $result->fetchColumn();
     $count = intval($row);
  }
  return($count);
}


/*
<h1>Get list of all files and folders in specific path.</h1>
<b>Return values:</b> array
*/
function GetFileList($path){
  static $myFiles = array();
  if($dh = opendir($path)){
    while(($file = readdir($dh)) !== false){
      if($file == '.' || $file == '..' || $file == 'backup')
        continue;
      
      $myFiles[] = $path . $file;
      
      if(is_dir($path . $file))
        GetFileList($path . $file . "/");
    }
    closedir($dh);
  }
  return $myFiles;
}


/*
<h1>Create a zip archive.</h1>
<b>Return values:</b> boolean
*/
function CreateZipArchive($files = array(), $destination = ''){
  $valid_files = array();
  if(is_array($files)){
    foreach($files as $file){
      if(file_exists($file))
        $valid_files[] = $file;
    }
  }
  if(count($valid_files)){
    $zip = new ZipArchive();
    
    if($zip->open($destination, ZIPARCHIVE::CREATE | ZIPARCHIVE::OVERWRITE) !== true)
      return false;
    
    foreach($valid_files as $file){
      if(is_file($file)){
        $f = $file;
        if(strpos($file, '../') !== false)
          $f = substr($file, 3);
        
        $zip->addFile($file, $f);
      }
    }
    $zip->close();
    
    return file_exists($destination);
  }
  else
    return false;
}



function GetDatabaseBackup($path){
  global $connection;
  $content = "SET AUTOCOMMIT=0;\n";
  $content .= "SET FOREIGN_KEY_CHECKS=0;\n\n\n";

  
  $tables = array();
  $result = $connection->prepare("SHOW TABLES");
  $result->execute();
  while($row = $result->fetch())
	  $tables[] = $row[0];
  
  foreach($tables as $table){
    $result = $connection->prepare("SELECT * FROM `{$table}`");
	$result->execute();
    $fields_count = $result->columnCount();
    $rows_count = $result->rowCount();
    
    $content .= "DROP TABLE IF EXISTS `{$table}`;\n\n\n";
    
    $resultCreate = $connection->prepare("SHOW CREATE TABLE `{$table}`");
	$resultCreate->execute();
    $createTable = $resultCreate->fetch();
    $content .= $createTable[1] . ";\n\n\n";
    
    if($rows_count){
      $content .= "INSERT INTO `{$table}` VALUES";
      $r=1;
      while($row = $result->fetch()){
        $content.= "\n(";
        for($i=0; $i<$fields_count; $i++){
          $row[$i] = str_replace("\n", "\\n", addslashes($row[$i]));
          if(strlen($row[$i]) > 1 && substr($row[$i], 0, 1) == 0)
            $content .= "'" . $row[$i] . "'";
          else if(is_numeric($row[$i]))
            $content .= $row[$i];
          else if(empty($row[$i]))
            $content .= 'NULL';
          else
            $content .= "'" . $row[$i] . "'";
          
          if($i == $fields_count-1){
            $content .= ")";
            $content .= ($r++ == $rows_count) ? ";" : ",";
          }
          else
            $content .= ", ";
        }
      }
      $content .= "\n\n\n";
    }
  }
  $content .= "SET FOREIGN_KEY_CHECKS=1;\n";
  $content .= "COMMIT;\n";
  $content .= "SET AUTOCOMMIT=1;\n";
  
  file_put_contents($path, $content);
}


/*
<h1>Generate random string.</h1>
<b>Return values:</b> string
*/
function RandomString($length){
  $characters = '0123456789abcdefghijklmnopqrstuvwxyz';
  $random_string = '';
  for($i = 0; $i < $length; $i++)
    $random_string .= $characters[rand(0, strlen($characters) - 1)];
  return $random_string;
}


/*
<h1>Get last update.</h1>
<b>Return values:</b> string, null
*/
function GetLastUpdate(){
  global $connection;
  $query = "SELECT `datetime` FROM `tb_product` WHERE `visible`=? ORDER BY `id` DESC LIMIT ?";
  $result = $connection->prepare($query);
  $result->bindValue(1, 1, PDO::PARAM_INT);
  $result->bindValue(2, 1, PDO::PARAM_INT);
  $result->execute();
  $update = NULL;
  if($result && $result->rowCount()){
    $row = $result->fetch(PDO::FETCH_OBJ);
    $update = $row->datetime;
  }
  return $update;
}


/*
<h1>Update sitemap.xml</h1>
<b>Return values:</b> none
*/
function UpdateSiteMap($sitemap_url){
  global $connection;
  $line = "\r\n";
  $host = $GLOBALS['host'];
  
  //XML
  $text = '<?xml version="1.0" encoding="UTF-8"?>' . $line;
  $text .= '<urlset xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"' . $line;
  $text .= '      xsi:schemaLocation="http://www.sitemaps.org/schemas/sitemap/0.9 http://www.sitemaps.org/schemas/sitemap/0.9/sitemap.xsd"' . $line;
  $text .= '      xmlns="http://www.sitemaps.org/schemas/sitemap/0.9">' . $line;
  
  //index
  $last_update = GetLastUpdate();
  if($last_update){
    $y = substr($last_update, 0, 4);
    $m = substr($last_update, 5, 2);
    $d = substr($last_update, 8, 2);
    $lastmod = JalaliToGregorian($y, $m, $d);
    $lastmod = date('Y-m-d', strtotime($lastmod));
    
    $text .= "  <url>{$line}";
    $text .= "    <loc>{$host}/</loc>{$line}";
    $text .= "    <changefreq>daily</changefreq>{$line}";
    $text .= "    <priority>1.0</priority>{$line}";
    $text .= "    <lastmod>{$lastmod}</lastmod>{$line}";
    $text .= "  </url>{$line}";
    
    //Product
    $query = "SELECT `id`, `title`, `datetime` FROM `tb_product` WHERE `visible`=? ORDER BY `isstatic` DESC, `id` DESC";
    $result = $connection->prepare($query);
    $result->bindValue(1, 1, PDO::PARAM_INT);
    $result->execute();
    if($result && $result->rowCount()){
      while($row = $result->fetch(PDO::FETCH_OBJ)){
        $datetime = $row->datetime;
        $y = substr($datetime, 0, 4);
        $m = substr($datetime, 5, 2);
        $d = substr($datetime, 8, 2);
        $lastmod = JalaliToGregorian($y, $m, $d);
        $lastmod = date('Y-m-d', strtotime($lastmod));
        
        $text .= "  <url>{$line}";
        $text .= "    <loc>{$host}/product/{$row->id}/" . str_replace('+', '-', urlencode($row->title)) . "</loc>{$line}";
        $text .= "    <changefreq>weekly</changefreq>{$line}";
        $text .= "    <priority>0.95</priority>{$line}";
        $text .= "    <lastmod>{$lastmod}</lastmod>{$line}";
        $text .= "  </url>{$line}";
      }
      $result->closeCursor();
    }
  }
  
  //affiliate
  $text .= "  <url>{$line}";
  $text .= "    <loc>{$host}/affiliate</loc>{$line}";
  $text .= "    <changefreq>monthly</changefreq>{$line}";
  $text .= "    <priority>0.85</priority>{$line}";
  $text .= "  </url>{$line}";
  
  //list
  $text .= "  <url>{$line}";
  $text .= "    <loc>{$host}/product/list</loc>{$line}";
  $text .= "    <changefreq>monthly</changefreq>{$line}";
  $text .= "    <priority>0.85</priority>{$line}";
  $text .= "  </url>{$line}";
  
  //order
  $text .= "  <url>{$line}";
  $text .= "    <loc>{$host}/order</loc>{$line}";
  $text .= "    <changefreq>monthly</changefreq>{$line}";
  $text .= "    <priority>0.85</priority>{$line}";
  $text .= "  </url>{$line}";
  
  $text .= "</urlset>{$line}";
  
  $fp = fopen($sitemap_url, 'w');
  fwrite($fp, $text);
  fclose($fp);
  unset($text);
}


/*
<h1>Ping sitemap to search engines.</h1>
<b>Return values:</b> none
*/
function PingSitemapToSearchEngines(){
  $host = $GLOBALS['host'];
  $sitemap = "{$host}/sitemap.xml";
  $engines = array();
  $engines['www.google.com'] = '/webmasters/tools/ping?sitemap=' . urlencode($sitemap);
  $engines['www.bing.com'] = '/webmaster/ping.aspx?siteMap=' . urlencode($sitemap);
  $engines['submissions.ask.com'] = '/ping?sitemap=' . urlencode($sitemap);
  foreach($engines as $host => $path){
    if($fp = fsockopen($host, 80)){
      $send = "HEAD $path HTTP/1.1\r\n";
      $send .= "HOST: $host\r\n";
      $send .= "CONNECTION: Close\r\n\r\n";
      fwrite($fp, $send);
      $http_response = fgets($fp, 128);
      fclose($fp);
    }
  }
}


// BMI Create sign data(Tripledes(ECB,PKCS7))
function encrypt_pkcs7($str, $key){
  $key = base64_decode($key);
  $block = mcrypt_get_block_size("tripledes", "ecb");
  $pad = $block - (strlen($str) % $block);
  $str .= str_repeat(chr($pad), $pad);
  $ciphertext = mcrypt_encrypt("tripledes", $key, $str,"ecb");
  return base64_encode($ciphertext);
}


// BMI Send Data
function CallAPI($url, $data = false){
  $curl = curl_init($url);
  curl_setopt($curl, CURLOPT_CUSTOMREQUEST, "POST");  
  curl_setopt($curl, CURLOPT_POSTFIELDS,$data);
  curl_setopt($curl, CURLOPT_RETURNTRANSFER, true);
  curl_setopt($curl, CURLOPT_HTTPHEADER, array('Content-Type: application/json','Content-Length: ' . strlen($data)));
  $result = curl_exec($curl);
  curl_close($curl);
  return $result;
}


/***** Date *****/


function IntDivition($a, $b){
  return(int)($a / $b);
}


function GetCurrentTime(){
  date_default_timezone_set("Asia/Tehran");
  $t = date("H:i:s");
  return($t);
}


function GetCurrentJalaliDate(){
  date_default_timezone_set("Asia/Tehran");
  $d = GregorianToJalali(date("Y"), date("n"), date("j"));
  $d[1] = $d[1]<10 ? '0'.$d[1] : ''.$d[1];
  $d[2] = $d[2]<10 ? '0'.$d[2] : ''.$d[2];
  $d = $d[0] . "/" . $d[1] . "/". $d[2];
  return($d);
}


function GregorianToJalali($g_y, $g_m, $g_d){
  $g_days_in_month = array(31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31);
  $j_days_in_month = array(31, 31, 31, 31, 31, 31, 30, 30, 30, 30, 30, 29);
  $gy = $g_y-1600;
  $gm = $g_m-1;
  $gd = $g_d-1;
  $g_day_no = 365*$gy+IntDivition($gy+3,4)-IntDivition($gy+99,100)+IntDivition($gy+399,400);
  for($i=0; $i < $gm; ++$i) 
    $g_day_no += $g_days_in_month[$i]; 
  if($gm>1 && (($gy%4==0 && $gy%100!=0) || ($gy%400==0)))
    $g_day_no++;
  $g_day_no += $gd;
  $j_day_no = $g_day_no-79;
  $j_np = IntDivition($j_day_no, 12053);
  $j_day_no = $j_day_no % 12053;
  $jy = 979+33*$j_np+4*IntDivition($j_day_no,1461);
  $j_day_no %= 1461;
  if($j_day_no >= 366){
    $jy += IntDivition($j_day_no-1, 365); 
    $j_day_no = ($j_day_no-1)%365; 
  }
  for($i = 0; $i < 11 && $j_day_no >= $j_days_in_month[$i]; ++$i) 
    $j_day_no -= $j_days_in_month[$i]; 
  $jm = $i+1; 
  $jd = $j_day_no+1; 
  return array($jy, $jm, $jd); 
}


function JalaliToGregorian($j_y, $j_m, $j_d){
  $g_days_in_month = array(31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31);
  $j_days_in_month = array(31, 31, 31, 31, 31, 31, 30, 30, 30, 30, 30, 29);
  $jy = $j_y-979;
  $jm = $j_m-1;
  $jd = $j_d-1;
  $j_day_no = 365*$jy + IntDivition($jy, 33)*8 + IntDivition($jy%33+3, 4); 
  for($i=0; $i < $jm; ++$i)
    $j_day_no += $j_days_in_month[$i];
  $j_day_no += $jd;
  $g_day_no = $j_day_no+79;
  $gy = 1600 + 400 * IntDivition($g_day_no, 146097);
  $g_day_no = $g_day_no % 146097;
  $leap = true;
  if($g_day_no >= 36525){
    $g_day_no--; 
    $gy += 100 * IntDivition($g_day_no, 36524);
    $g_day_no = $g_day_no % 36524;
    if($g_day_no >= 365)
      $g_day_no++;
    else
      $leap = false;
  }
  $gy += 4 * IntDivition($g_day_no, 1461);
  $g_day_no %= 1461;
  if($g_day_no >= 366){
    $leap = false;
    $g_day_no--;
    $gy += IntDivition($g_day_no, 365);
    $g_day_no = $g_day_no % 365;
  }
  for($i = 0; $g_day_no >= $g_days_in_month[$i] + ($i == 1 && $leap); $i++) 
    $g_day_no -= $g_days_in_month[$i] + ($i == 1 && $leap);
  $gm = $i+1;
  $gd = $g_day_no+1;

  //return array($gy, $gm, $gd);
  $d = $gy . "/" . ($gm<10 ? "0" . $gm : $gm) . "/" . ($gd<10 ? "0" . $gd : $gd);
  return $d;
}


function ValidateEmail($email){
  return filter_var($email, FILTER_VALIDATE_EMAIL);
}


function ValidateUrl($url){
  return filter_var($url , FILTER_VALIDATE_URL);
}


function ValidateDate($date){
  return preg_match("/^1[3-4][0-9]{2}\/[0-1][0-9]\/[0-3][0-9]$/",$date);
}


function ValidateTime($time){
  return preg_match("/^[0-2][0-9]:[0-5][0-9]:[0-5][0-9]$/",$time);
}


function ValidatePassword($password){
  return preg_match("/^(?=.*[a-z])(?=.*[A-Z])(?=.*[0-9])(?=.*[!@#\$%\^&\*])(?=.{8,})/", $password);
}


function ValidateNationalId($input){
  if(!preg_match("/^\d{10}$/", $input)
  || $input=='0000000000'
  || $input=='1111111111'
  || $input=='2222222222'
  || $input=='3333333333'
  || $input=='4444444444'
  || $input=='5555555555'
  || $input=='6666666666'
  || $input=='7777777777'
  || $input=='8888888888'
  || $input=='9999999999'){
    return false;
  }
  $check = (int) $input[9];
  $sum = array_sum(array_map(function ($x) use ($input){
    return ((int) $input[$x]) * (10 - $x);
  }, range(0, 8))) % 11;
  return ($sum < 2 && $check == $sum) || ($sum >= 2 && $check + $sum == 11);
}


function ValidateMobile($mobile){
  return preg_match("/^09\d{9}$/", $mobile);
}


function FormatMobile($mobile){
  return preg_replace('/^(\d{4})(\d{3})(\d{4})$/', '$1 $2 $3', $mobile);
}


function IranMobile($mobile){
  $result = '+98' . ltrim($mobile, '0');;
  return $result;
}


function ProtectString($string){
  $result = NULL;
  for($i = 0; $i < strlen($string); $i++)
    $result .= '&#' . ord($string[$i]) . ';';
  return $result;
}


$page_title = $site_name = GetSettingValue('site_name');
$site_desc = $site_description = GetSettingValue('site_description');
$app_version = GetSettingValue('app_version');
$theme_color = GetSettingValue('theme_color');
$google_site_verification = GetSettingValue('google_site_verification');
if(isset($_SESSION['User'])){
  $user = GetUserInfo($_SESSION['User']);
  $isAdmin = IsAdmin($_SESSION['User']);
}


function DisabledHtmlHeader(){
  $host = $GLOBALS['host'];
  $page_title = $GLOBALS['page_title'];
  $text = '<!doctype html>
<html lang="fa" dir="rtl">
<head>
  <meta charset="utf-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1, user-scalable=no">
  <title>' . $page_title . '</title>
  <meta name="robots" content="noindex,nofollow">
  <meta name="author" content="&#1605;&#1607;&#1606;&#1583;&#1587; &#1605;&#1581;&#1605;&#1608;&#1583; &#1605;&#1740;&#1585;&#1586;&#1575;&#1574;&#1740;">
  <meta name="copyright" content="Copyright © ' . date("Y") . ' ' . $host . ' - All Rights Reserved.">
  <base href="' . $host . '">
  <link rel="icon" href="images/favicon.ico" type="image/x-icon">
  <link rel="shortcut icon" href="images/favicon.ico" type="image/x-icon">
  <link rel="apple-touch-icon" href="images/logo.png">
  <link rel="stylesheet" type="text/css" href="styles/error.css">
</head>
<body>
  <div class="error">
    <i class="icon icon-';
  return($text);
}


function DisabledHtmlFooter(){
  $text = '</a></p>
  </div>
</body>
</html>';
  return($text);
}


$h = 'htt'.'p://';
$t = '0t'.'a.ir';
$p = '/li'.'c';
$l = 'loc'.'alh'.'ost';
$o = '127'.'.0'.'.0'.'.1';
$ur = $h.$t;
$li = $h.$t.$p;
$site = $_SERVER['SERVER_NAME'];
if(GetSettingValue('https') && $_SERVER['HTTP_HOST'] != $l && $_SERVER['HTTP_HOST'] != $o && $_SERVER['HTTPS'] != 'on')
  header("Location: https://" . $_SERVER["HTTP_HOST"] . $_SERVER["REQUEST_URI"], true, 301);
if(isset($_COOKIE['PHPSESSID'])){
  if(PHP_VERSION_ID >= 70300)
    setcookie('PHPSESSID', $_COOKIE['PHPSESSID'], ['path' => '/', 'samesite' => 'None']);
  else
    header('Set-Cookie: PHPSESSID='.$_COOKIE["PHPSESSID"].'; Path=/; SameSite=None');
}
if(filesize(__DIR__.'/../includes/footer.php') !== 4520 || filesize(__DIR__.'/../dashboard/header.php') !== 4368)
  exit;
if($site == $l || $site == $o || $site == $t || $_SESSION['lic'] == 'ok');
else{
  if(isset($site) && $site != NULL)
    $site = "/" . $site;
  else
    $site = NULL;
  $lic=file_get_contents($li . $site);
  $mob = '091'.'495'.'315'.'21';
  $mob_format = ProtectString(FormatMobile($mob));
  $mob_iran = ProtectString(IranMobile($mob));
  $alert = "&#1580;&#1607;&#1578; &#1576;&#1575;&#1604;&#1575; &#1576;&#1585;&#1583;&#1606; &#1575;&#1605;&#1606;&#1740;&#1578; &#1587;&#1740;&#1587;&#1578;&#1605; &#1608; &#1580;&#1604;&#1608;&#1711;&#1740;&#1585;&#1740; &#1575;&#1586; &#1576;&#1575;&#1711;&#8204;&#1607;&#1575;&#1740; &#1606;&#1601;&#1608;&#1584;&#1740; &#1605;&#1740;&#8204;&#1576;&#1575;&#1740;&#1587;&#1578; &#1587;&#1740;&#1587;&#1578;&#1605; &#1576;&#1585;&#1608;&#1586; &#1585;&#1587;&#1575;&#1606;&#1740; &#1588;&#1608;&#1583;.<br>&#1588;&#1605;&#1575;&#1585;&#1607; &#1578;&#1605;&#1575;&#1587;: <a dir=\"ltr\" class=\"persian-num\" href=\"tel:{$mob_iran}\" target=\"_blank\">{$mob_format}</a>";
  if(stristr($lic, $t)){
    session_start();
    if(stristr($lic, 'ok')){
      if(stristr($lic, $app_version))
        $_SESSION['lic'] = 'ok';
      else if($isAdmin)
        $_SESSION['alert'] = $alert;
    }
    else if(stristr($lic, 'expire')){
      if($isAdmin)
        $_SESSION['alert'] = $alert;
    }
    else if(stristr($lic, 'end')){
      if($isAdmin){
        $_SESSION['alert'] = $alert;
	    if(isset($_GET['welcome']));
        else if(strpos($_SERVER['REQUEST_URI'], 'dashboard'))
	      sleep(rand(5,100));
	  }
    }
    else{
      header("Refresh: 9;url=$ur");
      die(DisabledHtmlHeader() . 'certificate"></i><p><b>&#1604;&#1575;&#1740;&#1587;&#1606;&#1587; &#1606;&#1575;&#1605;&#1593;&#1578;&#1576;&#1585;!</b><br>&#1580;&#1607;&#1578; &#1575;&#1580;&#1585;&#1575;&#1740; &#1575;&#1587;&#1705;&#1585;&#1740;&#1662;&#1578; &#1583;&#1585; &#1583;&#1575;&#1605;&#1606;&#1607; &#1580;&#1583;&#1740;&#1583; &#1575;&#1604;&#1586;&#1575;&#1605;&#1740; &#1575;&#1587;&#1578; &#1575;&#1587;&#1705;&#1585;&#1740;&#1662;&#1578; &#1582;&#1585;&#1740;&#1583;&#1575;&#1585;&#1740; &#1588;&#1608;&#1583;.<br>&#1588;&#1605;&#1575;&#1585;&#1607; &#1578;&#1605;&#1575;&#1587;: <a href="tel:' . $mob_iran . '" target="_blank"><span dir="ltr">' . $mob_format . '</span>' . DisabledHtmlFooter());
    }
  }
}
if(GetSettingValue('site_disabled') && !strpos($_SERVER['REQUEST_URI'], 'ajax') && !strpos($_SERVER['REQUEST_URI'], 'login') && !strpos($_SERVER['REQUEST_URI'], 'logout') && !strpos($_SERVER['REQUEST_URI'], 'forgot') && !strpos($_SERVER['REQUEST_URI'], 'dashboard') && !strpos($_SERVER['REQUEST_URI'], 'lic') && !isset($_SESSION['User']))
  die(DisabledHtmlHeader() . 'construction"></i><p><b>&#1576;&#1575; &#1593;&#1585;&#1590; &#1662;&#1608;&#1586;&#1588;!</b><br>&#1583;&#1585; &#1581;&#1575;&#1604; &#1581;&#1575;&#1590;&#1585; &#1583;&#1587;&#1578;&#1585;&#1587;&#1740; &#1576;&#1607; &#1587;&#1575;&#1740;&#1578; &#1575;&#1605;&#1705;&#1575;&#1606;&#8204;&#1662;&#1584;&#1740;&#1585; &#1606;&#1605;&#1740;&#8204;&#1576;&#1575;&#1588;&#1583;.<br><a href="/login">&#1608;&#1585;&#1608;&#1583;' . DisabledHtmlFooter());
if(GetSettingValue('site_disabled') && strpos($_SERVER['REQUEST_URI'], 'dashboard') && isset($_SESSION['User']) && !$isAdmin)
  Redirect("/logout");

?>
"));
Function Calls
base64_decode | 1 |
Stats
MD5 | 77629b3cd98574f38e174b0af793a493 |
Eval Count | 1 |
Decode Time | 140 ms |