88 lines
3.0 KiB
PHP
Executable File
88 lines
3.0 KiB
PHP
Executable File
<?php
|
|
// =================================================================
|
|
// ملف: update_locations.php
|
|
// الوظيفة: إنشاء ملفات JSON للوضع المباشر واليومي
|
|
// =================================================================
|
|
|
|
// السماح بالوصول من أي مكان (CORS)
|
|
header("Access-Control-Allow-Origin: *");
|
|
header('Content-Type: text/html; charset=utf-8');
|
|
|
|
error_reporting(E_ALL);
|
|
ini_set('display_errors', 1);
|
|
|
|
include "../jwtconnect.php";
|
|
|
|
// 1. تحديد الوضع (Mode)
|
|
$mode = isset($_GET['mode']) && $_GET['mode'] == 'day' ? 'day' : 'live';
|
|
|
|
// 2. إعداد المتغيرات حسب الوضع
|
|
if ($mode == 'day') {
|
|
$fileName = 'locations_day.json';
|
|
// شرط: أي تحديث حدث اليوم
|
|
$condition = "DATE(updated_at) = CURDATE()";
|
|
$title = "سجل اليوم الكامل";
|
|
} else {
|
|
$fileName = 'locations_live.json';
|
|
// شرط: آخر 20 دقيقة فقط
|
|
$condition = "updated_at >= NOW() - INTERVAL 20 MINUTE";
|
|
$title = "مباشر (آخر 20 دقيقة)";
|
|
}
|
|
|
|
$savePath = __DIR__ . '/' . $fileName;
|
|
|
|
// دالة تنظيف النصوص العربية وإصلاح الترميز
|
|
function utf8ize($d) {
|
|
if (is_array($d)) {
|
|
foreach ($d as $k => $v) { $d[$k] = utf8ize($v); }
|
|
} else if (is_string ($d)) {
|
|
return mb_convert_encoding($d, 'UTF-8', 'UTF-8');
|
|
}
|
|
return $d;
|
|
}
|
|
|
|
try {
|
|
// إجبار قاعدة البيانات على ترميز UTF-8
|
|
if(isset($con)) { $con->exec("set names utf8mb4"); }
|
|
|
|
// تنفيذ الاستعلام
|
|
$sql = "SELECT * FROM `car_locations` WHERE $condition ORDER BY updated_at DESC";
|
|
$stmt = $con->prepare($sql);
|
|
$stmt->execute();
|
|
$rows = $stmt->fetchAll(PDO::FETCH_ASSOC);
|
|
|
|
// تنظيف البيانات
|
|
$cleanRows = utf8ize($rows);
|
|
|
|
// تجهيز البيانات للحفظ
|
|
$outputData = [
|
|
'mode' => $mode,
|
|
'title' => $title,
|
|
'last_updated' => date('Y-m-d H:i:s'),
|
|
'count' => count($cleanRows),
|
|
'drivers' => $cleanRows
|
|
];
|
|
|
|
// تحويل إلى JSON
|
|
$jsonContent = json_encode($outputData, JSON_UNESCAPED_UNICODE | JSON_PRETTY_PRINT);
|
|
|
|
if ($jsonContent === false) {
|
|
die("خطأ في تكوين JSON: " . json_last_error_msg());
|
|
}
|
|
|
|
// حفظ الملف
|
|
if (file_put_contents($savePath, $jsonContent) !== false) {
|
|
echo "<div style='font-family:tahoma; direction:rtl; text-align:right; padding:20px; background:#e8f5e9; border:1px solid #4caf50; border-radius:5px;'>";
|
|
echo "<h3 style='color:green; margin:0;'>✅ تم التحديث بنجاح!</h3>";
|
|
echo "<p><b>الوضع:</b> $title</p>";
|
|
echo "<p><b>اسم الملف:</b> $fileName</p>";
|
|
echo "<p><b>عدد السائقين:</b> " . count($cleanRows) . "</p>";
|
|
echo "</div>";
|
|
} else {
|
|
die("فشل الكتابة في الملف. تأكد من صلاحيات المجلد.");
|
|
}
|
|
|
|
} catch (PDOException $e) {
|
|
die("خطأ قاعدة بيانات: " . $e->getMessage());
|
|
}
|
|
?>
|