prepare("INSERT INTO payment_tokens (token, driverID, dateCreated, amount) VALUES (:token, :driverID, NOW(), :amount)"); $stmt->execute([':token' => $token, ':driverID' => $driverId, ':amount' => $amount]); return $stmt->rowCount() > 0 ? $token : null; } } if (!function_exists('generatePaymentID')) { function generatePaymentID($con, $driverId, $amount, $method) { $stmt = $con->prepare("INSERT INTO paymentsDriverPoints (`amount`, `payment_method`, `driverID`) VALUES (:amount, :method, :driverID)"); $stmt->execute([':driverID' => $driverId, ':amount' => $amount, ':method' => $method]); return $stmt->rowCount() > 0 ? $con->lastInsertId() : null; } } if (!function_exists('finalizeShamCashDeposit')) { function finalizeShamCashDeposit(PDO $con, $invoice_id) { // 1. جلب بيانات الفاتورة $stmt = $con->prepare("SELECT * FROM invoices_shamcash WHERE id = :id AND status = 'processing' LIMIT 1"); $stmt->execute([':id' => $invoice_id]); $invoice = $stmt->fetch(PDO::FETCH_ASSOC); if (!$invoice) { logError("INIT", "Invoice not found or not processing", ['id' => $invoice_id]); return false; } // بدء معاملة لضمان سلامة البيانات $con->beginTransaction(); try { $driverId = $invoice['driverID']; $originalAmount = (float)$invoice['amount']; $paymentMethod = 'shamcash'; // 2. حساب المكافأة (Bonus Calculation) - نفس المنطق المرسل $bonusAmount = match ((int)$originalAmount) { 100 => 100.0, 200 => 210.0, 400 => 450.0, 1000 => 1100.0, default => $originalAmount, }; // 3. إنشاء التوكنات $tokenDriver = generateToken($con, $driverId, $bonusAmount); if (!$tokenDriver) throw new Exception('Failed to generate driver token'); $tokenSefer = generateToken($con, $driverId, $originalAmount); if (!$tokenSefer) throw new Exception('Failed to generate sefer token'); // 4. إنشاء Payment ID $paymentID = generatePaymentID($con, $driverId, $bonusAmount, $paymentMethod); if (!$paymentID) throw new Exception('Failed to generate payment ID'); // 5. الإيداع في محفظة السائق (driverWallet) - المبلغ مع البونص $insertDriver = $con->prepare("INSERT INTO driverWallet (driverID, paymentID, amount, paymentMethod) VALUES (:driverID, :paymentID, :amount, :paymentMethod)"); $insertDriver->execute([ ':driverID' => $driverId, ':paymentID' => $paymentID, ':amount' => $bonusAmount, ':paymentMethod' => $paymentMethod ]); if ($insertDriver->rowCount() === 0) throw new Exception('Insert to driverWallet failed'); // حرق توكن السائق $con->prepare("UPDATE payment_tokens SET isUsed = TRUE WHERE token = :token")->execute([':token' => $tokenDriver]); // 6. الإيداع في محفظة الشركة (seferWallet) - المبلغ الأصلي $insertSefer = $con->prepare("INSERT INTO seferWallet (driverId, passengerId, amount, paymentMethod, token, createdAt) VALUES (:driverId, :passengerId, :amount, :paymentMethod, :token, CURRENT_TIMESTAMP)"); $insertSefer->execute([ ':driverId' => $driverId, ':passengerId' => 'driver', ':amount' => $originalAmount, ':paymentMethod' => $paymentMethod, ':token' => $tokenSefer ]); if ($insertSefer->rowCount() === 0) throw new Exception('Insert to seferWallet failed'); // حرق توكن الشركة $con->prepare("UPDATE payment_tokens SET isUsed = TRUE WHERE token = :token")->execute([':token' => $tokenSefer]); // 7. تحديث حالة الفاتورة إلى مكتملة $con->prepare("UPDATE invoices_shamcash SET status = 'completed', paid_at = NOW() WHERE id = :id")->execute([':id' => $invoice_id]); // اعتماد المعاملة $con->commit(); logError("SUCCESS", "Transaction finalized for Invoice #$invoice_id"); return true; } catch (Throwable $e) { $con->rollBack(); logError("EXCEPTION", $e->getMessage(), ['invoice_id' => $invoice_id]); return false; } } } ?>