decryptData($v); } catch (\Throwable $e) { return $v; } }; // أعمدة مشتركة/موحّدة للإخراج return [ 'id' => $get('id'), 'driverID' => $get('driverID'), 'vin' => $dec($get('vin')), // إن كان مُشفراً 'car_plate' => $dec($get('car_plate')), // إن كان مُشفراً 'make' => $get('make'), 'model' => $get('model'), 'year' => $get('year'), 'expiration_date' => $get('expiration_date'), 'color' => $get('color'), 'color_hex' => $get('color_hex'), 'owner' => $dec($get('owner')), // إن كان مُشفراً 'address' => $dec($get('address')), // قد لا يوجد في CarRegistration 'type' => $get('type'), // إن وُجد 'isDefault' => (int)($get('isDefault', 0)), 'status' => $get('status'), 'created_at' => $get('created_at'), 'source' => $source, // لمعرفة مصدر السجل ]; } // 1) جلب من captains_car $sql1 = "SELECT * FROM captains_car WHERE driverID = :driverID"; $st1 = $con->prepare($sql1); $st1->execute([':driverID' => $driverID]); $rows1 = $st1->fetchAll(PDO::FETCH_ASSOC); // 2) جلب من CarRegistration $sql2 = "SELECT * FROM CarRegistration WHERE driverID = :driverID"; $st2 = $con->prepare($sql2); $st2->execute([':driverID' => $driverID]); $rows2 = $st2->fetchAll(PDO::FETCH_ASSOC); // 3) توحيد النتائج مع فك التشفير $result = []; foreach ($rows1 as $r) { $result[] = normalize_car_row($r, 'captains_car', $encryptionHelper); } foreach ($rows2 as $r) { $result[] = normalize_car_row($r, 'CarRegistration', $encryptionHelper); } if (empty($result)) { jsonError("No driver car data found"); exit; } // 4) ترتيب النتيجة: السيارات الافتراضية أولاً ثم الأحدث إنشاءً usort($result, function($a, $b) { // isDefault desc if ((int)$a['isDefault'] !== (int)$b['isDefault']) { return (int)$b['isDefault'] <=> (int)$a['isDefault']; } // created_at desc (لو أحدهم null لن يؤثر) return strcmp((string)$b['created_at'], (string)$a['created_at']); }); jsonSuccess($result); } catch (PDOException $e) { error_log("Database error (get_driver_cars): " . $e->getMessage()); jsonError("Database error occurred"); } catch (Throwable $e) { error_log("App error (get_driver_cars): " . $e->getMessage()); jsonError("Unexpected error occurred"); }