48 lines
1.6 KiB
PHP
Executable File
48 lines
1.6 KiB
PHP
Executable File
<?php
|
|
include "../../connect.php";
|
|
|
|
// استقبال البيانات من تطبيق السائق
|
|
$driver_id = filterRequest("driver_id");
|
|
$lat = filterRequest("lat");
|
|
$lng = filterRequest("lng");
|
|
$heading = filterRequest("heading"); // اتجاه السيارة
|
|
$speed = filterRequest("speed");
|
|
$status = filterRequest("status"); // 'on' (متاح) أو 'off' (مشغول/غير متاح)
|
|
|
|
if (!$driver_id || !$lat || !$lng) {
|
|
printFailure("Missing Data");
|
|
exit;
|
|
}
|
|
|
|
try {
|
|
// استخدام ON DUPLICATE KEY UPDATE لضمان وجود صف واحد فقط لكل سائق
|
|
// الجدول: car_locations
|
|
$sql = "INSERT INTO car_locations (driver_id, latitude, longitude, heading, speed, status, updated_at)
|
|
VALUES (:id, :lat, :lng, :head, :spd, :stat, NOW())
|
|
ON DUPLICATE KEY UPDATE
|
|
latitude = :lat,
|
|
longitude = :lng,
|
|
heading = :head,
|
|
speed = :spd,
|
|
status = :stat,
|
|
updated_at = NOW()";
|
|
|
|
$stmt = $con_tracking->prepare($sql);
|
|
$stmt->execute([
|
|
':id' => $driver_id,
|
|
':lat' => $lat,
|
|
':lng' => $lng,
|
|
':head' => $heading,
|
|
':spd' => $speed,
|
|
':stat' => $status
|
|
]);
|
|
|
|
// ملاحظة: لا نحتاج لإرسال socket notification هنا لأن هذا يحدث كل ثانية
|
|
// الراكب يرى التحديث لأنه متصل بسوكيت اللوكيشن ويستمع لحدث 'update_driver_location'
|
|
|
|
printSuccess("Location Updated");
|
|
|
|
} catch (PDOException $e) {
|
|
printFailure("DB Error: " . $e->getMessage());
|
|
}
|
|
?>
|