Tag: invoices

  • Fulfillment – Daily Changelog – September 20, 2025

    Fulfillment – Daily Changelog – September 20, 2025

    2025-09-20 – Duplicate Invoice Prevention System

    Critical Issue – Duplicate Invoice Prevention

    Problem Identified

    • Issue: System created duplicate invoices for the same order yesterday
    • Impact: Both invoices were pushed to QuickBooks and automatically paid
    • Risk: Financial discrepancies and double payments
    • Priority: Critical – needs immediate attention

    Investigation Plan

    • [x] Analyze invoice creation workflow
    • [x] Identify potential race conditions or duplicate triggers
    • [x] Implement safeguards to prevent duplicate invoice generation
    • [x] Add validation checks before QuickBooks integration
    • [x] Test invoice creation process thoroughly

    Root Causes Identified

    • No Database Constraints: mama_tried_invoices table lacks unique constraint on invoice_number
    • No Idempotency Protection: Multiple API calls can create invoices for same orders
    • QuickBooks Integration Risk: No check if invoice already sent to QuickBooks
    • Race Condition Potential: Multiple users can create invoices simultaneously

    Implemented Solutions

    Database-Level Protection

    • Added UNIQUE constraint on mama_tried_invoices.invoice_number to prevent database-level duplicates
    • Created invoice_operations table for idempotency tracking and audit trail

    Invoice Creation Safeguards

    • Pre-invoice validation: Check if orders already have invoices before creation
    • Idempotency key system: Generate unique keys to prevent duplicate API calls
    • Conflict detection: Return 409 status code with detailed error information
    • Audit trail: Track all invoice creation operations with timestamps and user info

    QuickBooks Integration Safety

    • Duplicate push prevention: Check quickbooks_invoice_id and status before sending
    • Status validation: Prevent sending invoices already marked as ‘sent_to_quickbooks’
    • Detailed error responses: Clear messaging when duplicates are detected

    Frontend Protection

    • Idempotency key generation: Unique keys based on timestamp, order IDs, and random string
    • Enhanced error handling: Specific handling for 409 conflict responses
    • User feedback: Clear toast notifications for duplicate prevention triggers

    Current Status

    Completed

    • Comprehensive duplicate invoice prevention system implemented
    • Database constraints and validation in place
    • Idempotency protection for API calls
    • QuickBooks integration safeguards
    • Frontend duplicate prevention with user feedback

    Ready for Testing

    • All safeguards are in place and ready for production testing
    • System will now prevent duplicate invoices at multiple levels
    • Financial risk significantly reduced through layered protection

    Technical Implementation Details

    Database Changes

    • mama_tried_invoices: Added UNIQUE constraint on invoice_number column
    • invoice_operations: New table for idempotency tracking with columns:
    • idempotency_key (VARCHAR, UNIQUE)
    • operation_type (VARCHAR, default ‘invoice_creation’)
    • status (VARCHAR, default ‘completed’)
    • result_data (TEXT, stores JSON response)
    • created_at, created_by (audit fields)

    API Endpoint Changes

    • /api/invoices POST: Added pre-creation duplicate checks and idempotency support
    • /api/intuit/send-db-invoice GET: Added QuickBooks duplicate push prevention
    • Error handling: Enhanced with 409 Conflict status codes and detailed error messages

    Frontend Changes

    • invoice-dialog.tsx: Added idempotency key generation and duplicate error handling
    • User experience: Clear feedback when duplicate prevention triggers

    Notes

    • Critical financial protection: Multi-layered duplicate prevention system now active
    • Immediate deployment: All changes are backward compatible and safe for production
    • Testing recommended: Verify duplicate prevention works as expected before next invoice cycle
    • Monitoring: Watch logs for “DUPLICATE PREVENTION” and “IDEMPOTENCY” messages