[2026-02-12 09:22:39.000] === STARTING PROCESSING SESSION === [2026-02-12 09:22:39.000] PHP Version: 8.4.16 [2026-02-12 09:22:39.000] Memory Limit: 128M [2026-02-12 09:22:39.000] Max Execution Time: 120 [2026-02-12 09:22:39.000] Disabled functions: NONE [2026-02-12 09:22:39.000] Raw body length: 1582946 [2026-02-12 09:22:39.000] Provided signature: 4fa102c99e1babc7592b... [2026-02-12 09:22:39.000] Expected signature: 4fa102c99e1babc7592b... [2026-02-12 09:22:39.000] Signature verified successfully [2026-02-12 09:22:39.000] Payload JSON decoded: SUCCESS [2026-02-12 09:22:39.000] Number of PDFs to process: 1 [2026-02-12 09:22:39.000] --- Processing PDF #1 --- [2026-02-12 09:22:39.000] PDF base64 provided: YES, length: 1550132 [2026-02-12 09:22:39.000] PDF bytes decoded: 1162599 bytes [2026-02-12 09:22:39.000] Temp PDF written to /tmp/invoice_698d9bdf9d37a.pdf, bytes written: 1162599 [2026-02-12 09:22:39.000] Temp PDF exists: YES [2026-02-12 09:22:39.000] Temp PDF size: 1162599 bytes [2026-02-12 09:22:39.000] PDF hash: d4532ef876012cad5bfe8c67ea72283ac342983777c3198af56852ac03c0b512 [2026-02-12 09:22:39.000] Checking database cache for hash: d4532ef876012cad... [2026-02-12 09:22:39.000] CACHE MISS - Not found in database [2026-02-12 09:22:39.000] Starting PDF processing (not cached) [2026-02-12 09:22:39.000] STEP 1: Quick Smalot parser attempt [2026-02-12 09:22:39.000] Smalot parsing took: 0.02 seconds [2026-02-12 09:22:39.000] Number of pages detected: 7 [2026-02-12 09:22:39.000] Smalot extracted text length: 1027 [2026-02-12 09:22:39.000] Smalot parser SUCCESS - using text extraction [2026-02-12 09:22:39.000] Smalot text preview (first 200 chars): | Data: Zentrale: Föhrengasse 2, 8501 Lieboch Lazarettgürtel 81, 8020 Graz Name: ib-g engineering & consulting GmbH Datum: 12.02.2026 Adresse:Föhrengasse 2 RE-Zeitraum:Jänner PLZ: 8501 Lie [2026-02-12 09:22:39.000] Using Smalot OCR method, text length: 1027 [2026-02-12 09:22:39.000] Attempting OpenAI parsing with smalot OCR [2026-02-12 09:22:39.000] run_openai_parse called, text length: 1027 [2026-02-12 09:22:39.000] OpenAI input preview: | Data: Zentrale: Föhrengasse 2, 8501 Lieboch Lazarettgürtel 81, 8020 Graz Name: ib-g engineering & consulting GmbH Datum: 12.02.2026 Adresse:Föhrengasse 2 RE-Zeitraum:Jänner PLZ: 8501 Lie... [2026-02-12 09:22:39.000] Making OpenAI API call... [2026-02-12 09:22:42.000] OpenAI HTTP response code: 200 [2026-02-12 09:22:42.000] OpenAI response received, length: 987 [2026-02-12 09:22:42.000] OpenAI content extracted, length: 150 [2026-02-12 09:22:42.000] OpenAI parsed JSON result | Data: {"invoice_number":"2025-0595","amount":"13301.32","due_date":"2026-05-12","invoice_date":"2026-02-12","currency":"EUR"} [2026-02-12 09:22:42.000] Final AI result | Data: {"invoice_number":"2025-0595","amount":"13301.32","due_date":"2026-05-12","invoice_date":"2026-02-12","currency":"EUR"} [2026-02-12 09:22:42.000] normalize_amount called with: | Data: 13301.32 [2026-02-12 09:22:42.000] normalize_amount result: | Data: 13301.32 [2026-02-12 09:22:42.000] normalize_date_iso called with: | Data: 2026-02-12 [2026-02-12 09:22:42.000] Final extracted values | Data: {"invoice_number":"2025-0595","amount":"13301.32","due_date":"2026-05-12","invoice_date":"2026-02-12","currency":"EUR"} [2026-02-12 09:22:42.000] Attempting to save PDF to: /var/www/html/pdfs/invoice_a5802a53d8b6b54a29d5107b81bd99ad.pdf [2026-02-12 09:22:42.000] PDF saved successfully to /var/www/html/pdfs/invoice_a5802a53d8b6b54a29d5107b81bd99ad.pdf [2026-02-12 09:22:42.000] Database INSERT SUCCESS [2026-02-12 09:22:42.000] Adding to invoices array | Data: {"uuid":"a5802a53d8b6b54a29d5107b81bd99ad","invoice_number":"2025-0595","amount":"13301.32","due_date":"2026-05-12","invoice_date":"2026-02-12","currency":"EUR","cached":false,"ocr_method":"smalot","local_ocr_failed":false} [2026-02-12 09:22:42.000] --- Finished processing PDF #1 --- [2026-02-12 09:22:42.000] === TOTAL PROCESSING TIME: 3213.45ms === [2026-02-12 09:22:42.000] Total invoices processed: 1 [2026-02-12 09:22:42.000] Response sent, size: 238 bytes