Update: 2026-06-29 23:09:43
This commit is contained in:
88
loction_server/siro/ride/update_locations_web_app.php
Executable file
88
loction_server/siro/ride/update_locations_web_app.php
Executable file
@@ -0,0 +1,88 @@
|
||||
<?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());
|
||||
}
|
||||
?>
|
||||
Reference in New Issue
Block a user