[2026-02-27 09:36:33.000] === STARTING PROCESSING SESSION === [2026-02-27 09:36:33.000] PHP Version: 8.4.16 [2026-02-27 09:36:33.000] Memory Limit: 128M [2026-02-27 09:36:33.000] Max Execution Time: 120 [2026-02-27 09:36:33.000] Disabled functions: NONE [2026-02-27 09:36:33.000] Raw body length: 471087 [2026-02-27 09:36:33.000] Provided signature: bdd7d277a6b5c17954f5... [2026-02-27 09:36:33.000] Expected signature: bdd7d277a6b5c17954f5... [2026-02-27 09:36:33.000] Signature verified successfully [2026-02-27 09:36:33.000] Payload JSON decoded: SUCCESS [2026-02-27 09:36:33.000] Number of PDFs to process: 1 [2026-02-27 09:36:33.000] --- Processing PDF #1 --- [2026-02-27 09:36:33.000] PDF base64 provided: YES, length: 462400 [2026-02-27 09:36:33.000] PDF bytes decoded: 346799 bytes [2026-02-27 09:36:33.000] Temp PDF written to /tmp/invoice_69a165a11a1f5.pdf, bytes written: 346799 [2026-02-27 09:36:33.000] Temp PDF exists: YES [2026-02-27 09:36:33.000] Temp PDF size: 346799 bytes [2026-02-27 09:36:33.000] PDF hash: 1407b0363eb99663b1edd912be3c31bc86b3d46354cf6e08c61e80aaf13b6177 [2026-02-27 09:36:33.000] Checking database cache for hash: 1407b0363eb99663... [2026-02-27 09:36:33.000] CACHE MISS - Not found in database [2026-02-27 09:36:33.000] Starting PDF processing (not cached) [2026-02-27 09:36:33.000] STEP 1: Quick Smalot parser attempt [2026-02-27 09:36:33.000] Smalot parsing took: 0.01 seconds [2026-02-27 09:36:33.000] Number of pages detected: 3 [2026-02-27 09:36:33.000] Smalot extracted text length: 965 [2026-02-27 09:36:33.000] Smalot parser SUCCESS - using text extraction [2026-02-27 09:36:33.000] Smalot text preview (first 200 chars): | Data: Zentrale: Föhrengasse 2, 8501 Lieboch Weblinger Gürtel 33/16, 8054 Graz Name: FSC Hagelschutz GmbH Datum: 27.02.2026 Adresse:Ludersdorf 231 RE-Zeitraum: Februar PLZ: 8200 Ludersdorf-Wilfersdorf UID- [2026-02-27 09:36:33.000] Using Smalot OCR method, text length: 965 [2026-02-27 09:36:33.000] Attempting OpenAI parsing with smalot OCR [2026-02-27 09:36:33.000] run_openai_parse called, text length: 965 [2026-02-27 09:36:33.000] OpenAI input preview: | Data: Zentrale: Föhrengasse 2, 8501 Lieboch Weblinger Gürtel 33/16, 8054 Graz Name: FSC Hagelschutz GmbH Datum: 27.02.2026 Adresse:Ludersdorf 231 RE-Zeitraum: Februar PLZ: 8200 Ludersdorf-Wilfersdorf UID-... [2026-02-27 09:36:33.000] Making OpenAI API call... [2026-02-27 09:36:36.000] OpenAI HTTP response code: 200 [2026-02-27 09:36:36.000] OpenAI response received, length: 986 [2026-02-27 09:36:36.000] OpenAI content extracted, length: 149 [2026-02-27 09:36:36.000] OpenAI parsed JSON result | Data: {"invoice_number":"2025-0612","amount":"5561.08","due_date":"2026-03-20","invoice_date":"2026-02-27","currency":"EUR"} [2026-02-27 09:36:36.000] Final AI result | Data: {"invoice_number":"2025-0612","amount":"5561.08","due_date":"2026-03-20","invoice_date":"2026-02-27","currency":"EUR"} [2026-02-27 09:36:36.000] normalize_amount called with: | Data: 5561.08 [2026-02-27 09:36:36.000] normalize_amount result: | Data: 5561.08 [2026-02-27 09:36:36.000] normalize_date_iso called with: | Data: 2026-02-27 [2026-02-27 09:36:36.000] Final extracted values | Data: {"invoice_number":"2025-0612","amount":"5561.08","due_date":"2026-03-20","invoice_date":"2026-02-27","currency":"EUR"} [2026-02-27 09:36:36.000] Attempting to save PDF to: /var/www/html/pdfs/invoice_010bfa43ca6069bdcb16b6aa211bb0ce.pdf [2026-02-27 09:36:36.000] PDF saved successfully to /var/www/html/pdfs/invoice_010bfa43ca6069bdcb16b6aa211bb0ce.pdf [2026-02-27 09:36:36.000] Database INSERT SUCCESS [2026-02-27 09:36:36.000] Adding to invoices array | Data: {"uuid":"010bfa43ca6069bdcb16b6aa211bb0ce","invoice_number":"2025-0612","amount":"5561.08","due_date":"2026-03-20","invoice_date":"2026-02-27","currency":"EUR","cached":false,"ocr_method":"smalot","local_ocr_failed":false} [2026-02-27 09:36:36.000] --- Finished processing PDF #1 --- [2026-02-27 09:36:36.000] === TOTAL PROCESSING TIME: 2945.64ms === [2026-02-27 09:36:36.000] Total invoices processed: 1 [2026-02-27 09:36:36.000] Response sent, size: 237 bytes