Files
Siro/backend/ride/rides/getRideStatusFromStartApp.php
2026-06-16 02:14:35 +03:00

94 lines
3.4 KiB
PHP

<?php
require_once __DIR__ . '/../../connect.php';
$passenger_id = filterRequest("passenger_id");
try {
$con_ride = Database::get('ride');
// =========================================================
// 1. سيرفر الرحلات: جلب بيانات الرحلة
// =========================================================
$stmt = $con_ride->prepare("
SELECT
id AS rideId,
status,
start_location,
end_location,
carType,
driver_id,distance,
price,
created_at
FROM ride
WHERE passenger_id = ?
AND (
status IN ('Apply', 'Applied', 'accepted', 'arrived', 'Arrived', 'Begin') AND created_at >= NOW() - INTERVAL 24 HOUR
OR (status = 'Finished' AND created_at >= NOW() - INTERVAL 24 HOUR)
)
ORDER BY created_at DESC
LIMIT 1
");
$stmt->execute([$passenger_id]);
$ride = $stmt->fetch(PDO::FETCH_ASSOC);
if (!$ride) {
echo json_encode(["status" => "failure", "message" => "No active ride found"]);
exit;
}
// =========================================================
// 2. السيرفر الرئيسي: جلب اسم السائق + متوسط تقييمه العام
// =========================================================
// ملاحظة: تم الحفاظ على الاستعلام كما هو
// rateDriver: هو الاسم الذي سنستخدمه في PHP
$stmt2 = $con->prepare("
SELECT
d.first_name AS driverName,
(SELECT AVG(rating) FROM ratingDriver WHERE driver_id = d.id) AS rateDriver,
(SELECT COUNT(*) FROM ratingDriver WHERE ride_id = ?) AS thisRideRated
FROM driver d
WHERE d.id = ?
");
$stmt2->execute([$ride['rideId'], $ride['driver_id']]);
$driverData = $stmt2->fetch(PDO::FETCH_ASSOC);
// =========================================================
// 3. المعالجة النهائية
// =========================================================
if ($driverData) {
// فك التشفير
$ride['driverName'] = $encryptionHelper->decryptData($driverData['driverName']);
// --- تصحيح الخطأ هنا ---
// كان يستدعي driverAvg وهو غير موجود، تم تغييره لـ rateDriver
$ride['rateDriver'] = $driverData['rateDriver'] ? round($driverData['rateDriver'], 2) : 5;
// --- منطق هل تحتاج الرحلة لتقييم (needsReview) ---
$isFinished = ($ride['status'] === 'Finished');
$isRated = ($driverData['thisRideRated'] > 0);
$ride['needsReview'] = ($isFinished && !$isRated) ? 1 : 0;
} else {
// حالة عدم وجود سائق (نادراً ما تحدث إذا كان driver_id موجوداً في جدول الرحلات)
$ride['driverName'] = null;
$ride['rateDriver'] = 5;
$ride['needsReview'] = 0;
}
// تنظيف البيانات
unset($ride['created_at']);
echo json_encode([
"status" => "success",
"data" => $ride
]);
} catch (Exception $e) {
error_log("[getRideStatusFromStartApp] Error: " . $e->getMessage());
echo json_encode(["status" => "failure", "message" => "An internal error occurred."]);
}
?>