50 lines
1.5 KiB
PHP
50 lines
1.5 KiB
PHP
<?php
|
|
// =================================================================
|
|
// ملف: get_driver_live_pos.php
|
|
// الوظيفة: جلب الموقع اللحظي لسائق محدد (بناءً على ID)
|
|
// =================================================================
|
|
|
|
require_once __DIR__ . '/../../connect.php'; // تأكد أن هذا الملف يحتوي على $con_tracking
|
|
|
|
header("Access-Control-Allow-Origin: *");
|
|
header("Content-Type: application/json; charset=UTF-8");
|
|
|
|
try {
|
|
// 1. استقبال معرف السائق
|
|
$driver_id = filterRequest("driver_id");
|
|
|
|
if (!$driver_id) {
|
|
jsonError("driver_id is required");
|
|
exit;
|
|
}
|
|
|
|
// 2. الاستعلام من قاعدة بيانات التتبع (car_locations)
|
|
// نجلب أحدث إحداثيات تم تسجيلها لهذا السائق
|
|
$sql = "
|
|
SELECT
|
|
latitude,
|
|
longitude,
|
|
heading,
|
|
speed,
|
|
updated_at
|
|
FROM car_locations
|
|
WHERE driver_id = ?
|
|
ORDER BY updated_at DESC
|
|
LIMIT 1
|
|
";
|
|
|
|
$stmt = $con_tracking->prepare($sql);
|
|
$stmt->execute([$driver_id]);
|
|
$data = $stmt->fetch(PDO::FETCH_ASSOC);
|
|
|
|
if ($data) {
|
|
jsonSuccess($data);
|
|
} else {
|
|
// السائق ليس له موقع مسجل (ربما لم يشغل التطبيق بعد)
|
|
jsonError("No location found for this driver");
|
|
}
|
|
|
|
} catch (PDOException $e) {
|
|
jsonError("Database Error: " . $e->getMessage());
|
|
}
|
|
?>
|