Files
Siro/backend/ride/rides/start_ride.php
Hamza-Ayed 72eeb24cd7 Fix #18: Exception leak remediation across 87 PHP files
- Replaced all client-facing $e->getMessage() with generic error messages
- Added error_log() with filename prefix to all catch blocks
- Covered jsonError(), echo, and json_encode() response patterns
- Also fixed 2 remaining display_errors=1 and add_invoice.php leak
- Script-assisted fix for 75 files, manual fix for 12 remaining edge cases
2026-06-17 07:48:31 +03:00

128 lines
5.3 KiB
PHP

<?php
// start_ride.php
require_once __DIR__ . '/../../connect.php';
try {
$con_ride = Database::get('ride');
} catch (Exception $e) {
error_log("[start_ride] Failed to connect to Ride Database: " . $e->getMessage());
}
$ride_id = filterRequest("id");
$driver_id = filterRequest("driver_id");
$status = filterRequest("status"); // 'Begin'
$passengerToken = filterRequest("passengerToken");
if (!$ride_id || !$driver_id || !$status) {
jsonError("Missing parameters");
exit;
}
try {
// 1. تحديث سيرفر الرحلات (Remote DB - con_ride)
$stmtRemote = $con_ride->prepare("UPDATE ride SET status = ?, rideTimeStart = NOW() WHERE id = ?");
$stmtRemote->execute([$status, $ride_id]);
if ($stmtRemote->rowCount() == 0) {
// ملاحظة: أحياناً التحديث لا يؤثر بصفوف إذا كانت البيانات نفسها،
// لكن هنا نفترض الفشل إذا لم يجد الرحلة.
// يمكنك إكمال التنفيذ إذا كنت متأكداً أن الرحلة موجودة.
}
// 2. تحديث السيرفر المحلي (Local DB) والمعاملات
$con->beginTransaction();
// تحديث الرحلة محلياً
$stmtMainRide = $con->prepare("UPDATE ride SET status = ?, rideTimeStart = NOW() WHERE id = ?");
$stmtMainRide->execute([$status, $ride_id]);
// تحديث أو إدخال في جدول Driver Orders
$checkSql = "SELECT `order_id` FROM `driver_orders` WHERE `order_id` = ?";
$checkStmt = $con->prepare($checkSql);
$checkStmt->execute([$ride_id]);
if ($checkStmt->rowCount() > 0) {
$updateSql = "UPDATE `driver_orders` SET `driver_id` = ?, `status` = ?, `created_at` = NOW() WHERE `order_id` = ?";
$con->prepare($updateSql)->execute([$driver_id, $status, $ride_id]);
} else {
$insertSql = "INSERT INTO `driver_orders` (`driver_id`, `order_id`, `created_at`, `status`) VALUES (?, ?, NOW(), ?)";
$con->prepare($insertSql)->execute([$driver_id, $ride_id, $status]);
}
// =================================================================
// 🔥 الخطوة 3: إشعار الراكب (Socket + FCM)
// =================================================================
// جلب بيانات الراكب من قاعدة البيانات لضمان الدقة
$stmtPas = $con_ride->prepare("SELECT passenger_id FROM ride WHERE id = ?");
$stmtPas->execute([$ride_id]);
$passenger_id = $stmtPas->fetchColumn();
// 2.5 تصفير الدين من Redis عند بدء الرحلة (كما طلبت)
if ($passenger_id) {
try {
$redis = new Redis();
$redis->connect('127.0.0.1', 6379);
$redisKey = "passenger_debt_" . $passenger_id;
// قراءة الدين الحالي من Redis قبل الحذف (إن لزم الأمر للتسجيل مستقبلاً)
$currentDebt = (float) $redis->get($redisKey);
// تصفير / حذف الدين
$redis->del($redisKey);
// يمكنك هنا أيضاً إدراج حركة معاكسة في جدول passengerWallet إذا أردت تسوية قاعدة البيانات
if ($currentDebt < 0) {
$positiveOffset = abs($currentDebt);
$stmtWallet = $con->prepare("INSERT INTO `passengerWallet` (passenger_id, balance) VALUES (?, ?)");
$stmtWallet->execute([$passenger_id, $positiveOffset]);
}
} catch (Exception $e) {
error_log("Redis Error (zeroing debt): " . $e->getMessage());
}
}
if ($passenger_id) {
// أ) إرسال السوكيت (Socket)
// تم إلغاء التعليق عنه ليكون السيرفر هو المسؤول
$socketPayload = [
'ride_id' => $ride_id,
'status' => 'started', // أو 'Begin' حسب ما يتوقعه التطبيق
'msg' => 'بدأت الرحلة، نتمنى لك سلامة الوصول 🚀'
];
if (function_exists('notifyPassengerOnRideServer')) {
notifyPassengerOnRideServer($passenger_id, $socketPayload);
}
// ب) إرسال FCM (Internal)
if (!empty($passengerToken)) {
$fcmData = [
'category' => 'Trip is Begin',
'ride_id' => (string)$ride_id,
'status' => 'started'
];
// 🔥 استخدام sendFCM_Internal كرسالة صامتة
sendFCM_Internal(
$passengerToken, // الهدف
"", // تفريغ العنوان
"", // تفريغ النص
$fcmData, // البيانات
"Trip is Begin", // التصنيف
false // ليس Topic
);
}
}
$con->commit();
jsonSuccess(null, "Ride started successfully");
} catch (PDOException $e) {
if ($con->inTransaction()) {
$con->rollBack();
}
jsonError("An internal error occurred. Please try again later.");
}
?>