This commit is contained in:
Hamza-Ayed
2026-04-30 18:02:49 +03:00
parent 5e6e5c50fc
commit e089d72ff9
3 changed files with 64 additions and 10 deletions

View File

@@ -4,17 +4,47 @@ require_once __DIR__ . '/../../connect.php';
$phone = filterRequest("phone");
// Encrypt phone
$encphone = $encryptionHelper->encryptData($phone);
// تنظيف الرقم من أي مسافات أو رموز زائدة
$phone = preg_replace('/[^0-9]/', '', $phone);
// احتمالات الرقم (بالصفر الدولي أو بدونه)
$phoneVariants = [];
$phoneVariants[] = $phone; // كما هو (مثلاً 0992952235)
if (str_starts_with($phone, '0')) {
$phoneVariants[] = '963' . substr($phone, 1); // تحويل 09 إلى 9639
} elseif (str_starts_with($phone, '963')) {
$phoneVariants[] = '0' . substr($phone, 3); // تحويل 9639 إلى 09
}
// Encrypt each variant to see if any match the encrypted column
$encVariants = [];
foreach ($phoneVariants as $v) {
$encVariants[] = $encryptionHelper->encryptData($v);
}
error_log("[GIFT_CHECK] Received Phone: " . $phone);
error_log("[GIFT_CHECK] Encrypted Phone: " . $encphone);
error_log("[GIFT_CHECK] Variants: " . implode(', ', $phoneVariants));
$sql = "SELECT * FROM `driver` WHERE phone = :encPhone OR phone = :rawPhone";
// بناء استعلام يبحث عن كل الاحتمالات (المشفرة وغير المشفرة)
$placeholders = [];
$params = [];
foreach ($encVariants as $i => $ev) {
$placeholders[] = "phone = :enc$i";
$params[":enc$i"] = $ev;
}
foreach ($phoneVariants as $i => $pv) {
$placeholders[] = "phone = :raw$i";
$params[":raw$i"] = $pv;
}
$sql = "SELECT * FROM `driver` WHERE " . implode(" OR ", $placeholders);
$stmt = $con->prepare($sql);
$stmt->bindParam(':encPhone', $encphone, PDO::PARAM_STR);
$stmt->bindParam(':rawPhone', $phone, PDO::PARAM_STR);
foreach ($params as $key => $val) {
$stmt->bindValue($key, $val);
}
$stmt->execute();