prepare($sql_check); $stmt_check->execute(['driverID' => $driverID, 'user_phone' => $user_phone]); $existing = $stmt_check->fetch(PDO::FETCH_ASSOC); // إنشاء رقم فاتورة جديد ومميز $new_invoice_number = random_int(100000, 999999); if ($existing) { // --- 4a. تحديث الفاتورة المعلقة الحالية --- // error_log("[CreateInvoice] Found existing pending invoice (ID: {$existing['id']}). Updating it."); $sql_update = "UPDATE invoices_sms SET invoice_number = :invoice_number, amount = :amount, created_at = NOW() WHERE id = :id"; $stmt_update = $con->prepare($sql_update); $stmt_update->execute([ ':invoice_number' => $new_invoice_number, ':amount' => $amount, ':id' => $existing['id'] ]); // error_log("[CreateInvoice] Invoice updated. New invoice number: {$new_invoice_number}"); echo json_encode([ "status" => "success", "message" => "Pending invoice updated.", "invoice_number" => $new_invoice_number ]); } else { // --- 4b. إنشاء فاتورة جديدة --- // error_log("[CreateInvoice] No pending invoice found. Creating a new one."); $sql_insert = "INSERT INTO invoices_sms (invoice_number, driverID, user_phone, amount, status) VALUES (:invoice_number, :driverID, :user_phone, :amount, 'pending')"; $stmt_insert = $con->prepare($sql_insert); $ok = $stmt_insert->execute([ ':invoice_number' => $new_invoice_number, ':driverID' => $driverID, ':user_phone' => $user_phone, ':amount' => $amount ]); if ($ok) { // error_log("[CreateInvoice] New invoice created successfully. Invoice number: {$new_invoice_number}"); echo json_encode([ "status" => "success", "message" => "New invoice created.", "invoice_number" => $new_invoice_number ]); } else { // error_log("[CreateInvoice] CRITICAL: Failed to execute INSERT statement."); printFailure("Failed to create invoice."); } } } catch (PDOException $e) { // تسجيل أخطاء قاعدة البيانات // error_log("[CreateInvoice] PDOException: " . $e->getMessage()); printFailure("Database error: " . $e->getMessage()); } catch (Throwable $e) { // تسجيل أي أخطاء أخرى غير متوقعة // error_log("[CreateInvoice] Throwable Exception: " . $e->getMessage()); printFailure("An unexpected server error occurred."); } //error_log("[CreateInvoice] --- Request Ended ---"); ?>