Files
Siro/loction_server/siro/ride/update_locations_web_app.php
2026-06-29 23:09:43 +03:00

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());
}
?>