2026-05-16T03:36:32+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_033631_95d4e13b"}
2026-05-16T03:36:32+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_033631_c42bbad0"}
2026-05-16T03:36:32+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_033631_c42bbad0"}
2026-05-16T03:36:32+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_033631_95d4e13b"}
2026-05-16T03:36:32+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_033631_c42bbad0"}
2026-05-16T03:36:32+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_033631_95d4e13b"}
2026-05-16T03:36:32+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_033631_c42bbad0"}
2026-05-16T03:36:32+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_033631_95d4e13b"}
2026-05-16T03:36:32+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_033631_c42bbad0"}
2026-05-16T03:36:32+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_033631_c42bbad0"}
2026-05-16T03:36:32+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_033631_95d4e13b"}
2026-05-16T03:36:32+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_033631_95d4e13b"}
2026-05-16T03:36:32+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_033631_95d4e13b"}
2026-05-16T03:36:32+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_033631_c42bbad0"}
2026-05-16T03:36:32+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_033631_95d4e13b"}
2026-05-16T03:36:32+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":32614,"run_id":"20260516_033631_95d4e13b"}
2026-05-16T03:36:32+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.238,"exec_milliseconds":1238,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":32614,"important":true,"run_id":"20260516_033631_95d4e13b"}
2026-05-16T03:36:33+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_033633_67a7a7b6"}
2026-05-16T03:36:33+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_033633_67a7a7b6"}
2026-05-16T03:36:33+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_033633_67a7a7b6"}
2026-05-16T03:36:33+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_033633_67a7a7b6"}
2026-05-16T03:36:33+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_033631_c42bbad0"}
2026-05-16T03:36:33+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.68,"duration_milliseconds":680,"important":true,"run_id":"20260516_033631_c42bbad0"}
2026-05-16T03:36:33+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_033631_c42bbad0"}
2026-05-16T03:36:33+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.051,"duration_milliseconds":51,"important":true,"run_id":"20260516_033631_c42bbad0"}
2026-05-16T03:36:33+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":36924,"run_id":"20260516_033631_c42bbad0"}
2026-05-16T03:36:33+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.918,"exec_milliseconds":1918,"live_games":0,"fallback_games":2,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":36924,"important":true,"run_id":"20260516_033631_c42bbad0"}
2026-05-16T03:36:33+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_033633_67a7a7b6"}
2026-05-16T03:36:33+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_033633_67a7a7b6"}
2026-05-16T03:36:33+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_033633_67a7a7b6"}
2026-05-16T03:36:33+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_033633_67a7a7b6"}
2026-05-16T03:36:33+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_033633_67a7a7b6"}
2026-05-16T03:36:33+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.701,"exec_milliseconds":701,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_033633_67a7a7b6"}
2026-05-16T05:51:25+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_055125_4ee2a3e4"}
2026-05-16T05:51:25+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_055125_d6f2a822"}
2026-05-16T05:51:25+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_055125_4ee2a3e4"}
2026-05-16T05:51:25+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_055125_4ee2a3e4"}
2026-05-16T05:51:25+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_055125_4ee2a3e4"}
2026-05-16T05:51:25+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_055125_d6f2a822"}
2026-05-16T05:51:25+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_055125_d6f2a822"}
2026-05-16T05:51:26+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_055125_d6f2a822"}
2026-05-16T05:51:26+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_055125_2249bd1c"}
2026-05-16T05:51:26+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_055125_4ee2a3e4"}
2026-05-16T05:51:26+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_055125_4ee2a3e4"}
2026-05-16T05:51:26+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_055125_d6f2a822"}
2026-05-16T05:51:26+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_055125_4ee2a3e4"}
2026-05-16T05:51:26+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_055125_d6f2a822"}
2026-05-16T05:51:26+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_055125_d6f2a822"}
2026-05-16T05:51:26+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_055125_4ee2a3e4"}
2026-05-16T05:51:26+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_055125_4ee2a3e4"}
2026-05-16T05:51:26+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.895,"exec_milliseconds":895,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_055125_4ee2a3e4"}
2026-05-16T05:51:26+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_055125_d6f2a822"}
2026-05-16T05:51:26+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":32612,"run_id":"20260516_055125_d6f2a822"}
2026-05-16T05:51:26+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.932,"exec_milliseconds":932,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":32612,"important":true,"run_id":"20260516_055125_d6f2a822"}
2026-05-16T05:51:26+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_055125_2249bd1c"}
2026-05-16T05:51:26+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_055125_2249bd1c"}
2026-05-16T05:51:26+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_055125_2249bd1c"}
2026-05-16T05:51:26+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_055125_2249bd1c"}
2026-05-16T05:51:26+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_055125_2249bd1c"}
2026-05-16T05:51:26+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_055125_2249bd1c"}
2026-05-16T05:51:27+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_055125_2249bd1c"}
2026-05-16T05:51:27+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.7,"duration_milliseconds":700,"important":true,"run_id":"20260516_055125_2249bd1c"}
2026-05-16T05:51:27+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_055125_2249bd1c"}
2026-05-16T05:51:27+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.058,"duration_milliseconds":58,"important":true,"run_id":"20260516_055125_2249bd1c"}
2026-05-16T05:51:27+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":36924,"run_id":"20260516_055125_2249bd1c"}
2026-05-16T05:51:27+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.748,"exec_milliseconds":1748,"live_games":0,"fallback_games":2,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":36924,"important":true,"run_id":"20260516_055125_2249bd1c"}
2026-05-16T13:00:18+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_130017_9df94202"}
2026-05-16T13:00:18+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_130017_9df94202"}
2026-05-16T13:00:18+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_130017_9df94202"}
2026-05-16T13:00:18+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_130017_9df94202"}
2026-05-16T13:00:18+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_130017_9df94202"}
2026-05-16T13:00:18+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_130017_9df94202"}
2026-05-16T13:00:18+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_130017_9df94202"}
2026-05-16T13:00:18+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_130017_9df94202"}
2026-05-16T13:00:18+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_130017_9df94202"}
2026-05-16T13:00:18+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.807,"exec_milliseconds":807,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_130017_9df94202"}
2026-05-16T13:01:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_130101_33060d19"}
2026-05-16T13:01:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_130101_33060d19"}
2026-05-16T13:01:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_130101_33060d19"}
2026-05-16T13:01:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_130101_33060d19"}
2026-05-16T13:01:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_130101_33060d19"}
2026-05-16T13:01:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_130101_33060d19"}
2026-05-16T13:01:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_130101_33060d19"}
2026-05-16T13:01:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_130101_33060d19"}
2026-05-16T13:01:02+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_130101_33060d19"}
2026-05-16T13:01:02+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.762,"exec_milliseconds":762,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_130101_33060d19"}
2026-05-16T13:02:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_130202_5dc23f9f"}
2026-05-16T13:02:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_130202_5dc23f9f"}
2026-05-16T13:02:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_130202_5dc23f9f"}
2026-05-16T13:02:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_130202_5dc23f9f"}
2026-05-16T13:02:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_130202_5dc23f9f"}
2026-05-16T13:02:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_130202_5dc23f9f"}
2026-05-16T13:02:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_130202_5dc23f9f"}
2026-05-16T13:02:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_130202_5dc23f9f"}
2026-05-16T13:02:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_130202_5dc23f9f"}
2026-05-16T13:02:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.777,"exec_milliseconds":777,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_130202_5dc23f9f"}
2026-05-16T13:03:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_130301_276f800f"}
2026-05-16T13:03:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_130301_276f800f"}
2026-05-16T13:03:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_130301_276f800f"}
2026-05-16T13:03:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_130301_276f800f"}
2026-05-16T13:03:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_130301_276f800f"}
2026-05-16T13:03:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_130301_276f800f"}
2026-05-16T13:03:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_130301_276f800f"}
2026-05-16T13:03:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_130301_276f800f"}
2026-05-16T13:03:02+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_130301_276f800f"}
2026-05-16T13:03:02+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.757,"exec_milliseconds":757,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_130301_276f800f"}
2026-05-16T13:04:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_130402_33871bd2"}
2026-05-16T13:04:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_130402_33871bd2"}
2026-05-16T13:04:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_130402_33871bd2"}
2026-05-16T13:04:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_130402_33871bd2"}
2026-05-16T13:04:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_130402_33871bd2"}
2026-05-16T13:04:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_130402_33871bd2"}
2026-05-16T13:04:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_130402_33871bd2"}
2026-05-16T13:04:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_130402_33871bd2"}
2026-05-16T13:04:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_130402_33871bd2"}
2026-05-16T13:04:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.724,"exec_milliseconds":724,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_130402_33871bd2"}
2026-05-16T13:05:04+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_130504_5b9b6a3e"}
2026-05-16T13:05:05+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_130504_5b9b6a3e"}
2026-05-16T13:05:05+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_130504_5b9b6a3e"}
2026-05-16T13:05:05+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_130504_5b9b6a3e"}
2026-05-16T13:05:05+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_130504_5b9b6a3e"}
2026-05-16T13:05:05+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_130504_5b9b6a3e"}
2026-05-16T13:05:05+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_130504_5b9b6a3e"}
2026-05-16T13:05:05+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_130504_5b9b6a3e"}
2026-05-16T13:05:05+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_130504_5b9b6a3e"}
2026-05-16T13:05:05+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.739,"exec_milliseconds":739,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_130504_5b9b6a3e"}
2026-05-16T13:06:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_130602_b1815b9f"}
2026-05-16T13:06:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_130602_b1815b9f"}
2026-05-16T13:06:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_130602_b1815b9f"}
2026-05-16T13:06:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_130602_b1815b9f"}
2026-05-16T13:06:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_130602_b1815b9f"}
2026-05-16T13:06:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_130602_b1815b9f"}
2026-05-16T13:06:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_130602_b1815b9f"}
2026-05-16T13:06:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_130602_b1815b9f"}
2026-05-16T13:06:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_130602_b1815b9f"}
2026-05-16T13:06:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.751,"exec_milliseconds":751,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_130602_b1815b9f"}
2026-05-16T13:07:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_130701_4aa2307c"}
2026-05-16T13:07:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_130701_4aa2307c"}
2026-05-16T13:07:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_130701_4aa2307c"}
2026-05-16T13:07:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_130701_4aa2307c"}
2026-05-16T13:07:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_130701_4aa2307c"}
2026-05-16T13:07:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_130701_4aa2307c"}
2026-05-16T13:07:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_130701_4aa2307c"}
2026-05-16T13:07:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_130701_4aa2307c"}
2026-05-16T13:07:02+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_130701_4aa2307c"}
2026-05-16T13:07:02+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.741,"exec_milliseconds":741,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_130701_4aa2307c"}
2026-05-16T13:08:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_130802_a12ca2fc"}
2026-05-16T13:08:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_130802_a12ca2fc"}
2026-05-16T13:08:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_130802_a12ca2fc"}
2026-05-16T13:08:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_130802_a12ca2fc"}
2026-05-16T13:08:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_130802_a12ca2fc"}
2026-05-16T13:08:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_130802_a12ca2fc"}
2026-05-16T13:08:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_130802_a12ca2fc"}
2026-05-16T13:08:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_130802_a12ca2fc"}
2026-05-16T13:08:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_130802_a12ca2fc"}
2026-05-16T13:08:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.751,"exec_milliseconds":751,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_130802_a12ca2fc"}
2026-05-16T13:09:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_130901_873c4b72"}
2026-05-16T13:09:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_130901_873c4b72"}
2026-05-16T13:09:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_130901_873c4b72"}
2026-05-16T13:09:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_130901_873c4b72"}
2026-05-16T13:09:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_130901_873c4b72"}
2026-05-16T13:09:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_130901_873c4b72"}
2026-05-16T13:09:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_130901_873c4b72"}
2026-05-16T13:09:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_130901_873c4b72"}
2026-05-16T13:09:02+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_130901_873c4b72"}
2026-05-16T13:09:02+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.769,"exec_milliseconds":769,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_130901_873c4b72"}
2026-05-16T13:10:06+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_131006_bd2e27ee"}
2026-05-16T13:10:06+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_131006_bd2e27ee"}
2026-05-16T13:10:06+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_131006_bd2e27ee"}
2026-05-16T13:10:06+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_131006_bd2e27ee"}
2026-05-16T13:10:06+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_131006_bd2e27ee"}
2026-05-16T13:10:06+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_131006_bd2e27ee"}
2026-05-16T13:10:06+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_131006_bd2e27ee"}
2026-05-16T13:10:06+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_131006_bd2e27ee"}
2026-05-16T13:10:06+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_131006_bd2e27ee"}
2026-05-16T13:10:06+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.757,"exec_milliseconds":757,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_131006_bd2e27ee"}
2026-05-16T13:11:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_131101_3761a7c5"}
2026-05-16T13:11:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_131101_3761a7c5"}
2026-05-16T13:11:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_131101_3761a7c5"}
2026-05-16T13:11:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_131101_3761a7c5"}
2026-05-16T13:11:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_131101_3761a7c5"}
2026-05-16T13:11:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_131101_3761a7c5"}
2026-05-16T13:11:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_131101_3761a7c5"}
2026-05-16T13:11:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_131101_3761a7c5"}
2026-05-16T13:11:02+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_131101_3761a7c5"}
2026-05-16T13:11:02+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.767,"exec_milliseconds":767,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_131101_3761a7c5"}
2026-05-16T13:12:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_131202_716ff9dc"}
2026-05-16T13:12:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_131202_716ff9dc"}
2026-05-16T13:12:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_131202_716ff9dc"}
2026-05-16T13:12:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_131202_716ff9dc"}
2026-05-16T13:12:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_131202_716ff9dc"}
2026-05-16T13:12:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_131202_716ff9dc"}
2026-05-16T13:12:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_131202_716ff9dc"}
2026-05-16T13:12:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_131202_716ff9dc"}
2026-05-16T13:12:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_131202_716ff9dc"}
2026-05-16T13:12:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.754,"exec_milliseconds":754,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_131202_716ff9dc"}
2026-05-16T13:13:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_131301_5a97cb9f"}
2026-05-16T13:13:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_131301_5a97cb9f"}
2026-05-16T13:13:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_131301_5a97cb9f"}
2026-05-16T13:13:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_131301_5a97cb9f"}
2026-05-16T13:13:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_131301_5a97cb9f"}
2026-05-16T13:13:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_131301_5a97cb9f"}
2026-05-16T13:13:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_131301_5a97cb9f"}
2026-05-16T13:13:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_131301_5a97cb9f"}
2026-05-16T13:13:02+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_131301_5a97cb9f"}
2026-05-16T13:13:02+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.721,"exec_milliseconds":721,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_131301_5a97cb9f"}
2026-05-16T13:14:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_131402_10791718"}
2026-05-16T13:14:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_131402_10791718"}
2026-05-16T13:14:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_131402_10791718"}
2026-05-16T13:14:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_131402_10791718"}
2026-05-16T13:14:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_131402_10791718"}
2026-05-16T13:14:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_131402_10791718"}
2026-05-16T13:14:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_131402_10791718"}
2026-05-16T13:14:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_131402_10791718"}
2026-05-16T13:14:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_131402_10791718"}
2026-05-16T13:14:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.743,"exec_milliseconds":743,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_131402_10791718"}
2026-05-16T13:15:06+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_131506_757985e0"}
2026-05-16T13:15:07+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_131506_757985e0"}
2026-05-16T13:15:07+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_131506_757985e0"}
2026-05-16T13:15:07+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_131506_757985e0"}
2026-05-16T13:15:07+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_131506_757985e0"}
2026-05-16T13:15:07+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_131506_757985e0"}
2026-05-16T13:15:07+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_131506_757985e0"}
2026-05-16T13:15:07+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_131506_757985e0"}
2026-05-16T13:15:07+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_131506_757985e0"}
2026-05-16T13:15:07+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.734,"exec_milliseconds":734,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_131506_757985e0"}
2026-05-16T13:16:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_131602_65ceb926"}
2026-05-16T13:16:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_131602_65ceb926"}
2026-05-16T13:16:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_131602_65ceb926"}
2026-05-16T13:16:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_131602_65ceb926"}
2026-05-16T13:16:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_131602_65ceb926"}
2026-05-16T13:16:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_131602_65ceb926"}
2026-05-16T13:16:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_131602_65ceb926"}
2026-05-16T13:16:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_131602_65ceb926"}
2026-05-16T13:16:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_131602_65ceb926"}
2026-05-16T13:16:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.715,"exec_milliseconds":715,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_131602_65ceb926"}
2026-05-16T13:17:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_131701_0a05c099"}
2026-05-16T13:17:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_131701_0a05c099"}
2026-05-16T13:17:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_131701_0a05c099"}
2026-05-16T13:17:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_131701_0a05c099"}
2026-05-16T13:17:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_131701_0a05c099"}
2026-05-16T13:17:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_131701_0a05c099"}
2026-05-16T13:17:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_131701_0a05c099"}
2026-05-16T13:17:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_131701_0a05c099"}
2026-05-16T13:17:02+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_131701_0a05c099"}
2026-05-16T13:17:02+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.691,"exec_milliseconds":691,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_131701_0a05c099"}
2026-05-16T13:18:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_131802_2cf40705"}
2026-05-16T13:18:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_131802_2cf40705"}
2026-05-16T13:18:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_131802_2cf40705"}
2026-05-16T13:18:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_131802_2cf40705"}
2026-05-16T13:18:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_131802_2cf40705"}
2026-05-16T13:18:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_131802_2cf40705"}
2026-05-16T13:18:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_131802_2cf40705"}
2026-05-16T13:18:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_131802_2cf40705"}
2026-05-16T13:18:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_131802_2cf40705"}
2026-05-16T13:18:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.763,"exec_milliseconds":763,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_131802_2cf40705"}
2026-05-16T13:19:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_131901_10ab3a5c"}
2026-05-16T13:19:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_131901_10ab3a5c"}
2026-05-16T13:19:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_131901_10ab3a5c"}
2026-05-16T13:19:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_131901_10ab3a5c"}
2026-05-16T13:19:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_131901_10ab3a5c"}
2026-05-16T13:19:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_131901_10ab3a5c"}
2026-05-16T13:19:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_131901_10ab3a5c"}
2026-05-16T13:19:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_131901_10ab3a5c"}
2026-05-16T13:19:02+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_131901_10ab3a5c"}
2026-05-16T13:19:02+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.734,"exec_milliseconds":734,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_131901_10ab3a5c"}
2026-05-16T13:20:06+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_132006_fb832c78"}
2026-05-16T13:20:07+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_132006_fb832c78"}
2026-05-16T13:20:07+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_132006_fb832c78"}
2026-05-16T13:20:07+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_132006_fb832c78"}
2026-05-16T13:20:07+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_132006_fb832c78"}
2026-05-16T13:20:07+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_132006_fb832c78"}
2026-05-16T13:20:07+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_132006_fb832c78"}
2026-05-16T13:20:07+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_132006_fb832c78"}
2026-05-16T13:20:07+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_132006_fb832c78"}
2026-05-16T13:20:07+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.725,"exec_milliseconds":725,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_132006_fb832c78"}
2026-05-16T13:21:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_132101_d3edf00c"}
2026-05-16T13:21:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_132101_d3edf00c"}
2026-05-16T13:21:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_132101_d3edf00c"}
2026-05-16T13:21:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_132101_d3edf00c"}
2026-05-16T13:21:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_132101_d3edf00c"}
2026-05-16T13:21:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_132101_d3edf00c"}
2026-05-16T13:21:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_132101_d3edf00c"}
2026-05-16T13:21:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_132101_d3edf00c"}
2026-05-16T13:21:02+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_132101_d3edf00c"}
2026-05-16T13:21:02+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.711,"exec_milliseconds":711,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_132101_d3edf00c"}
2026-05-16T13:22:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_132202_6cec8f30"}
2026-05-16T13:22:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_132202_6cec8f30"}
2026-05-16T13:22:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_132202_6cec8f30"}
2026-05-16T13:22:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_132202_6cec8f30"}
2026-05-16T13:22:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_132202_6cec8f30"}
2026-05-16T13:22:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_132202_6cec8f30"}
2026-05-16T13:22:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_132202_6cec8f30"}
2026-05-16T13:22:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_132202_6cec8f30"}
2026-05-16T13:22:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_132202_6cec8f30"}
2026-05-16T13:22:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.763,"exec_milliseconds":763,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_132202_6cec8f30"}
2026-05-16T13:23:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_132301_39ca6090"}
2026-05-16T13:23:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_132301_39ca6090"}
2026-05-16T13:23:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_132301_39ca6090"}
2026-05-16T13:23:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_132301_39ca6090"}
2026-05-16T13:23:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_132301_39ca6090"}
2026-05-16T13:23:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_132301_39ca6090"}
2026-05-16T13:23:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_132301_39ca6090"}
2026-05-16T13:23:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_132301_39ca6090"}
2026-05-16T13:23:02+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_132301_39ca6090"}
2026-05-16T13:23:02+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.723,"exec_milliseconds":723,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_132301_39ca6090"}
2026-05-16T13:24:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_132402_10ba0964"}
2026-05-16T13:24:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_132402_10ba0964"}
2026-05-16T13:24:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_132402_10ba0964"}
2026-05-16T13:24:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_132402_10ba0964"}
2026-05-16T13:24:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_132402_10ba0964"}
2026-05-16T13:24:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_132402_10ba0964"}
2026-05-16T13:24:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_132402_10ba0964"}
2026-05-16T13:24:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_132402_10ba0964"}
2026-05-16T13:24:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_132402_10ba0964"}
2026-05-16T13:24:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.725,"exec_milliseconds":725,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_132402_10ba0964"}
2026-05-16T13:25:04+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_132504_90f41809"}
2026-05-16T13:25:04+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_132504_90f41809"}
2026-05-16T13:25:04+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_132504_90f41809"}
2026-05-16T13:25:04+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_132504_90f41809"}
2026-05-16T13:25:04+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_132504_90f41809"}
2026-05-16T13:25:04+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_132504_90f41809"}
2026-05-16T13:25:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_132504_90f41809"}
2026-05-16T13:25:04+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_132504_90f41809"}
2026-05-16T13:25:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_132504_90f41809"}
2026-05-16T13:25:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.737,"exec_milliseconds":737,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_132504_90f41809"}
2026-05-16T13:26:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_132602_3a6b8ae0"}
2026-05-16T13:26:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_132602_3a6b8ae0"}
2026-05-16T13:26:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_132602_3a6b8ae0"}
2026-05-16T13:26:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_132602_3a6b8ae0"}
2026-05-16T13:26:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_132602_3a6b8ae0"}
2026-05-16T13:26:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_132602_3a6b8ae0"}
2026-05-16T13:26:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_132602_3a6b8ae0"}
2026-05-16T13:26:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_132602_3a6b8ae0"}
2026-05-16T13:26:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_132602_3a6b8ae0"}
2026-05-16T13:26:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.725,"exec_milliseconds":725,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_132602_3a6b8ae0"}
2026-05-16T13:27:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_132701_37108f36"}
2026-05-16T13:27:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_132701_37108f36"}
2026-05-16T13:27:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_132701_37108f36"}
2026-05-16T13:27:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_132701_37108f36"}
2026-05-16T13:27:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_132701_37108f36"}
2026-05-16T13:27:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_132701_37108f36"}
2026-05-16T13:27:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_132701_37108f36"}
2026-05-16T13:27:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_132701_37108f36"}
2026-05-16T13:27:02+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_132701_37108f36"}
2026-05-16T13:27:02+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.751,"exec_milliseconds":751,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_132701_37108f36"}
2026-05-16T13:28:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_132802_446dc470"}
2026-05-16T13:28:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_132802_446dc470"}
2026-05-16T13:28:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_132802_446dc470"}
2026-05-16T13:28:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_132802_446dc470"}
2026-05-16T13:28:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_132802_446dc470"}
2026-05-16T13:28:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_132802_446dc470"}
2026-05-16T13:28:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_132802_446dc470"}
2026-05-16T13:28:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_132802_446dc470"}
2026-05-16T13:28:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_132802_446dc470"}
2026-05-16T13:28:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.708,"exec_milliseconds":708,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_132802_446dc470"}
2026-05-16T13:29:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_132902_481ec511"}
2026-05-16T13:29:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_132902_481ec511"}
2026-05-16T13:29:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_132902_481ec511"}
2026-05-16T13:29:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_132902_481ec511"}
2026-05-16T13:29:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_132902_481ec511"}
2026-05-16T13:29:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_132902_481ec511"}
2026-05-16T13:29:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_132902_481ec511"}
2026-05-16T13:29:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_132902_481ec511"}
2026-05-16T13:29:02+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_132902_481ec511"}
2026-05-16T13:29:02+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.747,"exec_milliseconds":747,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_132902_481ec511"}
2026-05-16T13:30:12+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_133012_e9c504af"}
2026-05-16T13:30:13+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_133012_e9c504af"}
2026-05-16T13:30:13+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_133012_e9c504af"}
2026-05-16T13:30:13+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_133012_e9c504af"}
2026-05-16T13:30:13+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_133012_e9c504af"}
2026-05-16T13:30:13+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_133012_e9c504af"}
2026-05-16T13:30:13+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_133012_e9c504af"}
2026-05-16T13:30:13+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_133012_e9c504af"}
2026-05-16T13:30:13+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_133012_e9c504af"}
2026-05-16T13:30:13+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.717,"exec_milliseconds":717,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_133012_e9c504af"}
2026-05-16T13:31:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_133101_2a6696b1"}
2026-05-16T13:31:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_133101_2a6696b1"}
2026-05-16T13:31:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_133101_2a6696b1"}
2026-05-16T13:31:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_133101_2a6696b1"}
2026-05-16T13:31:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_133101_2a6696b1"}
2026-05-16T13:31:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_133101_2a6696b1"}
2026-05-16T13:31:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_133101_2a6696b1"}
2026-05-16T13:31:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_133101_2a6696b1"}
2026-05-16T13:31:02+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_133101_2a6696b1"}
2026-05-16T13:31:02+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.73,"exec_milliseconds":730,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_133101_2a6696b1"}
2026-05-16T13:32:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_133202_74407128"}
2026-05-16T13:32:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_133202_74407128"}
2026-05-16T13:32:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_133202_74407128"}
2026-05-16T13:32:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_133202_74407128"}
2026-05-16T13:32:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_133202_74407128"}
2026-05-16T13:32:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_133202_74407128"}
2026-05-16T13:32:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_133202_74407128"}
2026-05-16T13:32:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_133202_74407128"}
2026-05-16T13:32:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_133202_74407128"}
2026-05-16T13:32:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.768,"exec_milliseconds":768,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_133202_74407128"}
2026-05-16T13:33:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_133301_8badfe46"}
2026-05-16T13:33:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_133301_8badfe46"}
2026-05-16T13:33:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_133301_8badfe46"}
2026-05-16T13:33:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_133301_8badfe46"}
2026-05-16T13:33:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_133301_8badfe46"}
2026-05-16T13:33:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_133301_8badfe46"}
2026-05-16T13:33:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_133301_8badfe46"}
2026-05-16T13:33:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_133301_8badfe46"}
2026-05-16T13:33:02+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_133301_8badfe46"}
2026-05-16T13:33:02+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.727,"exec_milliseconds":727,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_133301_8badfe46"}
2026-05-16T13:34:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_133402_87ba21eb"}
2026-05-16T13:34:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_133402_87ba21eb"}
2026-05-16T13:34:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_133402_87ba21eb"}
2026-05-16T13:34:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_133402_87ba21eb"}
2026-05-16T13:34:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_133402_87ba21eb"}
2026-05-16T13:34:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_133402_87ba21eb"}
2026-05-16T13:34:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_133402_87ba21eb"}
2026-05-16T13:34:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_133402_87ba21eb"}
2026-05-16T13:34:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_133402_87ba21eb"}
2026-05-16T13:34:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.745,"exec_milliseconds":745,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_133402_87ba21eb"}
2026-05-16T13:35:04+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_133503_b9ada6a5"}
2026-05-16T13:35:04+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_133503_b9ada6a5"}
2026-05-16T13:35:04+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_133503_b9ada6a5"}
2026-05-16T13:35:04+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_133503_b9ada6a5"}
2026-05-16T13:35:04+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_133503_b9ada6a5"}
2026-05-16T13:35:04+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_133503_b9ada6a5"}
2026-05-16T13:35:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_133503_b9ada6a5"}
2026-05-16T13:35:04+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_133503_b9ada6a5"}
2026-05-16T13:35:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_133503_b9ada6a5"}
2026-05-16T13:35:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.729,"exec_milliseconds":729,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_133503_b9ada6a5"}
2026-05-16T13:36:03+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_133602_6670554a"}
2026-05-16T13:36:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_133602_6670554a"}
2026-05-16T13:36:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_133602_6670554a"}
2026-05-16T13:36:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_133602_6670554a"}
2026-05-16T13:36:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_133602_6670554a"}
2026-05-16T13:36:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_133602_6670554a"}
2026-05-16T13:36:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_133602_6670554a"}
2026-05-16T13:36:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_133602_6670554a"}
2026-05-16T13:36:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_133602_6670554a"}
2026-05-16T13:36:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.775,"exec_milliseconds":775,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_133602_6670554a"}
2026-05-16T13:37:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_133701_7d184edb"}
2026-05-16T13:37:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_133701_7d184edb"}
2026-05-16T13:37:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_133701_7d184edb"}
2026-05-16T13:37:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_133701_7d184edb"}
2026-05-16T13:37:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_133701_7d184edb"}
2026-05-16T13:37:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_133701_7d184edb"}
2026-05-16T13:37:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_133701_7d184edb"}
2026-05-16T13:37:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_133701_7d184edb"}
2026-05-16T13:37:02+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_133701_7d184edb"}
2026-05-16T13:37:02+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.746,"exec_milliseconds":746,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_133701_7d184edb"}
2026-05-16T13:38:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_133802_de103e96"}
2026-05-16T13:38:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_133802_de103e96"}
2026-05-16T13:38:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_133802_de103e96"}
2026-05-16T13:38:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_133802_de103e96"}
2026-05-16T13:38:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_133802_de103e96"}
2026-05-16T13:38:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_133802_de103e96"}
2026-05-16T13:38:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_133802_de103e96"}
2026-05-16T13:38:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_133802_de103e96"}
2026-05-16T13:38:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_133802_de103e96"}
2026-05-16T13:38:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.786,"exec_milliseconds":786,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_133802_de103e96"}
2026-05-16T13:39:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_133902_90a92511"}
2026-05-16T13:39:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_133902_90a92511"}
2026-05-16T13:39:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_133902_90a92511"}
2026-05-16T13:39:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_133902_90a92511"}
2026-05-16T13:39:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_133902_90a92511"}
2026-05-16T13:39:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_133902_90a92511"}
2026-05-16T13:39:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_133902_90a92511"}
2026-05-16T13:39:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_133902_90a92511"}
2026-05-16T13:39:02+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_133902_90a92511"}
2026-05-16T13:39:02+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.779,"exec_milliseconds":779,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_133902_90a92511"}
2026-05-16T13:40:06+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_134006_c451b958"}
2026-05-16T13:40:06+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_134006_c451b958"}
2026-05-16T13:40:06+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_134006_c451b958"}
2026-05-16T13:40:06+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_134006_c451b958"}
2026-05-16T13:40:06+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_134006_c451b958"}
2026-05-16T13:40:06+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_134006_c451b958"}
2026-05-16T13:40:06+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_134006_c451b958"}
2026-05-16T13:40:06+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_134006_c451b958"}
2026-05-16T13:40:06+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_134006_c451b958"}
2026-05-16T13:40:06+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.755,"exec_milliseconds":755,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_134006_c451b958"}
2026-05-16T13:41:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_134101_7d636c71"}
2026-05-16T13:41:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_134101_7d636c71"}
2026-05-16T13:41:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_134101_7d636c71"}
2026-05-16T13:41:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_134101_7d636c71"}
2026-05-16T13:41:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_134101_7d636c71"}
2026-05-16T13:41:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_134101_7d636c71"}
2026-05-16T13:41:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_134101_7d636c71"}
2026-05-16T13:41:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_134101_7d636c71"}
2026-05-16T13:41:02+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_134101_7d636c71"}
2026-05-16T13:41:02+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.723,"exec_milliseconds":723,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_134101_7d636c71"}
2026-05-16T13:42:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_134202_b83fbbde"}
2026-05-16T13:42:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_134202_b83fbbde"}
2026-05-16T13:42:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_134202_b83fbbde"}
2026-05-16T13:42:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_134202_b83fbbde"}
2026-05-16T13:42:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_134202_b83fbbde"}
2026-05-16T13:42:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_134202_b83fbbde"}
2026-05-16T13:42:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_134202_b83fbbde"}
2026-05-16T13:42:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_134202_b83fbbde"}
2026-05-16T13:42:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_134202_b83fbbde"}
2026-05-16T13:42:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.755,"exec_milliseconds":755,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_134202_b83fbbde"}
2026-05-16T13:43:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_134302_0f28ef54"}
2026-05-16T13:43:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_134302_0f28ef54"}
2026-05-16T13:43:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_134302_0f28ef54"}
2026-05-16T13:43:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_134302_0f28ef54"}
2026-05-16T13:43:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_134302_0f28ef54"}
2026-05-16T13:43:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_134302_0f28ef54"}
2026-05-16T13:43:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_134302_0f28ef54"}
2026-05-16T13:43:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_134302_0f28ef54"}
2026-05-16T13:43:02+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_134302_0f28ef54"}
2026-05-16T13:43:02+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.687,"exec_milliseconds":687,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_134302_0f28ef54"}
2026-05-16T13:44:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_134402_9d8f0320"}
2026-05-16T13:44:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_134402_9d8f0320"}
2026-05-16T13:44:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_134402_9d8f0320"}
2026-05-16T13:44:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_134402_9d8f0320"}
2026-05-16T13:44:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_134402_9d8f0320"}
2026-05-16T13:44:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_134402_9d8f0320"}
2026-05-16T13:44:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_134402_9d8f0320"}
2026-05-16T13:44:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_134402_9d8f0320"}
2026-05-16T13:44:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_134402_9d8f0320"}
2026-05-16T13:44:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.762,"exec_milliseconds":762,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_134402_9d8f0320"}
2026-05-16T13:45:07+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_134506_11de5d0b"}
2026-05-16T13:45:07+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_134506_11de5d0b"}
2026-05-16T13:45:07+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_134506_11de5d0b"}
2026-05-16T13:45:07+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_134506_11de5d0b"}
2026-05-16T13:45:07+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_134506_11de5d0b"}
2026-05-16T13:45:07+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_134506_11de5d0b"}
2026-05-16T13:45:07+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_134506_11de5d0b"}
2026-05-16T13:45:07+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_134506_11de5d0b"}
2026-05-16T13:45:07+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_134506_11de5d0b"}
2026-05-16T13:45:07+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.752,"exec_milliseconds":752,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_134506_11de5d0b"}
2026-05-16T13:46:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_134602_e6fb444f"}
2026-05-16T13:46:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_134602_e6fb444f"}
2026-05-16T13:46:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_134602_e6fb444f"}
2026-05-16T13:46:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_134602_e6fb444f"}
2026-05-16T13:46:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_134602_e6fb444f"}
2026-05-16T13:46:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_134602_e6fb444f"}
2026-05-16T13:46:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_134602_e6fb444f"}
2026-05-16T13:46:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_134602_e6fb444f"}
2026-05-16T13:46:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_134602_e6fb444f"}
2026-05-16T13:46:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.716,"exec_milliseconds":716,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_134602_e6fb444f"}
2026-05-16T13:47:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_134701_101f580a"}
2026-05-16T13:47:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_134701_101f580a"}
2026-05-16T13:47:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_134701_101f580a"}
2026-05-16T13:47:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_134701_101f580a"}
2026-05-16T13:47:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_134701_101f580a"}
2026-05-16T13:47:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_134701_101f580a"}
2026-05-16T13:47:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_134701_101f580a"}
2026-05-16T13:47:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_134701_101f580a"}
2026-05-16T13:47:02+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_134701_101f580a"}
2026-05-16T13:47:02+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.767,"exec_milliseconds":767,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_134701_101f580a"}
2026-05-16T13:48:03+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_134802_cd6db2ef"}
2026-05-16T13:48:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_134802_cd6db2ef"}
2026-05-16T13:48:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_134802_cd6db2ef"}
2026-05-16T13:48:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_134802_cd6db2ef"}
2026-05-16T13:48:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_134802_cd6db2ef"}
2026-05-16T13:48:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_134802_cd6db2ef"}
2026-05-16T13:48:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_134802_cd6db2ef"}
2026-05-16T13:48:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_134802_cd6db2ef"}
2026-05-16T13:48:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_134802_cd6db2ef"}
2026-05-16T13:48:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.898,"exec_milliseconds":898,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_134802_cd6db2ef"}
2026-05-16T13:49:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_134901_2064d4e3"}
2026-05-16T13:49:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_134901_2064d4e3"}
2026-05-16T13:49:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_134901_2064d4e3"}
2026-05-16T13:49:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_134901_2064d4e3"}
2026-05-16T13:49:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_134901_2064d4e3"}
2026-05-16T13:49:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_134901_2064d4e3"}
2026-05-16T13:49:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_134901_2064d4e3"}
2026-05-16T13:49:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_134901_2064d4e3"}
2026-05-16T13:49:02+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_134901_2064d4e3"}
2026-05-16T13:49:02+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.746,"exec_milliseconds":746,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_134901_2064d4e3"}
2026-05-16T13:50:07+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_135007_c2469e29"}
2026-05-16T13:50:07+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_135007_c2469e29"}
2026-05-16T13:50:07+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_135007_c2469e29"}
2026-05-16T13:50:07+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_135007_c2469e29"}
2026-05-16T13:50:07+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_135007_c2469e29"}
2026-05-16T13:50:07+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_135007_c2469e29"}
2026-05-16T13:50:07+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_135007_c2469e29"}
2026-05-16T13:50:07+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_135007_c2469e29"}
2026-05-16T13:50:07+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_135007_c2469e29"}
2026-05-16T13:50:07+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.745,"exec_milliseconds":745,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_135007_c2469e29"}
2026-05-16T13:51:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_135101_a587abc8"}
2026-05-16T13:51:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_135101_a587abc8"}
2026-05-16T13:51:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_135101_a587abc8"}
2026-05-16T13:51:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_135101_a587abc8"}
2026-05-16T13:51:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_135101_a587abc8"}
2026-05-16T13:51:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_135101_a587abc8"}
2026-05-16T13:51:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_135101_a587abc8"}
2026-05-16T13:51:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_135101_a587abc8"}
2026-05-16T13:51:02+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_135101_a587abc8"}
2026-05-16T13:51:02+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.788,"exec_milliseconds":788,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_135101_a587abc8"}
2026-05-16T13:52:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_135202_dffb17ab"}
2026-05-16T13:52:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_135202_dffb17ab"}
2026-05-16T13:52:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_135202_dffb17ab"}
2026-05-16T13:52:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_135202_dffb17ab"}
2026-05-16T13:52:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_135202_dffb17ab"}
2026-05-16T13:52:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_135202_dffb17ab"}
2026-05-16T13:52:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_135202_dffb17ab"}
2026-05-16T13:52:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_135202_dffb17ab"}
2026-05-16T13:52:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_135202_dffb17ab"}
2026-05-16T13:52:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.753,"exec_milliseconds":753,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_135202_dffb17ab"}
2026-05-16T13:53:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_135301_b45a19ec"}
2026-05-16T13:53:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_135301_b45a19ec"}
2026-05-16T13:53:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_135301_b45a19ec"}
2026-05-16T13:53:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_135301_b45a19ec"}
2026-05-16T13:53:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_135301_b45a19ec"}
2026-05-16T13:53:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_135301_b45a19ec"}
2026-05-16T13:53:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_135301_b45a19ec"}
2026-05-16T13:53:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_135301_b45a19ec"}
2026-05-16T13:53:02+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_135301_b45a19ec"}
2026-05-16T13:53:02+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.738,"exec_milliseconds":738,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_135301_b45a19ec"}
2026-05-16T13:54:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_135402_575e2a56"}
2026-05-16T13:54:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_135402_575e2a56"}
2026-05-16T13:54:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_135402_575e2a56"}
2026-05-16T13:54:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_135402_575e2a56"}
2026-05-16T13:54:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_135402_575e2a56"}
2026-05-16T13:54:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_135402_575e2a56"}
2026-05-16T13:54:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_135402_575e2a56"}
2026-05-16T13:54:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_135402_575e2a56"}
2026-05-16T13:54:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_135402_575e2a56"}
2026-05-16T13:54:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.706,"exec_milliseconds":706,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_135402_575e2a56"}
2026-05-16T13:55:04+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_135504_612660b5"}
2026-05-16T13:55:04+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_135504_612660b5"}
2026-05-16T13:55:04+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_135504_612660b5"}
2026-05-16T13:55:04+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_135504_612660b5"}
2026-05-16T13:55:04+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_135504_612660b5"}
2026-05-16T13:55:04+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_135504_612660b5"}
2026-05-16T13:55:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_135504_612660b5"}
2026-05-16T13:55:05+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_135504_612660b5"}
2026-05-16T13:55:05+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_135504_612660b5"}
2026-05-16T13:55:05+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.75,"exec_milliseconds":750,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_135504_612660b5"}
2026-05-16T13:56:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_135602_4e6a6912"}
2026-05-16T13:56:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_135602_4e6a6912"}
2026-05-16T13:56:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_135602_4e6a6912"}
2026-05-16T13:56:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_135602_4e6a6912"}
2026-05-16T13:56:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_135602_4e6a6912"}
2026-05-16T13:56:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_135602_4e6a6912"}
2026-05-16T13:56:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_135602_4e6a6912"}
2026-05-16T13:56:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_135602_4e6a6912"}
2026-05-16T13:56:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_135602_4e6a6912"}
2026-05-16T13:56:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.767,"exec_milliseconds":767,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_135602_4e6a6912"}
2026-05-16T13:57:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_135701_09d56991"}
2026-05-16T13:57:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_135701_09d56991"}
2026-05-16T13:57:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_135701_09d56991"}
2026-05-16T13:57:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_135701_09d56991"}
2026-05-16T13:57:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_135701_09d56991"}
2026-05-16T13:57:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_135701_09d56991"}
2026-05-16T13:57:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_135701_09d56991"}
2026-05-16T13:57:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_135701_09d56991"}
2026-05-16T13:57:02+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_135701_09d56991"}
2026-05-16T13:57:02+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.708,"exec_milliseconds":708,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_135701_09d56991"}
2026-05-16T13:58:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_135802_d1082180"}
2026-05-16T13:58:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_135802_d1082180"}
2026-05-16T13:58:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_135802_d1082180"}
2026-05-16T13:58:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_135802_d1082180"}
2026-05-16T13:58:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_135802_d1082180"}
2026-05-16T13:58:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_135802_d1082180"}
2026-05-16T13:58:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_135802_d1082180"}
2026-05-16T13:58:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_135802_d1082180"}
2026-05-16T13:58:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_135802_d1082180"}
2026-05-16T13:58:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.749,"exec_milliseconds":749,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_135802_d1082180"}
2026-05-16T13:59:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_135901_a0dda9f2"}
2026-05-16T13:59:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_135901_a0dda9f2"}
2026-05-16T13:59:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_135901_a0dda9f2"}
2026-05-16T13:59:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_135901_a0dda9f2"}
2026-05-16T13:59:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_135901_a0dda9f2"}
2026-05-16T13:59:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_135901_a0dda9f2"}
2026-05-16T13:59:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_135901_a0dda9f2"}
2026-05-16T13:59:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_135901_a0dda9f2"}
2026-05-16T13:59:02+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_135901_a0dda9f2"}
2026-05-16T13:59:02+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.728,"exec_milliseconds":728,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_135901_a0dda9f2"}
2026-05-16T14:00:19+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_140019_9f587120"}
2026-05-16T14:00:19+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_140019_9f587120"}
2026-05-16T14:00:19+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_140019_9f587120"}
2026-05-16T14:00:19+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_140019_9f587120"}
2026-05-16T14:00:19+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_140019_9f587120"}
2026-05-16T14:00:19+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_140019_9f587120"}
2026-05-16T14:00:20+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_140019_9f587120"}
2026-05-16T14:00:20+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_140019_9f587120"}
2026-05-16T14:00:20+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_140019_9f587120"}
2026-05-16T14:00:20+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.725,"exec_milliseconds":725,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_140019_9f587120"}
2026-05-16T14:01:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_140101_400fb801"}
2026-05-16T14:01:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_140101_400fb801"}
2026-05-16T14:01:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_140101_400fb801"}
2026-05-16T14:01:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_140101_400fb801"}
2026-05-16T14:01:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_140101_400fb801"}
2026-05-16T14:01:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_140101_400fb801"}
2026-05-16T14:01:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_140101_400fb801"}
2026-05-16T14:01:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_140101_400fb801"}
2026-05-16T14:01:02+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_140101_400fb801"}
2026-05-16T14:01:02+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.802,"exec_milliseconds":802,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_140101_400fb801"}
2026-05-16T14:02:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_140202_a4b0032e"}
2026-05-16T14:02:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_140202_a4b0032e"}
2026-05-16T14:02:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_140202_a4b0032e"}
2026-05-16T14:02:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_140202_a4b0032e"}
2026-05-16T14:02:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_140202_a4b0032e"}
2026-05-16T14:02:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_140202_a4b0032e"}
2026-05-16T14:02:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_140202_a4b0032e"}
2026-05-16T14:02:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_140202_a4b0032e"}
2026-05-16T14:02:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_140202_a4b0032e"}
2026-05-16T14:02:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.804,"exec_milliseconds":804,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_140202_a4b0032e"}
2026-05-16T14:03:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_140301_21c422e4"}
2026-05-16T14:03:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_140301_21c422e4"}
2026-05-16T14:03:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_140301_21c422e4"}
2026-05-16T14:03:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_140301_21c422e4"}
2026-05-16T14:03:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_140301_21c422e4"}
2026-05-16T14:03:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_140301_21c422e4"}
2026-05-16T14:03:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_140301_21c422e4"}
2026-05-16T14:03:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_140301_21c422e4"}
2026-05-16T14:03:02+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_140301_21c422e4"}
2026-05-16T14:03:02+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.733,"exec_milliseconds":733,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_140301_21c422e4"}
2026-05-16T14:04:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_140402_f07ea9fb"}
2026-05-16T14:04:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_140402_f07ea9fb"}
2026-05-16T14:04:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_140402_f07ea9fb"}
2026-05-16T14:04:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_140402_f07ea9fb"}
2026-05-16T14:04:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_140402_f07ea9fb"}
2026-05-16T14:04:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_140402_f07ea9fb"}
2026-05-16T14:04:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_140402_f07ea9fb"}
2026-05-16T14:04:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_140402_f07ea9fb"}
2026-05-16T14:04:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_140402_f07ea9fb"}
2026-05-16T14:04:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.737,"exec_milliseconds":737,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_140402_f07ea9fb"}
2026-05-16T14:05:04+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_140504_9b37d9f9"}
2026-05-16T14:05:04+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_140504_9b37d9f9"}
2026-05-16T14:05:05+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_140504_9b37d9f9"}
2026-05-16T14:05:05+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_140504_9b37d9f9"}
2026-05-16T14:05:05+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_140504_9b37d9f9"}
2026-05-16T14:05:05+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_140504_9b37d9f9"}
2026-05-16T14:05:05+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_140504_9b37d9f9"}
2026-05-16T14:05:05+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_140504_9b37d9f9"}
2026-05-16T14:05:05+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_140504_9b37d9f9"}
2026-05-16T14:05:05+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.736,"exec_milliseconds":736,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_140504_9b37d9f9"}
2026-05-16T14:06:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_140602_e1c47179"}
2026-05-16T14:06:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_140602_e1c47179"}
2026-05-16T14:06:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_140602_e1c47179"}
2026-05-16T14:06:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_140602_e1c47179"}
2026-05-16T14:06:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_140602_e1c47179"}
2026-05-16T14:06:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_140602_e1c47179"}
2026-05-16T14:06:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_140602_e1c47179"}
2026-05-16T14:06:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_140602_e1c47179"}
2026-05-16T14:06:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_140602_e1c47179"}
2026-05-16T14:06:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.764,"exec_milliseconds":764,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_140602_e1c47179"}
2026-05-16T14:07:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_140701_dc72f947"}
2026-05-16T14:07:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_140701_dc72f947"}
2026-05-16T14:07:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_140701_dc72f947"}
2026-05-16T14:07:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_140701_dc72f947"}
2026-05-16T14:07:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_140701_dc72f947"}
2026-05-16T14:07:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_140701_dc72f947"}
2026-05-16T14:07:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_140701_dc72f947"}
2026-05-16T14:07:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_140701_dc72f947"}
2026-05-16T14:07:02+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_140701_dc72f947"}
2026-05-16T14:07:02+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.73,"exec_milliseconds":730,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_140701_dc72f947"}
2026-05-16T14:08:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_140802_22cd120b"}
2026-05-16T14:08:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_140802_22cd120b"}
2026-05-16T14:08:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_140802_22cd120b"}
2026-05-16T14:08:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_140802_22cd120b"}
2026-05-16T14:08:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_140802_22cd120b"}
2026-05-16T14:08:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_140802_22cd120b"}
2026-05-16T14:08:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_140802_22cd120b"}
2026-05-16T14:08:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_140802_22cd120b"}
2026-05-16T14:08:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_140802_22cd120b"}
2026-05-16T14:08:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.752,"exec_milliseconds":752,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_140802_22cd120b"}
2026-05-16T14:09:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_140901_663f3298"}
2026-05-16T14:09:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_140901_663f3298"}
2026-05-16T14:09:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_140901_663f3298"}
2026-05-16T14:09:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_140901_663f3298"}
2026-05-16T14:09:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_140901_663f3298"}
2026-05-16T14:09:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_140901_663f3298"}
2026-05-16T14:09:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_140901_663f3298"}
2026-05-16T14:09:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_140901_663f3298"}
2026-05-16T14:09:02+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_140901_663f3298"}
2026-05-16T14:09:02+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.73,"exec_milliseconds":730,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_140901_663f3298"}
2026-05-16T14:10:06+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_141006_f3b6edcb"}
2026-05-16T14:10:07+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_141006_f3b6edcb"}
2026-05-16T14:10:07+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_141006_f3b6edcb"}
2026-05-16T14:10:07+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_141006_f3b6edcb"}
2026-05-16T14:10:07+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_141006_f3b6edcb"}
2026-05-16T14:10:07+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_141006_f3b6edcb"}
2026-05-16T14:10:07+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_141006_f3b6edcb"}
2026-05-16T14:10:07+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_141006_f3b6edcb"}
2026-05-16T14:10:07+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_141006_f3b6edcb"}
2026-05-16T14:10:07+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.716,"exec_milliseconds":716,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_141006_f3b6edcb"}
2026-05-16T14:11:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_141101_ca9c3c20"}
2026-05-16T14:11:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_141101_ca9c3c20"}
2026-05-16T14:11:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_141101_ca9c3c20"}
2026-05-16T14:11:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_141101_ca9c3c20"}
2026-05-16T14:11:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_141101_ca9c3c20"}
2026-05-16T14:11:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_141101_ca9c3c20"}
2026-05-16T14:11:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_141101_ca9c3c20"}
2026-05-16T14:11:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_141101_ca9c3c20"}
2026-05-16T14:11:02+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_141101_ca9c3c20"}
2026-05-16T14:11:02+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.747,"exec_milliseconds":747,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_141101_ca9c3c20"}
2026-05-16T14:12:03+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_141202_f96feb51"}
2026-05-16T14:12:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_141202_f96feb51"}
2026-05-16T14:12:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_141202_f96feb51"}
2026-05-16T14:12:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_141202_f96feb51"}
2026-05-16T14:12:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_141202_f96feb51"}
2026-05-16T14:12:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_141202_f96feb51"}
2026-05-16T14:12:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_141202_f96feb51"}
2026-05-16T14:12:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_141202_f96feb51"}
2026-05-16T14:12:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_141202_f96feb51"}
2026-05-16T14:12:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.761,"exec_milliseconds":761,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_141202_f96feb51"}
2026-05-16T14:13:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_141301_0c3540a6"}
2026-05-16T14:13:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_141301_0c3540a6"}
2026-05-16T14:13:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_141301_0c3540a6"}
2026-05-16T14:13:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_141301_0c3540a6"}
2026-05-16T14:13:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_141301_0c3540a6"}
2026-05-16T14:13:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_141301_0c3540a6"}
2026-05-16T14:13:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_141301_0c3540a6"}
2026-05-16T14:13:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_141301_0c3540a6"}
2026-05-16T14:13:02+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_141301_0c3540a6"}
2026-05-16T14:13:02+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.721,"exec_milliseconds":721,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_141301_0c3540a6"}
2026-05-16T14:14:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_141402_f33b6b76"}
2026-05-16T14:14:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_141402_f33b6b76"}
2026-05-16T14:14:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_141402_f33b6b76"}
2026-05-16T14:14:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_141402_f33b6b76"}
2026-05-16T14:14:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_141402_f33b6b76"}
2026-05-16T14:14:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_141402_f33b6b76"}
2026-05-16T14:14:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_141402_f33b6b76"}
2026-05-16T14:14:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_141402_f33b6b76"}
2026-05-16T14:14:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_141402_f33b6b76"}
2026-05-16T14:14:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.736,"exec_milliseconds":736,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_141402_f33b6b76"}
2026-05-16T14:15:07+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_141507_9ac837f9"}
2026-05-16T14:15:07+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_141507_9ac837f9"}
2026-05-16T14:15:07+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_141507_9ac837f9"}
2026-05-16T14:15:07+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_141507_9ac837f9"}
2026-05-16T14:15:07+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_141507_9ac837f9"}
2026-05-16T14:15:07+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_141507_9ac837f9"}
2026-05-16T14:15:07+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_141507_9ac837f9"}
2026-05-16T14:15:07+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_141507_9ac837f9"}
2026-05-16T14:15:07+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_141507_9ac837f9"}
2026-05-16T14:15:07+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.767,"exec_milliseconds":767,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_141507_9ac837f9"}
2026-05-16T14:16:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_141602_b51b80b9"}
2026-05-16T14:16:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_141602_b51b80b9"}
2026-05-16T14:16:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_141602_b51b80b9"}
2026-05-16T14:16:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_141602_b51b80b9"}
2026-05-16T14:16:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_141602_b51b80b9"}
2026-05-16T14:16:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_141602_b51b80b9"}
2026-05-16T14:16:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_141602_b51b80b9"}
2026-05-16T14:16:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_141602_b51b80b9"}
2026-05-16T14:16:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_141602_b51b80b9"}
2026-05-16T14:16:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.806,"exec_milliseconds":806,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_141602_b51b80b9"}
2026-05-16T14:17:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_141701_4e1fa181"}
2026-05-16T14:17:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_141701_4e1fa181"}
2026-05-16T14:17:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_141701_4e1fa181"}
2026-05-16T14:17:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_141701_4e1fa181"}
2026-05-16T14:17:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_141701_4e1fa181"}
2026-05-16T14:17:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_141701_4e1fa181"}
2026-05-16T14:17:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_141701_4e1fa181"}
2026-05-16T14:17:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_141701_4e1fa181"}
2026-05-16T14:17:02+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_141701_4e1fa181"}
2026-05-16T14:17:02+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.773,"exec_milliseconds":773,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_141701_4e1fa181"}
2026-05-16T14:18:03+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_141802_44a767cd"}
2026-05-16T14:18:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_141802_44a767cd"}
2026-05-16T14:18:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_141802_44a767cd"}
2026-05-16T14:18:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_141802_44a767cd"}
2026-05-16T14:18:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_141802_44a767cd"}
2026-05-16T14:18:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_141802_44a767cd"}
2026-05-16T14:18:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_141802_44a767cd"}
2026-05-16T14:18:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_141802_44a767cd"}
2026-05-16T14:18:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_141802_44a767cd"}
2026-05-16T14:18:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.722,"exec_milliseconds":722,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_141802_44a767cd"}
2026-05-16T14:19:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_141901_b40c94d3"}
2026-05-16T14:19:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_141901_b40c94d3"}
2026-05-16T14:19:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_141901_b40c94d3"}
2026-05-16T14:19:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_141901_b40c94d3"}
2026-05-16T14:19:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_141901_b40c94d3"}
2026-05-16T14:19:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_141901_b40c94d3"}
2026-05-16T14:19:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_141901_b40c94d3"}
2026-05-16T14:19:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_141901_b40c94d3"}
2026-05-16T14:19:02+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_141901_b40c94d3"}
2026-05-16T14:19:02+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.73,"exec_milliseconds":730,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_141901_b40c94d3"}
2026-05-16T14:20:07+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_142007_18e38835"}
2026-05-16T14:20:07+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_142007_18e38835"}
2026-05-16T14:20:07+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_142007_18e38835"}
2026-05-16T14:20:07+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_142007_18e38835"}
2026-05-16T14:20:07+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_142007_18e38835"}
2026-05-16T14:20:07+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_142007_18e38835"}
2026-05-16T14:20:07+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_142007_18e38835"}
2026-05-16T14:20:07+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_142007_18e38835"}
2026-05-16T14:20:07+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_142007_18e38835"}
2026-05-16T14:20:07+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.738,"exec_milliseconds":738,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_142007_18e38835"}
2026-05-16T14:21:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_142101_03c4b7cb"}
2026-05-16T14:21:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_142101_03c4b7cb"}
2026-05-16T14:21:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_142101_03c4b7cb"}
2026-05-16T14:21:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_142101_03c4b7cb"}
2026-05-16T14:21:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_142101_03c4b7cb"}
2026-05-16T14:21:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_142101_03c4b7cb"}
2026-05-16T14:21:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_142101_03c4b7cb"}
2026-05-16T14:21:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_142101_03c4b7cb"}
2026-05-16T14:21:02+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_142101_03c4b7cb"}
2026-05-16T14:21:02+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.73,"exec_milliseconds":730,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_142101_03c4b7cb"}
2026-05-16T14:22:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_142202_41dbd3ee"}
2026-05-16T14:22:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_142202_41dbd3ee"}
2026-05-16T14:22:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_142202_41dbd3ee"}
2026-05-16T14:22:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_142202_41dbd3ee"}
2026-05-16T14:22:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_142202_41dbd3ee"}
2026-05-16T14:22:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_142202_41dbd3ee"}
2026-05-16T14:22:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_142202_41dbd3ee"}
2026-05-16T14:22:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_142202_41dbd3ee"}
2026-05-16T14:22:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_142202_41dbd3ee"}
2026-05-16T14:22:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.734,"exec_milliseconds":734,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_142202_41dbd3ee"}
2026-05-16T14:23:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_142301_e6c06104"}
2026-05-16T14:23:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_142301_e6c06104"}
2026-05-16T14:23:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_142301_e6c06104"}
2026-05-16T14:23:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_142301_e6c06104"}
2026-05-16T14:23:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_142301_e6c06104"}
2026-05-16T14:23:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_142301_e6c06104"}
2026-05-16T14:23:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_142301_e6c06104"}
2026-05-16T14:23:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_142301_e6c06104"}
2026-05-16T14:23:02+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_142301_e6c06104"}
2026-05-16T14:23:02+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.759,"exec_milliseconds":759,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_142301_e6c06104"}
2026-05-16T14:24:03+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_142402_4f0c54a6"}
2026-05-16T14:24:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_142402_4f0c54a6"}
2026-05-16T14:24:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_142402_4f0c54a6"}
2026-05-16T14:24:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_142402_4f0c54a6"}
2026-05-16T14:24:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_142402_4f0c54a6"}
2026-05-16T14:24:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_142402_4f0c54a6"}
2026-05-16T14:24:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_142402_4f0c54a6"}
2026-05-16T14:24:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_142402_4f0c54a6"}
2026-05-16T14:24:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_142402_4f0c54a6"}
2026-05-16T14:24:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.698,"exec_milliseconds":698,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_142402_4f0c54a6"}
2026-05-16T14:25:04+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_142504_9e0d454d"}
2026-05-16T14:25:04+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_142504_9e0d454d"}
2026-05-16T14:25:04+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_142504_9e0d454d"}
2026-05-16T14:25:04+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_142504_9e0d454d"}
2026-05-16T14:25:04+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_142504_9e0d454d"}
2026-05-16T14:25:04+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_142504_9e0d454d"}
2026-05-16T14:25:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_142504_9e0d454d"}
2026-05-16T14:25:04+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_142504_9e0d454d"}
2026-05-16T14:25:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_142504_9e0d454d"}
2026-05-16T14:25:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.715,"exec_milliseconds":715,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_142504_9e0d454d"}
2026-05-16T14:26:03+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_142603_9d5747aa"}
2026-05-16T14:26:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_142603_9d5747aa"}
2026-05-16T14:26:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_142603_9d5747aa"}
2026-05-16T14:26:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_142603_9d5747aa"}
2026-05-16T14:26:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_142603_9d5747aa"}
2026-05-16T14:26:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_142603_9d5747aa"}
2026-05-16T14:26:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_142603_9d5747aa"}
2026-05-16T14:26:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_142603_9d5747aa"}
2026-05-16T14:26:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_142603_9d5747aa"}
2026-05-16T14:26:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.703,"exec_milliseconds":703,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_142603_9d5747aa"}
2026-05-16T14:27:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_142701_b0488a3c"}
2026-05-16T14:27:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_142701_b0488a3c"}
2026-05-16T14:27:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_142701_b0488a3c"}
2026-05-16T14:27:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_142701_b0488a3c"}
2026-05-16T14:27:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_142701_b0488a3c"}
2026-05-16T14:27:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_142701_b0488a3c"}
2026-05-16T14:27:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_142701_b0488a3c"}
2026-05-16T14:27:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_142701_b0488a3c"}
2026-05-16T14:27:02+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_142701_b0488a3c"}
2026-05-16T14:27:02+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.679,"exec_milliseconds":679,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_142701_b0488a3c"}
2026-05-16T14:28:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_142802_69187654"}
2026-05-16T14:28:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_142802_69187654"}
2026-05-16T14:28:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_142802_69187654"}
2026-05-16T14:28:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_142802_69187654"}
2026-05-16T14:28:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_142802_69187654"}
2026-05-16T14:28:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_142802_69187654"}
2026-05-16T14:28:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_142802_69187654"}
2026-05-16T14:28:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_142802_69187654"}
2026-05-16T14:28:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_142802_69187654"}
2026-05-16T14:28:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.691,"exec_milliseconds":691,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_142802_69187654"}
2026-05-16T14:29:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_142901_88ea03f7"}
2026-05-16T14:29:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_142901_88ea03f7"}
2026-05-16T14:29:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_142901_88ea03f7"}
2026-05-16T14:29:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_142901_88ea03f7"}
2026-05-16T14:29:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_142901_88ea03f7"}
2026-05-16T14:29:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_142901_88ea03f7"}
2026-05-16T14:29:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_142901_88ea03f7"}
2026-05-16T14:29:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_142901_88ea03f7"}
2026-05-16T14:29:02+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":33125,"run_id":"20260516_142901_88ea03f7"}
2026-05-16T14:29:02+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":0.736,"exec_milliseconds":736,"live_games":0,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":33125,"important":true,"run_id":"20260516_142901_88ea03f7"}
2026-05-16T14:30:12+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_143012_13d3b2d1"}
2026-05-16T14:30:13+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_143012_13d3b2d1"}
2026-05-16T14:30:13+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_143012_13d3b2d1"}
2026-05-16T14:30:13+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_143012_13d3b2d1"}
2026-05-16T14:30:13+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_143012_13d3b2d1"}
2026-05-16T14:30:13+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_143012_13d3b2d1"}
2026-05-16T14:30:13+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_143012_13d3b2d1"}
2026-05-16T14:30:13+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_143012_13d3b2d1"}
2026-05-16T14:30:14+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_143012_13d3b2d1"}
2026-05-16T14:30:14+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.684,"duration_milliseconds":684,"important":true,"run_id":"20260516_143012_13d3b2d1"}
2026-05-16T14:30:14+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_143012_13d3b2d1"}
2026-05-16T14:30:14+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.417,"exec_milliseconds":1417,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_143012_13d3b2d1"}
2026-05-16T14:31:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_143101_20cbc6b7"}
2026-05-16T14:31:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_143101_20cbc6b7"}
2026-05-16T14:31:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_143101_20cbc6b7"}
2026-05-16T14:31:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_143101_20cbc6b7"}
2026-05-16T14:31:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_143101_20cbc6b7"}
2026-05-16T14:31:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_143101_20cbc6b7"}
2026-05-16T14:31:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_143101_20cbc6b7"}
2026-05-16T14:31:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_143101_20cbc6b7"}
2026-05-16T14:31:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_143101_20cbc6b7"}
2026-05-16T14:31:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.694,"duration_milliseconds":694,"important":true,"run_id":"20260516_143101_20cbc6b7"}
2026-05-16T14:31:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_143101_20cbc6b7"}
2026-05-16T14:31:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.438,"exec_milliseconds":1438,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_143101_20cbc6b7"}
2026-05-16T14:32:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_143202_7ca914d7"}
2026-05-16T14:32:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_143202_7ca914d7"}
2026-05-16T14:32:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_143202_7ca914d7"}
2026-05-16T14:32:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_143202_7ca914d7"}
2026-05-16T14:32:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_143202_7ca914d7"}
2026-05-16T14:32:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_143202_7ca914d7"}
2026-05-16T14:32:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_143202_7ca914d7"}
2026-05-16T14:32:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_143202_7ca914d7"}
2026-05-16T14:32:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_143202_7ca914d7"}
2026-05-16T14:32:04+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.698,"duration_milliseconds":698,"important":true,"run_id":"20260516_143202_7ca914d7"}
2026-05-16T14:32:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_143202_7ca914d7"}
2026-05-16T14:32:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.468,"exec_milliseconds":1468,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_143202_7ca914d7"}
2026-05-16T14:33:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_143301_57fc9a62"}
2026-05-16T14:33:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_143301_57fc9a62"}
2026-05-16T14:33:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_143301_57fc9a62"}
2026-05-16T14:33:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_143301_57fc9a62"}
2026-05-16T14:33:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_143301_57fc9a62"}
2026-05-16T14:33:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_143301_57fc9a62"}
2026-05-16T14:33:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_143301_57fc9a62"}
2026-05-16T14:33:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_143301_57fc9a62"}
2026-05-16T14:33:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_143301_57fc9a62"}
2026-05-16T14:33:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.694,"duration_milliseconds":694,"important":true,"run_id":"20260516_143301_57fc9a62"}
2026-05-16T14:33:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_143301_57fc9a62"}
2026-05-16T14:33:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.488,"exec_milliseconds":1488,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_143301_57fc9a62"}
2026-05-16T14:34:03+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_143402_3ae5885d"}
2026-05-16T14:34:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_143402_3ae5885d"}
2026-05-16T14:34:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_143402_3ae5885d"}
2026-05-16T14:34:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_143402_3ae5885d"}
2026-05-16T14:34:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_143402_3ae5885d"}
2026-05-16T14:34:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_143402_3ae5885d"}
2026-05-16T14:34:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_143402_3ae5885d"}
2026-05-16T14:34:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_143402_3ae5885d"}
2026-05-16T14:34:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_143402_3ae5885d"}
2026-05-16T14:34:04+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.684,"duration_milliseconds":684,"important":true,"run_id":"20260516_143402_3ae5885d"}
2026-05-16T14:34:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_143402_3ae5885d"}
2026-05-16T14:34:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.417,"exec_milliseconds":1417,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_143402_3ae5885d"}
2026-05-16T14:35:03+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_143503_9b25029c"}
2026-05-16T14:35:04+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_143503_9b25029c"}
2026-05-16T14:35:04+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_143503_9b25029c"}
2026-05-16T14:35:04+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_143503_9b25029c"}
2026-05-16T14:35:04+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_143503_9b25029c"}
2026-05-16T14:35:04+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_143503_9b25029c"}
2026-05-16T14:35:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_143503_9b25029c"}
2026-05-16T14:35:04+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_143503_9b25029c"}
2026-05-16T14:35:05+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_143503_9b25029c"}
2026-05-16T14:35:05+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.692,"duration_milliseconds":692,"important":true,"run_id":"20260516_143503_9b25029c"}
2026-05-16T14:35:05+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_143503_9b25029c"}
2026-05-16T14:35:05+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.402,"exec_milliseconds":1402,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_143503_9b25029c"}
2026-05-16T14:36:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_143602_ae1399ee"}
2026-05-16T14:36:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_143602_ae1399ee"}
2026-05-16T14:36:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_143602_ae1399ee"}
2026-05-16T14:36:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_143602_ae1399ee"}
2026-05-16T14:36:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_143602_ae1399ee"}
2026-05-16T14:36:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_143602_ae1399ee"}
2026-05-16T14:36:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_143602_ae1399ee"}
2026-05-16T14:36:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_143602_ae1399ee"}
2026-05-16T14:36:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_143602_ae1399ee"}
2026-05-16T14:36:04+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.687,"duration_milliseconds":687,"important":true,"run_id":"20260516_143602_ae1399ee"}
2026-05-16T14:36:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_143602_ae1399ee"}
2026-05-16T14:36:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.429,"exec_milliseconds":1429,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_143602_ae1399ee"}
2026-05-16T14:37:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_143701_0416faac"}
2026-05-16T14:37:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_143701_0416faac"}
2026-05-16T14:37:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_143701_0416faac"}
2026-05-16T14:37:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_143701_0416faac"}
2026-05-16T14:37:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_143701_0416faac"}
2026-05-16T14:37:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_143701_0416faac"}
2026-05-16T14:37:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_143701_0416faac"}
2026-05-16T14:37:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_143701_0416faac"}
2026-05-16T14:37:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_143701_0416faac"}
2026-05-16T14:37:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.687,"duration_milliseconds":687,"important":true,"run_id":"20260516_143701_0416faac"}
2026-05-16T14:37:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_143701_0416faac"}
2026-05-16T14:37:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.424,"exec_milliseconds":1424,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_143701_0416faac"}
2026-05-16T14:38:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_143802_c6622578"}
2026-05-16T14:38:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_143802_c6622578"}
2026-05-16T14:38:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_143802_c6622578"}
2026-05-16T14:38:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_143802_c6622578"}
2026-05-16T14:38:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_143802_c6622578"}
2026-05-16T14:38:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_143802_c6622578"}
2026-05-16T14:38:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_143802_c6622578"}
2026-05-16T14:38:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_143802_c6622578"}
2026-05-16T14:38:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_143802_c6622578"}
2026-05-16T14:38:04+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.684,"duration_milliseconds":684,"important":true,"run_id":"20260516_143802_c6622578"}
2026-05-16T14:38:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_143802_c6622578"}
2026-05-16T14:38:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.447,"exec_milliseconds":1447,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_143802_c6622578"}
2026-05-16T14:39:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_143901_eed12057"}
2026-05-16T14:39:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_143901_eed12057"}
2026-05-16T14:39:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_143901_eed12057"}
2026-05-16T14:39:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_143901_eed12057"}
2026-05-16T14:39:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_143901_eed12057"}
2026-05-16T14:39:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_143901_eed12057"}
2026-05-16T14:39:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_143901_eed12057"}
2026-05-16T14:39:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_143901_eed12057"}
2026-05-16T14:39:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_143901_eed12057"}
2026-05-16T14:39:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.682,"duration_milliseconds":682,"important":true,"run_id":"20260516_143901_eed12057"}
2026-05-16T14:39:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_143901_eed12057"}
2026-05-16T14:39:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.398,"exec_milliseconds":1398,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_143901_eed12057"}
2026-05-16T14:40:06+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_144006_2a4d4853"}
2026-05-16T14:40:06+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_144006_2a4d4853"}
2026-05-16T14:40:06+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_144006_2a4d4853"}
2026-05-16T14:40:06+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_144006_2a4d4853"}
2026-05-16T14:40:06+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_144006_2a4d4853"}
2026-05-16T14:40:06+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_144006_2a4d4853"}
2026-05-16T14:40:06+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_144006_2a4d4853"}
2026-05-16T14:40:07+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_144006_2a4d4853"}
2026-05-16T14:40:07+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_144006_2a4d4853"}
2026-05-16T14:40:07+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.684,"duration_milliseconds":684,"important":true,"run_id":"20260516_144006_2a4d4853"}
2026-05-16T14:40:07+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_144006_2a4d4853"}
2026-05-16T14:40:07+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.407,"exec_milliseconds":1407,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_144006_2a4d4853"}
2026-05-16T14:41:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_144102_88e30a6c"}
2026-05-16T14:41:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_144102_88e30a6c"}
2026-05-16T14:41:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_144102_88e30a6c"}
2026-05-16T14:41:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_144102_88e30a6c"}
2026-05-16T14:41:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_144102_88e30a6c"}
2026-05-16T14:41:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_144102_88e30a6c"}
2026-05-16T14:41:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_144102_88e30a6c"}
2026-05-16T14:41:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_144102_88e30a6c"}
2026-05-16T14:41:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_144102_88e30a6c"}
2026-05-16T14:41:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.685,"duration_milliseconds":685,"important":true,"run_id":"20260516_144102_88e30a6c"}
2026-05-16T14:41:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_144102_88e30a6c"}
2026-05-16T14:41:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.437,"exec_milliseconds":1437,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_144102_88e30a6c"}
2026-05-16T14:42:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_144202_02633b0d"}
2026-05-16T14:42:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_144202_02633b0d"}
2026-05-16T14:42:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_144202_02633b0d"}
2026-05-16T14:42:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_144202_02633b0d"}
2026-05-16T14:42:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_144202_02633b0d"}
2026-05-16T14:42:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_144202_02633b0d"}
2026-05-16T14:42:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_144202_02633b0d"}
2026-05-16T14:42:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_144202_02633b0d"}
2026-05-16T14:42:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_144202_02633b0d"}
2026-05-16T14:42:04+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.69,"duration_milliseconds":690,"important":true,"run_id":"20260516_144202_02633b0d"}
2026-05-16T14:42:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_144202_02633b0d"}
2026-05-16T14:42:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.419,"exec_milliseconds":1419,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_144202_02633b0d"}
2026-05-16T14:43:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_144302_e3b14498"}
2026-05-16T14:43:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_144302_e3b14498"}
2026-05-16T14:43:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_144302_e3b14498"}
2026-05-16T14:43:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_144302_e3b14498"}
2026-05-16T14:43:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_144302_e3b14498"}
2026-05-16T14:43:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_144302_e3b14498"}
2026-05-16T14:43:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_144302_e3b14498"}
2026-05-16T14:43:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_144302_e3b14498"}
2026-05-16T14:43:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_144302_e3b14498"}
2026-05-16T14:43:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.684,"duration_milliseconds":684,"important":true,"run_id":"20260516_144302_e3b14498"}
2026-05-16T14:43:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_144302_e3b14498"}
2026-05-16T14:43:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.468,"exec_milliseconds":1468,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_144302_e3b14498"}
2026-05-16T14:44:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_144402_9f12abe3"}
2026-05-16T14:44:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_144402_9f12abe3"}
2026-05-16T14:44:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_144402_9f12abe3"}
2026-05-16T14:44:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_144402_9f12abe3"}
2026-05-16T14:44:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_144402_9f12abe3"}
2026-05-16T14:44:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_144402_9f12abe3"}
2026-05-16T14:44:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_144402_9f12abe3"}
2026-05-16T14:44:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_144402_9f12abe3"}
2026-05-16T14:44:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_144402_9f12abe3"}
2026-05-16T14:44:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.687,"duration_milliseconds":687,"important":true,"run_id":"20260516_144402_9f12abe3"}
2026-05-16T14:44:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_144402_9f12abe3"}
2026-05-16T14:44:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.409,"exec_milliseconds":1409,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_144402_9f12abe3"}
2026-05-16T14:45:07+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_144507_29ebb090"}
2026-05-16T14:45:07+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_144507_29ebb090"}
2026-05-16T14:45:07+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_144507_29ebb090"}
2026-05-16T14:45:07+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_144507_29ebb090"}
2026-05-16T14:45:07+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_144507_29ebb090"}
2026-05-16T14:45:07+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_144507_29ebb090"}
2026-05-16T14:45:07+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_144507_29ebb090"}
2026-05-16T14:45:07+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_144507_29ebb090"}
2026-05-16T14:45:08+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_144507_29ebb090"}
2026-05-16T14:45:08+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.681,"duration_milliseconds":681,"important":true,"run_id":"20260516_144507_29ebb090"}
2026-05-16T14:45:08+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_144507_29ebb090"}
2026-05-16T14:45:08+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.413,"exec_milliseconds":1413,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_144507_29ebb090"}
2026-05-16T14:46:03+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_144603_b6456c0d"}
2026-05-16T14:46:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_144603_b6456c0d"}
2026-05-16T14:46:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_144603_b6456c0d"}
2026-05-16T14:46:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_144603_b6456c0d"}
2026-05-16T14:46:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_144603_b6456c0d"}
2026-05-16T14:46:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_144603_b6456c0d"}
2026-05-16T14:46:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_144603_b6456c0d"}
2026-05-16T14:46:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_144603_b6456c0d"}
2026-05-16T14:46:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_144603_b6456c0d"}
2026-05-16T14:46:04+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.685,"duration_milliseconds":685,"important":true,"run_id":"20260516_144603_b6456c0d"}
2026-05-16T14:46:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_144603_b6456c0d"}
2026-05-16T14:46:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.437,"exec_milliseconds":1437,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_144603_b6456c0d"}
2026-05-16T14:47:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_144701_107e4ae8"}
2026-05-16T14:47:01+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_144701_107e4ae8"}
2026-05-16T14:47:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_144701_107e4ae8"}
2026-05-16T14:47:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_144701_107e4ae8"}
2026-05-16T14:47:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_144701_107e4ae8"}
2026-05-16T14:47:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_144701_107e4ae8"}
2026-05-16T14:47:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_144701_107e4ae8"}
2026-05-16T14:47:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_144701_107e4ae8"}
2026-05-16T14:47:02+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_144701_107e4ae8"}
2026-05-16T14:47:02+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.687,"duration_milliseconds":687,"important":true,"run_id":"20260516_144701_107e4ae8"}
2026-05-16T14:47:02+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_144701_107e4ae8"}
2026-05-16T14:47:02+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.435,"exec_milliseconds":1435,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_144701_107e4ae8"}
2026-05-16T14:48:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_144802_031f13d5"}
2026-05-16T14:48:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_144802_031f13d5"}
2026-05-16T14:48:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_144802_031f13d5"}
2026-05-16T14:48:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_144802_031f13d5"}
2026-05-16T14:48:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_144802_031f13d5"}
2026-05-16T14:48:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_144802_031f13d5"}
2026-05-16T14:48:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_144802_031f13d5"}
2026-05-16T14:48:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_144802_031f13d5"}
2026-05-16T14:48:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_144802_031f13d5"}
2026-05-16T14:48:04+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.707,"duration_milliseconds":707,"important":true,"run_id":"20260516_144802_031f13d5"}
2026-05-16T14:48:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_144802_031f13d5"}
2026-05-16T14:48:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.447,"exec_milliseconds":1447,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_144802_031f13d5"}
2026-05-16T14:49:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_144901_5e424a29"}
2026-05-16T14:49:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_144901_5e424a29"}
2026-05-16T14:49:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_144901_5e424a29"}
2026-05-16T14:49:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_144901_5e424a29"}
2026-05-16T14:49:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_144901_5e424a29"}
2026-05-16T14:49:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_144901_5e424a29"}
2026-05-16T14:49:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_144901_5e424a29"}
2026-05-16T14:49:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_144901_5e424a29"}
2026-05-16T14:49:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_144901_5e424a29"}
2026-05-16T14:49:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.693,"duration_milliseconds":693,"important":true,"run_id":"20260516_144901_5e424a29"}
2026-05-16T14:49:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_144901_5e424a29"}
2026-05-16T14:49:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.43,"exec_milliseconds":1430,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_144901_5e424a29"}
2026-05-16T14:50:07+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_145006_acb673fb"}
2026-05-16T14:50:07+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_145006_acb673fb"}
2026-05-16T14:50:07+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_145006_acb673fb"}
2026-05-16T14:50:07+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_145006_acb673fb"}
2026-05-16T14:50:07+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_145006_acb673fb"}
2026-05-16T14:50:07+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_145006_acb673fb"}
2026-05-16T14:50:07+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_145006_acb673fb"}
2026-05-16T14:50:07+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_145006_acb673fb"}
2026-05-16T14:50:08+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_145006_acb673fb"}
2026-05-16T14:50:08+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.685,"duration_milliseconds":685,"important":true,"run_id":"20260516_145006_acb673fb"}
2026-05-16T14:50:08+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_145006_acb673fb"}
2026-05-16T14:50:08+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.415,"exec_milliseconds":1415,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_145006_acb673fb"}
2026-05-16T14:51:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_145101_59ddd711"}
2026-05-16T14:51:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_145101_59ddd711"}
2026-05-16T14:51:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_145101_59ddd711"}
2026-05-16T14:51:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_145101_59ddd711"}
2026-05-16T14:51:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_145101_59ddd711"}
2026-05-16T14:51:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_145101_59ddd711"}
2026-05-16T14:51:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_145101_59ddd711"}
2026-05-16T14:51:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_145101_59ddd711"}
2026-05-16T14:51:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_145101_59ddd711"}
2026-05-16T14:51:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.686,"duration_milliseconds":686,"important":true,"run_id":"20260516_145101_59ddd711"}
2026-05-16T14:51:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_145101_59ddd711"}
2026-05-16T14:51:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.449,"exec_milliseconds":1449,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_145101_59ddd711"}
2026-05-16T14:52:03+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_145202_95383545"}
2026-05-16T14:52:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_145202_95383545"}
2026-05-16T14:52:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_145202_95383545"}
2026-05-16T14:52:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_145202_95383545"}
2026-05-16T14:52:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_145202_95383545"}
2026-05-16T14:52:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_145202_95383545"}
2026-05-16T14:52:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_145202_95383545"}
2026-05-16T14:52:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_145202_95383545"}
2026-05-16T14:52:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_145202_95383545"}
2026-05-16T14:52:04+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.698,"duration_milliseconds":698,"important":true,"run_id":"20260516_145202_95383545"}
2026-05-16T14:52:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_145202_95383545"}
2026-05-16T14:52:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.439,"exec_milliseconds":1439,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_145202_95383545"}
2026-05-16T14:53:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_145301_6e8a4619"}
2026-05-16T14:53:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_145301_6e8a4619"}
2026-05-16T14:53:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_145301_6e8a4619"}
2026-05-16T14:53:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_145301_6e8a4619"}
2026-05-16T14:53:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_145301_6e8a4619"}
2026-05-16T14:53:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_145301_6e8a4619"}
2026-05-16T14:53:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_145301_6e8a4619"}
2026-05-16T14:53:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_145301_6e8a4619"}
2026-05-16T14:53:02+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_145301_6e8a4619"}
2026-05-16T14:53:02+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.69,"duration_milliseconds":690,"important":true,"run_id":"20260516_145301_6e8a4619"}
2026-05-16T14:53:02+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_145301_6e8a4619"}
2026-05-16T14:53:02+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.427,"exec_milliseconds":1427,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_145301_6e8a4619"}
2026-05-16T14:54:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_145402_fd1b1976"}
2026-05-16T14:54:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_145402_fd1b1976"}
2026-05-16T14:54:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_145402_fd1b1976"}
2026-05-16T14:54:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_145402_fd1b1976"}
2026-05-16T14:54:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_145402_fd1b1976"}
2026-05-16T14:54:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_145402_fd1b1976"}
2026-05-16T14:54:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_145402_fd1b1976"}
2026-05-16T14:54:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_145402_fd1b1976"}
2026-05-16T14:54:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_145402_fd1b1976"}
2026-05-16T14:54:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.687,"duration_milliseconds":687,"important":true,"run_id":"20260516_145402_fd1b1976"}
2026-05-16T14:54:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_145402_fd1b1976"}
2026-05-16T14:54:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.448,"exec_milliseconds":1448,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_145402_fd1b1976"}
2026-05-16T14:55:04+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_145504_55fbd196"}
2026-05-16T14:55:04+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_145504_55fbd196"}
2026-05-16T14:55:04+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_145504_55fbd196"}
2026-05-16T14:55:04+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_145504_55fbd196"}
2026-05-16T14:55:04+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_145504_55fbd196"}
2026-05-16T14:55:04+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_145504_55fbd196"}
2026-05-16T14:55:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_145504_55fbd196"}
2026-05-16T14:55:04+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_145504_55fbd196"}
2026-05-16T14:55:05+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_145504_55fbd196"}
2026-05-16T14:55:05+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.689,"duration_milliseconds":689,"important":true,"run_id":"20260516_145504_55fbd196"}
2026-05-16T14:55:05+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_145504_55fbd196"}
2026-05-16T14:55:05+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.4,"exec_milliseconds":1400,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_145504_55fbd196"}
2026-05-16T14:56:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_145602_fe43d6b6"}
2026-05-16T14:56:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_145602_fe43d6b6"}
2026-05-16T14:56:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_145602_fe43d6b6"}
2026-05-16T14:56:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_145602_fe43d6b6"}
2026-05-16T14:56:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_145602_fe43d6b6"}
2026-05-16T14:56:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_145602_fe43d6b6"}
2026-05-16T14:56:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_145602_fe43d6b6"}
2026-05-16T14:56:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_145602_fe43d6b6"}
2026-05-16T14:56:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_145602_fe43d6b6"}
2026-05-16T14:56:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.681,"duration_milliseconds":681,"important":true,"run_id":"20260516_145602_fe43d6b6"}
2026-05-16T14:56:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_145602_fe43d6b6"}
2026-05-16T14:56:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.432,"exec_milliseconds":1432,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_145602_fe43d6b6"}
2026-05-16T14:57:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_145701_f773ffc8"}
2026-05-16T14:57:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_145701_f773ffc8"}
2026-05-16T14:57:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_145701_f773ffc8"}
2026-05-16T14:57:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_145701_f773ffc8"}
2026-05-16T14:57:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_145701_f773ffc8"}
2026-05-16T14:57:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_145701_f773ffc8"}
2026-05-16T14:57:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_145701_f773ffc8"}
2026-05-16T14:57:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_145701_f773ffc8"}
2026-05-16T14:57:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_145701_f773ffc8"}
2026-05-16T14:57:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.688,"duration_milliseconds":688,"important":true,"run_id":"20260516_145701_f773ffc8"}
2026-05-16T14:57:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_145701_f773ffc8"}
2026-05-16T14:57:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.421,"exec_milliseconds":1421,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_145701_f773ffc8"}
2026-05-16T14:58:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_145802_90044b48"}
2026-05-16T14:58:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_145802_90044b48"}
2026-05-16T14:58:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_145802_90044b48"}
2026-05-16T14:58:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_145802_90044b48"}
2026-05-16T14:58:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_145802_90044b48"}
2026-05-16T14:58:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_145802_90044b48"}
2026-05-16T14:58:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_145802_90044b48"}
2026-05-16T14:58:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_145802_90044b48"}
2026-05-16T14:58:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_145802_90044b48"}
2026-05-16T14:58:04+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.693,"duration_milliseconds":693,"important":true,"run_id":"20260516_145802_90044b48"}
2026-05-16T14:58:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_145802_90044b48"}
2026-05-16T14:58:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.419,"exec_milliseconds":1419,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_145802_90044b48"}
2026-05-16T14:59:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_145901_49dfb049"}
2026-05-16T14:59:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_145901_49dfb049"}
2026-05-16T14:59:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_145901_49dfb049"}
2026-05-16T14:59:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_145901_49dfb049"}
2026-05-16T14:59:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_145901_49dfb049"}
2026-05-16T14:59:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_145901_49dfb049"}
2026-05-16T14:59:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_145901_49dfb049"}
2026-05-16T14:59:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_145901_49dfb049"}
2026-05-16T14:59:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_145901_49dfb049"}
2026-05-16T14:59:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.7,"duration_milliseconds":700,"important":true,"run_id":"20260516_145901_49dfb049"}
2026-05-16T14:59:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_145901_49dfb049"}
2026-05-16T14:59:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.465,"exec_milliseconds":1465,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_145901_49dfb049"}
2026-05-16T15:00:18+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_150018_4de1c958"}
2026-05-16T15:00:19+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_150018_4de1c958"}
2026-05-16T15:00:19+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_150018_4de1c958"}
2026-05-16T15:00:19+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_150018_4de1c958"}
2026-05-16T15:00:19+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_150018_4de1c958"}
2026-05-16T15:00:19+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_150018_4de1c958"}
2026-05-16T15:00:19+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_150018_4de1c958"}
2026-05-16T15:00:19+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_150018_4de1c958"}
2026-05-16T15:00:20+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_150018_4de1c958"}
2026-05-16T15:00:20+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.685,"duration_milliseconds":685,"important":true,"run_id":"20260516_150018_4de1c958"}
2026-05-16T15:00:20+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_150018_4de1c958"}
2026-05-16T15:00:20+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.454,"exec_milliseconds":1454,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_150018_4de1c958"}
2026-05-16T15:01:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_150101_56076418"}
2026-05-16T15:01:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_150101_56076418"}
2026-05-16T15:01:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_150101_56076418"}
2026-05-16T15:01:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_150101_56076418"}
2026-05-16T15:01:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_150101_56076418"}
2026-05-16T15:01:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_150101_56076418"}
2026-05-16T15:01:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_150101_56076418"}
2026-05-16T15:01:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_150101_56076418"}
2026-05-16T15:01:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_150101_56076418"}
2026-05-16T15:01:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.7,"duration_milliseconds":700,"important":true,"run_id":"20260516_150101_56076418"}
2026-05-16T15:01:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_150101_56076418"}
2026-05-16T15:01:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.442,"exec_milliseconds":1442,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_150101_56076418"}
2026-05-16T15:02:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_150202_ef09f4f2"}
2026-05-16T15:02:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_150202_ef09f4f2"}
2026-05-16T15:02:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_150202_ef09f4f2"}
2026-05-16T15:02:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_150202_ef09f4f2"}
2026-05-16T15:02:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_150202_ef09f4f2"}
2026-05-16T15:02:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_150202_ef09f4f2"}
2026-05-16T15:02:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_150202_ef09f4f2"}
2026-05-16T15:02:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_150202_ef09f4f2"}
2026-05-16T15:02:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_150202_ef09f4f2"}
2026-05-16T15:02:04+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.683,"duration_milliseconds":683,"important":true,"run_id":"20260516_150202_ef09f4f2"}
2026-05-16T15:02:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_150202_ef09f4f2"}
2026-05-16T15:02:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.404,"exec_milliseconds":1404,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_150202_ef09f4f2"}
2026-05-16T15:03:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_150302_923e820f"}
2026-05-16T15:03:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_150302_923e820f"}
2026-05-16T15:03:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_150302_923e820f"}
2026-05-16T15:03:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_150302_923e820f"}
2026-05-16T15:03:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_150302_923e820f"}
2026-05-16T15:03:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_150302_923e820f"}
2026-05-16T15:03:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_150302_923e820f"}
2026-05-16T15:03:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_150302_923e820f"}
2026-05-16T15:03:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_150302_923e820f"}
2026-05-16T15:03:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.677,"duration_milliseconds":677,"important":true,"run_id":"20260516_150302_923e820f"}
2026-05-16T15:03:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_150302_923e820f"}
2026-05-16T15:03:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.425,"exec_milliseconds":1425,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_150302_923e820f"}
2026-05-16T15:04:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_150402_8ad73914"}
2026-05-16T15:04:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_150402_8ad73914"}
2026-05-16T15:04:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_150402_8ad73914"}
2026-05-16T15:04:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_150402_8ad73914"}
2026-05-16T15:04:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_150402_8ad73914"}
2026-05-16T15:04:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_150402_8ad73914"}
2026-05-16T15:04:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_150402_8ad73914"}
2026-05-16T15:04:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_150402_8ad73914"}
2026-05-16T15:04:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_150402_8ad73914"}
2026-05-16T15:04:04+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.682,"duration_milliseconds":682,"important":true,"run_id":"20260516_150402_8ad73914"}
2026-05-16T15:04:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_150402_8ad73914"}
2026-05-16T15:04:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.415,"exec_milliseconds":1415,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_150402_8ad73914"}
2026-05-16T15:05:04+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_150504_e3b2f2c1"}
2026-05-16T15:05:04+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_150504_e3b2f2c1"}
2026-05-16T15:05:04+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_150504_e3b2f2c1"}
2026-05-16T15:05:04+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_150504_e3b2f2c1"}
2026-05-16T15:05:05+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_150504_e3b2f2c1"}
2026-05-16T15:05:05+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_150504_e3b2f2c1"}
2026-05-16T15:05:05+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_150504_e3b2f2c1"}
2026-05-16T15:05:05+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_150504_e3b2f2c1"}
2026-05-16T15:05:05+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_150504_e3b2f2c1"}
2026-05-16T15:05:05+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.677,"duration_milliseconds":677,"important":true,"run_id":"20260516_150504_e3b2f2c1"}
2026-05-16T15:05:05+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_150504_e3b2f2c1"}
2026-05-16T15:05:05+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.44,"exec_milliseconds":1440,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_150504_e3b2f2c1"}
2026-05-16T15:06:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_150602_f73609c3"}
2026-05-16T15:06:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_150602_f73609c3"}
2026-05-16T15:06:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_150602_f73609c3"}
2026-05-16T15:06:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_150602_f73609c3"}
2026-05-16T15:06:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_150602_f73609c3"}
2026-05-16T15:06:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_150602_f73609c3"}
2026-05-16T15:06:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_150602_f73609c3"}
2026-05-16T15:06:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_150602_f73609c3"}
2026-05-16T15:06:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_150602_f73609c3"}
2026-05-16T15:06:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.688,"duration_milliseconds":688,"important":true,"run_id":"20260516_150602_f73609c3"}
2026-05-16T15:06:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_150602_f73609c3"}
2026-05-16T15:06:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.441,"exec_milliseconds":1441,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_150602_f73609c3"}
2026-05-16T15:07:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_150701_8f12cafc"}
2026-05-16T15:07:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_150701_8f12cafc"}
2026-05-16T15:07:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_150701_8f12cafc"}
2026-05-16T15:07:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_150701_8f12cafc"}
2026-05-16T15:07:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_150701_8f12cafc"}
2026-05-16T15:07:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_150701_8f12cafc"}
2026-05-16T15:07:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_150701_8f12cafc"}
2026-05-16T15:07:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_150701_8f12cafc"}
2026-05-16T15:07:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_150701_8f12cafc"}
2026-05-16T15:07:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.7,"duration_milliseconds":700,"important":true,"run_id":"20260516_150701_8f12cafc"}
2026-05-16T15:07:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_150701_8f12cafc"}
2026-05-16T15:07:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.454,"exec_milliseconds":1454,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_150701_8f12cafc"}
2026-05-16T15:08:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_150802_f2ba9696"}
2026-05-16T15:08:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_150802_f2ba9696"}
2026-05-16T15:08:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_150802_f2ba9696"}
2026-05-16T15:08:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_150802_f2ba9696"}
2026-05-16T15:08:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_150802_f2ba9696"}
2026-05-16T15:08:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_150802_f2ba9696"}
2026-05-16T15:08:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_150802_f2ba9696"}
2026-05-16T15:08:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_150802_f2ba9696"}
2026-05-16T15:08:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_150802_f2ba9696"}
2026-05-16T15:08:04+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.68,"duration_milliseconds":680,"important":true,"run_id":"20260516_150802_f2ba9696"}
2026-05-16T15:08:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_150802_f2ba9696"}
2026-05-16T15:08:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.393,"exec_milliseconds":1393,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_150802_f2ba9696"}
2026-05-16T15:09:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_150901_bb03d606"}
2026-05-16T15:09:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_150901_bb03d606"}
2026-05-16T15:09:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_150901_bb03d606"}
2026-05-16T15:09:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_150901_bb03d606"}
2026-05-16T15:09:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_150901_bb03d606"}
2026-05-16T15:09:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_150901_bb03d606"}
2026-05-16T15:09:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_150901_bb03d606"}
2026-05-16T15:09:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_150901_bb03d606"}
2026-05-16T15:09:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_150901_bb03d606"}
2026-05-16T15:09:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.692,"duration_milliseconds":692,"important":true,"run_id":"20260516_150901_bb03d606"}
2026-05-16T15:09:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_150901_bb03d606"}
2026-05-16T15:09:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.404,"exec_milliseconds":1404,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_150901_bb03d606"}
2026-05-16T15:10:06+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_151006_ddb8f801"}
2026-05-16T15:10:07+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_151006_ddb8f801"}
2026-05-16T15:10:07+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_151006_ddb8f801"}
2026-05-16T15:10:07+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_151006_ddb8f801"}
2026-05-16T15:10:07+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_151006_ddb8f801"}
2026-05-16T15:10:07+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_151006_ddb8f801"}
2026-05-16T15:10:07+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_151006_ddb8f801"}
2026-05-16T15:10:07+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_151006_ddb8f801"}
2026-05-16T15:10:08+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_151006_ddb8f801"}
2026-05-16T15:10:08+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.69,"duration_milliseconds":690,"important":true,"run_id":"20260516_151006_ddb8f801"}
2026-05-16T15:10:08+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_151006_ddb8f801"}
2026-05-16T15:10:08+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.45,"exec_milliseconds":1450,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_151006_ddb8f801"}
2026-05-16T15:11:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_151101_2c2959f8"}
2026-05-16T15:11:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_151101_2c2959f8"}
2026-05-16T15:11:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_151101_2c2959f8"}
2026-05-16T15:11:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_151101_2c2959f8"}
2026-05-16T15:11:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_151101_2c2959f8"}
2026-05-16T15:11:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_151101_2c2959f8"}
2026-05-16T15:11:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_151101_2c2959f8"}
2026-05-16T15:11:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_151101_2c2959f8"}
2026-05-16T15:11:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_151101_2c2959f8"}
2026-05-16T15:11:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.688,"duration_milliseconds":688,"important":true,"run_id":"20260516_151101_2c2959f8"}
2026-05-16T15:11:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_151101_2c2959f8"}
2026-05-16T15:11:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.449,"exec_milliseconds":1449,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_151101_2c2959f8"}
2026-05-16T15:12:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_151202_c35b7ff0"}
2026-05-16T15:12:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_151202_c35b7ff0"}
2026-05-16T15:12:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_151202_c35b7ff0"}
2026-05-16T15:12:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_151202_c35b7ff0"}
2026-05-16T15:12:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_151202_c35b7ff0"}
2026-05-16T15:12:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_151202_c35b7ff0"}
2026-05-16T15:12:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_151202_c35b7ff0"}
2026-05-16T15:12:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_151202_c35b7ff0"}
2026-05-16T15:12:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_151202_c35b7ff0"}
2026-05-16T15:12:04+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.683,"duration_milliseconds":683,"important":true,"run_id":"20260516_151202_c35b7ff0"}
2026-05-16T15:12:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_151202_c35b7ff0"}
2026-05-16T15:12:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.422,"exec_milliseconds":1422,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_151202_c35b7ff0"}
2026-05-16T15:13:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_151301_bde78c90"}
2026-05-16T15:13:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_151301_bde78c90"}
2026-05-16T15:13:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_151301_bde78c90"}
2026-05-16T15:13:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_151301_bde78c90"}
2026-05-16T15:13:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_151301_bde78c90"}
2026-05-16T15:13:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_151301_bde78c90"}
2026-05-16T15:13:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_151301_bde78c90"}
2026-05-16T15:13:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_151301_bde78c90"}
2026-05-16T15:13:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_151301_bde78c90"}
2026-05-16T15:13:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.704,"duration_milliseconds":704,"important":true,"run_id":"20260516_151301_bde78c90"}
2026-05-16T15:13:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_151301_bde78c90"}
2026-05-16T15:13:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.456,"exec_milliseconds":1456,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_151301_bde78c90"}
2026-05-16T15:14:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_151402_020cbbc8"}
2026-05-16T15:14:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_151402_020cbbc8"}
2026-05-16T15:14:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_151402_020cbbc8"}
2026-05-16T15:14:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_151402_020cbbc8"}
2026-05-16T15:14:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_151402_020cbbc8"}
2026-05-16T15:14:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_151402_020cbbc8"}
2026-05-16T15:14:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_151402_020cbbc8"}
2026-05-16T15:14:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_151402_020cbbc8"}
2026-05-16T15:14:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_151402_020cbbc8"}
2026-05-16T15:14:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.692,"duration_milliseconds":692,"important":true,"run_id":"20260516_151402_020cbbc8"}
2026-05-16T15:14:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_151402_020cbbc8"}
2026-05-16T15:14:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.397,"exec_milliseconds":1397,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_151402_020cbbc8"}
2026-05-16T15:15:06+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_151506_f3e81efb"}
2026-05-16T15:15:07+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_151506_f3e81efb"}
2026-05-16T15:15:07+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_151506_f3e81efb"}
2026-05-16T15:15:07+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_151506_f3e81efb"}
2026-05-16T15:15:07+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_151506_f3e81efb"}
2026-05-16T15:15:07+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_151506_f3e81efb"}
2026-05-16T15:15:07+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_151506_f3e81efb"}
2026-05-16T15:15:07+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_151506_f3e81efb"}
2026-05-16T15:15:08+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_151506_f3e81efb"}
2026-05-16T15:15:08+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.69,"duration_milliseconds":690,"important":true,"run_id":"20260516_151506_f3e81efb"}
2026-05-16T15:15:08+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_151506_f3e81efb"}
2026-05-16T15:15:08+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.408,"exec_milliseconds":1408,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_151506_f3e81efb"}
2026-05-16T15:16:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_151602_c976c997"}
2026-05-16T15:16:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_151602_c976c997"}
2026-05-16T15:16:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_151602_c976c997"}
2026-05-16T15:16:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_151602_c976c997"}
2026-05-16T15:16:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_151602_c976c997"}
2026-05-16T15:16:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_151602_c976c997"}
2026-05-16T15:16:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_151602_c976c997"}
2026-05-16T15:16:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_151602_c976c997"}
2026-05-16T15:16:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_151602_c976c997"}
2026-05-16T15:16:04+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.687,"duration_milliseconds":687,"important":true,"run_id":"20260516_151602_c976c997"}
2026-05-16T15:16:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_151602_c976c997"}
2026-05-16T15:16:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.452,"exec_milliseconds":1452,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_151602_c976c997"}
2026-05-16T15:17:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_151701_65e09f0a"}
2026-05-16T15:17:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_151701_65e09f0a"}
2026-05-16T15:17:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_151701_65e09f0a"}
2026-05-16T15:17:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_151701_65e09f0a"}
2026-05-16T15:17:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_151701_65e09f0a"}
2026-05-16T15:17:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_151701_65e09f0a"}
2026-05-16T15:17:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_151701_65e09f0a"}
2026-05-16T15:17:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_151701_65e09f0a"}
2026-05-16T15:17:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_151701_65e09f0a"}
2026-05-16T15:17:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.69,"duration_milliseconds":690,"important":true,"run_id":"20260516_151701_65e09f0a"}
2026-05-16T15:17:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_151701_65e09f0a"}
2026-05-16T15:17:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.448,"exec_milliseconds":1448,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_151701_65e09f0a"}
2026-05-16T15:18:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_151802_f763ac3a"}
2026-05-16T15:18:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_151802_f763ac3a"}
2026-05-16T15:18:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_151802_f763ac3a"}
2026-05-16T15:18:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_151802_f763ac3a"}
2026-05-16T15:18:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_151802_f763ac3a"}
2026-05-16T15:18:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_151802_f763ac3a"}
2026-05-16T15:18:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_151802_f763ac3a"}
2026-05-16T15:18:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_151802_f763ac3a"}
2026-05-16T15:18:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_151802_f763ac3a"}
2026-05-16T15:18:04+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.678,"duration_milliseconds":678,"important":true,"run_id":"20260516_151802_f763ac3a"}
2026-05-16T15:18:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_151802_f763ac3a"}
2026-05-16T15:18:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.413,"exec_milliseconds":1413,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_151802_f763ac3a"}
2026-05-16T15:19:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_151901_75f3a159"}
2026-05-16T15:19:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_151901_75f3a159"}
2026-05-16T15:19:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_151901_75f3a159"}
2026-05-16T15:19:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_151901_75f3a159"}
2026-05-16T15:19:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_151901_75f3a159"}
2026-05-16T15:19:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_151901_75f3a159"}
2026-05-16T15:19:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_151901_75f3a159"}
2026-05-16T15:19:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_151901_75f3a159"}
2026-05-16T15:19:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_151901_75f3a159"}
2026-05-16T15:19:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.693,"duration_milliseconds":693,"important":true,"run_id":"20260516_151901_75f3a159"}
2026-05-16T15:19:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_151901_75f3a159"}
2026-05-16T15:19:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.408,"exec_milliseconds":1408,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_151901_75f3a159"}
2026-05-16T15:20:06+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_152006_50f0c4fb"}
2026-05-16T15:20:07+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_152006_50f0c4fb"}
2026-05-16T15:20:07+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_152006_50f0c4fb"}
2026-05-16T15:20:07+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_152006_50f0c4fb"}
2026-05-16T15:20:07+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_152006_50f0c4fb"}
2026-05-16T15:20:07+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_152006_50f0c4fb"}
2026-05-16T15:20:07+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_152006_50f0c4fb"}
2026-05-16T15:20:07+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_152006_50f0c4fb"}
2026-05-16T15:20:08+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_152006_50f0c4fb"}
2026-05-16T15:20:08+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.688,"duration_milliseconds":688,"important":true,"run_id":"20260516_152006_50f0c4fb"}
2026-05-16T15:20:08+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_152006_50f0c4fb"}
2026-05-16T15:20:08+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.452,"exec_milliseconds":1452,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_152006_50f0c4fb"}
2026-05-16T15:21:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_152101_07790bda"}
2026-05-16T15:21:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_152101_07790bda"}
2026-05-16T15:21:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_152101_07790bda"}
2026-05-16T15:21:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_152101_07790bda"}
2026-05-16T15:21:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_152101_07790bda"}
2026-05-16T15:21:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_152101_07790bda"}
2026-05-16T15:21:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_152101_07790bda"}
2026-05-16T15:21:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_152101_07790bda"}
2026-05-16T15:21:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_152101_07790bda"}
2026-05-16T15:21:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.683,"duration_milliseconds":683,"important":true,"run_id":"20260516_152101_07790bda"}
2026-05-16T15:21:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_152101_07790bda"}
2026-05-16T15:21:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.415,"exec_milliseconds":1415,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_152101_07790bda"}
2026-05-16T15:22:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_152202_8f9cea48"}
2026-05-16T15:22:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_152202_8f9cea48"}
2026-05-16T15:22:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_152202_8f9cea48"}
2026-05-16T15:22:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_152202_8f9cea48"}
2026-05-16T15:22:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_152202_8f9cea48"}
2026-05-16T15:22:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_152202_8f9cea48"}
2026-05-16T15:22:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_152202_8f9cea48"}
2026-05-16T15:22:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_152202_8f9cea48"}
2026-05-16T15:22:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_152202_8f9cea48"}
2026-05-16T15:22:04+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.683,"duration_milliseconds":683,"important":true,"run_id":"20260516_152202_8f9cea48"}
2026-05-16T15:22:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_152202_8f9cea48"}
2026-05-16T15:22:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.406,"exec_milliseconds":1406,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_152202_8f9cea48"}
2026-05-16T15:23:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_152302_5b863351"}
2026-05-16T15:23:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_152302_5b863351"}
2026-05-16T15:23:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_152302_5b863351"}
2026-05-16T15:23:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_152302_5b863351"}
2026-05-16T15:23:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_152302_5b863351"}
2026-05-16T15:23:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_152302_5b863351"}
2026-05-16T15:23:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_152302_5b863351"}
2026-05-16T15:23:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_152302_5b863351"}
2026-05-16T15:23:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_152302_5b863351"}
2026-05-16T15:23:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.678,"duration_milliseconds":678,"important":true,"run_id":"20260516_152302_5b863351"}
2026-05-16T15:23:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_152302_5b863351"}
2026-05-16T15:23:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.433,"exec_milliseconds":1433,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_152302_5b863351"}
2026-05-16T15:24:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_152402_cde102fb"}
2026-05-16T15:24:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_152402_cde102fb"}
2026-05-16T15:24:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_152402_cde102fb"}
2026-05-16T15:24:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_152402_cde102fb"}
2026-05-16T15:24:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_152402_cde102fb"}
2026-05-16T15:24:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_152402_cde102fb"}
2026-05-16T15:24:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_152402_cde102fb"}
2026-05-16T15:24:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_152402_cde102fb"}
2026-05-16T15:24:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_152402_cde102fb"}
2026-05-16T15:24:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.689,"duration_milliseconds":689,"important":true,"run_id":"20260516_152402_cde102fb"}
2026-05-16T15:24:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_152402_cde102fb"}
2026-05-16T15:24:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.429,"exec_milliseconds":1429,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_152402_cde102fb"}
2026-05-16T15:25:04+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_152503_2817fe22"}
2026-05-16T15:25:04+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_152503_2817fe22"}
2026-05-16T15:25:04+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_152503_2817fe22"}
2026-05-16T15:25:04+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_152503_2817fe22"}
2026-05-16T15:25:04+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_152503_2817fe22"}
2026-05-16T15:25:04+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_152503_2817fe22"}
2026-05-16T15:25:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_152503_2817fe22"}
2026-05-16T15:25:04+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_152503_2817fe22"}
2026-05-16T15:25:05+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_152503_2817fe22"}
2026-05-16T15:25:05+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.69,"duration_milliseconds":690,"important":true,"run_id":"20260516_152503_2817fe22"}
2026-05-16T15:25:05+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_152503_2817fe22"}
2026-05-16T15:25:05+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.448,"exec_milliseconds":1448,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_152503_2817fe22"}
2026-05-16T15:26:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_152602_d7936199"}
2026-05-16T15:26:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_152602_d7936199"}
2026-05-16T15:26:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_152602_d7936199"}
2026-05-16T15:26:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_152602_d7936199"}
2026-05-16T15:26:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_152602_d7936199"}
2026-05-16T15:26:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_152602_d7936199"}
2026-05-16T15:26:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_152602_d7936199"}
2026-05-16T15:26:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_152602_d7936199"}
2026-05-16T15:26:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_152602_d7936199"}
2026-05-16T15:26:04+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.687,"duration_milliseconds":687,"important":true,"run_id":"20260516_152602_d7936199"}
2026-05-16T15:26:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_152602_d7936199"}
2026-05-16T15:26:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.432,"exec_milliseconds":1432,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_152602_d7936199"}
2026-05-16T15:27:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_152701_be4bccbe"}
2026-05-16T15:27:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_152701_be4bccbe"}
2026-05-16T15:27:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_152701_be4bccbe"}
2026-05-16T15:27:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_152701_be4bccbe"}
2026-05-16T15:27:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_152701_be4bccbe"}
2026-05-16T15:27:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_152701_be4bccbe"}
2026-05-16T15:27:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_152701_be4bccbe"}
2026-05-16T15:27:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_152701_be4bccbe"}
2026-05-16T15:27:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_152701_be4bccbe"}
2026-05-16T15:27:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.695,"duration_milliseconds":695,"important":true,"run_id":"20260516_152701_be4bccbe"}
2026-05-16T15:27:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_152701_be4bccbe"}
2026-05-16T15:27:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.427,"exec_milliseconds":1427,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_152701_be4bccbe"}
2026-05-16T15:28:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_152802_15b71fdf"}
2026-05-16T15:28:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_152802_15b71fdf"}
2026-05-16T15:28:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_152802_15b71fdf"}
2026-05-16T15:28:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_152802_15b71fdf"}
2026-05-16T15:28:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_152802_15b71fdf"}
2026-05-16T15:28:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_152802_15b71fdf"}
2026-05-16T15:28:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_152802_15b71fdf"}
2026-05-16T15:28:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_152802_15b71fdf"}
2026-05-16T15:28:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_152802_15b71fdf"}
2026-05-16T15:28:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.68,"duration_milliseconds":680,"important":true,"run_id":"20260516_152802_15b71fdf"}
2026-05-16T15:28:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_152802_15b71fdf"}
2026-05-16T15:28:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.401,"exec_milliseconds":1401,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_152802_15b71fdf"}
2026-05-16T15:29:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_152901_44e81618"}
2026-05-16T15:29:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_152901_44e81618"}
2026-05-16T15:29:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_152901_44e81618"}
2026-05-16T15:29:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_152901_44e81618"}
2026-05-16T15:29:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_152901_44e81618"}
2026-05-16T15:29:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_152901_44e81618"}
2026-05-16T15:29:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_152901_44e81618"}
2026-05-16T15:29:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_152901_44e81618"}
2026-05-16T15:29:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_152901_44e81618"}
2026-05-16T15:29:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.672,"duration_milliseconds":672,"important":true,"run_id":"20260516_152901_44e81618"}
2026-05-16T15:29:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_152901_44e81618"}
2026-05-16T15:29:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.43,"exec_milliseconds":1430,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_152901_44e81618"}
2026-05-16T15:30:12+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_153012_6bef424b"}
2026-05-16T15:30:12+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_153012_6bef424b"}
2026-05-16T15:30:12+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_153012_6bef424b"}
2026-05-16T15:30:12+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_153012_6bef424b"}
2026-05-16T15:30:13+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_153012_6bef424b"}
2026-05-16T15:30:13+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_153012_6bef424b"}
2026-05-16T15:30:13+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_153012_6bef424b"}
2026-05-16T15:30:13+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_153012_6bef424b"}
2026-05-16T15:30:13+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_153012_6bef424b"}
2026-05-16T15:30:13+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.69,"duration_milliseconds":690,"important":true,"run_id":"20260516_153012_6bef424b"}
2026-05-16T15:30:13+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_153012_6bef424b"}
2026-05-16T15:30:13+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.414,"exec_milliseconds":1414,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_153012_6bef424b"}
2026-05-16T15:31:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_153101_439d1df3"}
2026-05-16T15:31:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_153101_439d1df3"}
2026-05-16T15:31:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_153101_439d1df3"}
2026-05-16T15:31:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_153101_439d1df3"}
2026-05-16T15:31:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_153101_439d1df3"}
2026-05-16T15:31:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_153101_439d1df3"}
2026-05-16T15:31:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_153101_439d1df3"}
2026-05-16T15:31:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_153101_439d1df3"}
2026-05-16T15:31:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_153101_439d1df3"}
2026-05-16T15:31:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.687,"duration_milliseconds":687,"important":true,"run_id":"20260516_153101_439d1df3"}
2026-05-16T15:31:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_153101_439d1df3"}
2026-05-16T15:31:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.448,"exec_milliseconds":1448,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_153101_439d1df3"}
2026-05-16T15:32:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_153202_a779d3d1"}
2026-05-16T15:32:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_153202_a779d3d1"}
2026-05-16T15:32:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_153202_a779d3d1"}
2026-05-16T15:32:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_153202_a779d3d1"}
2026-05-16T15:32:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_153202_a779d3d1"}
2026-05-16T15:32:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_153202_a779d3d1"}
2026-05-16T15:32:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_153202_a779d3d1"}
2026-05-16T15:32:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_153202_a779d3d1"}
2026-05-16T15:32:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_153202_a779d3d1"}
2026-05-16T15:32:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.68,"duration_milliseconds":680,"important":true,"run_id":"20260516_153202_a779d3d1"}
2026-05-16T15:32:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_153202_a779d3d1"}
2026-05-16T15:32:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.413,"exec_milliseconds":1413,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_153202_a779d3d1"}
2026-05-16T15:33:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_153301_8d85b952"}
2026-05-16T15:33:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_153301_8d85b952"}
2026-05-16T15:33:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_153301_8d85b952"}
2026-05-16T15:33:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_153301_8d85b952"}
2026-05-16T15:33:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_153301_8d85b952"}
2026-05-16T15:33:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_153301_8d85b952"}
2026-05-16T15:33:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_153301_8d85b952"}
2026-05-16T15:33:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_153301_8d85b952"}
2026-05-16T15:33:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_153301_8d85b952"}
2026-05-16T15:33:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.687,"duration_milliseconds":687,"important":true,"run_id":"20260516_153301_8d85b952"}
2026-05-16T15:33:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_153301_8d85b952"}
2026-05-16T15:33:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.438,"exec_milliseconds":1438,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_153301_8d85b952"}
2026-05-16T15:34:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_153402_39bc6bae"}
2026-05-16T15:34:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_153402_39bc6bae"}
2026-05-16T15:34:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_153402_39bc6bae"}
2026-05-16T15:34:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_153402_39bc6bae"}
2026-05-16T15:34:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_153402_39bc6bae"}
2026-05-16T15:34:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_153402_39bc6bae"}
2026-05-16T15:34:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_153402_39bc6bae"}
2026-05-16T15:34:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_153402_39bc6bae"}
2026-05-16T15:34:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_153402_39bc6bae"}
2026-05-16T15:34:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.686,"duration_milliseconds":686,"important":true,"run_id":"20260516_153402_39bc6bae"}
2026-05-16T15:34:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_153402_39bc6bae"}
2026-05-16T15:34:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.434,"exec_milliseconds":1434,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_153402_39bc6bae"}
2026-05-16T15:35:04+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_153504_45b4766a"}
2026-05-16T15:35:04+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_153504_45b4766a"}
2026-05-16T15:35:04+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_153504_45b4766a"}
2026-05-16T15:35:04+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_153504_45b4766a"}
2026-05-16T15:35:05+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_153504_45b4766a"}
2026-05-16T15:35:05+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_153504_45b4766a"}
2026-05-16T15:35:05+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_153504_45b4766a"}
2026-05-16T15:35:05+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_153504_45b4766a"}
2026-05-16T15:35:05+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_153504_45b4766a"}
2026-05-16T15:35:05+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.687,"duration_milliseconds":687,"important":true,"run_id":"20260516_153504_45b4766a"}
2026-05-16T15:35:05+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_153504_45b4766a"}
2026-05-16T15:35:05+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.408,"exec_milliseconds":1408,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_153504_45b4766a"}
2026-05-16T15:36:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_153602_8ec18bb6"}
2026-05-16T15:36:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_153602_8ec18bb6"}
2026-05-16T15:36:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_153602_8ec18bb6"}
2026-05-16T15:36:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_153602_8ec18bb6"}
2026-05-16T15:36:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_153602_8ec18bb6"}
2026-05-16T15:36:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_153602_8ec18bb6"}
2026-05-16T15:36:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_153602_8ec18bb6"}
2026-05-16T15:36:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_153602_8ec18bb6"}
2026-05-16T15:36:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_153602_8ec18bb6"}
2026-05-16T15:36:04+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.688,"duration_milliseconds":688,"important":true,"run_id":"20260516_153602_8ec18bb6"}
2026-05-16T15:36:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_153602_8ec18bb6"}
2026-05-16T15:36:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.448,"exec_milliseconds":1448,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_153602_8ec18bb6"}
2026-05-16T15:37:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_153701_bf500026"}
2026-05-16T15:37:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_153701_bf500026"}
2026-05-16T15:37:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_153701_bf500026"}
2026-05-16T15:37:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_153701_bf500026"}
2026-05-16T15:37:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_153701_bf500026"}
2026-05-16T15:37:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_153701_bf500026"}
2026-05-16T15:37:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_153701_bf500026"}
2026-05-16T15:37:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_153701_bf500026"}
2026-05-16T15:37:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_153701_bf500026"}
2026-05-16T15:37:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.685,"duration_milliseconds":685,"important":true,"run_id":"20260516_153701_bf500026"}
2026-05-16T15:37:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_153701_bf500026"}
2026-05-16T15:37:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.439,"exec_milliseconds":1439,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_153701_bf500026"}
2026-05-16T15:38:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_153802_63bc8c1c"}
2026-05-16T15:38:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_153802_63bc8c1c"}
2026-05-16T15:38:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_153802_63bc8c1c"}
2026-05-16T15:38:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_153802_63bc8c1c"}
2026-05-16T15:38:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_153802_63bc8c1c"}
2026-05-16T15:38:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_153802_63bc8c1c"}
2026-05-16T15:38:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_153802_63bc8c1c"}
2026-05-16T15:38:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_153802_63bc8c1c"}
2026-05-16T15:38:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_153802_63bc8c1c"}
2026-05-16T15:38:04+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.692,"duration_milliseconds":692,"important":true,"run_id":"20260516_153802_63bc8c1c"}
2026-05-16T15:38:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_153802_63bc8c1c"}
2026-05-16T15:38:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.439,"exec_milliseconds":1439,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_153802_63bc8c1c"}
2026-05-16T15:39:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_153901_100b7a9f"}
2026-05-16T15:39:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_153901_100b7a9f"}
2026-05-16T15:39:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_153901_100b7a9f"}
2026-05-16T15:39:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_153901_100b7a9f"}
2026-05-16T15:39:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_153901_100b7a9f"}
2026-05-16T15:39:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_153901_100b7a9f"}
2026-05-16T15:39:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_153901_100b7a9f"}
2026-05-16T15:39:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_153901_100b7a9f"}
2026-05-16T15:39:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_153901_100b7a9f"}
2026-05-16T15:39:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.691,"duration_milliseconds":691,"important":true,"run_id":"20260516_153901_100b7a9f"}
2026-05-16T15:39:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_153901_100b7a9f"}
2026-05-16T15:39:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.421,"exec_milliseconds":1421,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_153901_100b7a9f"}
2026-05-16T15:40:06+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_154006_17b4fe9f"}
2026-05-16T15:40:07+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_154006_17b4fe9f"}
2026-05-16T15:40:07+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_154006_17b4fe9f"}
2026-05-16T15:40:07+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_154006_17b4fe9f"}
2026-05-16T15:40:07+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_154006_17b4fe9f"}
2026-05-16T15:40:07+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_154006_17b4fe9f"}
2026-05-16T15:40:07+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_154006_17b4fe9f"}
2026-05-16T15:40:07+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_154006_17b4fe9f"}
2026-05-16T15:40:08+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_154006_17b4fe9f"}
2026-05-16T15:40:08+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.685,"duration_milliseconds":685,"important":true,"run_id":"20260516_154006_17b4fe9f"}
2026-05-16T15:40:08+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_154006_17b4fe9f"}
2026-05-16T15:40:08+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.429,"exec_milliseconds":1429,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_154006_17b4fe9f"}
2026-05-16T15:41:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_154101_8537d3c9"}
2026-05-16T15:41:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_154101_8537d3c9"}
2026-05-16T15:41:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_154101_8537d3c9"}
2026-05-16T15:41:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_154101_8537d3c9"}
2026-05-16T15:41:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_154101_8537d3c9"}
2026-05-16T15:41:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_154101_8537d3c9"}
2026-05-16T15:41:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_154101_8537d3c9"}
2026-05-16T15:41:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_154101_8537d3c9"}
2026-05-16T15:41:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_154101_8537d3c9"}
2026-05-16T15:41:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.686,"duration_milliseconds":686,"important":true,"run_id":"20260516_154101_8537d3c9"}
2026-05-16T15:41:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_154101_8537d3c9"}
2026-05-16T15:41:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.43,"exec_milliseconds":1430,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_154101_8537d3c9"}
2026-05-16T15:42:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_154202_928ddd7a"}
2026-05-16T15:42:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_154202_928ddd7a"}
2026-05-16T15:42:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_154202_928ddd7a"}
2026-05-16T15:42:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_154202_928ddd7a"}
2026-05-16T15:42:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_154202_928ddd7a"}
2026-05-16T15:42:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_154202_928ddd7a"}
2026-05-16T15:42:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_154202_928ddd7a"}
2026-05-16T15:42:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_154202_928ddd7a"}
2026-05-16T15:42:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_154202_928ddd7a"}
2026-05-16T15:42:04+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.691,"duration_milliseconds":691,"important":true,"run_id":"20260516_154202_928ddd7a"}
2026-05-16T15:42:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_154202_928ddd7a"}
2026-05-16T15:42:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.471,"exec_milliseconds":1471,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_154202_928ddd7a"}
2026-05-16T15:43:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_154301_edc7605c"}
2026-05-16T15:43:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_154301_edc7605c"}
2026-05-16T15:43:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_154301_edc7605c"}
2026-05-16T15:43:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_154301_edc7605c"}
2026-05-16T15:43:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_154301_edc7605c"}
2026-05-16T15:43:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_154301_edc7605c"}
2026-05-16T15:43:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_154301_edc7605c"}
2026-05-16T15:43:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_154301_edc7605c"}
2026-05-16T15:43:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_154301_edc7605c"}
2026-05-16T15:43:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.702,"duration_milliseconds":702,"important":true,"run_id":"20260516_154301_edc7605c"}
2026-05-16T15:43:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_154301_edc7605c"}
2026-05-16T15:43:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.465,"exec_milliseconds":1465,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_154301_edc7605c"}
2026-05-16T15:44:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_154402_d343d574"}
2026-05-16T15:44:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_154402_d343d574"}
2026-05-16T15:44:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_154402_d343d574"}
2026-05-16T15:44:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_154402_d343d574"}
2026-05-16T15:44:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_154402_d343d574"}
2026-05-16T15:44:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_154402_d343d574"}
2026-05-16T15:44:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_154402_d343d574"}
2026-05-16T15:44:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_154402_d343d574"}
2026-05-16T15:44:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_154402_d343d574"}
2026-05-16T15:44:04+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.689,"duration_milliseconds":689,"important":true,"run_id":"20260516_154402_d343d574"}
2026-05-16T15:44:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_154402_d343d574"}
2026-05-16T15:44:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.429,"exec_milliseconds":1429,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_154402_d343d574"}
2026-05-16T15:45:07+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_154506_40dcd858"}
2026-05-16T15:45:07+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_154506_40dcd858"}
2026-05-16T15:45:07+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_154506_40dcd858"}
2026-05-16T15:45:07+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_154506_40dcd858"}
2026-05-16T15:45:07+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_154506_40dcd858"}
2026-05-16T15:45:07+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_154506_40dcd858"}
2026-05-16T15:45:07+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_154506_40dcd858"}
2026-05-16T15:45:07+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_154506_40dcd858"}
2026-05-16T15:45:08+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_154506_40dcd858"}
2026-05-16T15:45:08+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.679,"duration_milliseconds":679,"important":true,"run_id":"20260516_154506_40dcd858"}
2026-05-16T15:45:08+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_154506_40dcd858"}
2026-05-16T15:45:08+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.404,"exec_milliseconds":1404,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_154506_40dcd858"}
2026-05-16T15:46:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_154602_3166b907"}
2026-05-16T15:46:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_154602_3166b907"}
2026-05-16T15:46:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_154602_3166b907"}
2026-05-16T15:46:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_154602_3166b907"}
2026-05-16T15:46:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_154602_3166b907"}
2026-05-16T15:46:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_154602_3166b907"}
2026-05-16T15:46:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_154602_3166b907"}
2026-05-16T15:46:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_154602_3166b907"}
2026-05-16T15:46:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_154602_3166b907"}
2026-05-16T15:46:04+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.68,"duration_milliseconds":680,"important":true,"run_id":"20260516_154602_3166b907"}
2026-05-16T15:46:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_154602_3166b907"}
2026-05-16T15:46:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.436,"exec_milliseconds":1436,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_154602_3166b907"}
2026-05-16T15:47:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_154701_3633c7a4"}
2026-05-16T15:47:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_154701_3633c7a4"}
2026-05-16T15:47:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_154701_3633c7a4"}
2026-05-16T15:47:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_154701_3633c7a4"}
2026-05-16T15:47:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_154701_3633c7a4"}
2026-05-16T15:47:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_154701_3633c7a4"}
2026-05-16T15:47:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_154701_3633c7a4"}
2026-05-16T15:47:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_154701_3633c7a4"}
2026-05-16T15:47:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_154701_3633c7a4"}
2026-05-16T15:47:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.686,"duration_milliseconds":686,"important":true,"run_id":"20260516_154701_3633c7a4"}
2026-05-16T15:47:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_154701_3633c7a4"}
2026-05-16T15:47:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.47,"exec_milliseconds":1470,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_154701_3633c7a4"}
2026-05-16T15:48:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_154802_df91528c"}
2026-05-16T15:48:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_154802_df91528c"}
2026-05-16T15:48:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_154802_df91528c"}
2026-05-16T15:48:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_154802_df91528c"}
2026-05-16T15:48:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_154802_df91528c"}
2026-05-16T15:48:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_154802_df91528c"}
2026-05-16T15:48:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_154802_df91528c"}
2026-05-16T15:48:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_154802_df91528c"}
2026-05-16T15:48:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_154802_df91528c"}
2026-05-16T15:48:04+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.691,"duration_milliseconds":691,"important":true,"run_id":"20260516_154802_df91528c"}
2026-05-16T15:48:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_154802_df91528c"}
2026-05-16T15:48:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.448,"exec_milliseconds":1448,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_154802_df91528c"}
2026-05-16T15:49:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_154902_b4667049"}
2026-05-16T15:49:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_154902_b4667049"}
2026-05-16T15:49:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_154902_b4667049"}
2026-05-16T15:49:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_154902_b4667049"}
2026-05-16T15:49:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_154902_b4667049"}
2026-05-16T15:49:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_154902_b4667049"}
2026-05-16T15:49:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_154902_b4667049"}
2026-05-16T15:49:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_154902_b4667049"}
2026-05-16T15:49:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_154902_b4667049"}
2026-05-16T15:49:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.689,"duration_milliseconds":689,"important":true,"run_id":"20260516_154902_b4667049"}
2026-05-16T15:49:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_154902_b4667049"}
2026-05-16T15:49:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.378,"exec_milliseconds":1378,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_154902_b4667049"}
2026-05-16T15:50:06+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_155006_f7a9617a"}
2026-05-16T15:50:06+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_155006_f7a9617a"}
2026-05-16T15:50:06+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_155006_f7a9617a"}
2026-05-16T15:50:06+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_155006_f7a9617a"}
2026-05-16T15:50:07+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_155006_f7a9617a"}
2026-05-16T15:50:07+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_155006_f7a9617a"}
2026-05-16T15:50:07+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_155006_f7a9617a"}
2026-05-16T15:50:07+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_155006_f7a9617a"}
2026-05-16T15:50:07+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_155006_f7a9617a"}
2026-05-16T15:50:07+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.688,"duration_milliseconds":688,"important":true,"run_id":"20260516_155006_f7a9617a"}
2026-05-16T15:50:07+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_155006_f7a9617a"}
2026-05-16T15:50:07+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.428,"exec_milliseconds":1428,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_155006_f7a9617a"}
2026-05-16T15:51:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_155101_4384be5f"}
2026-05-16T15:51:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_155101_4384be5f"}
2026-05-16T15:51:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_155101_4384be5f"}
2026-05-16T15:51:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_155101_4384be5f"}
2026-05-16T15:51:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_155101_4384be5f"}
2026-05-16T15:51:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_155101_4384be5f"}
2026-05-16T15:51:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_155101_4384be5f"}
2026-05-16T15:51:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_155101_4384be5f"}
2026-05-16T15:51:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_155101_4384be5f"}
2026-05-16T15:51:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.689,"duration_milliseconds":689,"important":true,"run_id":"20260516_155101_4384be5f"}
2026-05-16T15:51:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_155101_4384be5f"}
2026-05-16T15:51:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.459,"exec_milliseconds":1459,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_155101_4384be5f"}
2026-05-16T15:52:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_155202_93369850"}
2026-05-16T15:52:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_155202_93369850"}
2026-05-16T15:52:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_155202_93369850"}
2026-05-16T15:52:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_155202_93369850"}
2026-05-16T15:52:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_155202_93369850"}
2026-05-16T15:52:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_155202_93369850"}
2026-05-16T15:52:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_155202_93369850"}
2026-05-16T15:52:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_155202_93369850"}
2026-05-16T15:52:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_155202_93369850"}
2026-05-16T15:52:04+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.713,"duration_milliseconds":713,"important":true,"run_id":"20260516_155202_93369850"}
2026-05-16T15:52:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_155202_93369850"}
2026-05-16T15:52:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.456,"exec_milliseconds":1456,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_155202_93369850"}
2026-05-16T15:53:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_155301_c345df37"}
2026-05-16T15:53:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_155301_c345df37"}
2026-05-16T15:53:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_155301_c345df37"}
2026-05-16T15:53:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_155301_c345df37"}
2026-05-16T15:53:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_155301_c345df37"}
2026-05-16T15:53:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_155301_c345df37"}
2026-05-16T15:53:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_155301_c345df37"}
2026-05-16T15:53:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_155301_c345df37"}
2026-05-16T15:53:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_155301_c345df37"}
2026-05-16T15:53:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.692,"duration_milliseconds":692,"important":true,"run_id":"20260516_155301_c345df37"}
2026-05-16T15:53:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_155301_c345df37"}
2026-05-16T15:53:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.425,"exec_milliseconds":1425,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_155301_c345df37"}
2026-05-16T15:54:03+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_155403_3c34f22d"}
2026-05-16T15:54:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_155403_3c34f22d"}
2026-05-16T15:54:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_155403_3c34f22d"}
2026-05-16T15:54:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_155403_3c34f22d"}
2026-05-16T15:54:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_155403_3c34f22d"}
2026-05-16T15:54:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_155403_3c34f22d"}
2026-05-16T15:54:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_155403_3c34f22d"}
2026-05-16T15:54:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_155403_3c34f22d"}
2026-05-16T15:54:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_155403_3c34f22d"}
2026-05-16T15:54:04+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.675,"duration_milliseconds":675,"important":true,"run_id":"20260516_155403_3c34f22d"}
2026-05-16T15:54:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_155403_3c34f22d"}
2026-05-16T15:54:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.428,"exec_milliseconds":1428,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_155403_3c34f22d"}
2026-05-16T15:55:04+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_155504_2d104ec9"}
2026-05-16T15:55:04+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_155504_2d104ec9"}
2026-05-16T15:55:04+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_155504_2d104ec9"}
2026-05-16T15:55:04+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_155504_2d104ec9"}
2026-05-16T15:55:05+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_155504_2d104ec9"}
2026-05-16T15:55:05+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_155504_2d104ec9"}
2026-05-16T15:55:05+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_155504_2d104ec9"}
2026-05-16T15:55:05+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_155504_2d104ec9"}
2026-05-16T15:55:05+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_155504_2d104ec9"}
2026-05-16T15:55:05+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.678,"duration_milliseconds":678,"important":true,"run_id":"20260516_155504_2d104ec9"}
2026-05-16T15:55:05+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_155504_2d104ec9"}
2026-05-16T15:55:05+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.41,"exec_milliseconds":1410,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_155504_2d104ec9"}
2026-05-16T15:56:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_155602_2bb760be"}
2026-05-16T15:56:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_155602_2bb760be"}
2026-05-16T15:56:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_155602_2bb760be"}
2026-05-16T15:56:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_155602_2bb760be"}
2026-05-16T15:56:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_155602_2bb760be"}
2026-05-16T15:56:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_155602_2bb760be"}
2026-05-16T15:56:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_155602_2bb760be"}
2026-05-16T15:56:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_155602_2bb760be"}
2026-05-16T15:56:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_155602_2bb760be"}
2026-05-16T15:56:04+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.682,"duration_milliseconds":682,"important":true,"run_id":"20260516_155602_2bb760be"}
2026-05-16T15:56:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_155602_2bb760be"}
2026-05-16T15:56:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.448,"exec_milliseconds":1448,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_155602_2bb760be"}
2026-05-16T15:57:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_155701_a14c4816"}
2026-05-16T15:57:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_155701_a14c4816"}
2026-05-16T15:57:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_155701_a14c4816"}
2026-05-16T15:57:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_155701_a14c4816"}
2026-05-16T15:57:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_155701_a14c4816"}
2026-05-16T15:57:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_155701_a14c4816"}
2026-05-16T15:57:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_155701_a14c4816"}
2026-05-16T15:57:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_155701_a14c4816"}
2026-05-16T15:57:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_155701_a14c4816"}
2026-05-16T15:57:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.678,"duration_milliseconds":678,"important":true,"run_id":"20260516_155701_a14c4816"}
2026-05-16T15:57:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_155701_a14c4816"}
2026-05-16T15:57:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.417,"exec_milliseconds":1417,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_155701_a14c4816"}
2026-05-16T15:58:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_155802_734b3325"}
2026-05-16T15:58:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_155802_734b3325"}
2026-05-16T15:58:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_155802_734b3325"}
2026-05-16T15:58:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_155802_734b3325"}
2026-05-16T15:58:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_155802_734b3325"}
2026-05-16T15:58:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_155802_734b3325"}
2026-05-16T15:58:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_155802_734b3325"}
2026-05-16T15:58:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_155802_734b3325"}
2026-05-16T15:58:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_155802_734b3325"}
2026-05-16T15:58:04+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.687,"duration_milliseconds":687,"important":true,"run_id":"20260516_155802_734b3325"}
2026-05-16T15:58:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_155802_734b3325"}
2026-05-16T15:58:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.437,"exec_milliseconds":1437,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_155802_734b3325"}
2026-05-16T15:59:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_155901_f037897a"}
2026-05-16T15:59:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_155901_f037897a"}
2026-05-16T15:59:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_155901_f037897a"}
2026-05-16T15:59:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_155901_f037897a"}
2026-05-16T15:59:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_155901_f037897a"}
2026-05-16T15:59:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_155901_f037897a"}
2026-05-16T15:59:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_155901_f037897a"}
2026-05-16T15:59:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_155901_f037897a"}
2026-05-16T15:59:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_155901_f037897a"}
2026-05-16T15:59:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.695,"duration_milliseconds":695,"important":true,"run_id":"20260516_155901_f037897a"}
2026-05-16T15:59:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_155901_f037897a"}
2026-05-16T15:59:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.473,"exec_milliseconds":1473,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_155901_f037897a"}
2026-05-16T16:00:17+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_160017_47b64ee0"}
2026-05-16T16:00:17+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_160017_47b64ee0"}
2026-05-16T16:00:17+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_160017_47b64ee0"}
2026-05-16T16:00:17+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_160017_47b64ee0"}
2026-05-16T16:00:18+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_160017_47b64ee0"}
2026-05-16T16:00:18+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_160017_47b64ee0"}
2026-05-16T16:00:18+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_160017_47b64ee0"}
2026-05-16T16:00:18+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_160017_47b64ee0"}
2026-05-16T16:00:18+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_160017_47b64ee0"}
2026-05-16T16:00:18+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.684,"duration_milliseconds":684,"important":true,"run_id":"20260516_160017_47b64ee0"}
2026-05-16T16:00:18+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_160017_47b64ee0"}
2026-05-16T16:00:18+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.448,"exec_milliseconds":1448,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_160017_47b64ee0"}
2026-05-16T16:01:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_160101_9736265a"}
2026-05-16T16:01:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_160101_9736265a"}
2026-05-16T16:01:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_160101_9736265a"}
2026-05-16T16:01:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_160101_9736265a"}
2026-05-16T16:01:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_160101_9736265a"}
2026-05-16T16:01:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_160101_9736265a"}
2026-05-16T16:01:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_160101_9736265a"}
2026-05-16T16:01:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_160101_9736265a"}
2026-05-16T16:01:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_160101_9736265a"}
2026-05-16T16:01:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.685,"duration_milliseconds":685,"important":true,"run_id":"20260516_160101_9736265a"}
2026-05-16T16:01:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_160101_9736265a"}
2026-05-16T16:01:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.452,"exec_milliseconds":1452,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_160101_9736265a"}
2026-05-16T16:02:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_160202_ff0730d5"}
2026-05-16T16:02:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_160202_ff0730d5"}
2026-05-16T16:02:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_160202_ff0730d5"}
2026-05-16T16:02:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_160202_ff0730d5"}
2026-05-16T16:02:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_160202_ff0730d5"}
2026-05-16T16:02:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_160202_ff0730d5"}
2026-05-16T16:02:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_160202_ff0730d5"}
2026-05-16T16:02:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_160202_ff0730d5"}
2026-05-16T16:02:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_160202_ff0730d5"}
2026-05-16T16:02:04+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.686,"duration_milliseconds":686,"important":true,"run_id":"20260516_160202_ff0730d5"}
2026-05-16T16:02:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_160202_ff0730d5"}
2026-05-16T16:02:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.434,"exec_milliseconds":1434,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_160202_ff0730d5"}
2026-05-16T16:03:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_160301_b47e20e5"}
2026-05-16T16:03:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_160301_b47e20e5"}
2026-05-16T16:03:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_160301_b47e20e5"}
2026-05-16T16:03:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_160301_b47e20e5"}
2026-05-16T16:03:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_160301_b47e20e5"}
2026-05-16T16:03:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_160301_b47e20e5"}
2026-05-16T16:03:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_160301_b47e20e5"}
2026-05-16T16:03:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_160301_b47e20e5"}
2026-05-16T16:03:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_160301_b47e20e5"}
2026-05-16T16:03:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.688,"duration_milliseconds":688,"important":true,"run_id":"20260516_160301_b47e20e5"}
2026-05-16T16:03:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_160301_b47e20e5"}
2026-05-16T16:03:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.453,"exec_milliseconds":1453,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_160301_b47e20e5"}
2026-05-16T16:04:03+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_160402_601880b1"}
2026-05-16T16:04:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_160402_601880b1"}
2026-05-16T16:04:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_160402_601880b1"}
2026-05-16T16:04:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_160402_601880b1"}
2026-05-16T16:04:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_160402_601880b1"}
2026-05-16T16:04:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_160402_601880b1"}
2026-05-16T16:04:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_160402_601880b1"}
2026-05-16T16:04:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_160402_601880b1"}
2026-05-16T16:04:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_160402_601880b1"}
2026-05-16T16:04:04+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.684,"duration_milliseconds":684,"important":true,"run_id":"20260516_160402_601880b1"}
2026-05-16T16:04:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_160402_601880b1"}
2026-05-16T16:04:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.38,"exec_milliseconds":1380,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_160402_601880b1"}
2026-05-16T16:05:04+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_160503_f44f6afc"}
2026-05-16T16:05:04+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_160503_f44f6afc"}
2026-05-16T16:05:04+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_160503_f44f6afc"}
2026-05-16T16:05:04+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_160503_f44f6afc"}
2026-05-16T16:05:04+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_160503_f44f6afc"}
2026-05-16T16:05:04+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_160503_f44f6afc"}
2026-05-16T16:05:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_160503_f44f6afc"}
2026-05-16T16:05:04+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_160503_f44f6afc"}
2026-05-16T16:05:05+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_160503_f44f6afc"}
2026-05-16T16:05:05+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.68,"duration_milliseconds":680,"important":true,"run_id":"20260516_160503_f44f6afc"}
2026-05-16T16:05:05+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_160503_f44f6afc"}
2026-05-16T16:05:05+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.418,"exec_milliseconds":1418,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_160503_f44f6afc"}
2026-05-16T16:06:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_160602_41ec8382"}
2026-05-16T16:06:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_160602_41ec8382"}
2026-05-16T16:06:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_160602_41ec8382"}
2026-05-16T16:06:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_160602_41ec8382"}
2026-05-16T16:06:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_160602_41ec8382"}
2026-05-16T16:06:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_160602_41ec8382"}
2026-05-16T16:06:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_160602_41ec8382"}
2026-05-16T16:06:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_160602_41ec8382"}
2026-05-16T16:06:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_160602_41ec8382"}
2026-05-16T16:06:04+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.681,"duration_milliseconds":681,"important":true,"run_id":"20260516_160602_41ec8382"}
2026-05-16T16:06:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_160602_41ec8382"}
2026-05-16T16:06:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.448,"exec_milliseconds":1448,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_160602_41ec8382"}
2026-05-16T16:07:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_160701_1d7efbc1"}
2026-05-16T16:07:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_160701_1d7efbc1"}
2026-05-16T16:07:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_160701_1d7efbc1"}
2026-05-16T16:07:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_160701_1d7efbc1"}
2026-05-16T16:07:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_160701_1d7efbc1"}
2026-05-16T16:07:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_160701_1d7efbc1"}
2026-05-16T16:07:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_160701_1d7efbc1"}
2026-05-16T16:07:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_160701_1d7efbc1"}
2026-05-16T16:07:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_160701_1d7efbc1"}
2026-05-16T16:07:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.681,"duration_milliseconds":681,"important":true,"run_id":"20260516_160701_1d7efbc1"}
2026-05-16T16:07:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_160701_1d7efbc1"}
2026-05-16T16:07:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.417,"exec_milliseconds":1417,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_160701_1d7efbc1"}
2026-05-16T16:08:03+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_160803_a059ed2a"}
2026-05-16T16:08:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_160803_a059ed2a"}
2026-05-16T16:08:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_160803_a059ed2a"}
2026-05-16T16:08:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_160803_a059ed2a"}
2026-05-16T16:08:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_160803_a059ed2a"}
2026-05-16T16:08:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_160803_a059ed2a"}
2026-05-16T16:08:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_160803_a059ed2a"}
2026-05-16T16:08:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_160803_a059ed2a"}
2026-05-16T16:08:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_160803_a059ed2a"}
2026-05-16T16:08:04+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.683,"duration_milliseconds":683,"important":true,"run_id":"20260516_160803_a059ed2a"}
2026-05-16T16:08:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_160803_a059ed2a"}
2026-05-16T16:08:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.394,"exec_milliseconds":1394,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_160803_a059ed2a"}
2026-05-16T16:09:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_160902_313adac4"}
2026-05-16T16:09:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_160902_313adac4"}
2026-05-16T16:09:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_160902_313adac4"}
2026-05-16T16:09:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_160902_313adac4"}
2026-05-16T16:09:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_160902_313adac4"}
2026-05-16T16:09:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_160902_313adac4"}
2026-05-16T16:09:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_160902_313adac4"}
2026-05-16T16:09:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_160902_313adac4"}
2026-05-16T16:09:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_160902_313adac4"}
2026-05-16T16:09:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.76,"duration_milliseconds":760,"important":true,"run_id":"20260516_160902_313adac4"}
2026-05-16T16:09:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_160902_313adac4"}
2026-05-16T16:09:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.497,"exec_milliseconds":1497,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_160902_313adac4"}
2026-05-16T16:10:07+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_161007_de529458"}
2026-05-16T16:10:07+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_161007_de529458"}
2026-05-16T16:10:07+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_161007_de529458"}
2026-05-16T16:10:07+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_161007_de529458"}
2026-05-16T16:10:07+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_161007_de529458"}
2026-05-16T16:10:07+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_161007_de529458"}
2026-05-16T16:10:07+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_161007_de529458"}
2026-05-16T16:10:07+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_161007_de529458"}
2026-05-16T16:10:08+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_161007_de529458"}
2026-05-16T16:10:08+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.691,"duration_milliseconds":691,"important":true,"run_id":"20260516_161007_de529458"}
2026-05-16T16:10:08+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_161007_de529458"}
2026-05-16T16:10:08+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.404,"exec_milliseconds":1404,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_161007_de529458"}
2026-05-16T16:11:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_161101_801684d5"}
2026-05-16T16:11:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_161101_801684d5"}
2026-05-16T16:11:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_161101_801684d5"}
2026-05-16T16:11:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_161101_801684d5"}
2026-05-16T16:11:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_161101_801684d5"}
2026-05-16T16:11:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_161101_801684d5"}
2026-05-16T16:11:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_161101_801684d5"}
2026-05-16T16:11:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_161101_801684d5"}
2026-05-16T16:11:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_161101_801684d5"}
2026-05-16T16:11:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.678,"duration_milliseconds":678,"important":true,"run_id":"20260516_161101_801684d5"}
2026-05-16T16:11:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_161101_801684d5"}
2026-05-16T16:11:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.395,"exec_milliseconds":1395,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_161101_801684d5"}
2026-05-16T16:12:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_161202_e2d957ff"}
2026-05-16T16:12:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_161202_e2d957ff"}
2026-05-16T16:12:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_161202_e2d957ff"}
2026-05-16T16:12:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_161202_e2d957ff"}
2026-05-16T16:12:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_161202_e2d957ff"}
2026-05-16T16:12:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_161202_e2d957ff"}
2026-05-16T16:12:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_161202_e2d957ff"}
2026-05-16T16:12:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_161202_e2d957ff"}
2026-05-16T16:12:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_161202_e2d957ff"}
2026-05-16T16:12:04+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.681,"duration_milliseconds":681,"important":true,"run_id":"20260516_161202_e2d957ff"}
2026-05-16T16:12:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_161202_e2d957ff"}
2026-05-16T16:12:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.464,"exec_milliseconds":1464,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_161202_e2d957ff"}
2026-05-16T16:13:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_161301_5667b16f"}
2026-05-16T16:13:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_161301_5667b16f"}
2026-05-16T16:13:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_161301_5667b16f"}
2026-05-16T16:13:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_161301_5667b16f"}
2026-05-16T16:13:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_161301_5667b16f"}
2026-05-16T16:13:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_161301_5667b16f"}
2026-05-16T16:13:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_161301_5667b16f"}
2026-05-16T16:13:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_161301_5667b16f"}
2026-05-16T16:13:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_161301_5667b16f"}
2026-05-16T16:13:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.685,"duration_milliseconds":685,"important":true,"run_id":"20260516_161301_5667b16f"}
2026-05-16T16:13:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_161301_5667b16f"}
2026-05-16T16:13:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.415,"exec_milliseconds":1415,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_161301_5667b16f"}
2026-05-16T16:14:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_161402_90a9e674"}
2026-05-16T16:14:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_161402_90a9e674"}
2026-05-16T16:14:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_161402_90a9e674"}
2026-05-16T16:14:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_161402_90a9e674"}
2026-05-16T16:14:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_161402_90a9e674"}
2026-05-16T16:14:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_161402_90a9e674"}
2026-05-16T16:14:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_161402_90a9e674"}
2026-05-16T16:14:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_161402_90a9e674"}
2026-05-16T16:14:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_161402_90a9e674"}
2026-05-16T16:14:04+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.689,"duration_milliseconds":689,"important":true,"run_id":"20260516_161402_90a9e674"}
2026-05-16T16:14:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_161402_90a9e674"}
2026-05-16T16:14:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.424,"exec_milliseconds":1424,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_161402_90a9e674"}
2026-05-16T16:15:07+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_161507_8f8bc483"}
2026-05-16T16:15:07+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_161507_8f8bc483"}
2026-05-16T16:15:07+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_161507_8f8bc483"}
2026-05-16T16:15:07+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_161507_8f8bc483"}
2026-05-16T16:15:07+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_161507_8f8bc483"}
2026-05-16T16:15:07+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_161507_8f8bc483"}
2026-05-16T16:15:07+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_161507_8f8bc483"}
2026-05-16T16:15:07+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_161507_8f8bc483"}
2026-05-16T16:15:08+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_161507_8f8bc483"}
2026-05-16T16:15:08+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.685,"duration_milliseconds":685,"important":true,"run_id":"20260516_161507_8f8bc483"}
2026-05-16T16:15:08+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_161507_8f8bc483"}
2026-05-16T16:15:08+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.432,"exec_milliseconds":1432,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_161507_8f8bc483"}
2026-05-16T16:16:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_161602_e7325ca2"}
2026-05-16T16:16:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_161602_e7325ca2"}
2026-05-16T16:16:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_161602_e7325ca2"}
2026-05-16T16:16:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_161602_e7325ca2"}
2026-05-16T16:16:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_161602_e7325ca2"}
2026-05-16T16:16:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_161602_e7325ca2"}
2026-05-16T16:16:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_161602_e7325ca2"}
2026-05-16T16:16:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_161602_e7325ca2"}
2026-05-16T16:16:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_161602_e7325ca2"}
2026-05-16T16:16:04+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.694,"duration_milliseconds":694,"important":true,"run_id":"20260516_161602_e7325ca2"}
2026-05-16T16:16:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_161602_e7325ca2"}
2026-05-16T16:16:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.485,"exec_milliseconds":1485,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_161602_e7325ca2"}
2026-05-16T16:17:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_161701_789e4738"}
2026-05-16T16:17:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_161701_789e4738"}
2026-05-16T16:17:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_161701_789e4738"}
2026-05-16T16:17:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_161701_789e4738"}
2026-05-16T16:17:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_161701_789e4738"}
2026-05-16T16:17:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_161701_789e4738"}
2026-05-16T16:17:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_161701_789e4738"}
2026-05-16T16:17:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_161701_789e4738"}
2026-05-16T16:17:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_161701_789e4738"}
2026-05-16T16:17:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.686,"duration_milliseconds":686,"important":true,"run_id":"20260516_161701_789e4738"}
2026-05-16T16:17:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_161701_789e4738"}
2026-05-16T16:17:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.461,"exec_milliseconds":1461,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_161701_789e4738"}
2026-05-16T16:18:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_161802_f1434e62"}
2026-05-16T16:18:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_161802_f1434e62"}
2026-05-16T16:18:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_161802_f1434e62"}
2026-05-16T16:18:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_161802_f1434e62"}
2026-05-16T16:18:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_161802_f1434e62"}
2026-05-16T16:18:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_161802_f1434e62"}
2026-05-16T16:18:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_161802_f1434e62"}
2026-05-16T16:18:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_161802_f1434e62"}
2026-05-16T16:18:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_161802_f1434e62"}
2026-05-16T16:18:04+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.687,"duration_milliseconds":687,"important":true,"run_id":"20260516_161802_f1434e62"}
2026-05-16T16:18:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_161802_f1434e62"}
2026-05-16T16:18:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.404,"exec_milliseconds":1404,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_161802_f1434e62"}
2026-05-16T16:19:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_161901_f4706bee"}
2026-05-16T16:19:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_161901_f4706bee"}
2026-05-16T16:19:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_161901_f4706bee"}
2026-05-16T16:19:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_161901_f4706bee"}
2026-05-16T16:19:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_161901_f4706bee"}
2026-05-16T16:19:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_161901_f4706bee"}
2026-05-16T16:19:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_161901_f4706bee"}
2026-05-16T16:19:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_161901_f4706bee"}
2026-05-16T16:19:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_161901_f4706bee"}
2026-05-16T16:19:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.685,"duration_milliseconds":685,"important":true,"run_id":"20260516_161901_f4706bee"}
2026-05-16T16:19:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_161901_f4706bee"}
2026-05-16T16:19:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.405,"exec_milliseconds":1405,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_161901_f4706bee"}
2026-05-16T16:20:06+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_162006_7fcbf769"}
2026-05-16T16:20:07+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_162006_7fcbf769"}
2026-05-16T16:20:07+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_162006_7fcbf769"}
2026-05-16T16:20:07+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_162006_7fcbf769"}
2026-05-16T16:20:07+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_162006_7fcbf769"}
2026-05-16T16:20:07+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_162006_7fcbf769"}
2026-05-16T16:20:07+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_162006_7fcbf769"}
2026-05-16T16:20:07+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_162006_7fcbf769"}
2026-05-16T16:20:08+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_162006_7fcbf769"}
2026-05-16T16:20:08+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.689,"duration_milliseconds":689,"important":true,"run_id":"20260516_162006_7fcbf769"}
2026-05-16T16:20:08+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_162006_7fcbf769"}
2026-05-16T16:20:08+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.438,"exec_milliseconds":1438,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_162006_7fcbf769"}
2026-05-16T16:21:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_162101_2eeb0a70"}
2026-05-16T16:21:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_162101_2eeb0a70"}
2026-05-16T16:21:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_162101_2eeb0a70"}
2026-05-16T16:21:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_162101_2eeb0a70"}
2026-05-16T16:21:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_162101_2eeb0a70"}
2026-05-16T16:21:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_162101_2eeb0a70"}
2026-05-16T16:21:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_162101_2eeb0a70"}
2026-05-16T16:21:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_162101_2eeb0a70"}
2026-05-16T16:21:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_162101_2eeb0a70"}
2026-05-16T16:21:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.702,"duration_milliseconds":702,"important":true,"run_id":"20260516_162101_2eeb0a70"}
2026-05-16T16:21:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_162101_2eeb0a70"}
2026-05-16T16:21:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.429,"exec_milliseconds":1429,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_162101_2eeb0a70"}
2026-05-16T16:22:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_162202_74f2c6ad"}
2026-05-16T16:22:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_162202_74f2c6ad"}
2026-05-16T16:22:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_162202_74f2c6ad"}
2026-05-16T16:22:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_162202_74f2c6ad"}
2026-05-16T16:22:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_162202_74f2c6ad"}
2026-05-16T16:22:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_162202_74f2c6ad"}
2026-05-16T16:22:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_162202_74f2c6ad"}
2026-05-16T16:22:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_162202_74f2c6ad"}
2026-05-16T16:22:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_162202_74f2c6ad"}
2026-05-16T16:22:04+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.677,"duration_milliseconds":677,"important":true,"run_id":"20260516_162202_74f2c6ad"}
2026-05-16T16:22:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_162202_74f2c6ad"}
2026-05-16T16:22:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.471,"exec_milliseconds":1471,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_162202_74f2c6ad"}
2026-05-16T16:23:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_162301_117065d2"}
2026-05-16T16:23:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_162301_117065d2"}
2026-05-16T16:23:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_162301_117065d2"}
2026-05-16T16:23:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_162301_117065d2"}
2026-05-16T16:23:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_162301_117065d2"}
2026-05-16T16:23:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_162301_117065d2"}
2026-05-16T16:23:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_162301_117065d2"}
2026-05-16T16:23:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_162301_117065d2"}
2026-05-16T16:23:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_162301_117065d2"}
2026-05-16T16:23:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.681,"duration_milliseconds":681,"important":true,"run_id":"20260516_162301_117065d2"}
2026-05-16T16:23:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_162301_117065d2"}
2026-05-16T16:23:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.43,"exec_milliseconds":1430,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_162301_117065d2"}
2026-05-16T16:24:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_162402_3e084ca5"}
2026-05-16T16:24:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_162402_3e084ca5"}
2026-05-16T16:24:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_162402_3e084ca5"}
2026-05-16T16:24:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_162402_3e084ca5"}
2026-05-16T16:24:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_162402_3e084ca5"}
2026-05-16T16:24:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_162402_3e084ca5"}
2026-05-16T16:24:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_162402_3e084ca5"}
2026-05-16T16:24:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_162402_3e084ca5"}
2026-05-16T16:24:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_162402_3e084ca5"}
2026-05-16T16:24:04+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.693,"duration_milliseconds":693,"important":true,"run_id":"20260516_162402_3e084ca5"}
2026-05-16T16:24:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_162402_3e084ca5"}
2026-05-16T16:24:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.382,"exec_milliseconds":1382,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_162402_3e084ca5"}
2026-05-16T16:25:04+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_162504_b6bedf28"}
2026-05-16T16:25:04+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_162504_b6bedf28"}
2026-05-16T16:25:04+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_162504_b6bedf28"}
2026-05-16T16:25:04+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_162504_b6bedf28"}
2026-05-16T16:25:04+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_162504_b6bedf28"}
2026-05-16T16:25:04+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_162504_b6bedf28"}
2026-05-16T16:25:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_162504_b6bedf28"}
2026-05-16T16:25:04+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_162504_b6bedf28"}
2026-05-16T16:25:05+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_162504_b6bedf28"}
2026-05-16T16:25:05+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.689,"duration_milliseconds":689,"important":true,"run_id":"20260516_162504_b6bedf28"}
2026-05-16T16:25:05+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_162504_b6bedf28"}
2026-05-16T16:25:05+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.438,"exec_milliseconds":1438,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_162504_b6bedf28"}
2026-05-16T16:26:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_162602_c9b4f326"}
2026-05-16T16:26:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_162602_c9b4f326"}
2026-05-16T16:26:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_162602_c9b4f326"}
2026-05-16T16:26:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_162602_c9b4f326"}
2026-05-16T16:26:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_162602_c9b4f326"}
2026-05-16T16:26:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_162602_c9b4f326"}
2026-05-16T16:26:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_162602_c9b4f326"}
2026-05-16T16:26:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_162602_c9b4f326"}
2026-05-16T16:26:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_162602_c9b4f326"}
2026-05-16T16:26:04+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.682,"duration_milliseconds":682,"important":true,"run_id":"20260516_162602_c9b4f326"}
2026-05-16T16:26:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_162602_c9b4f326"}
2026-05-16T16:26:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.401,"exec_milliseconds":1401,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_162602_c9b4f326"}
2026-05-16T16:27:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_162701_2f64c92e"}
2026-05-16T16:27:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_162701_2f64c92e"}
2026-05-16T16:27:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_162701_2f64c92e"}
2026-05-16T16:27:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_162701_2f64c92e"}
2026-05-16T16:27:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_162701_2f64c92e"}
2026-05-16T16:27:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_162701_2f64c92e"}
2026-05-16T16:27:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_162701_2f64c92e"}
2026-05-16T16:27:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_162701_2f64c92e"}
2026-05-16T16:27:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_162701_2f64c92e"}
2026-05-16T16:27:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.687,"duration_milliseconds":687,"important":true,"run_id":"20260516_162701_2f64c92e"}
2026-05-16T16:27:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_162701_2f64c92e"}
2026-05-16T16:27:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.433,"exec_milliseconds":1433,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_162701_2f64c92e"}
2026-05-16T16:28:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_162802_973191b6"}
2026-05-16T16:28:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_162802_973191b6"}
2026-05-16T16:28:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_162802_973191b6"}
2026-05-16T16:28:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_162802_973191b6"}
2026-05-16T16:28:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_162802_973191b6"}
2026-05-16T16:28:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_162802_973191b6"}
2026-05-16T16:28:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_162802_973191b6"}
2026-05-16T16:28:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_162802_973191b6"}
2026-05-16T16:28:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_162802_973191b6"}
2026-05-16T16:28:04+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.683,"duration_milliseconds":683,"important":true,"run_id":"20260516_162802_973191b6"}
2026-05-16T16:28:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_162802_973191b6"}
2026-05-16T16:28:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.439,"exec_milliseconds":1439,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_162802_973191b6"}
2026-05-16T16:29:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_162901_b33fef5f"}
2026-05-16T16:29:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_162901_b33fef5f"}
2026-05-16T16:29:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_162901_b33fef5f"}
2026-05-16T16:29:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_162901_b33fef5f"}
2026-05-16T16:29:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_162901_b33fef5f"}
2026-05-16T16:29:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_162901_b33fef5f"}
2026-05-16T16:29:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_162901_b33fef5f"}
2026-05-16T16:29:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_162901_b33fef5f"}
2026-05-16T16:29:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_162901_b33fef5f"}
2026-05-16T16:29:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.681,"duration_milliseconds":681,"important":true,"run_id":"20260516_162901_b33fef5f"}
2026-05-16T16:29:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":35642,"run_id":"20260516_162901_b33fef5f"}
2026-05-16T16:29:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.376,"exec_milliseconds":1376,"live_games":0,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":35642,"important":true,"run_id":"20260516_162901_b33fef5f"}
2026-05-16T16:30:12+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_163012_d21264f7"}
2026-05-16T16:30:12+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_163012_d21264f7"}
2026-05-16T16:30:12+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_163012_d21264f7"}
2026-05-16T16:30:12+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_163012_d21264f7"}
2026-05-16T16:30:13+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_163012_d21264f7"}
2026-05-16T16:30:13+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_163012_d21264f7"}
2026-05-16T16:30:13+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_163012_d21264f7"}
2026-05-16T16:30:13+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_163012_d21264f7"}
2026-05-16T16:30:13+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_163012_d21264f7"}
2026-05-16T16:30:13+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.688,"duration_milliseconds":688,"important":true,"run_id":"20260516_163012_d21264f7"}
2026-05-16T16:30:13+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_163012_d21264f7"}
2026-05-16T16:30:13+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.047,"duration_milliseconds":47,"important":true,"run_id":"20260516_163012_d21264f7"}
2026-05-16T16:30:13+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":38187,"run_id":"20260516_163012_d21264f7"}
2026-05-16T16:30:13+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.47,"exec_milliseconds":1470,"live_games":0,"fallback_games":2,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":38187,"important":true,"run_id":"20260516_163012_d21264f7"}
2026-05-16T16:31:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_163101_a8f03008"}
2026-05-16T16:31:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_163101_a8f03008"}
2026-05-16T16:31:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_163101_a8f03008"}
2026-05-16T16:31:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_163101_a8f03008"}
2026-05-16T16:31:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_163101_a8f03008"}
2026-05-16T16:31:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_163101_a8f03008"}
2026-05-16T16:31:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_163101_a8f03008"}
2026-05-16T16:31:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_163101_a8f03008"}
2026-05-16T16:31:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"--:--","run_id":"20260516_163101_a8f03008"}
2026-05-16T16:31:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.682,"duration_milliseconds":682,"important":true,"run_id":"20260516_163101_a8f03008"}
2026-05-16T16:31:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_163101_a8f03008"}
2026-05-16T16:31:03+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.045,"duration_milliseconds":45,"important":true,"run_id":"20260516_163101_a8f03008"}
2026-05-16T16:31:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":38187,"run_id":"20260516_163101_a8f03008"}
2026-05-16T16:31:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.479,"exec_milliseconds":1479,"live_games":0,"fallback_games":2,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":38187,"important":true,"run_id":"20260516_163101_a8f03008"}
2026-05-16T16:32:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_163202_8626aee8"}
2026-05-16T16:32:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_163202_8626aee8"}
2026-05-16T16:32:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_163202_8626aee8"}
2026-05-16T16:32:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_163202_8626aee8"}
2026-05-16T16:32:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_163202_8626aee8"}
2026-05-16T16:32:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_163202_8626aee8"}
2026-05-16T16:32:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_163202_8626aee8"}
2026-05-16T16:32:04+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_163202_8626aee8"}
2026-05-16T16:32:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":5091,"mtime":"2026-05-16T16:31:28+02:00","run_id":"20260516_163202_8626aee8"}
2026-05-16T16:32:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_163202_8626aee8"}
2026-05-16T16:32:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":4676,"mtime":"2026-05-16T16:31:27+02:00","run_id":"20260516_163202_8626aee8"}
2026-05-16T16:32:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_163202_8626aee8"}
2026-05-16T16:32:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_163202_8626aee8"}
2026-05-16T16:32:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.957,"duration_milliseconds":957,"important":true,"run_id":"20260516_163202_8626aee8"}
2026-05-16T16:32:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_163202_8626aee8"}
2026-05-16T16:32:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_163202_8626aee8"}
2026-05-16T16:32:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_163202_8626aee8"}
2026-05-16T16:32:04+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.048,"duration_milliseconds":48,"important":true,"run_id":"20260516_163202_8626aee8"}
2026-05-16T16:32:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":87761,"run_id":"20260516_163202_8626aee8"}
2026-05-16T16:32:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.796,"exec_milliseconds":1796,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":87761,"important":true,"run_id":"20260516_163202_8626aee8"}
2026-05-16T16:33:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_163301_02eeb84b"}
2026-05-16T16:33:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_163301_02eeb84b"}
2026-05-16T16:33:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_163301_02eeb84b"}
2026-05-16T16:33:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_163301_02eeb84b"}
2026-05-16T16:33:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_163301_02eeb84b"}
2026-05-16T16:33:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_163301_02eeb84b"}
2026-05-16T16:33:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_163301_02eeb84b"}
2026-05-16T16:33:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_163301_02eeb84b"}
2026-05-16T16:33:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":5091,"mtime":"2026-05-16T16:31:28+02:00","run_id":"20260516_163301_02eeb84b"}
2026-05-16T16:33:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_163301_02eeb84b"}
2026-05-16T16:33:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":4676,"mtime":"2026-05-16T16:31:27+02:00","run_id":"20260516_163301_02eeb84b"}
2026-05-16T16:33:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_163301_02eeb84b"}
2026-05-16T16:33:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_163301_02eeb84b"}
2026-05-16T16:33:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":1.008,"duration_milliseconds":1008,"important":true,"run_id":"20260516_163301_02eeb84b"}
2026-05-16T16:33:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_163301_02eeb84b"}
2026-05-16T16:33:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_163301_02eeb84b"}
2026-05-16T16:33:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_163301_02eeb84b"}
2026-05-16T16:33:03+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.05,"duration_milliseconds":50,"important":true,"run_id":"20260516_163301_02eeb84b"}
2026-05-16T16:33:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":87860,"run_id":"20260516_163301_02eeb84b"}
2026-05-16T16:33:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.915,"exec_milliseconds":1915,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":87860,"important":true,"run_id":"20260516_163301_02eeb84b"}
2026-05-16T16:34:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_163402_5362954c"}
2026-05-16T16:34:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_163402_5362954c"}
2026-05-16T16:34:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_163402_5362954c"}
2026-05-16T16:34:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_163402_5362954c"}
2026-05-16T16:34:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_163402_5362954c"}
2026-05-16T16:34:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_163402_5362954c"}
2026-05-16T16:34:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_163402_5362954c"}
2026-05-16T16:34:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_163402_5362954c"}
2026-05-16T16:34:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":5091,"mtime":"2026-05-16T16:31:28+02:00","run_id":"20260516_163402_5362954c"}
2026-05-16T16:34:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_163402_5362954c"}
2026-05-16T16:34:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":4676,"mtime":"2026-05-16T16:31:27+02:00","run_id":"20260516_163402_5362954c"}
2026-05-16T16:34:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_163402_5362954c"}
2026-05-16T16:34:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_163402_5362954c"}
2026-05-16T16:34:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.946,"duration_milliseconds":946,"important":true,"run_id":"20260516_163402_5362954c"}
2026-05-16T16:34:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_163402_5362954c"}
2026-05-16T16:34:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_163402_5362954c"}
2026-05-16T16:34:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_163402_5362954c"}
2026-05-16T16:34:04+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.047,"duration_milliseconds":47,"important":true,"run_id":"20260516_163402_5362954c"}
2026-05-16T16:34:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":87861,"run_id":"20260516_163402_5362954c"}
2026-05-16T16:34:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.84,"exec_milliseconds":1840,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":87861,"important":true,"run_id":"20260516_163402_5362954c"}
2026-05-16T16:35:04+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_163503_b5250b9e"}
2026-05-16T16:35:04+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_163503_b5250b9e"}
2026-05-16T16:35:04+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_163503_b5250b9e"}
2026-05-16T16:35:04+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_163503_b5250b9e"}
2026-05-16T16:35:04+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_163503_b5250b9e"}
2026-05-16T16:35:04+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_163503_b5250b9e"}
2026-05-16T16:35:04+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_163503_b5250b9e"}
2026-05-16T16:35:05+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_163503_b5250b9e"}
2026-05-16T16:35:05+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":5091,"mtime":"2026-05-16T16:31:28+02:00","run_id":"20260516_163503_b5250b9e"}
2026-05-16T16:35:05+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_163503_b5250b9e"}
2026-05-16T16:35:05+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":4676,"mtime":"2026-05-16T16:31:27+02:00","run_id":"20260516_163503_b5250b9e"}
2026-05-16T16:35:05+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_163503_b5250b9e"}
2026-05-16T16:35:05+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_163503_b5250b9e"}
2026-05-16T16:35:05+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.964,"duration_milliseconds":964,"important":true,"run_id":"20260516_163503_b5250b9e"}
2026-05-16T16:35:05+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_163503_b5250b9e"}
2026-05-16T16:35:05+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_163503_b5250b9e"}
2026-05-16T16:35:05+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_163503_b5250b9e"}
2026-05-16T16:35:05+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.048,"duration_milliseconds":48,"important":true,"run_id":"20260516_163503_b5250b9e"}
2026-05-16T16:35:05+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":87861,"run_id":"20260516_163503_b5250b9e"}
2026-05-16T16:35:05+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.786,"exec_milliseconds":1786,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":87861,"important":true,"run_id":"20260516_163503_b5250b9e"}
2026-05-16T16:36:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_163602_c2961b2a"}
2026-05-16T16:36:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_163602_c2961b2a"}
2026-05-16T16:36:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_163602_c2961b2a"}
2026-05-16T16:36:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_163602_c2961b2a"}
2026-05-16T16:36:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_163602_c2961b2a"}
2026-05-16T16:36:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_163602_c2961b2a"}
2026-05-16T16:36:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_163602_c2961b2a"}
2026-05-16T16:36:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_163602_c2961b2a"}
2026-05-16T16:36:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":5091,"mtime":"2026-05-16T16:31:28+02:00","run_id":"20260516_163602_c2961b2a"}
2026-05-16T16:36:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_163602_c2961b2a"}
2026-05-16T16:36:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":4676,"mtime":"2026-05-16T16:31:27+02:00","run_id":"20260516_163602_c2961b2a"}
2026-05-16T16:36:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_163602_c2961b2a"}
2026-05-16T16:36:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_163602_c2961b2a"}
2026-05-16T16:36:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.925,"duration_milliseconds":925,"important":true,"run_id":"20260516_163602_c2961b2a"}
2026-05-16T16:36:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_163602_c2961b2a"}
2026-05-16T16:36:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_163602_c2961b2a"}
2026-05-16T16:36:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_163602_c2961b2a"}
2026-05-16T16:36:04+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.038,"duration_milliseconds":38,"important":true,"run_id":"20260516_163602_c2961b2a"}
2026-05-16T16:36:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":87861,"run_id":"20260516_163602_c2961b2a"}
2026-05-16T16:36:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.737,"exec_milliseconds":1737,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":87861,"important":true,"run_id":"20260516_163602_c2961b2a"}
2026-05-16T16:37:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_163701_71dc0289"}
2026-05-16T16:37:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_163701_71dc0289"}
2026-05-16T16:37:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_163701_71dc0289"}
2026-05-16T16:37:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_163701_71dc0289"}
2026-05-16T16:37:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_163701_71dc0289"}
2026-05-16T16:37:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_163701_71dc0289"}
2026-05-16T16:37:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_163701_71dc0289"}
2026-05-16T16:37:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_163701_71dc0289"}
2026-05-16T16:37:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":5091,"mtime":"2026-05-16T16:31:28+02:00","run_id":"20260516_163701_71dc0289"}
2026-05-16T16:37:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_163701_71dc0289"}
2026-05-16T16:37:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":4676,"mtime":"2026-05-16T16:31:27+02:00","run_id":"20260516_163701_71dc0289"}
2026-05-16T16:37:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_163701_71dc0289"}
2026-05-16T16:37:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_163701_71dc0289"}
2026-05-16T16:37:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.959,"duration_milliseconds":959,"important":true,"run_id":"20260516_163701_71dc0289"}
2026-05-16T16:37:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_163701_71dc0289"}
2026-05-16T16:37:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_163701_71dc0289"}
2026-05-16T16:37:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_163701_71dc0289"}
2026-05-16T16:37:03+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.052,"duration_milliseconds":52,"important":true,"run_id":"20260516_163701_71dc0289"}
2026-05-16T16:37:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":87861,"run_id":"20260516_163701_71dc0289"}
2026-05-16T16:37:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.8,"exec_milliseconds":1800,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":87861,"important":true,"run_id":"20260516_163701_71dc0289"}
2026-05-16T16:38:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_163802_7e4ec6f6"}
2026-05-16T16:38:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_163802_7e4ec6f6"}
2026-05-16T16:38:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_163802_7e4ec6f6"}
2026-05-16T16:38:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_163802_7e4ec6f6"}
2026-05-16T16:38:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_163802_7e4ec6f6"}
2026-05-16T16:38:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_163802_7e4ec6f6"}
2026-05-16T16:38:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_163802_7e4ec6f6"}
2026-05-16T16:38:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_163802_7e4ec6f6"}
2026-05-16T16:38:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":5091,"mtime":"2026-05-16T16:31:28+02:00","run_id":"20260516_163802_7e4ec6f6"}
2026-05-16T16:38:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_163802_7e4ec6f6"}
2026-05-16T16:38:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":4676,"mtime":"2026-05-16T16:31:27+02:00","run_id":"20260516_163802_7e4ec6f6"}
2026-05-16T16:38:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_163802_7e4ec6f6"}
2026-05-16T16:38:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_163802_7e4ec6f6"}
2026-05-16T16:38:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.964,"duration_milliseconds":964,"important":true,"run_id":"20260516_163802_7e4ec6f6"}
2026-05-16T16:38:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_163802_7e4ec6f6"}
2026-05-16T16:38:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_163802_7e4ec6f6"}
2026-05-16T16:38:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_163802_7e4ec6f6"}
2026-05-16T16:38:04+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.045,"duration_milliseconds":45,"important":true,"run_id":"20260516_163802_7e4ec6f6"}
2026-05-16T16:38:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":87861,"run_id":"20260516_163802_7e4ec6f6"}
2026-05-16T16:38:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.762,"exec_milliseconds":1762,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":87861,"important":true,"run_id":"20260516_163802_7e4ec6f6"}
2026-05-16T16:39:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_163901_b38a0a24"}
2026-05-16T16:39:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_163901_b38a0a24"}
2026-05-16T16:39:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_163901_b38a0a24"}
2026-05-16T16:39:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_163901_b38a0a24"}
2026-05-16T16:39:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_163901_b38a0a24"}
2026-05-16T16:39:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_163901_b38a0a24"}
2026-05-16T16:39:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_163901_b38a0a24"}
2026-05-16T16:39:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_163901_b38a0a24"}
2026-05-16T16:39:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":5091,"mtime":"2026-05-16T16:31:28+02:00","run_id":"20260516_163901_b38a0a24"}
2026-05-16T16:39:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_163901_b38a0a24"}
2026-05-16T16:39:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":4676,"mtime":"2026-05-16T16:31:27+02:00","run_id":"20260516_163901_b38a0a24"}
2026-05-16T16:39:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_163901_b38a0a24"}
2026-05-16T16:39:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_163901_b38a0a24"}
2026-05-16T16:39:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.984,"duration_milliseconds":984,"important":true,"run_id":"20260516_163901_b38a0a24"}
2026-05-16T16:39:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_163901_b38a0a24"}
2026-05-16T16:39:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_163901_b38a0a24"}
2026-05-16T16:39:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_163901_b38a0a24"}
2026-05-16T16:39:03+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.049,"duration_milliseconds":49,"important":true,"run_id":"20260516_163901_b38a0a24"}
2026-05-16T16:39:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":87861,"run_id":"20260516_163901_b38a0a24"}
2026-05-16T16:39:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.836,"exec_milliseconds":1836,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":87861,"important":true,"run_id":"20260516_163901_b38a0a24"}
2026-05-16T16:40:06+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_164006_6e6f879a"}
2026-05-16T16:40:06+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_164006_6e6f879a"}
2026-05-16T16:40:06+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_164006_6e6f879a"}
2026-05-16T16:40:06+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_164006_6e6f879a"}
2026-05-16T16:40:07+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_164006_6e6f879a"}
2026-05-16T16:40:07+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_164006_6e6f879a"}
2026-05-16T16:40:07+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_164006_6e6f879a"}
2026-05-16T16:40:07+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_164006_6e6f879a"}
2026-05-16T16:40:07+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":5091,"mtime":"2026-05-16T16:31:28+02:00","run_id":"20260516_164006_6e6f879a"}
2026-05-16T16:40:07+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_164006_6e6f879a"}
2026-05-16T16:40:07+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":4676,"mtime":"2026-05-16T16:31:27+02:00","run_id":"20260516_164006_6e6f879a"}
2026-05-16T16:40:07+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_164006_6e6f879a"}
2026-05-16T16:40:08+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_164006_6e6f879a"}
2026-05-16T16:40:08+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.96,"duration_milliseconds":960,"important":true,"run_id":"20260516_164006_6e6f879a"}
2026-05-16T16:40:08+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_164006_6e6f879a"}
2026-05-16T16:40:08+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_164006_6e6f879a"}
2026-05-16T16:40:08+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_164006_6e6f879a"}
2026-05-16T16:40:08+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.048,"duration_milliseconds":48,"important":true,"run_id":"20260516_164006_6e6f879a"}
2026-05-16T16:40:08+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":87861,"run_id":"20260516_164006_6e6f879a"}
2026-05-16T16:40:08+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.795,"exec_milliseconds":1795,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":87861,"important":true,"run_id":"20260516_164006_6e6f879a"}
2026-05-16T16:41:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_164101_ded5e93f"}
2026-05-16T16:41:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_164101_ded5e93f"}
2026-05-16T16:41:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_164101_ded5e93f"}
2026-05-16T16:41:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_164101_ded5e93f"}
2026-05-16T16:41:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_164101_ded5e93f"}
2026-05-16T16:41:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_164101_ded5e93f"}
2026-05-16T16:41:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_164101_ded5e93f"}
2026-05-16T16:41:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_164101_ded5e93f"}
2026-05-16T16:41:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":5091,"mtime":"2026-05-16T16:31:28+02:00","run_id":"20260516_164101_ded5e93f"}
2026-05-16T16:41:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_164101_ded5e93f"}
2026-05-16T16:41:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":4676,"mtime":"2026-05-16T16:31:27+02:00","run_id":"20260516_164101_ded5e93f"}
2026-05-16T16:41:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_164101_ded5e93f"}
2026-05-16T16:41:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_164101_ded5e93f"}
2026-05-16T16:41:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.906,"duration_milliseconds":906,"important":true,"run_id":"20260516_164101_ded5e93f"}
2026-05-16T16:41:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_164101_ded5e93f"}
2026-05-16T16:41:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_164101_ded5e93f"}
2026-05-16T16:41:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_164101_ded5e93f"}
2026-05-16T16:41:03+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.04,"duration_milliseconds":40,"important":true,"run_id":"20260516_164101_ded5e93f"}
2026-05-16T16:41:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":87861,"run_id":"20260516_164101_ded5e93f"}
2026-05-16T16:41:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.747,"exec_milliseconds":1747,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":87861,"important":true,"run_id":"20260516_164101_ded5e93f"}
2026-05-16T16:42:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_164202_ac1b0cda"}
2026-05-16T16:42:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_164202_ac1b0cda"}
2026-05-16T16:42:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_164202_ac1b0cda"}
2026-05-16T16:42:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_164202_ac1b0cda"}
2026-05-16T16:42:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_164202_ac1b0cda"}
2026-05-16T16:42:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_164202_ac1b0cda"}
2026-05-16T16:42:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_164202_ac1b0cda"}
2026-05-16T16:42:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_164202_ac1b0cda"}
2026-05-16T16:42:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":5091,"mtime":"2026-05-16T16:31:28+02:00","run_id":"20260516_164202_ac1b0cda"}
2026-05-16T16:42:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_164202_ac1b0cda"}
2026-05-16T16:42:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":4676,"mtime":"2026-05-16T16:31:27+02:00","run_id":"20260516_164202_ac1b0cda"}
2026-05-16T16:42:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_164202_ac1b0cda"}
2026-05-16T16:42:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_164202_ac1b0cda"}
2026-05-16T16:42:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.957,"duration_milliseconds":957,"important":true,"run_id":"20260516_164202_ac1b0cda"}
2026-05-16T16:42:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_164202_ac1b0cda"}
2026-05-16T16:42:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_164202_ac1b0cda"}
2026-05-16T16:42:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_164202_ac1b0cda"}
2026-05-16T16:42:04+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.046,"duration_milliseconds":46,"important":true,"run_id":"20260516_164202_ac1b0cda"}
2026-05-16T16:42:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":87861,"run_id":"20260516_164202_ac1b0cda"}
2026-05-16T16:42:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.752,"exec_milliseconds":1752,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":87861,"important":true,"run_id":"20260516_164202_ac1b0cda"}
2026-05-16T16:43:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_164301_85e7fdf9"}
2026-05-16T16:43:01+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_164301_85e7fdf9"}
2026-05-16T16:43:01+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_164301_85e7fdf9"}
2026-05-16T16:43:01+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_164301_85e7fdf9"}
2026-05-16T16:43:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_164301_85e7fdf9"}
2026-05-16T16:43:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_164301_85e7fdf9"}
2026-05-16T16:43:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_164301_85e7fdf9"}
2026-05-16T16:43:02+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_164301_85e7fdf9"}
2026-05-16T16:43:02+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":5091,"mtime":"2026-05-16T16:31:28+02:00","run_id":"20260516_164301_85e7fdf9"}
2026-05-16T16:43:02+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_164301_85e7fdf9"}
2026-05-16T16:43:02+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":4676,"mtime":"2026-05-16T16:31:27+02:00","run_id":"20260516_164301_85e7fdf9"}
2026-05-16T16:43:02+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_164301_85e7fdf9"}
2026-05-16T16:43:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_164301_85e7fdf9"}
2026-05-16T16:43:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.954,"duration_milliseconds":954,"important":true,"run_id":"20260516_164301_85e7fdf9"}
2026-05-16T16:43:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_164301_85e7fdf9"}
2026-05-16T16:43:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_164301_85e7fdf9"}
2026-05-16T16:43:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_164301_85e7fdf9"}
2026-05-16T16:43:03+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.048,"duration_milliseconds":48,"important":true,"run_id":"20260516_164301_85e7fdf9"}
2026-05-16T16:43:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":87861,"run_id":"20260516_164301_85e7fdf9"}
2026-05-16T16:43:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.761,"exec_milliseconds":1761,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":87861,"important":true,"run_id":"20260516_164301_85e7fdf9"}
2026-05-16T16:44:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_164402_b2e54b91"}
2026-05-16T16:44:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_164402_b2e54b91"}
2026-05-16T16:44:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_164402_b2e54b91"}
2026-05-16T16:44:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_164402_b2e54b91"}
2026-05-16T16:44:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_164402_b2e54b91"}
2026-05-16T16:44:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_164402_b2e54b91"}
2026-05-16T16:44:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_164402_b2e54b91"}
2026-05-16T16:44:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_164402_b2e54b91"}
2026-05-16T16:44:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":5091,"mtime":"2026-05-16T16:31:28+02:00","run_id":"20260516_164402_b2e54b91"}
2026-05-16T16:44:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_164402_b2e54b91"}
2026-05-16T16:44:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":4676,"mtime":"2026-05-16T16:31:27+02:00","run_id":"20260516_164402_b2e54b91"}
2026-05-16T16:44:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_164402_b2e54b91"}
2026-05-16T16:44:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_164402_b2e54b91"}
2026-05-16T16:44:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.964,"duration_milliseconds":964,"important":true,"run_id":"20260516_164402_b2e54b91"}
2026-05-16T16:44:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_164402_b2e54b91"}
2026-05-16T16:44:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_164402_b2e54b91"}
2026-05-16T16:44:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_164402_b2e54b91"}
2026-05-16T16:44:04+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.046,"duration_milliseconds":46,"important":true,"run_id":"20260516_164402_b2e54b91"}
2026-05-16T16:44:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":87861,"run_id":"20260516_164402_b2e54b91"}
2026-05-16T16:44:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.748,"exec_milliseconds":1748,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":87861,"important":true,"run_id":"20260516_164402_b2e54b91"}
2026-05-16T16:45:06+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_164506_7f0198b3"}
2026-05-16T16:45:07+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_164506_7f0198b3"}
2026-05-16T16:45:07+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_164506_7f0198b3"}
2026-05-16T16:45:07+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_164506_7f0198b3"}
2026-05-16T16:45:07+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_164506_7f0198b3"}
2026-05-16T16:45:07+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_164506_7f0198b3"}
2026-05-16T16:45:07+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_164506_7f0198b3"}
2026-05-16T16:45:08+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_164506_7f0198b3"}
2026-05-16T16:45:08+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":5091,"mtime":"2026-05-16T16:31:28+02:00","run_id":"20260516_164506_7f0198b3"}
2026-05-16T16:45:08+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_164506_7f0198b3"}
2026-05-16T16:45:08+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":4676,"mtime":"2026-05-16T16:31:27+02:00","run_id":"20260516_164506_7f0198b3"}
2026-05-16T16:45:08+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_164506_7f0198b3"}
2026-05-16T16:45:08+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_164506_7f0198b3"}
2026-05-16T16:45:08+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.978,"duration_milliseconds":978,"important":true,"run_id":"20260516_164506_7f0198b3"}
2026-05-16T16:45:08+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_164506_7f0198b3"}
2026-05-16T16:45:08+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_164506_7f0198b3"}
2026-05-16T16:45:08+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_164506_7f0198b3"}
2026-05-16T16:45:08+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.049,"duration_milliseconds":49,"important":true,"run_id":"20260516_164506_7f0198b3"}
2026-05-16T16:45:08+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":87856,"run_id":"20260516_164506_7f0198b3"}
2026-05-16T16:45:08+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.774,"exec_milliseconds":1774,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":87856,"important":true,"run_id":"20260516_164506_7f0198b3"}
2026-05-16T16:46:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_164602_ba2784e6"}
2026-05-16T16:46:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_164602_ba2784e6"}
2026-05-16T16:46:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_164602_ba2784e6"}
2026-05-16T16:46:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_164602_ba2784e6"}
2026-05-16T16:46:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_164602_ba2784e6"}
2026-05-16T16:46:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_164602_ba2784e6"}
2026-05-16T16:46:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_164602_ba2784e6"}
2026-05-16T16:46:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_164602_ba2784e6"}
2026-05-16T16:46:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":5091,"mtime":"2026-05-16T16:31:28+02:00","run_id":"20260516_164602_ba2784e6"}
2026-05-16T16:46:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_164602_ba2784e6"}
2026-05-16T16:46:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":4676,"mtime":"2026-05-16T16:31:27+02:00","run_id":"20260516_164602_ba2784e6"}
2026-05-16T16:46:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_164602_ba2784e6"}
2026-05-16T16:46:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_164602_ba2784e6"}
2026-05-16T16:46:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.934,"duration_milliseconds":934,"important":true,"run_id":"20260516_164602_ba2784e6"}
2026-05-16T16:46:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_164602_ba2784e6"}
2026-05-16T16:46:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_164602_ba2784e6"}
2026-05-16T16:46:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_164602_ba2784e6"}
2026-05-16T16:46:04+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.048,"duration_milliseconds":48,"important":true,"run_id":"20260516_164602_ba2784e6"}
2026-05-16T16:46:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":87856,"run_id":"20260516_164602_ba2784e6"}
2026-05-16T16:46:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.784,"exec_milliseconds":1784,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":87856,"important":true,"run_id":"20260516_164602_ba2784e6"}
2026-05-16T16:47:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_164701_134e0d90"}
2026-05-16T16:47:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_164701_134e0d90"}
2026-05-16T16:47:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_164701_134e0d90"}
2026-05-16T16:47:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_164701_134e0d90"}
2026-05-16T16:47:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_164701_134e0d90"}
2026-05-16T16:47:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_164701_134e0d90"}
2026-05-16T16:47:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_164701_134e0d90"}
2026-05-16T16:47:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_164701_134e0d90"}
2026-05-16T16:47:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":5091,"mtime":"2026-05-16T16:31:28+02:00","run_id":"20260516_164701_134e0d90"}
2026-05-16T16:47:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_164701_134e0d90"}
2026-05-16T16:47:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":4676,"mtime":"2026-05-16T16:31:27+02:00","run_id":"20260516_164701_134e0d90"}
2026-05-16T16:47:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_164701_134e0d90"}
2026-05-16T16:47:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_164701_134e0d90"}
2026-05-16T16:47:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.93,"duration_milliseconds":930,"important":true,"run_id":"20260516_164701_134e0d90"}
2026-05-16T16:47:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_164701_134e0d90"}
2026-05-16T16:47:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_164701_134e0d90"}
2026-05-16T16:47:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_164701_134e0d90"}
2026-05-16T16:47:03+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.041,"duration_milliseconds":41,"important":true,"run_id":"20260516_164701_134e0d90"}
2026-05-16T16:47:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":87856,"run_id":"20260516_164701_134e0d90"}
2026-05-16T16:47:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.726,"exec_milliseconds":1726,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":87856,"important":true,"run_id":"20260516_164701_134e0d90"}
2026-05-16T16:48:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_164802_63c888e1"}
2026-05-16T16:48:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_164802_63c888e1"}
2026-05-16T16:48:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_164802_63c888e1"}
2026-05-16T16:48:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_164802_63c888e1"}
2026-05-16T16:48:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_164802_63c888e1"}
2026-05-16T16:48:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_164802_63c888e1"}
2026-05-16T16:48:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_164802_63c888e1"}
2026-05-16T16:48:04+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_164802_63c888e1"}
2026-05-16T16:48:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":5091,"mtime":"2026-05-16T16:31:28+02:00","run_id":"20260516_164802_63c888e1"}
2026-05-16T16:48:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_164802_63c888e1"}
2026-05-16T16:48:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":4676,"mtime":"2026-05-16T16:31:27+02:00","run_id":"20260516_164802_63c888e1"}
2026-05-16T16:48:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_164802_63c888e1"}
2026-05-16T16:48:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_164802_63c888e1"}
2026-05-16T16:48:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.954,"duration_milliseconds":954,"important":true,"run_id":"20260516_164802_63c888e1"}
2026-05-16T16:48:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_164802_63c888e1"}
2026-05-16T16:48:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_164802_63c888e1"}
2026-05-16T16:48:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_164802_63c888e1"}
2026-05-16T16:48:04+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.049,"duration_milliseconds":49,"important":true,"run_id":"20260516_164802_63c888e1"}
2026-05-16T16:48:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":87856,"run_id":"20260516_164802_63c888e1"}
2026-05-16T16:48:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.777,"exec_milliseconds":1777,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":87856,"important":true,"run_id":"20260516_164802_63c888e1"}
2026-05-16T16:49:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_164902_9a45a07f"}
2026-05-16T16:49:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_164902_9a45a07f"}
2026-05-16T16:49:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_164902_9a45a07f"}
2026-05-16T16:49:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_164902_9a45a07f"}
2026-05-16T16:49:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_164902_9a45a07f"}
2026-05-16T16:49:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_164902_9a45a07f"}
2026-05-16T16:49:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_164902_9a45a07f"}
2026-05-16T16:49:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_164902_9a45a07f"}
2026-05-16T16:49:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":5091,"mtime":"2026-05-16T16:31:28+02:00","run_id":"20260516_164902_9a45a07f"}
2026-05-16T16:49:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_164902_9a45a07f"}
2026-05-16T16:49:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":4676,"mtime":"2026-05-16T16:31:27+02:00","run_id":"20260516_164902_9a45a07f"}
2026-05-16T16:49:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_164902_9a45a07f"}
2026-05-16T16:49:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_164902_9a45a07f"}
2026-05-16T16:49:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.945,"duration_milliseconds":945,"important":true,"run_id":"20260516_164902_9a45a07f"}
2026-05-16T16:49:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_164902_9a45a07f"}
2026-05-16T16:49:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_164902_9a45a07f"}
2026-05-16T16:49:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_164902_9a45a07f"}
2026-05-16T16:49:03+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.045,"duration_milliseconds":45,"important":true,"run_id":"20260516_164902_9a45a07f"}
2026-05-16T16:49:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":87858,"run_id":"20260516_164902_9a45a07f"}
2026-05-16T16:49:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.764,"exec_milliseconds":1764,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":87858,"important":true,"run_id":"20260516_164902_9a45a07f"}
2026-05-16T16:50:06+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_165006_00bfaa20"}
2026-05-16T16:50:07+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_165006_00bfaa20"}
2026-05-16T16:50:07+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_165006_00bfaa20"}
2026-05-16T16:50:07+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_165006_00bfaa20"}
2026-05-16T16:50:07+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_165006_00bfaa20"}
2026-05-16T16:50:07+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_165006_00bfaa20"}
2026-05-16T16:50:07+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_165006_00bfaa20"}
2026-05-16T16:50:07+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_165006_00bfaa20"}
2026-05-16T16:50:07+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":5091,"mtime":"2026-05-16T16:31:28+02:00","run_id":"20260516_165006_00bfaa20"}
2026-05-16T16:50:08+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_165006_00bfaa20"}
2026-05-16T16:50:08+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":4676,"mtime":"2026-05-16T16:31:27+02:00","run_id":"20260516_165006_00bfaa20"}
2026-05-16T16:50:08+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_165006_00bfaa20"}
2026-05-16T16:50:08+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_165006_00bfaa20"}
2026-05-16T16:50:08+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.964,"duration_milliseconds":964,"important":true,"run_id":"20260516_165006_00bfaa20"}
2026-05-16T16:50:08+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_165006_00bfaa20"}
2026-05-16T16:50:08+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_165006_00bfaa20"}
2026-05-16T16:50:08+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_165006_00bfaa20"}
2026-05-16T16:50:08+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.05,"duration_milliseconds":50,"important":true,"run_id":"20260516_165006_00bfaa20"}
2026-05-16T16:50:08+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":87858,"run_id":"20260516_165006_00bfaa20"}
2026-05-16T16:50:08+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.794,"exec_milliseconds":1794,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":87858,"important":true,"run_id":"20260516_165006_00bfaa20"}
2026-05-16T16:51:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_165101_3ab8637d"}
2026-05-16T16:51:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_165101_3ab8637d"}
2026-05-16T16:51:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_165101_3ab8637d"}
2026-05-16T16:51:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_165101_3ab8637d"}
2026-05-16T16:51:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_165101_3ab8637d"}
2026-05-16T16:51:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_165101_3ab8637d"}
2026-05-16T16:51:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_165101_3ab8637d"}
2026-05-16T16:51:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_165101_3ab8637d"}
2026-05-16T16:51:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":5091,"mtime":"2026-05-16T16:31:28+02:00","run_id":"20260516_165101_3ab8637d"}
2026-05-16T16:51:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_165101_3ab8637d"}
2026-05-16T16:51:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":4676,"mtime":"2026-05-16T16:31:27+02:00","run_id":"20260516_165101_3ab8637d"}
2026-05-16T16:51:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_165101_3ab8637d"}
2026-05-16T16:51:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_165101_3ab8637d"}
2026-05-16T16:51:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.939,"duration_milliseconds":939,"important":true,"run_id":"20260516_165101_3ab8637d"}
2026-05-16T16:51:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_165101_3ab8637d"}
2026-05-16T16:51:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_165101_3ab8637d"}
2026-05-16T16:51:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_165101_3ab8637d"}
2026-05-16T16:51:03+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.049,"duration_milliseconds":49,"important":true,"run_id":"20260516_165101_3ab8637d"}
2026-05-16T16:51:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":87858,"run_id":"20260516_165101_3ab8637d"}
2026-05-16T16:51:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.782,"exec_milliseconds":1782,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":87858,"important":true,"run_id":"20260516_165101_3ab8637d"}
2026-05-16T16:52:03+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_165202_6cd4cf71"}
2026-05-16T16:52:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_165202_6cd4cf71"}
2026-05-16T16:52:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_165202_6cd4cf71"}
2026-05-16T16:52:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_165202_6cd4cf71"}
2026-05-16T16:52:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_165202_6cd4cf71"}
2026-05-16T16:52:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_165202_6cd4cf71"}
2026-05-16T16:52:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_165202_6cd4cf71"}
2026-05-16T16:52:04+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_165202_6cd4cf71"}
2026-05-16T16:52:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":5091,"mtime":"2026-05-16T16:31:28+02:00","run_id":"20260516_165202_6cd4cf71"}
2026-05-16T16:52:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_165202_6cd4cf71"}
2026-05-16T16:52:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":4676,"mtime":"2026-05-16T16:31:27+02:00","run_id":"20260516_165202_6cd4cf71"}
2026-05-16T16:52:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_165202_6cd4cf71"}
2026-05-16T16:52:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_165202_6cd4cf71"}
2026-05-16T16:52:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.943,"duration_milliseconds":943,"important":true,"run_id":"20260516_165202_6cd4cf71"}
2026-05-16T16:52:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_165202_6cd4cf71"}
2026-05-16T16:52:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_165202_6cd4cf71"}
2026-05-16T16:52:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_165202_6cd4cf71"}
2026-05-16T16:52:04+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.044,"duration_milliseconds":44,"important":true,"run_id":"20260516_165202_6cd4cf71"}
2026-05-16T16:52:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":87858,"run_id":"20260516_165202_6cd4cf71"}
2026-05-16T16:52:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.775,"exec_milliseconds":1775,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":87858,"important":true,"run_id":"20260516_165202_6cd4cf71"}
2026-05-16T16:53:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_165302_5a624a5b"}
2026-05-16T16:53:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_165302_5a624a5b"}
2026-05-16T16:53:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_165302_5a624a5b"}
2026-05-16T16:53:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_165302_5a624a5b"}
2026-05-16T16:53:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_165302_5a624a5b"}
2026-05-16T16:53:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_165302_5a624a5b"}
2026-05-16T16:53:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_165302_5a624a5b"}
2026-05-16T16:53:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_165302_5a624a5b"}
2026-05-16T16:53:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":5091,"mtime":"2026-05-16T16:31:28+02:00","run_id":"20260516_165302_5a624a5b"}
2026-05-16T16:53:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_165302_5a624a5b"}
2026-05-16T16:53:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":4676,"mtime":"2026-05-16T16:31:27+02:00","run_id":"20260516_165302_5a624a5b"}
2026-05-16T16:53:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_165302_5a624a5b"}
2026-05-16T16:53:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_165302_5a624a5b"}
2026-05-16T16:53:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.945,"duration_milliseconds":945,"important":true,"run_id":"20260516_165302_5a624a5b"}
2026-05-16T16:53:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_165302_5a624a5b"}
2026-05-16T16:53:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_165302_5a624a5b"}
2026-05-16T16:53:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_165302_5a624a5b"}
2026-05-16T16:53:03+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.047,"duration_milliseconds":47,"important":true,"run_id":"20260516_165302_5a624a5b"}
2026-05-16T16:53:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":87858,"run_id":"20260516_165302_5a624a5b"}
2026-05-16T16:53:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.765,"exec_milliseconds":1765,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":87858,"important":true,"run_id":"20260516_165302_5a624a5b"}
2026-05-16T16:54:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_165402_921f400a"}
2026-05-16T16:54:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_165402_921f400a"}
2026-05-16T16:54:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_165402_921f400a"}
2026-05-16T16:54:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_165402_921f400a"}
2026-05-16T16:54:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_165402_921f400a"}
2026-05-16T16:54:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_165402_921f400a"}
2026-05-16T16:54:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_165402_921f400a"}
2026-05-16T16:54:04+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_165402_921f400a"}
2026-05-16T16:54:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":5091,"mtime":"2026-05-16T16:31:28+02:00","run_id":"20260516_165402_921f400a"}
2026-05-16T16:54:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_165402_921f400a"}
2026-05-16T16:54:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":4676,"mtime":"2026-05-16T16:31:27+02:00","run_id":"20260516_165402_921f400a"}
2026-05-16T16:54:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_165402_921f400a"}
2026-05-16T16:54:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_165402_921f400a"}
2026-05-16T16:54:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.959,"duration_milliseconds":959,"important":true,"run_id":"20260516_165402_921f400a"}
2026-05-16T16:54:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_165402_921f400a"}
2026-05-16T16:54:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_165402_921f400a"}
2026-05-16T16:54:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_165402_921f400a"}
2026-05-16T16:54:04+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.045,"duration_milliseconds":45,"important":true,"run_id":"20260516_165402_921f400a"}
2026-05-16T16:54:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":87858,"run_id":"20260516_165402_921f400a"}
2026-05-16T16:54:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.77,"exec_milliseconds":1770,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":87858,"important":true,"run_id":"20260516_165402_921f400a"}
2026-05-16T16:55:04+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_165504_581f068c"}
2026-05-16T16:55:04+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_165504_581f068c"}
2026-05-16T16:55:04+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_165504_581f068c"}
2026-05-16T16:55:04+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_165504_581f068c"}
2026-05-16T16:55:04+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_165504_581f068c"}
2026-05-16T16:55:05+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_165504_581f068c"}
2026-05-16T16:55:05+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_165504_581f068c"}
2026-05-16T16:55:05+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_165504_581f068c"}
2026-05-16T16:55:05+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":5091,"mtime":"2026-05-16T16:31:28+02:00","run_id":"20260516_165504_581f068c"}
2026-05-16T16:55:05+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_165504_581f068c"}
2026-05-16T16:55:05+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":4676,"mtime":"2026-05-16T16:31:27+02:00","run_id":"20260516_165504_581f068c"}
2026-05-16T16:55:05+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_165504_581f068c"}
2026-05-16T16:55:05+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_165504_581f068c"}
2026-05-16T16:55:05+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.933,"duration_milliseconds":933,"important":true,"run_id":"20260516_165504_581f068c"}
2026-05-16T16:55:06+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_165504_581f068c"}
2026-05-16T16:55:06+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_165504_581f068c"}
2026-05-16T16:55:06+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_165504_581f068c"}
2026-05-16T16:55:06+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.046,"duration_milliseconds":46,"important":true,"run_id":"20260516_165504_581f068c"}
2026-05-16T16:55:06+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":87858,"run_id":"20260516_165504_581f068c"}
2026-05-16T16:55:06+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.76,"exec_milliseconds":1760,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":87858,"important":true,"run_id":"20260516_165504_581f068c"}
2026-05-16T16:56:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_165602_bf0ed05b"}
2026-05-16T16:56:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_165602_bf0ed05b"}
2026-05-16T16:56:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_165602_bf0ed05b"}
2026-05-16T16:56:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_165602_bf0ed05b"}
2026-05-16T16:56:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_165602_bf0ed05b"}
2026-05-16T16:56:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_165602_bf0ed05b"}
2026-05-16T16:56:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_165602_bf0ed05b"}
2026-05-16T16:56:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_165602_bf0ed05b"}
2026-05-16T16:56:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":5091,"mtime":"2026-05-16T16:31:28+02:00","run_id":"20260516_165602_bf0ed05b"}
2026-05-16T16:56:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_165602_bf0ed05b"}
2026-05-16T16:56:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":4676,"mtime":"2026-05-16T16:31:27+02:00","run_id":"20260516_165602_bf0ed05b"}
2026-05-16T16:56:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_165602_bf0ed05b"}
2026-05-16T16:56:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_165602_bf0ed05b"}
2026-05-16T16:56:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.948,"duration_milliseconds":948,"important":true,"run_id":"20260516_165602_bf0ed05b"}
2026-05-16T16:56:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_165602_bf0ed05b"}
2026-05-16T16:56:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_165602_bf0ed05b"}
2026-05-16T16:56:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_165602_bf0ed05b"}
2026-05-16T16:56:04+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.046,"duration_milliseconds":46,"important":true,"run_id":"20260516_165602_bf0ed05b"}
2026-05-16T16:56:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":87858,"run_id":"20260516_165602_bf0ed05b"}
2026-05-16T16:56:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.769,"exec_milliseconds":1769,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":87858,"important":true,"run_id":"20260516_165602_bf0ed05b"}
2026-05-16T16:57:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_165701_ce30b0d4"}
2026-05-16T16:57:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_165701_ce30b0d4"}
2026-05-16T16:57:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_165701_ce30b0d4"}
2026-05-16T16:57:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_165701_ce30b0d4"}
2026-05-16T16:57:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_165701_ce30b0d4"}
2026-05-16T16:57:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_165701_ce30b0d4"}
2026-05-16T16:57:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_165701_ce30b0d4"}
2026-05-16T16:57:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_165701_ce30b0d4"}
2026-05-16T16:57:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":5091,"mtime":"2026-05-16T16:31:28+02:00","run_id":"20260516_165701_ce30b0d4"}
2026-05-16T16:57:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_165701_ce30b0d4"}
2026-05-16T16:57:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":4676,"mtime":"2026-05-16T16:31:27+02:00","run_id":"20260516_165701_ce30b0d4"}
2026-05-16T16:57:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_165701_ce30b0d4"}
2026-05-16T16:57:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_165701_ce30b0d4"}
2026-05-16T16:57:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.938,"duration_milliseconds":938,"important":true,"run_id":"20260516_165701_ce30b0d4"}
2026-05-16T16:57:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_165701_ce30b0d4"}
2026-05-16T16:57:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_165701_ce30b0d4"}
2026-05-16T16:57:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_165701_ce30b0d4"}
2026-05-16T16:57:03+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.044,"duration_milliseconds":44,"important":true,"run_id":"20260516_165701_ce30b0d4"}
2026-05-16T16:57:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":87858,"run_id":"20260516_165701_ce30b0d4"}
2026-05-16T16:57:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.759,"exec_milliseconds":1759,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":87858,"important":true,"run_id":"20260516_165701_ce30b0d4"}
2026-05-16T16:58:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_165802_e9aa3813"}
2026-05-16T16:58:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_165802_e9aa3813"}
2026-05-16T16:58:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_165802_e9aa3813"}
2026-05-16T16:58:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_165802_e9aa3813"}
2026-05-16T16:58:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_165802_e9aa3813"}
2026-05-16T16:58:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_165802_e9aa3813"}
2026-05-16T16:58:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_165802_e9aa3813"}
2026-05-16T16:58:04+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_165802_e9aa3813"}
2026-05-16T16:58:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":5091,"mtime":"2026-05-16T16:31:28+02:00","run_id":"20260516_165802_e9aa3813"}
2026-05-16T16:58:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_165802_e9aa3813"}
2026-05-16T16:58:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":4676,"mtime":"2026-05-16T16:31:27+02:00","run_id":"20260516_165802_e9aa3813"}
2026-05-16T16:58:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_165802_e9aa3813"}
2026-05-16T16:58:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_165802_e9aa3813"}
2026-05-16T16:58:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.955,"duration_milliseconds":955,"important":true,"run_id":"20260516_165802_e9aa3813"}
2026-05-16T16:58:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_165802_e9aa3813"}
2026-05-16T16:58:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_165802_e9aa3813"}
2026-05-16T16:58:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_165802_e9aa3813"}
2026-05-16T16:58:04+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.047,"duration_milliseconds":47,"important":true,"run_id":"20260516_165802_e9aa3813"}
2026-05-16T16:58:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":87858,"run_id":"20260516_165802_e9aa3813"}
2026-05-16T16:58:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.76,"exec_milliseconds":1760,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":87858,"important":true,"run_id":"20260516_165802_e9aa3813"}
2026-05-16T16:59:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_165902_aa92543c"}
2026-05-16T16:59:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_165902_aa92543c"}
2026-05-16T16:59:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_165902_aa92543c"}
2026-05-16T16:59:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_165902_aa92543c"}
2026-05-16T16:59:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_165902_aa92543c"}
2026-05-16T16:59:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_165902_aa92543c"}
2026-05-16T16:59:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_165902_aa92543c"}
2026-05-16T16:59:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_165902_aa92543c"}
2026-05-16T16:59:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":5091,"mtime":"2026-05-16T16:31:28+02:00","run_id":"20260516_165902_aa92543c"}
2026-05-16T16:59:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_165902_aa92543c"}
2026-05-16T16:59:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":4676,"mtime":"2026-05-16T16:31:27+02:00","run_id":"20260516_165902_aa92543c"}
2026-05-16T16:59:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_165902_aa92543c"}
2026-05-16T16:59:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_165902_aa92543c"}
2026-05-16T16:59:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.966,"duration_milliseconds":966,"important":true,"run_id":"20260516_165902_aa92543c"}
2026-05-16T16:59:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_165902_aa92543c"}
2026-05-16T16:59:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_165902_aa92543c"}
2026-05-16T16:59:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_165902_aa92543c"}
2026-05-16T16:59:03+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.05,"duration_milliseconds":50,"important":true,"run_id":"20260516_165902_aa92543c"}
2026-05-16T16:59:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":87858,"run_id":"20260516_165902_aa92543c"}
2026-05-16T16:59:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.782,"exec_milliseconds":1782,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":87858,"important":true,"run_id":"20260516_165902_aa92543c"}
2026-05-16T17:00:19+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_170019_fa8c3f25"}
2026-05-16T17:00:19+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_170019_fa8c3f25"}
2026-05-16T17:00:19+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_170019_fa8c3f25"}
2026-05-16T17:00:19+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_170019_fa8c3f25"}
2026-05-16T17:00:19+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_170019_fa8c3f25"}
2026-05-16T17:00:19+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_170019_fa8c3f25"}
2026-05-16T17:00:19+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_170019_fa8c3f25"}
2026-05-16T17:00:20+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_170019_fa8c3f25"}
2026-05-16T17:00:20+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":5091,"mtime":"2026-05-16T16:31:28+02:00","run_id":"20260516_170019_fa8c3f25"}
2026-05-16T17:00:20+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_170019_fa8c3f25"}
2026-05-16T17:00:20+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":4676,"mtime":"2026-05-16T16:31:27+02:00","run_id":"20260516_170019_fa8c3f25"}
2026-05-16T17:00:20+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_170019_fa8c3f25"}
2026-05-16T17:00:20+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_170019_fa8c3f25"}
2026-05-16T17:00:20+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.955,"duration_milliseconds":955,"important":true,"run_id":"20260516_170019_fa8c3f25"}
2026-05-16T17:00:20+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_170019_fa8c3f25"}
2026-05-16T17:00:20+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_170019_fa8c3f25"}
2026-05-16T17:00:20+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_170019_fa8c3f25"}
2026-05-16T17:00:20+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.047,"duration_milliseconds":47,"important":true,"run_id":"20260516_170019_fa8c3f25"}
2026-05-16T17:00:20+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":87858,"run_id":"20260516_170019_fa8c3f25"}
2026-05-16T17:00:20+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.783,"exec_milliseconds":1783,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":87858,"important":true,"run_id":"20260516_170019_fa8c3f25"}
2026-05-16T17:01:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_170102_1ba800a2"}
2026-05-16T17:01:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_170102_1ba800a2"}
2026-05-16T17:01:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_170102_1ba800a2"}
2026-05-16T17:01:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_170102_1ba800a2"}
2026-05-16T17:01:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_170102_1ba800a2"}
2026-05-16T17:01:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_170102_1ba800a2"}
2026-05-16T17:01:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_170102_1ba800a2"}
2026-05-16T17:01:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_170102_1ba800a2"}
2026-05-16T17:01:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":5091,"mtime":"2026-05-16T16:31:28+02:00","run_id":"20260516_170102_1ba800a2"}
2026-05-16T17:01:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_170102_1ba800a2"}
2026-05-16T17:01:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":4676,"mtime":"2026-05-16T16:31:27+02:00","run_id":"20260516_170102_1ba800a2"}
2026-05-16T17:01:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_170102_1ba800a2"}
2026-05-16T17:01:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_170102_1ba800a2"}
2026-05-16T17:01:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.964,"duration_milliseconds":964,"important":true,"run_id":"20260516_170102_1ba800a2"}
2026-05-16T17:01:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_170102_1ba800a2"}
2026-05-16T17:01:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_170102_1ba800a2"}
2026-05-16T17:01:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_170102_1ba800a2"}
2026-05-16T17:01:03+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.049,"duration_milliseconds":49,"important":true,"run_id":"20260516_170102_1ba800a2"}
2026-05-16T17:01:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":87858,"run_id":"20260516_170102_1ba800a2"}
2026-05-16T17:01:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.797,"exec_milliseconds":1797,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":87858,"important":true,"run_id":"20260516_170102_1ba800a2"}
2026-05-16T17:02:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_170202_1bd9b935"}
2026-05-16T17:02:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_170202_1bd9b935"}
2026-05-16T17:02:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_170202_1bd9b935"}
2026-05-16T17:02:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_170202_1bd9b935"}
2026-05-16T17:02:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_170202_1bd9b935"}
2026-05-16T17:02:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_170202_1bd9b935"}
2026-05-16T17:02:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_170202_1bd9b935"}
2026-05-16T17:02:04+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_170202_1bd9b935"}
2026-05-16T17:02:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":5091,"mtime":"2026-05-16T16:31:28+02:00","run_id":"20260516_170202_1bd9b935"}
2026-05-16T17:02:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_170202_1bd9b935"}
2026-05-16T17:02:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":4676,"mtime":"2026-05-16T16:31:27+02:00","run_id":"20260516_170202_1bd9b935"}
2026-05-16T17:02:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_170202_1bd9b935"}
2026-05-16T17:02:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_170202_1bd9b935"}
2026-05-16T17:02:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.967,"duration_milliseconds":967,"important":true,"run_id":"20260516_170202_1bd9b935"}
2026-05-16T17:02:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_170202_1bd9b935"}
2026-05-16T17:02:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_170202_1bd9b935"}
2026-05-16T17:02:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_170202_1bd9b935"}
2026-05-16T17:02:04+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.043,"duration_milliseconds":43,"important":true,"run_id":"20260516_170202_1bd9b935"}
2026-05-16T17:02:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":87858,"run_id":"20260516_170202_1bd9b935"}
2026-05-16T17:02:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.798,"exec_milliseconds":1798,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":87858,"important":true,"run_id":"20260516_170202_1bd9b935"}
2026-05-16T17:03:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_170301_56bdd892"}
2026-05-16T17:03:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_170301_56bdd892"}
2026-05-16T17:03:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_170301_56bdd892"}
2026-05-16T17:03:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_170301_56bdd892"}
2026-05-16T17:03:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_170301_56bdd892"}
2026-05-16T17:03:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_170301_56bdd892"}
2026-05-16T17:03:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_170301_56bdd892"}
2026-05-16T17:03:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_170301_56bdd892"}
2026-05-16T17:03:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":5091,"mtime":"2026-05-16T16:31:28+02:00","run_id":"20260516_170301_56bdd892"}
2026-05-16T17:03:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_170301_56bdd892"}
2026-05-16T17:03:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":4676,"mtime":"2026-05-16T16:31:27+02:00","run_id":"20260516_170301_56bdd892"}
2026-05-16T17:03:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_170301_56bdd892"}
2026-05-16T17:03:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_170301_56bdd892"}
2026-05-16T17:03:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.931,"duration_milliseconds":931,"important":true,"run_id":"20260516_170301_56bdd892"}
2026-05-16T17:03:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_170301_56bdd892"}
2026-05-16T17:03:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_170301_56bdd892"}
2026-05-16T17:03:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_170301_56bdd892"}
2026-05-16T17:03:03+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.045,"duration_milliseconds":45,"important":true,"run_id":"20260516_170301_56bdd892"}
2026-05-16T17:03:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":87858,"run_id":"20260516_170301_56bdd892"}
2026-05-16T17:03:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.75,"exec_milliseconds":1750,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":87858,"important":true,"run_id":"20260516_170301_56bdd892"}
2026-05-16T17:04:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_170402_9a98fe0e"}
2026-05-16T17:04:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_170402_9a98fe0e"}
2026-05-16T17:04:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_170402_9a98fe0e"}
2026-05-16T17:04:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_170402_9a98fe0e"}
2026-05-16T17:04:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_170402_9a98fe0e"}
2026-05-16T17:04:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_170402_9a98fe0e"}
2026-05-16T17:04:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_170402_9a98fe0e"}
2026-05-16T17:04:04+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_170402_9a98fe0e"}
2026-05-16T17:04:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":5091,"mtime":"2026-05-16T16:31:28+02:00","run_id":"20260516_170402_9a98fe0e"}
2026-05-16T17:04:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_170402_9a98fe0e"}
2026-05-16T17:04:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":4676,"mtime":"2026-05-16T16:31:27+02:00","run_id":"20260516_170402_9a98fe0e"}
2026-05-16T17:04:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_170402_9a98fe0e"}
2026-05-16T17:04:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_170402_9a98fe0e"}
2026-05-16T17:04:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.978,"duration_milliseconds":978,"important":true,"run_id":"20260516_170402_9a98fe0e"}
2026-05-16T17:04:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_170402_9a98fe0e"}
2026-05-16T17:04:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_170402_9a98fe0e"}
2026-05-16T17:04:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_170402_9a98fe0e"}
2026-05-16T17:04:04+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.043,"duration_milliseconds":43,"important":true,"run_id":"20260516_170402_9a98fe0e"}
2026-05-16T17:04:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":87858,"run_id":"20260516_170402_9a98fe0e"}
2026-05-16T17:04:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.841,"exec_milliseconds":1841,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":87858,"important":true,"run_id":"20260516_170402_9a98fe0e"}
2026-05-16T17:05:04+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_170504_f935cb39"}
2026-05-16T17:05:05+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_170504_f935cb39"}
2026-05-16T17:05:05+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_170504_f935cb39"}
2026-05-16T17:05:05+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_170504_f935cb39"}
2026-05-16T17:05:05+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_170504_f935cb39"}
2026-05-16T17:05:05+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_170504_f935cb39"}
2026-05-16T17:05:05+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_170504_f935cb39"}
2026-05-16T17:05:06+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_170504_f935cb39"}
2026-05-16T17:05:06+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":5091,"mtime":"2026-05-16T16:31:28+02:00","run_id":"20260516_170504_f935cb39"}
2026-05-16T17:05:06+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_170504_f935cb39"}
2026-05-16T17:05:06+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":4676,"mtime":"2026-05-16T16:31:27+02:00","run_id":"20260516_170504_f935cb39"}
2026-05-16T17:05:06+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_170504_f935cb39"}
2026-05-16T17:05:06+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_170504_f935cb39"}
2026-05-16T17:05:06+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.937,"duration_milliseconds":937,"important":true,"run_id":"20260516_170504_f935cb39"}
2026-05-16T17:05:06+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_170504_f935cb39"}
2026-05-16T17:05:06+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_170504_f935cb39"}
2026-05-16T17:05:06+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_170504_f935cb39"}
2026-05-16T17:05:06+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.045,"duration_milliseconds":45,"important":true,"run_id":"20260516_170504_f935cb39"}
2026-05-16T17:05:06+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":87858,"run_id":"20260516_170504_f935cb39"}
2026-05-16T17:05:06+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.759,"exec_milliseconds":1759,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":87858,"important":true,"run_id":"20260516_170504_f935cb39"}
2026-05-16T17:06:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_170602_f67c1652"}
2026-05-16T17:06:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_170602_f67c1652"}
2026-05-16T17:06:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_170602_f67c1652"}
2026-05-16T17:06:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_170602_f67c1652"}
2026-05-16T17:06:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_170602_f67c1652"}
2026-05-16T17:06:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_170602_f67c1652"}
2026-05-16T17:06:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_170602_f67c1652"}
2026-05-16T17:06:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_170602_f67c1652"}
2026-05-16T17:06:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":5091,"mtime":"2026-05-16T16:31:28+02:00","run_id":"20260516_170602_f67c1652"}
2026-05-16T17:06:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_170602_f67c1652"}
2026-05-16T17:06:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":4676,"mtime":"2026-05-16T16:31:27+02:00","run_id":"20260516_170602_f67c1652"}
2026-05-16T17:06:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_170602_f67c1652"}
2026-05-16T17:06:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_170602_f67c1652"}
2026-05-16T17:06:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.932,"duration_milliseconds":932,"important":true,"run_id":"20260516_170602_f67c1652"}
2026-05-16T17:06:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_170602_f67c1652"}
2026-05-16T17:06:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_170602_f67c1652"}
2026-05-16T17:06:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_170602_f67c1652"}
2026-05-16T17:06:04+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.049,"duration_milliseconds":49,"important":true,"run_id":"20260516_170602_f67c1652"}
2026-05-16T17:06:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":87858,"run_id":"20260516_170602_f67c1652"}
2026-05-16T17:06:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.789,"exec_milliseconds":1789,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":87858,"important":true,"run_id":"20260516_170602_f67c1652"}
2026-05-16T17:07:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_170701_bbf70cfe"}
2026-05-16T17:07:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_170701_bbf70cfe"}
2026-05-16T17:07:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_170701_bbf70cfe"}
2026-05-16T17:07:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_170701_bbf70cfe"}
2026-05-16T17:07:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_170701_bbf70cfe"}
2026-05-16T17:07:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_170701_bbf70cfe"}
2026-05-16T17:07:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_170701_bbf70cfe"}
2026-05-16T17:07:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_170701_bbf70cfe"}
2026-05-16T17:07:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":5091,"mtime":"2026-05-16T16:31:28+02:00","run_id":"20260516_170701_bbf70cfe"}
2026-05-16T17:07:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_170701_bbf70cfe"}
2026-05-16T17:07:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":4676,"mtime":"2026-05-16T16:31:27+02:00","run_id":"20260516_170701_bbf70cfe"}
2026-05-16T17:07:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_170701_bbf70cfe"}
2026-05-16T17:07:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_170701_bbf70cfe"}
2026-05-16T17:07:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.959,"duration_milliseconds":959,"important":true,"run_id":"20260516_170701_bbf70cfe"}
2026-05-16T17:07:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_170701_bbf70cfe"}
2026-05-16T17:07:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_170701_bbf70cfe"}
2026-05-16T17:07:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_170701_bbf70cfe"}
2026-05-16T17:07:03+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.045,"duration_milliseconds":45,"important":true,"run_id":"20260516_170701_bbf70cfe"}
2026-05-16T17:07:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":87858,"run_id":"20260516_170701_bbf70cfe"}
2026-05-16T17:07:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.769,"exec_milliseconds":1769,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":87858,"important":true,"run_id":"20260516_170701_bbf70cfe"}
2026-05-16T17:08:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_170802_5f212af3"}
2026-05-16T17:08:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_170802_5f212af3"}
2026-05-16T17:08:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_170802_5f212af3"}
2026-05-16T17:08:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_170802_5f212af3"}
2026-05-16T17:08:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_170802_5f212af3"}
2026-05-16T17:08:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_170802_5f212af3"}
2026-05-16T17:08:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_170802_5f212af3"}
2026-05-16T17:08:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_170802_5f212af3"}
2026-05-16T17:08:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":5091,"mtime":"2026-05-16T16:31:28+02:00","run_id":"20260516_170802_5f212af3"}
2026-05-16T17:08:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_170802_5f212af3"}
2026-05-16T17:08:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":4676,"mtime":"2026-05-16T16:31:27+02:00","run_id":"20260516_170802_5f212af3"}
2026-05-16T17:08:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_170802_5f212af3"}
2026-05-16T17:08:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_170802_5f212af3"}
2026-05-16T17:08:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.943,"duration_milliseconds":943,"important":true,"run_id":"20260516_170802_5f212af3"}
2026-05-16T17:08:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_170802_5f212af3"}
2026-05-16T17:08:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_170802_5f212af3"}
2026-05-16T17:08:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_170802_5f212af3"}
2026-05-16T17:08:04+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.05,"duration_milliseconds":50,"important":true,"run_id":"20260516_170802_5f212af3"}
2026-05-16T17:08:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":87858,"run_id":"20260516_170802_5f212af3"}
2026-05-16T17:08:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.779,"exec_milliseconds":1779,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":87858,"important":true,"run_id":"20260516_170802_5f212af3"}
2026-05-16T17:09:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_170901_2e58bdcb"}
2026-05-16T17:09:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_170901_2e58bdcb"}
2026-05-16T17:09:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_170901_2e58bdcb"}
2026-05-16T17:09:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_170901_2e58bdcb"}
2026-05-16T17:09:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_170901_2e58bdcb"}
2026-05-16T17:09:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_170901_2e58bdcb"}
2026-05-16T17:09:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_170901_2e58bdcb"}
2026-05-16T17:09:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_170901_2e58bdcb"}
2026-05-16T17:09:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":5091,"mtime":"2026-05-16T16:31:28+02:00","run_id":"20260516_170901_2e58bdcb"}
2026-05-16T17:09:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_170901_2e58bdcb"}
2026-05-16T17:09:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":4676,"mtime":"2026-05-16T16:31:27+02:00","run_id":"20260516_170901_2e58bdcb"}
2026-05-16T17:09:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_170901_2e58bdcb"}
2026-05-16T17:09:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_170901_2e58bdcb"}
2026-05-16T17:09:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.915,"duration_milliseconds":915,"important":true,"run_id":"20260516_170901_2e58bdcb"}
2026-05-16T17:09:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_170901_2e58bdcb"}
2026-05-16T17:09:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_170901_2e58bdcb"}
2026-05-16T17:09:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_170901_2e58bdcb"}
2026-05-16T17:09:03+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.056,"duration_milliseconds":56,"important":true,"run_id":"20260516_170901_2e58bdcb"}
2026-05-16T17:09:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":87858,"run_id":"20260516_170901_2e58bdcb"}
2026-05-16T17:09:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.764,"exec_milliseconds":1764,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":87858,"important":true,"run_id":"20260516_170901_2e58bdcb"}
2026-05-16T17:10:06+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_171006_a8941566"}
2026-05-16T17:10:07+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_171006_a8941566"}
2026-05-16T17:10:07+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_171006_a8941566"}
2026-05-16T17:10:07+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_171006_a8941566"}
2026-05-16T17:10:07+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_171006_a8941566"}
2026-05-16T17:10:07+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_171006_a8941566"}
2026-05-16T17:10:07+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_171006_a8941566"}
2026-05-16T17:10:08+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_171006_a8941566"}
2026-05-16T17:10:08+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":5091,"mtime":"2026-05-16T16:31:28+02:00","run_id":"20260516_171006_a8941566"}
2026-05-16T17:10:08+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_171006_a8941566"}
2026-05-16T17:10:08+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":4676,"mtime":"2026-05-16T16:31:27+02:00","run_id":"20260516_171006_a8941566"}
2026-05-16T17:10:08+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_171006_a8941566"}
2026-05-16T17:10:08+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_171006_a8941566"}
2026-05-16T17:10:08+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.911,"duration_milliseconds":911,"important":true,"run_id":"20260516_171006_a8941566"}
2026-05-16T17:10:08+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_171006_a8941566"}
2026-05-16T17:10:08+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_171006_a8941566"}
2026-05-16T17:10:08+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_171006_a8941566"}
2026-05-16T17:10:08+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.046,"duration_milliseconds":46,"important":true,"run_id":"20260516_171006_a8941566"}
2026-05-16T17:10:08+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":87858,"run_id":"20260516_171006_a8941566"}
2026-05-16T17:10:08+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.732,"exec_milliseconds":1732,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":87858,"important":true,"run_id":"20260516_171006_a8941566"}
2026-05-16T17:11:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_171101_5efe07b2"}
2026-05-16T17:11:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_171101_5efe07b2"}
2026-05-16T17:11:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_171101_5efe07b2"}
2026-05-16T17:11:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_171101_5efe07b2"}
2026-05-16T17:11:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_171101_5efe07b2"}
2026-05-16T17:11:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_171101_5efe07b2"}
2026-05-16T17:11:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_171101_5efe07b2"}
2026-05-16T17:11:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_171101_5efe07b2"}
2026-05-16T17:11:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":5091,"mtime":"2026-05-16T16:31:28+02:00","run_id":"20260516_171101_5efe07b2"}
2026-05-16T17:11:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_171101_5efe07b2"}
2026-05-16T17:11:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":4676,"mtime":"2026-05-16T16:31:27+02:00","run_id":"20260516_171101_5efe07b2"}
2026-05-16T17:11:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_171101_5efe07b2"}
2026-05-16T17:11:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_171101_5efe07b2"}
2026-05-16T17:11:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.974,"duration_milliseconds":974,"important":true,"run_id":"20260516_171101_5efe07b2"}
2026-05-16T17:11:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_171101_5efe07b2"}
2026-05-16T17:11:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_171101_5efe07b2"}
2026-05-16T17:11:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_171101_5efe07b2"}
2026-05-16T17:11:03+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.046,"duration_milliseconds":46,"important":true,"run_id":"20260516_171101_5efe07b2"}
2026-05-16T17:11:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":87858,"run_id":"20260516_171101_5efe07b2"}
2026-05-16T17:11:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.785,"exec_milliseconds":1785,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":87858,"important":true,"run_id":"20260516_171101_5efe07b2"}
2026-05-16T17:12:03+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_171202_3734d5db"}
2026-05-16T17:12:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_171202_3734d5db"}
2026-05-16T17:12:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_171202_3734d5db"}
2026-05-16T17:12:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_171202_3734d5db"}
2026-05-16T17:12:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_171202_3734d5db"}
2026-05-16T17:12:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_171202_3734d5db"}
2026-05-16T17:12:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_171202_3734d5db"}
2026-05-16T17:12:04+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_171202_3734d5db"}
2026-05-16T17:12:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":5091,"mtime":"2026-05-16T16:31:28+02:00","run_id":"20260516_171202_3734d5db"}
2026-05-16T17:12:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_171202_3734d5db"}
2026-05-16T17:12:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":4676,"mtime":"2026-05-16T16:31:27+02:00","run_id":"20260516_171202_3734d5db"}
2026-05-16T17:12:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_171202_3734d5db"}
2026-05-16T17:12:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_171202_3734d5db"}
2026-05-16T17:12:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.953,"duration_milliseconds":953,"important":true,"run_id":"20260516_171202_3734d5db"}
2026-05-16T17:12:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_171202_3734d5db"}
2026-05-16T17:12:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_171202_3734d5db"}
2026-05-16T17:12:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_171202_3734d5db"}
2026-05-16T17:12:04+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.047,"duration_milliseconds":47,"important":true,"run_id":"20260516_171202_3734d5db"}
2026-05-16T17:12:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":87858,"run_id":"20260516_171202_3734d5db"}
2026-05-16T17:12:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.798,"exec_milliseconds":1798,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":87858,"important":true,"run_id":"20260516_171202_3734d5db"}
2026-05-16T17:13:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_171301_0a7e8029"}
2026-05-16T17:13:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_171301_0a7e8029"}
2026-05-16T17:13:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_171301_0a7e8029"}
2026-05-16T17:13:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_171301_0a7e8029"}
2026-05-16T17:13:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_171301_0a7e8029"}
2026-05-16T17:13:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_171301_0a7e8029"}
2026-05-16T17:13:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_171301_0a7e8029"}
2026-05-16T17:13:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_171301_0a7e8029"}
2026-05-16T17:13:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_171301_0a7e8029"}
2026-05-16T17:13:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_171301_0a7e8029"}
2026-05-16T17:13:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3742,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_171301_0a7e8029"}
2026-05-16T17:13:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_171301_0a7e8029"}
2026-05-16T17:13:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_171301_0a7e8029"}
2026-05-16T17:13:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.939,"duration_milliseconds":939,"important":true,"run_id":"20260516_171301_0a7e8029"}
2026-05-16T17:13:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_171301_0a7e8029"}
2026-05-16T17:13:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_171301_0a7e8029"}
2026-05-16T17:13:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_171301_0a7e8029"}
2026-05-16T17:13:03+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.046,"duration_milliseconds":46,"important":true,"run_id":"20260516_171301_0a7e8029"}
2026-05-16T17:13:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":79212,"run_id":"20260516_171301_0a7e8029"}
2026-05-16T17:13:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.754,"exec_milliseconds":1754,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":79212,"important":true,"run_id":"20260516_171301_0a7e8029"}
2026-05-16T17:14:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_171402_40fba148"}
2026-05-16T17:14:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_171402_40fba148"}
2026-05-16T17:14:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_171402_40fba148"}
2026-05-16T17:14:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_171402_40fba148"}
2026-05-16T17:14:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_171402_40fba148"}
2026-05-16T17:14:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_171402_40fba148"}
2026-05-16T17:14:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_171402_40fba148"}
2026-05-16T17:14:04+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_171402_40fba148"}
2026-05-16T17:14:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_171402_40fba148"}
2026-05-16T17:14:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_171402_40fba148"}
2026-05-16T17:14:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3742,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_171402_40fba148"}
2026-05-16T17:14:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_171402_40fba148"}
2026-05-16T17:14:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_171402_40fba148"}
2026-05-16T17:14:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.948,"duration_milliseconds":948,"important":true,"run_id":"20260516_171402_40fba148"}
2026-05-16T17:14:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_171402_40fba148"}
2026-05-16T17:14:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_171402_40fba148"}
2026-05-16T17:14:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_171402_40fba148"}
2026-05-16T17:14:04+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.049,"duration_milliseconds":49,"important":true,"run_id":"20260516_171402_40fba148"}
2026-05-16T17:14:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":79212,"run_id":"20260516_171402_40fba148"}
2026-05-16T17:14:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.762,"exec_milliseconds":1762,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":79212,"important":true,"run_id":"20260516_171402_40fba148"}
2026-05-16T17:15:06+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_171506_ee10e8fa"}
2026-05-16T17:15:06+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_171506_ee10e8fa"}
2026-05-16T17:15:06+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_171506_ee10e8fa"}
2026-05-16T17:15:06+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_171506_ee10e8fa"}
2026-05-16T17:15:07+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_171506_ee10e8fa"}
2026-05-16T17:15:07+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_171506_ee10e8fa"}
2026-05-16T17:15:07+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_171506_ee10e8fa"}
2026-05-16T17:15:07+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_171506_ee10e8fa"}
2026-05-16T17:15:07+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_171506_ee10e8fa"}
2026-05-16T17:15:07+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_171506_ee10e8fa"}
2026-05-16T17:15:07+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3742,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_171506_ee10e8fa"}
2026-05-16T17:15:07+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_171506_ee10e8fa"}
2026-05-16T17:15:08+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_171506_ee10e8fa"}
2026-05-16T17:15:08+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.932,"duration_milliseconds":932,"important":true,"run_id":"20260516_171506_ee10e8fa"}
2026-05-16T17:15:08+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_171506_ee10e8fa"}
2026-05-16T17:15:08+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_171506_ee10e8fa"}
2026-05-16T17:15:08+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_171506_ee10e8fa"}
2026-05-16T17:15:08+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.047,"duration_milliseconds":47,"important":true,"run_id":"20260516_171506_ee10e8fa"}
2026-05-16T17:15:08+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":79312,"run_id":"20260516_171506_ee10e8fa"}
2026-05-16T17:15:08+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.747,"exec_milliseconds":1747,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":79312,"important":true,"run_id":"20260516_171506_ee10e8fa"}
2026-05-16T17:16:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_171602_6754526d"}
2026-05-16T17:16:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_171602_6754526d"}
2026-05-16T17:16:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_171602_6754526d"}
2026-05-16T17:16:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_171602_6754526d"}
2026-05-16T17:16:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_171602_6754526d"}
2026-05-16T17:16:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_171602_6754526d"}
2026-05-16T17:16:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_171602_6754526d"}
2026-05-16T17:16:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_171602_6754526d"}
2026-05-16T17:16:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_171602_6754526d"}
2026-05-16T17:16:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_171602_6754526d"}
2026-05-16T17:16:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3742,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_171602_6754526d"}
2026-05-16T17:16:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_171602_6754526d"}
2026-05-16T17:16:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_171602_6754526d"}
2026-05-16T17:16:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.975,"duration_milliseconds":975,"important":true,"run_id":"20260516_171602_6754526d"}
2026-05-16T17:16:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_171602_6754526d"}
2026-05-16T17:16:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_171602_6754526d"}
2026-05-16T17:16:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_171602_6754526d"}
2026-05-16T17:16:04+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.048,"duration_milliseconds":48,"important":true,"run_id":"20260516_171602_6754526d"}
2026-05-16T17:16:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":79312,"run_id":"20260516_171602_6754526d"}
2026-05-16T17:16:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.8,"exec_milliseconds":1800,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":79312,"important":true,"run_id":"20260516_171602_6754526d"}
2026-05-16T17:17:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_171702_55211aab"}
2026-05-16T17:17:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_171702_55211aab"}
2026-05-16T17:17:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_171702_55211aab"}
2026-05-16T17:17:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_171702_55211aab"}
2026-05-16T17:17:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_171702_55211aab"}
2026-05-16T17:17:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_171702_55211aab"}
2026-05-16T17:17:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_171702_55211aab"}
2026-05-16T17:17:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_171702_55211aab"}
2026-05-16T17:17:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_171702_55211aab"}
2026-05-16T17:17:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_171702_55211aab"}
2026-05-16T17:17:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3742,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_171702_55211aab"}
2026-05-16T17:17:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_171702_55211aab"}
2026-05-16T17:17:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_171702_55211aab"}
2026-05-16T17:17:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.968,"duration_milliseconds":968,"important":true,"run_id":"20260516_171702_55211aab"}
2026-05-16T17:17:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_171702_55211aab"}
2026-05-16T17:17:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_171702_55211aab"}
2026-05-16T17:17:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_171702_55211aab"}
2026-05-16T17:17:03+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.048,"duration_milliseconds":48,"important":true,"run_id":"20260516_171702_55211aab"}
2026-05-16T17:17:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":79312,"run_id":"20260516_171702_55211aab"}
2026-05-16T17:17:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.818,"exec_milliseconds":1818,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":79312,"important":true,"run_id":"20260516_171702_55211aab"}
2026-05-16T17:18:03+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_171803_6aebba26"}
2026-05-16T17:18:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_171803_6aebba26"}
2026-05-16T17:18:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_171803_6aebba26"}
2026-05-16T17:18:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_171803_6aebba26"}
2026-05-16T17:18:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_171803_6aebba26"}
2026-05-16T17:18:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_171803_6aebba26"}
2026-05-16T17:18:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_171803_6aebba26"}
2026-05-16T17:18:04+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_171803_6aebba26"}
2026-05-16T17:18:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_171803_6aebba26"}
2026-05-16T17:18:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_171803_6aebba26"}
2026-05-16T17:18:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3742,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_171803_6aebba26"}
2026-05-16T17:18:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_171803_6aebba26"}
2026-05-16T17:18:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_171803_6aebba26"}
2026-05-16T17:18:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.91,"duration_milliseconds":910,"important":true,"run_id":"20260516_171803_6aebba26"}
2026-05-16T17:18:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_171803_6aebba26"}
2026-05-16T17:18:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_171803_6aebba26"}
2026-05-16T17:18:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_171803_6aebba26"}
2026-05-16T17:18:04+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.046,"duration_milliseconds":46,"important":true,"run_id":"20260516_171803_6aebba26"}
2026-05-16T17:18:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":79312,"run_id":"20260516_171803_6aebba26"}
2026-05-16T17:18:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.701,"exec_milliseconds":1701,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":79312,"important":true,"run_id":"20260516_171803_6aebba26"}
2026-05-16T17:19:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_171901_8409d501"}
2026-05-16T17:19:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_171901_8409d501"}
2026-05-16T17:19:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_171901_8409d501"}
2026-05-16T17:19:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_171901_8409d501"}
2026-05-16T17:19:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_171901_8409d501"}
2026-05-16T17:19:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_171901_8409d501"}
2026-05-16T17:19:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_171901_8409d501"}
2026-05-16T17:19:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_171901_8409d501"}
2026-05-16T17:19:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_171901_8409d501"}
2026-05-16T17:19:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_171901_8409d501"}
2026-05-16T17:19:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3742,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_171901_8409d501"}
2026-05-16T17:19:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_171901_8409d501"}
2026-05-16T17:19:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_171901_8409d501"}
2026-05-16T17:19:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.942,"duration_milliseconds":942,"important":true,"run_id":"20260516_171901_8409d501"}
2026-05-16T17:19:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_171901_8409d501"}
2026-05-16T17:19:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_171901_8409d501"}
2026-05-16T17:19:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_171901_8409d501"}
2026-05-16T17:19:03+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.038,"duration_milliseconds":38,"important":true,"run_id":"20260516_171901_8409d501"}
2026-05-16T17:19:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":79312,"run_id":"20260516_171901_8409d501"}
2026-05-16T17:19:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.749,"exec_milliseconds":1749,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":79312,"important":true,"run_id":"20260516_171901_8409d501"}
2026-05-16T17:20:07+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_172007_02091d42"}
2026-05-16T17:20:07+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_172007_02091d42"}
2026-05-16T17:20:07+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_172007_02091d42"}
2026-05-16T17:20:07+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_172007_02091d42"}
2026-05-16T17:20:07+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_172007_02091d42"}
2026-05-16T17:20:07+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_172007_02091d42"}
2026-05-16T17:20:07+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_172007_02091d42"}
2026-05-16T17:20:08+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_172007_02091d42"}
2026-05-16T17:20:08+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_172007_02091d42"}
2026-05-16T17:20:08+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_172007_02091d42"}
2026-05-16T17:20:08+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3742,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_172007_02091d42"}
2026-05-16T17:20:08+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_172007_02091d42"}
2026-05-16T17:20:08+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_172007_02091d42"}
2026-05-16T17:20:08+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.959,"duration_milliseconds":959,"important":true,"run_id":"20260516_172007_02091d42"}
2026-05-16T17:20:08+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_172007_02091d42"}
2026-05-16T17:20:08+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_172007_02091d42"}
2026-05-16T17:20:08+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_172007_02091d42"}
2026-05-16T17:20:08+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.045,"duration_milliseconds":45,"important":true,"run_id":"20260516_172007_02091d42"}
2026-05-16T17:20:08+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":79312,"run_id":"20260516_172007_02091d42"}
2026-05-16T17:20:08+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.783,"exec_milliseconds":1783,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":79312,"important":true,"run_id":"20260516_172007_02091d42"}
2026-05-16T17:21:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_172102_40e7df35"}
2026-05-16T17:21:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_172102_40e7df35"}
2026-05-16T17:21:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_172102_40e7df35"}
2026-05-16T17:21:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_172102_40e7df35"}
2026-05-16T17:21:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_172102_40e7df35"}
2026-05-16T17:21:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_172102_40e7df35"}
2026-05-16T17:21:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_172102_40e7df35"}
2026-05-16T17:21:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_172102_40e7df35"}
2026-05-16T17:21:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_172102_40e7df35"}
2026-05-16T17:21:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_172102_40e7df35"}
2026-05-16T17:21:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3742,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_172102_40e7df35"}
2026-05-16T17:21:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_172102_40e7df35"}
2026-05-16T17:21:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_172102_40e7df35"}
2026-05-16T17:21:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.945,"duration_milliseconds":945,"important":true,"run_id":"20260516_172102_40e7df35"}
2026-05-16T17:21:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_172102_40e7df35"}
2026-05-16T17:21:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_172102_40e7df35"}
2026-05-16T17:21:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_172102_40e7df35"}
2026-05-16T17:21:03+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.046,"duration_milliseconds":46,"important":true,"run_id":"20260516_172102_40e7df35"}
2026-05-16T17:21:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":79312,"run_id":"20260516_172102_40e7df35"}
2026-05-16T17:21:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.765,"exec_milliseconds":1765,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":79312,"important":true,"run_id":"20260516_172102_40e7df35"}
2026-05-16T17:22:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_172202_1324f5b9"}
2026-05-16T17:22:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_172202_1324f5b9"}
2026-05-16T17:22:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_172202_1324f5b9"}
2026-05-16T17:22:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_172202_1324f5b9"}
2026-05-16T17:22:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_172202_1324f5b9"}
2026-05-16T17:22:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_172202_1324f5b9"}
2026-05-16T17:22:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_172202_1324f5b9"}
2026-05-16T17:22:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_172202_1324f5b9"}
2026-05-16T17:22:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_172202_1324f5b9"}
2026-05-16T17:22:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_172202_1324f5b9"}
2026-05-16T17:22:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3742,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_172202_1324f5b9"}
2026-05-16T17:22:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_172202_1324f5b9"}
2026-05-16T17:22:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_172202_1324f5b9"}
2026-05-16T17:22:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.924,"duration_milliseconds":924,"important":true,"run_id":"20260516_172202_1324f5b9"}
2026-05-16T17:22:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_172202_1324f5b9"}
2026-05-16T17:22:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_172202_1324f5b9"}
2026-05-16T17:22:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_172202_1324f5b9"}
2026-05-16T17:22:04+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.044,"duration_milliseconds":44,"important":true,"run_id":"20260516_172202_1324f5b9"}
2026-05-16T17:22:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":79312,"run_id":"20260516_172202_1324f5b9"}
2026-05-16T17:22:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.735,"exec_milliseconds":1735,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":79312,"important":true,"run_id":"20260516_172202_1324f5b9"}
2026-05-16T17:23:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_172301_535ee31c"}
2026-05-16T17:23:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_172301_535ee31c"}
2026-05-16T17:23:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_172301_535ee31c"}
2026-05-16T17:23:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_172301_535ee31c"}
2026-05-16T17:23:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_172301_535ee31c"}
2026-05-16T17:23:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_172301_535ee31c"}
2026-05-16T17:23:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_172301_535ee31c"}
2026-05-16T17:23:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_172301_535ee31c"}
2026-05-16T17:23:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_172301_535ee31c"}
2026-05-16T17:23:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_172301_535ee31c"}
2026-05-16T17:23:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3742,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_172301_535ee31c"}
2026-05-16T17:23:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_172301_535ee31c"}
2026-05-16T17:23:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_172301_535ee31c"}
2026-05-16T17:23:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.962,"duration_milliseconds":962,"important":true,"run_id":"20260516_172301_535ee31c"}
2026-05-16T17:23:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_172301_535ee31c"}
2026-05-16T17:23:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_172301_535ee31c"}
2026-05-16T17:23:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_172301_535ee31c"}
2026-05-16T17:23:03+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.047,"duration_milliseconds":47,"important":true,"run_id":"20260516_172301_535ee31c"}
2026-05-16T17:23:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":79312,"run_id":"20260516_172301_535ee31c"}
2026-05-16T17:23:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.768,"exec_milliseconds":1768,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":79312,"important":true,"run_id":"20260516_172301_535ee31c"}
2026-05-16T17:24:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_172402_63f5613f"}
2026-05-16T17:24:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_172402_63f5613f"}
2026-05-16T17:24:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_172402_63f5613f"}
2026-05-16T17:24:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_172402_63f5613f"}
2026-05-16T17:24:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_172402_63f5613f"}
2026-05-16T17:24:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_172402_63f5613f"}
2026-05-16T17:24:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_172402_63f5613f"}
2026-05-16T17:24:04+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_172402_63f5613f"}
2026-05-16T17:24:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_172402_63f5613f"}
2026-05-16T17:24:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_172402_63f5613f"}
2026-05-16T17:24:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3742,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_172402_63f5613f"}
2026-05-16T17:24:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_172402_63f5613f"}
2026-05-16T17:24:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_172402_63f5613f"}
2026-05-16T17:24:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.951,"duration_milliseconds":951,"important":true,"run_id":"20260516_172402_63f5613f"}
2026-05-16T17:24:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_172402_63f5613f"}
2026-05-16T17:24:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_172402_63f5613f"}
2026-05-16T17:24:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_172402_63f5613f"}
2026-05-16T17:24:04+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.046,"duration_milliseconds":46,"important":true,"run_id":"20260516_172402_63f5613f"}
2026-05-16T17:24:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":79312,"run_id":"20260516_172402_63f5613f"}
2026-05-16T17:24:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.741,"exec_milliseconds":1741,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":79312,"important":true,"run_id":"20260516_172402_63f5613f"}
2026-05-16T17:25:04+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_172503_018dedb8"}
2026-05-16T17:25:04+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_172503_018dedb8"}
2026-05-16T17:25:04+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_172503_018dedb8"}
2026-05-16T17:25:04+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_172503_018dedb8"}
2026-05-16T17:25:04+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_172503_018dedb8"}
2026-05-16T17:25:04+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_172503_018dedb8"}
2026-05-16T17:25:04+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_172503_018dedb8"}
2026-05-16T17:25:05+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_172503_018dedb8"}
2026-05-16T17:25:05+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_172503_018dedb8"}
2026-05-16T17:25:05+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_172503_018dedb8"}
2026-05-16T17:25:05+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3742,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_172503_018dedb8"}
2026-05-16T17:25:05+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_172503_018dedb8"}
2026-05-16T17:25:05+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_172503_018dedb8"}
2026-05-16T17:25:05+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.955,"duration_milliseconds":955,"important":true,"run_id":"20260516_172503_018dedb8"}
2026-05-16T17:25:05+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_172503_018dedb8"}
2026-05-16T17:25:05+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_172503_018dedb8"}
2026-05-16T17:25:05+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_172503_018dedb8"}
2026-05-16T17:25:05+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.051,"duration_milliseconds":51,"important":true,"run_id":"20260516_172503_018dedb8"}
2026-05-16T17:25:05+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":79312,"run_id":"20260516_172503_018dedb8"}
2026-05-16T17:25:05+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.778,"exec_milliseconds":1778,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":79312,"important":true,"run_id":"20260516_172503_018dedb8"}
2026-05-16T17:26:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_172602_c8c93fff"}
2026-05-16T17:26:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_172602_c8c93fff"}
2026-05-16T17:26:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_172602_c8c93fff"}
2026-05-16T17:26:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_172602_c8c93fff"}
2026-05-16T17:26:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_172602_c8c93fff"}
2026-05-16T17:26:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_172602_c8c93fff"}
2026-05-16T17:26:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_172602_c8c93fff"}
2026-05-16T17:26:04+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_172602_c8c93fff"}
2026-05-16T17:26:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_172602_c8c93fff"}
2026-05-16T17:26:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_172602_c8c93fff"}
2026-05-16T17:26:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3742,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_172602_c8c93fff"}
2026-05-16T17:26:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_172602_c8c93fff"}
2026-05-16T17:26:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_172602_c8c93fff"}
2026-05-16T17:26:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":1.042,"duration_milliseconds":1042,"important":true,"run_id":"20260516_172602_c8c93fff"}
2026-05-16T17:26:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_172602_c8c93fff"}
2026-05-16T17:26:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_172602_c8c93fff"}
2026-05-16T17:26:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_172602_c8c93fff"}
2026-05-16T17:26:04+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.043,"duration_milliseconds":43,"important":true,"run_id":"20260516_172602_c8c93fff"}
2026-05-16T17:26:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":79313,"run_id":"20260516_172602_c8c93fff"}
2026-05-16T17:26:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.859,"exec_milliseconds":1859,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":79313,"important":true,"run_id":"20260516_172602_c8c93fff"}
2026-05-16T17:27:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_172701_405f8006"}
2026-05-16T17:27:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_172701_405f8006"}
2026-05-16T17:27:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_172701_405f8006"}
2026-05-16T17:27:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_172701_405f8006"}
2026-05-16T17:27:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_172701_405f8006"}
2026-05-16T17:27:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_172701_405f8006"}
2026-05-16T17:27:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_172701_405f8006"}
2026-05-16T17:27:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_172701_405f8006"}
2026-05-16T17:27:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_172701_405f8006"}
2026-05-16T17:27:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_172701_405f8006"}
2026-05-16T17:27:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3742,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_172701_405f8006"}
2026-05-16T17:27:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_172701_405f8006"}
2026-05-16T17:27:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_172701_405f8006"}
2026-05-16T17:27:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.98,"duration_milliseconds":980,"important":true,"run_id":"20260516_172701_405f8006"}
2026-05-16T17:27:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_172701_405f8006"}
2026-05-16T17:27:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_172701_405f8006"}
2026-05-16T17:27:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_172701_405f8006"}
2026-05-16T17:27:03+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.05,"duration_milliseconds":50,"important":true,"run_id":"20260516_172701_405f8006"}
2026-05-16T17:27:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":79312,"run_id":"20260516_172701_405f8006"}
2026-05-16T17:27:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.788,"exec_milliseconds":1788,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":79312,"important":true,"run_id":"20260516_172701_405f8006"}
2026-05-16T17:28:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_172802_2649e97a"}
2026-05-16T17:28:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_172802_2649e97a"}
2026-05-16T17:28:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_172802_2649e97a"}
2026-05-16T17:28:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_172802_2649e97a"}
2026-05-16T17:28:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_172802_2649e97a"}
2026-05-16T17:28:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_172802_2649e97a"}
2026-05-16T17:28:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_172802_2649e97a"}
2026-05-16T17:28:04+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_172802_2649e97a"}
2026-05-16T17:28:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_172802_2649e97a"}
2026-05-16T17:28:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_172802_2649e97a"}
2026-05-16T17:28:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3742,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_172802_2649e97a"}
2026-05-16T17:28:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_172802_2649e97a"}
2026-05-16T17:28:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_172802_2649e97a"}
2026-05-16T17:28:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.942,"duration_milliseconds":942,"important":true,"run_id":"20260516_172802_2649e97a"}
2026-05-16T17:28:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_172802_2649e97a"}
2026-05-16T17:28:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_172802_2649e97a"}
2026-05-16T17:28:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_172802_2649e97a"}
2026-05-16T17:28:04+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.047,"duration_milliseconds":47,"important":true,"run_id":"20260516_172802_2649e97a"}
2026-05-16T17:28:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":79312,"run_id":"20260516_172802_2649e97a"}
2026-05-16T17:28:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.751,"exec_milliseconds":1751,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":79312,"important":true,"run_id":"20260516_172802_2649e97a"}
2026-05-16T17:29:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_172901_bc3f0ea2"}
2026-05-16T17:29:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_172901_bc3f0ea2"}
2026-05-16T17:29:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_172901_bc3f0ea2"}
2026-05-16T17:29:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_172901_bc3f0ea2"}
2026-05-16T17:29:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_172901_bc3f0ea2"}
2026-05-16T17:29:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_172901_bc3f0ea2"}
2026-05-16T17:29:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_172901_bc3f0ea2"}
2026-05-16T17:29:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_172901_bc3f0ea2"}
2026-05-16T17:29:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_172901_bc3f0ea2"}
2026-05-16T17:29:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_172901_bc3f0ea2"}
2026-05-16T17:29:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3742,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_172901_bc3f0ea2"}
2026-05-16T17:29:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_172901_bc3f0ea2"}
2026-05-16T17:29:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_172901_bc3f0ea2"}
2026-05-16T17:29:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.955,"duration_milliseconds":955,"important":true,"run_id":"20260516_172901_bc3f0ea2"}
2026-05-16T17:29:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_172901_bc3f0ea2"}
2026-05-16T17:29:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_172901_bc3f0ea2"}
2026-05-16T17:29:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_172901_bc3f0ea2"}
2026-05-16T17:29:03+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.046,"duration_milliseconds":46,"important":true,"run_id":"20260516_172901_bc3f0ea2"}
2026-05-16T17:29:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":79312,"run_id":"20260516_172901_bc3f0ea2"}
2026-05-16T17:29:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.78,"exec_milliseconds":1780,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":79312,"important":true,"run_id":"20260516_172901_bc3f0ea2"}
2026-05-16T17:30:13+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_173013_1827341f"}
2026-05-16T17:30:13+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_173013_1827341f"}
2026-05-16T17:30:13+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_173013_1827341f"}
2026-05-16T17:30:13+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_173013_1827341f"}
2026-05-16T17:30:13+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_173013_1827341f"}
2026-05-16T17:30:13+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_173013_1827341f"}
2026-05-16T17:30:13+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_173013_1827341f"}
2026-05-16T17:30:14+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_173013_1827341f"}
2026-05-16T17:30:14+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_173013_1827341f"}
2026-05-16T17:30:14+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_173013_1827341f"}
2026-05-16T17:30:14+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3742,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_173013_1827341f"}
2026-05-16T17:30:14+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_173013_1827341f"}
2026-05-16T17:30:14+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_173013_1827341f"}
2026-05-16T17:30:14+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.925,"duration_milliseconds":925,"important":true,"run_id":"20260516_173013_1827341f"}
2026-05-16T17:30:14+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_173013_1827341f"}
2026-05-16T17:30:14+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_173013_1827341f"}
2026-05-16T17:30:14+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_173013_1827341f"}
2026-05-16T17:30:14+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.038,"duration_milliseconds":38,"important":true,"run_id":"20260516_173013_1827341f"}
2026-05-16T17:30:14+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":79314,"run_id":"20260516_173013_1827341f"}
2026-05-16T17:30:14+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.721,"exec_milliseconds":1721,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":79314,"important":true,"run_id":"20260516_173013_1827341f"}
2026-05-16T17:31:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_173102_0ad4859f"}
2026-05-16T17:31:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_173102_0ad4859f"}
2026-05-16T17:31:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_173102_0ad4859f"}
2026-05-16T17:31:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_173102_0ad4859f"}
2026-05-16T17:31:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_173102_0ad4859f"}
2026-05-16T17:31:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_173102_0ad4859f"}
2026-05-16T17:31:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_173102_0ad4859f"}
2026-05-16T17:31:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_173102_0ad4859f"}
2026-05-16T17:31:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_173102_0ad4859f"}
2026-05-16T17:31:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_173102_0ad4859f"}
2026-05-16T17:31:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3742,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_173102_0ad4859f"}
2026-05-16T17:31:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_173102_0ad4859f"}
2026-05-16T17:31:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_173102_0ad4859f"}
2026-05-16T17:31:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.946,"duration_milliseconds":946,"important":true,"run_id":"20260516_173102_0ad4859f"}
2026-05-16T17:31:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_173102_0ad4859f"}
2026-05-16T17:31:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_173102_0ad4859f"}
2026-05-16T17:31:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_173102_0ad4859f"}
2026-05-16T17:31:03+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.047,"duration_milliseconds":47,"important":true,"run_id":"20260516_173102_0ad4859f"}
2026-05-16T17:31:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":79314,"run_id":"20260516_173102_0ad4859f"}
2026-05-16T17:31:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.745,"exec_milliseconds":1745,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":79314,"important":true,"run_id":"20260516_173102_0ad4859f"}
2026-05-16T17:32:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_173202_51fd44cc"}
2026-05-16T17:32:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_173202_51fd44cc"}
2026-05-16T17:32:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_173202_51fd44cc"}
2026-05-16T17:32:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_173202_51fd44cc"}
2026-05-16T17:32:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_173202_51fd44cc"}
2026-05-16T17:32:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_173202_51fd44cc"}
2026-05-16T17:32:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_173202_51fd44cc"}
2026-05-16T17:32:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_173202_51fd44cc"}
2026-05-16T17:32:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_173202_51fd44cc"}
2026-05-16T17:32:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_173202_51fd44cc"}
2026-05-16T17:32:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3742,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_173202_51fd44cc"}
2026-05-16T17:32:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_173202_51fd44cc"}
2026-05-16T17:32:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_173202_51fd44cc"}
2026-05-16T17:32:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.957,"duration_milliseconds":957,"important":true,"run_id":"20260516_173202_51fd44cc"}
2026-05-16T17:32:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_173202_51fd44cc"}
2026-05-16T17:32:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_173202_51fd44cc"}
2026-05-16T17:32:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_173202_51fd44cc"}
2026-05-16T17:32:04+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.046,"duration_milliseconds":46,"important":true,"run_id":"20260516_173202_51fd44cc"}
2026-05-16T17:32:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":79314,"run_id":"20260516_173202_51fd44cc"}
2026-05-16T17:32:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.796,"exec_milliseconds":1796,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":79314,"important":true,"run_id":"20260516_173202_51fd44cc"}
2026-05-16T17:33:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_173301_a544fa4a"}
2026-05-16T17:33:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_173301_a544fa4a"}
2026-05-16T17:33:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_173301_a544fa4a"}
2026-05-16T17:33:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_173301_a544fa4a"}
2026-05-16T17:33:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_173301_a544fa4a"}
2026-05-16T17:33:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_173301_a544fa4a"}
2026-05-16T17:33:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_173301_a544fa4a"}
2026-05-16T17:33:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_173301_a544fa4a"}
2026-05-16T17:33:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_173301_a544fa4a"}
2026-05-16T17:33:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_173301_a544fa4a"}
2026-05-16T17:33:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3742,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_173301_a544fa4a"}
2026-05-16T17:33:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_173301_a544fa4a"}
2026-05-16T17:33:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_173301_a544fa4a"}
2026-05-16T17:33:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.971,"duration_milliseconds":971,"important":true,"run_id":"20260516_173301_a544fa4a"}
2026-05-16T17:33:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_173301_a544fa4a"}
2026-05-16T17:33:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_173301_a544fa4a"}
2026-05-16T17:33:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_173301_a544fa4a"}
2026-05-16T17:33:03+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.05,"duration_milliseconds":50,"important":true,"run_id":"20260516_173301_a544fa4a"}
2026-05-16T17:33:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":79314,"run_id":"20260516_173301_a544fa4a"}
2026-05-16T17:33:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.831,"exec_milliseconds":1831,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":79314,"important":true,"run_id":"20260516_173301_a544fa4a"}
2026-05-16T17:34:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_173402_036ffff9"}
2026-05-16T17:34:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_173402_036ffff9"}
2026-05-16T17:34:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_173402_036ffff9"}
2026-05-16T17:34:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_173402_036ffff9"}
2026-05-16T17:34:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_173402_036ffff9"}
2026-05-16T17:34:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_173402_036ffff9"}
2026-05-16T17:34:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_173402_036ffff9"}
2026-05-16T17:34:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_173402_036ffff9"}
2026-05-16T17:34:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_173402_036ffff9"}
2026-05-16T17:34:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_173402_036ffff9"}
2026-05-16T17:34:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3742,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_173402_036ffff9"}
2026-05-16T17:34:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_173402_036ffff9"}
2026-05-16T17:34:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_173402_036ffff9"}
2026-05-16T17:34:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.956,"duration_milliseconds":956,"important":true,"run_id":"20260516_173402_036ffff9"}
2026-05-16T17:34:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_173402_036ffff9"}
2026-05-16T17:34:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_173402_036ffff9"}
2026-05-16T17:34:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_173402_036ffff9"}
2026-05-16T17:34:04+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.047,"duration_milliseconds":47,"important":true,"run_id":"20260516_173402_036ffff9"}
2026-05-16T17:34:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":79314,"run_id":"20260516_173402_036ffff9"}
2026-05-16T17:34:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.758,"exec_milliseconds":1758,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":79314,"important":true,"run_id":"20260516_173402_036ffff9"}
2026-05-16T17:35:04+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_173503_52212214"}
2026-05-16T17:35:04+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_173503_52212214"}
2026-05-16T17:35:04+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_173503_52212214"}
2026-05-16T17:35:04+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_173503_52212214"}
2026-05-16T17:35:04+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_173503_52212214"}
2026-05-16T17:35:04+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_173503_52212214"}
2026-05-16T17:35:04+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_173503_52212214"}
2026-05-16T17:35:05+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_173503_52212214"}
2026-05-16T17:35:05+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_173503_52212214"}
2026-05-16T17:35:05+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_173503_52212214"}
2026-05-16T17:35:05+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3742,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_173503_52212214"}
2026-05-16T17:35:05+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_173503_52212214"}
2026-05-16T17:35:05+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_173503_52212214"}
2026-05-16T17:35:05+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.936,"duration_milliseconds":936,"important":true,"run_id":"20260516_173503_52212214"}
2026-05-16T17:35:05+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_173503_52212214"}
2026-05-16T17:35:05+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_173503_52212214"}
2026-05-16T17:35:05+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_173503_52212214"}
2026-05-16T17:35:05+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.047,"duration_milliseconds":47,"important":true,"run_id":"20260516_173503_52212214"}
2026-05-16T17:35:05+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":79314,"run_id":"20260516_173503_52212214"}
2026-05-16T17:35:05+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.802,"exec_milliseconds":1802,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":79314,"important":true,"run_id":"20260516_173503_52212214"}
2026-05-16T17:36:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_173602_ba366b81"}
2026-05-16T17:36:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_173602_ba366b81"}
2026-05-16T17:36:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_173602_ba366b81"}
2026-05-16T17:36:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_173602_ba366b81"}
2026-05-16T17:36:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_173602_ba366b81"}
2026-05-16T17:36:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_173602_ba366b81"}
2026-05-16T17:36:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_173602_ba366b81"}
2026-05-16T17:36:04+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_173602_ba366b81"}
2026-05-16T17:36:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_173602_ba366b81"}
2026-05-16T17:36:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_173602_ba366b81"}
2026-05-16T17:36:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3742,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_173602_ba366b81"}
2026-05-16T17:36:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_173602_ba366b81"}
2026-05-16T17:36:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_173602_ba366b81"}
2026-05-16T17:36:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.971,"duration_milliseconds":971,"important":true,"run_id":"20260516_173602_ba366b81"}
2026-05-16T17:36:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_173602_ba366b81"}
2026-05-16T17:36:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_173602_ba366b81"}
2026-05-16T17:36:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_173602_ba366b81"}
2026-05-16T17:36:04+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.047,"duration_milliseconds":47,"important":true,"run_id":"20260516_173602_ba366b81"}
2026-05-16T17:36:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":79314,"run_id":"20260516_173602_ba366b81"}
2026-05-16T17:36:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.799,"exec_milliseconds":1799,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":79314,"important":true,"run_id":"20260516_173602_ba366b81"}
2026-05-16T17:37:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_173701_b151069c"}
2026-05-16T17:37:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_173701_b151069c"}
2026-05-16T17:37:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_173701_b151069c"}
2026-05-16T17:37:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_173701_b151069c"}
2026-05-16T17:37:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_173701_b151069c"}
2026-05-16T17:37:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_173701_b151069c"}
2026-05-16T17:37:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_173701_b151069c"}
2026-05-16T17:37:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_173701_b151069c"}
2026-05-16T17:37:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_173701_b151069c"}
2026-05-16T17:37:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_173701_b151069c"}
2026-05-16T17:37:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3742,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_173701_b151069c"}
2026-05-16T17:37:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_173701_b151069c"}
2026-05-16T17:37:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_173701_b151069c"}
2026-05-16T17:37:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.933,"duration_milliseconds":933,"important":true,"run_id":"20260516_173701_b151069c"}
2026-05-16T17:37:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_173701_b151069c"}
2026-05-16T17:37:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_173701_b151069c"}
2026-05-16T17:37:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_173701_b151069c"}
2026-05-16T17:37:03+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.044,"duration_milliseconds":44,"important":true,"run_id":"20260516_173701_b151069c"}
2026-05-16T17:37:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":79314,"run_id":"20260516_173701_b151069c"}
2026-05-16T17:37:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.746,"exec_milliseconds":1746,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":79314,"important":true,"run_id":"20260516_173701_b151069c"}
2026-05-16T17:38:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_173802_238df883"}
2026-05-16T17:38:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_173802_238df883"}
2026-05-16T17:38:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_173802_238df883"}
2026-05-16T17:38:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_173802_238df883"}
2026-05-16T17:38:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_173802_238df883"}
2026-05-16T17:38:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_173802_238df883"}
2026-05-16T17:38:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_173802_238df883"}
2026-05-16T17:38:04+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_173802_238df883"}
2026-05-16T17:38:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_173802_238df883"}
2026-05-16T17:38:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_173802_238df883"}
2026-05-16T17:38:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3742,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_173802_238df883"}
2026-05-16T17:38:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_173802_238df883"}
2026-05-16T17:38:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_173802_238df883"}
2026-05-16T17:38:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.941,"duration_milliseconds":941,"important":true,"run_id":"20260516_173802_238df883"}
2026-05-16T17:38:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_173802_238df883"}
2026-05-16T17:38:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_173802_238df883"}
2026-05-16T17:38:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_173802_238df883"}
2026-05-16T17:38:04+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.046,"duration_milliseconds":46,"important":true,"run_id":"20260516_173802_238df883"}
2026-05-16T17:38:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":79314,"run_id":"20260516_173802_238df883"}
2026-05-16T17:38:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.726,"exec_milliseconds":1726,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":79314,"important":true,"run_id":"20260516_173802_238df883"}
2026-05-16T17:39:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_173901_d8fa5398"}
2026-05-16T17:39:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_173901_d8fa5398"}
2026-05-16T17:39:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_173901_d8fa5398"}
2026-05-16T17:39:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_173901_d8fa5398"}
2026-05-16T17:39:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_173901_d8fa5398"}
2026-05-16T17:39:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_173901_d8fa5398"}
2026-05-16T17:39:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_173901_d8fa5398"}
2026-05-16T17:39:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_173901_d8fa5398"}
2026-05-16T17:39:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_173901_d8fa5398"}
2026-05-16T17:39:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_173901_d8fa5398"}
2026-05-16T17:39:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3742,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_173901_d8fa5398"}
2026-05-16T17:39:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_173901_d8fa5398"}
2026-05-16T17:39:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_173901_d8fa5398"}
2026-05-16T17:39:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.964,"duration_milliseconds":964,"important":true,"run_id":"20260516_173901_d8fa5398"}
2026-05-16T17:39:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_173901_d8fa5398"}
2026-05-16T17:39:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_173901_d8fa5398"}
2026-05-16T17:39:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_173901_d8fa5398"}
2026-05-16T17:39:03+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.049,"duration_milliseconds":49,"important":true,"run_id":"20260516_173901_d8fa5398"}
2026-05-16T17:39:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":79314,"run_id":"20260516_173901_d8fa5398"}
2026-05-16T17:39:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.788,"exec_milliseconds":1788,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":79314,"important":true,"run_id":"20260516_173901_d8fa5398"}
2026-05-16T17:40:07+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_174007_41ed0094"}
2026-05-16T17:40:07+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_174007_41ed0094"}
2026-05-16T17:40:07+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_174007_41ed0094"}
2026-05-16T17:40:07+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_174007_41ed0094"}
2026-05-16T17:40:07+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_174007_41ed0094"}
2026-05-16T17:40:07+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_174007_41ed0094"}
2026-05-16T17:40:07+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_174007_41ed0094"}
2026-05-16T17:40:08+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_174007_41ed0094"}
2026-05-16T17:40:08+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_174007_41ed0094"}
2026-05-16T17:40:08+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_174007_41ed0094"}
2026-05-16T17:40:08+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3742,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_174007_41ed0094"}
2026-05-16T17:40:08+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_174007_41ed0094"}
2026-05-16T17:40:08+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_174007_41ed0094"}
2026-05-16T17:40:08+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.96,"duration_milliseconds":960,"important":true,"run_id":"20260516_174007_41ed0094"}
2026-05-16T17:40:08+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_174007_41ed0094"}
2026-05-16T17:40:08+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_174007_41ed0094"}
2026-05-16T17:40:08+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_174007_41ed0094"}
2026-05-16T17:40:08+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.049,"duration_milliseconds":49,"important":true,"run_id":"20260516_174007_41ed0094"}
2026-05-16T17:40:08+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":79314,"run_id":"20260516_174007_41ed0094"}
2026-05-16T17:40:08+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.768,"exec_milliseconds":1768,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":79314,"important":true,"run_id":"20260516_174007_41ed0094"}
2026-05-16T17:41:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_174102_95ec90f3"}
2026-05-16T17:41:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_174102_95ec90f3"}
2026-05-16T17:41:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_174102_95ec90f3"}
2026-05-16T17:41:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_174102_95ec90f3"}
2026-05-16T17:41:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_174102_95ec90f3"}
2026-05-16T17:41:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_174102_95ec90f3"}
2026-05-16T17:41:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_174102_95ec90f3"}
2026-05-16T17:41:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_174102_95ec90f3"}
2026-05-16T17:41:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_174102_95ec90f3"}
2026-05-16T17:41:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_174102_95ec90f3"}
2026-05-16T17:41:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3742,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_174102_95ec90f3"}
2026-05-16T17:41:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_174102_95ec90f3"}
2026-05-16T17:41:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_174102_95ec90f3"}
2026-05-16T17:41:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.94,"duration_milliseconds":940,"important":true,"run_id":"20260516_174102_95ec90f3"}
2026-05-16T17:41:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_174102_95ec90f3"}
2026-05-16T17:41:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_174102_95ec90f3"}
2026-05-16T17:41:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_174102_95ec90f3"}
2026-05-16T17:41:03+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.047,"duration_milliseconds":47,"important":true,"run_id":"20260516_174102_95ec90f3"}
2026-05-16T17:41:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":79314,"run_id":"20260516_174102_95ec90f3"}
2026-05-16T17:41:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.73,"exec_milliseconds":1730,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":79314,"important":true,"run_id":"20260516_174102_95ec90f3"}
2026-05-16T17:42:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_174202_fcec2d33"}
2026-05-16T17:42:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_174202_fcec2d33"}
2026-05-16T17:42:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_174202_fcec2d33"}
2026-05-16T17:42:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_174202_fcec2d33"}
2026-05-16T17:42:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_174202_fcec2d33"}
2026-05-16T17:42:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_174202_fcec2d33"}
2026-05-16T17:42:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_174202_fcec2d33"}
2026-05-16T17:42:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_174202_fcec2d33"}
2026-05-16T17:42:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_174202_fcec2d33"}
2026-05-16T17:42:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_174202_fcec2d33"}
2026-05-16T17:42:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3742,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_174202_fcec2d33"}
2026-05-16T17:42:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_174202_fcec2d33"}
2026-05-16T17:42:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_174202_fcec2d33"}
2026-05-16T17:42:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.932,"duration_milliseconds":932,"important":true,"run_id":"20260516_174202_fcec2d33"}
2026-05-16T17:42:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_174202_fcec2d33"}
2026-05-16T17:42:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_174202_fcec2d33"}
2026-05-16T17:42:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_174202_fcec2d33"}
2026-05-16T17:42:04+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.047,"duration_milliseconds":47,"important":true,"run_id":"20260516_174202_fcec2d33"}
2026-05-16T17:42:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":79314,"run_id":"20260516_174202_fcec2d33"}
2026-05-16T17:42:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.787,"exec_milliseconds":1787,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":79314,"important":true,"run_id":"20260516_174202_fcec2d33"}
2026-05-16T17:43:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_174301_2627c872"}
2026-05-16T17:43:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_174301_2627c872"}
2026-05-16T17:43:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_174301_2627c872"}
2026-05-16T17:43:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_174301_2627c872"}
2026-05-16T17:43:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_174301_2627c872"}
2026-05-16T17:43:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_174301_2627c872"}
2026-05-16T17:43:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_174301_2627c872"}
2026-05-16T17:43:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_174301_2627c872"}
2026-05-16T17:43:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_174301_2627c872"}
2026-05-16T17:43:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_174301_2627c872"}
2026-05-16T17:43:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3742,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_174301_2627c872"}
2026-05-16T17:43:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_174301_2627c872"}
2026-05-16T17:43:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_174301_2627c872"}
2026-05-16T17:43:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.952,"duration_milliseconds":952,"important":true,"run_id":"20260516_174301_2627c872"}
2026-05-16T17:43:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_174301_2627c872"}
2026-05-16T17:43:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_174301_2627c872"}
2026-05-16T17:43:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_174301_2627c872"}
2026-05-16T17:43:03+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.047,"duration_milliseconds":47,"important":true,"run_id":"20260516_174301_2627c872"}
2026-05-16T17:43:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":79314,"run_id":"20260516_174301_2627c872"}
2026-05-16T17:43:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.774,"exec_milliseconds":1774,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":79314,"important":true,"run_id":"20260516_174301_2627c872"}
2026-05-16T17:44:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_174402_39f34053"}
2026-05-16T17:44:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_174402_39f34053"}
2026-05-16T17:44:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_174402_39f34053"}
2026-05-16T17:44:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_174402_39f34053"}
2026-05-16T17:44:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_174402_39f34053"}
2026-05-16T17:44:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_174402_39f34053"}
2026-05-16T17:44:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_174402_39f34053"}
2026-05-16T17:44:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_174402_39f34053"}
2026-05-16T17:44:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_174402_39f34053"}
2026-05-16T17:44:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_174402_39f34053"}
2026-05-16T17:44:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3742,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_174402_39f34053"}
2026-05-16T17:44:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_174402_39f34053"}
2026-05-16T17:44:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_174402_39f34053"}
2026-05-16T17:44:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.917,"duration_milliseconds":917,"important":true,"run_id":"20260516_174402_39f34053"}
2026-05-16T17:44:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_174402_39f34053"}
2026-05-16T17:44:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_174402_39f34053"}
2026-05-16T17:44:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_174402_39f34053"}
2026-05-16T17:44:04+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.056,"duration_milliseconds":56,"important":true,"run_id":"20260516_174402_39f34053"}
2026-05-16T17:44:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":79314,"run_id":"20260516_174402_39f34053"}
2026-05-16T17:44:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.745,"exec_milliseconds":1745,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":79314,"important":true,"run_id":"20260516_174402_39f34053"}
2026-05-16T17:45:06+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_174506_4bc9b602"}
2026-05-16T17:45:06+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_174506_4bc9b602"}
2026-05-16T17:45:06+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_174506_4bc9b602"}
2026-05-16T17:45:07+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_174506_4bc9b602"}
2026-05-16T17:45:07+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_174506_4bc9b602"}
2026-05-16T17:45:07+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_174506_4bc9b602"}
2026-05-16T17:45:07+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_174506_4bc9b602"}
2026-05-16T17:45:07+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_174506_4bc9b602"}
2026-05-16T17:45:07+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_174506_4bc9b602"}
2026-05-16T17:45:07+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_174506_4bc9b602"}
2026-05-16T17:45:07+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3742,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_174506_4bc9b602"}
2026-05-16T17:45:07+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_174506_4bc9b602"}
2026-05-16T17:45:08+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_174506_4bc9b602"}
2026-05-16T17:45:08+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.925,"duration_milliseconds":925,"important":true,"run_id":"20260516_174506_4bc9b602"}
2026-05-16T17:45:08+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_174506_4bc9b602"}
2026-05-16T17:45:08+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_174506_4bc9b602"}
2026-05-16T17:45:08+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_174506_4bc9b602"}
2026-05-16T17:45:08+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.042,"duration_milliseconds":42,"important":true,"run_id":"20260516_174506_4bc9b602"}
2026-05-16T17:45:08+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":79314,"run_id":"20260516_174506_4bc9b602"}
2026-05-16T17:45:08+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.697,"exec_milliseconds":1697,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":79314,"important":true,"run_id":"20260516_174506_4bc9b602"}
2026-05-16T17:46:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_174602_255cad3d"}
2026-05-16T17:46:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_174602_255cad3d"}
2026-05-16T17:46:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_174602_255cad3d"}
2026-05-16T17:46:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_174602_255cad3d"}
2026-05-16T17:46:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_174602_255cad3d"}
2026-05-16T17:46:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_174602_255cad3d"}
2026-05-16T17:46:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_174602_255cad3d"}
2026-05-16T17:46:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_174602_255cad3d"}
2026-05-16T17:46:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_174602_255cad3d"}
2026-05-16T17:46:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_174602_255cad3d"}
2026-05-16T17:46:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3742,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_174602_255cad3d"}
2026-05-16T17:46:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_174602_255cad3d"}
2026-05-16T17:46:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_174602_255cad3d"}
2026-05-16T17:46:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.929,"duration_milliseconds":929,"important":true,"run_id":"20260516_174602_255cad3d"}
2026-05-16T17:46:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_174602_255cad3d"}
2026-05-16T17:46:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_174602_255cad3d"}
2026-05-16T17:46:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_174602_255cad3d"}
2026-05-16T17:46:04+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.046,"duration_milliseconds":46,"important":true,"run_id":"20260516_174602_255cad3d"}
2026-05-16T17:46:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":79314,"run_id":"20260516_174602_255cad3d"}
2026-05-16T17:46:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.745,"exec_milliseconds":1745,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":79314,"important":true,"run_id":"20260516_174602_255cad3d"}
2026-05-16T17:47:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_174701_7141d7b0"}
2026-05-16T17:47:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_174701_7141d7b0"}
2026-05-16T17:47:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_174701_7141d7b0"}
2026-05-16T17:47:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_174701_7141d7b0"}
2026-05-16T17:47:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_174701_7141d7b0"}
2026-05-16T17:47:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_174701_7141d7b0"}
2026-05-16T17:47:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_174701_7141d7b0"}
2026-05-16T17:47:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_174701_7141d7b0"}
2026-05-16T17:47:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_174701_7141d7b0"}
2026-05-16T17:47:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_174701_7141d7b0"}
2026-05-16T17:47:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3742,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_174701_7141d7b0"}
2026-05-16T17:47:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_174701_7141d7b0"}
2026-05-16T17:47:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_174701_7141d7b0"}
2026-05-16T17:47:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.932,"duration_milliseconds":932,"important":true,"run_id":"20260516_174701_7141d7b0"}
2026-05-16T17:47:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_174701_7141d7b0"}
2026-05-16T17:47:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_174701_7141d7b0"}
2026-05-16T17:47:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_174701_7141d7b0"}
2026-05-16T17:47:03+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.042,"duration_milliseconds":42,"important":true,"run_id":"20260516_174701_7141d7b0"}
2026-05-16T17:47:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":79314,"run_id":"20260516_174701_7141d7b0"}
2026-05-16T17:47:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.762,"exec_milliseconds":1762,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":79314,"important":true,"run_id":"20260516_174701_7141d7b0"}
2026-05-16T17:48:03+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_174803_328d2fa5"}
2026-05-16T17:48:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_174803_328d2fa5"}
2026-05-16T17:48:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_174803_328d2fa5"}
2026-05-16T17:48:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_174803_328d2fa5"}
2026-05-16T17:48:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_174803_328d2fa5"}
2026-05-16T17:48:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_174803_328d2fa5"}
2026-05-16T17:48:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_174803_328d2fa5"}
2026-05-16T17:48:04+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_174803_328d2fa5"}
2026-05-16T17:48:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_174803_328d2fa5"}
2026-05-16T17:48:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_174803_328d2fa5"}
2026-05-16T17:48:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3742,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_174803_328d2fa5"}
2026-05-16T17:48:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_174803_328d2fa5"}
2026-05-16T17:48:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_174803_328d2fa5"}
2026-05-16T17:48:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.945,"duration_milliseconds":945,"important":true,"run_id":"20260516_174803_328d2fa5"}
2026-05-16T17:48:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_174803_328d2fa5"}
2026-05-16T17:48:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_174803_328d2fa5"}
2026-05-16T17:48:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_174803_328d2fa5"}
2026-05-16T17:48:04+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.047,"duration_milliseconds":47,"important":true,"run_id":"20260516_174803_328d2fa5"}
2026-05-16T17:48:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":79314,"run_id":"20260516_174803_328d2fa5"}
2026-05-16T17:48:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.742,"exec_milliseconds":1742,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":79314,"important":true,"run_id":"20260516_174803_328d2fa5"}
2026-05-16T17:49:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_174901_11935641"}
2026-05-16T17:49:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_174901_11935641"}
2026-05-16T17:49:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_174901_11935641"}
2026-05-16T17:49:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_174901_11935641"}
2026-05-16T17:49:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_174901_11935641"}
2026-05-16T17:49:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_174901_11935641"}
2026-05-16T17:49:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_174901_11935641"}
2026-05-16T17:49:02+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_174901_11935641"}
2026-05-16T17:49:02+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_174901_11935641"}
2026-05-16T17:49:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_174901_11935641"}
2026-05-16T17:49:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3742,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_174901_11935641"}
2026-05-16T17:49:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_174901_11935641"}
2026-05-16T17:49:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_174901_11935641"}
2026-05-16T17:49:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.946,"duration_milliseconds":946,"important":true,"run_id":"20260516_174901_11935641"}
2026-05-16T17:49:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_174901_11935641"}
2026-05-16T17:49:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_174901_11935641"}
2026-05-16T17:49:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_174901_11935641"}
2026-05-16T17:49:03+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.045,"duration_milliseconds":45,"important":true,"run_id":"20260516_174901_11935641"}
2026-05-16T17:49:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":79314,"run_id":"20260516_174901_11935641"}
2026-05-16T17:49:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.736,"exec_milliseconds":1736,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":79314,"important":true,"run_id":"20260516_174901_11935641"}
2026-05-16T17:50:07+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_175007_b7794401"}
2026-05-16T17:50:07+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_175007_b7794401"}
2026-05-16T17:50:07+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_175007_b7794401"}
2026-05-16T17:50:07+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_175007_b7794401"}
2026-05-16T17:50:07+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_175007_b7794401"}
2026-05-16T17:50:07+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_175007_b7794401"}
2026-05-16T17:50:07+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_175007_b7794401"}
2026-05-16T17:50:08+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_175007_b7794401"}
2026-05-16T17:50:08+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_175007_b7794401"}
2026-05-16T17:50:08+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_175007_b7794401"}
2026-05-16T17:50:08+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3742,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_175007_b7794401"}
2026-05-16T17:50:08+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_175007_b7794401"}
2026-05-16T17:50:08+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_175007_b7794401"}
2026-05-16T17:50:08+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.97,"duration_milliseconds":970,"important":true,"run_id":"20260516_175007_b7794401"}
2026-05-16T17:50:09+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_175007_b7794401"}
2026-05-16T17:50:09+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_175007_b7794401"}
2026-05-16T17:50:09+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_175007_b7794401"}
2026-05-16T17:50:09+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.052,"duration_milliseconds":52,"important":true,"run_id":"20260516_175007_b7794401"}
2026-05-16T17:50:09+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":79314,"run_id":"20260516_175007_b7794401"}
2026-05-16T17:50:09+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.784,"exec_milliseconds":1784,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":79314,"important":true,"run_id":"20260516_175007_b7794401"}
2026-05-16T17:51:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_175101_3ff3420d"}
2026-05-16T17:51:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_175101_3ff3420d"}
2026-05-16T17:51:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_175101_3ff3420d"}
2026-05-16T17:51:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_175101_3ff3420d"}
2026-05-16T17:51:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_175101_3ff3420d"}
2026-05-16T17:51:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_175101_3ff3420d"}
2026-05-16T17:51:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_175101_3ff3420d"}
2026-05-16T17:51:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_175101_3ff3420d"}
2026-05-16T17:51:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_175101_3ff3420d"}
2026-05-16T17:51:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_175101_3ff3420d"}
2026-05-16T17:51:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3742,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_175101_3ff3420d"}
2026-05-16T17:51:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_175101_3ff3420d"}
2026-05-16T17:51:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_175101_3ff3420d"}
2026-05-16T17:51:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.941,"duration_milliseconds":941,"important":true,"run_id":"20260516_175101_3ff3420d"}
2026-05-16T17:51:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_175101_3ff3420d"}
2026-05-16T17:51:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_175101_3ff3420d"}
2026-05-16T17:51:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_175101_3ff3420d"}
2026-05-16T17:51:03+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.047,"duration_milliseconds":47,"important":true,"run_id":"20260516_175101_3ff3420d"}
2026-05-16T17:51:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":79314,"run_id":"20260516_175101_3ff3420d"}
2026-05-16T17:51:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.72,"exec_milliseconds":1720,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":79314,"important":true,"run_id":"20260516_175101_3ff3420d"}
2026-05-16T17:52:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_175202_cf2c8c2b"}
2026-05-16T17:52:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_175202_cf2c8c2b"}
2026-05-16T17:52:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_175202_cf2c8c2b"}
2026-05-16T17:52:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_175202_cf2c8c2b"}
2026-05-16T17:52:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_175202_cf2c8c2b"}
2026-05-16T17:52:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_175202_cf2c8c2b"}
2026-05-16T17:52:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_175202_cf2c8c2b"}
2026-05-16T17:52:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_175202_cf2c8c2b"}
2026-05-16T17:52:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_175202_cf2c8c2b"}
2026-05-16T17:52:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_175202_cf2c8c2b"}
2026-05-16T17:52:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3742,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_175202_cf2c8c2b"}
2026-05-16T17:52:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_175202_cf2c8c2b"}
2026-05-16T17:52:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_175202_cf2c8c2b"}
2026-05-16T17:52:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.963,"duration_milliseconds":963,"important":true,"run_id":"20260516_175202_cf2c8c2b"}
2026-05-16T17:52:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_175202_cf2c8c2b"}
2026-05-16T17:52:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_175202_cf2c8c2b"}
2026-05-16T17:52:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_175202_cf2c8c2b"}
2026-05-16T17:52:04+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.047,"duration_milliseconds":47,"important":true,"run_id":"20260516_175202_cf2c8c2b"}
2026-05-16T17:52:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":79314,"run_id":"20260516_175202_cf2c8c2b"}
2026-05-16T17:52:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.781,"exec_milliseconds":1781,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":79314,"important":true,"run_id":"20260516_175202_cf2c8c2b"}
2026-05-16T17:53:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_175301_7067f770"}
2026-05-16T17:53:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_175301_7067f770"}
2026-05-16T17:53:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_175301_7067f770"}
2026-05-16T17:53:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_175301_7067f770"}
2026-05-16T17:53:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_175301_7067f770"}
2026-05-16T17:53:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_175301_7067f770"}
2026-05-16T17:53:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_175301_7067f770"}
2026-05-16T17:53:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_175301_7067f770"}
2026-05-16T17:53:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_175301_7067f770"}
2026-05-16T17:53:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_175301_7067f770"}
2026-05-16T17:53:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3742,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_175301_7067f770"}
2026-05-16T17:53:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_175301_7067f770"}
2026-05-16T17:53:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_175301_7067f770"}
2026-05-16T17:53:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.938,"duration_milliseconds":938,"important":true,"run_id":"20260516_175301_7067f770"}
2026-05-16T17:53:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_175301_7067f770"}
2026-05-16T17:53:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_175301_7067f770"}
2026-05-16T17:53:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_175301_7067f770"}
2026-05-16T17:53:03+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.047,"duration_milliseconds":47,"important":true,"run_id":"20260516_175301_7067f770"}
2026-05-16T17:53:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":79314,"run_id":"20260516_175301_7067f770"}
2026-05-16T17:53:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.759,"exec_milliseconds":1759,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":79314,"important":true,"run_id":"20260516_175301_7067f770"}
2026-05-16T17:54:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_175402_ce861658"}
2026-05-16T17:54:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_175402_ce861658"}
2026-05-16T17:54:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_175402_ce861658"}
2026-05-16T17:54:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_175402_ce861658"}
2026-05-16T17:54:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_175402_ce861658"}
2026-05-16T17:54:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_175402_ce861658"}
2026-05-16T17:54:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_175402_ce861658"}
2026-05-16T17:54:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_175402_ce861658"}
2026-05-16T17:54:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_175402_ce861658"}
2026-05-16T17:54:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_175402_ce861658"}
2026-05-16T17:54:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3742,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_175402_ce861658"}
2026-05-16T17:54:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_175402_ce861658"}
2026-05-16T17:54:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_175402_ce861658"}
2026-05-16T17:54:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.976,"duration_milliseconds":976,"important":true,"run_id":"20260516_175402_ce861658"}
2026-05-16T17:54:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_175402_ce861658"}
2026-05-16T17:54:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_175402_ce861658"}
2026-05-16T17:54:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_175402_ce861658"}
2026-05-16T17:54:04+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.042,"duration_milliseconds":42,"important":true,"run_id":"20260516_175402_ce861658"}
2026-05-16T17:54:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":79314,"run_id":"20260516_175402_ce861658"}
2026-05-16T17:54:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.771,"exec_milliseconds":1771,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":79314,"important":true,"run_id":"20260516_175402_ce861658"}
2026-05-16T17:55:04+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_175504_913dcd34"}
2026-05-16T17:55:04+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_175504_913dcd34"}
2026-05-16T17:55:04+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_175504_913dcd34"}
2026-05-16T17:55:04+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_175504_913dcd34"}
2026-05-16T17:55:04+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_175504_913dcd34"}
2026-05-16T17:55:04+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_175504_913dcd34"}
2026-05-16T17:55:04+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_175504_913dcd34"}
2026-05-16T17:55:05+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_175504_913dcd34"}
2026-05-16T17:55:05+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_175504_913dcd34"}
2026-05-16T17:55:05+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_175504_913dcd34"}
2026-05-16T17:55:05+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3742,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_175504_913dcd34"}
2026-05-16T17:55:05+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_175504_913dcd34"}
2026-05-16T17:55:05+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_175504_913dcd34"}
2026-05-16T17:55:05+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.938,"duration_milliseconds":938,"important":true,"run_id":"20260516_175504_913dcd34"}
2026-05-16T17:55:05+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_175504_913dcd34"}
2026-05-16T17:55:06+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_175504_913dcd34"}
2026-05-16T17:55:06+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_175504_913dcd34"}
2026-05-16T17:55:06+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.047,"duration_milliseconds":47,"important":true,"run_id":"20260516_175504_913dcd34"}
2026-05-16T17:55:06+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":79314,"run_id":"20260516_175504_913dcd34"}
2026-05-16T17:55:06+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.738,"exec_milliseconds":1738,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":79314,"important":true,"run_id":"20260516_175504_913dcd34"}
2026-05-16T17:56:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_175602_b9ce41b2"}
2026-05-16T17:56:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_175602_b9ce41b2"}
2026-05-16T17:56:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_175602_b9ce41b2"}
2026-05-16T17:56:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_175602_b9ce41b2"}
2026-05-16T17:56:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_175602_b9ce41b2"}
2026-05-16T17:56:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_175602_b9ce41b2"}
2026-05-16T17:56:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_175602_b9ce41b2"}
2026-05-16T17:56:04+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_175602_b9ce41b2"}
2026-05-16T17:56:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_175602_b9ce41b2"}
2026-05-16T17:56:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_175602_b9ce41b2"}
2026-05-16T17:56:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3742,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_175602_b9ce41b2"}
2026-05-16T17:56:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_175602_b9ce41b2"}
2026-05-16T17:56:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_175602_b9ce41b2"}
2026-05-16T17:56:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.957,"duration_milliseconds":957,"important":true,"run_id":"20260516_175602_b9ce41b2"}
2026-05-16T17:56:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_175602_b9ce41b2"}
2026-05-16T17:56:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_175602_b9ce41b2"}
2026-05-16T17:56:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_175602_b9ce41b2"}
2026-05-16T17:56:04+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.05,"duration_milliseconds":50,"important":true,"run_id":"20260516_175602_b9ce41b2"}
2026-05-16T17:56:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":79314,"run_id":"20260516_175602_b9ce41b2"}
2026-05-16T17:56:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.787,"exec_milliseconds":1787,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":79314,"important":true,"run_id":"20260516_175602_b9ce41b2"}
2026-05-16T17:57:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_175702_7aef62bc"}
2026-05-16T17:57:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_175702_7aef62bc"}
2026-05-16T17:57:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_175702_7aef62bc"}
2026-05-16T17:57:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_175702_7aef62bc"}
2026-05-16T17:57:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_175702_7aef62bc"}
2026-05-16T17:57:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_175702_7aef62bc"}
2026-05-16T17:57:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_175702_7aef62bc"}
2026-05-16T17:57:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_175702_7aef62bc"}
2026-05-16T17:57:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_175702_7aef62bc"}
2026-05-16T17:57:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_175702_7aef62bc"}
2026-05-16T17:57:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3742,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_175702_7aef62bc"}
2026-05-16T17:57:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_175702_7aef62bc"}
2026-05-16T17:57:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_175702_7aef62bc"}
2026-05-16T17:57:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.931,"duration_milliseconds":931,"important":true,"run_id":"20260516_175702_7aef62bc"}
2026-05-16T17:57:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_175702_7aef62bc"}
2026-05-16T17:57:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_175702_7aef62bc"}
2026-05-16T17:57:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_175702_7aef62bc"}
2026-05-16T17:57:03+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.045,"duration_milliseconds":45,"important":true,"run_id":"20260516_175702_7aef62bc"}
2026-05-16T17:57:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":79314,"run_id":"20260516_175702_7aef62bc"}
2026-05-16T17:57:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.727,"exec_milliseconds":1727,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":79314,"important":true,"run_id":"20260516_175702_7aef62bc"}
2026-05-16T17:57:09+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_175709_8245ecb2"}
2026-05-16T17:57:09+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_175709_8245ecb2"}
2026-05-16T17:57:09+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_175709_8245ecb2"}
2026-05-16T17:57:09+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_175709_8245ecb2"}
2026-05-16T17:57:10+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_175709_8245ecb2"}
2026-05-16T17:57:10+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_175709_8245ecb2"}
2026-05-16T17:57:10+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_175709_8245ecb2"}
2026-05-16T17:57:10+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_175709_8245ecb2"}
2026-05-16T17:57:10+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_175709_8245ecb2"}
2026-05-16T17:57:10+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_175709_8245ecb2"}
2026-05-16T17:57:10+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3742,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_175709_8245ecb2"}
2026-05-16T17:57:10+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_175709_8245ecb2"}
2026-05-16T17:57:11+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_175709_8245ecb2"}
2026-05-16T17:57:11+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.939,"duration_milliseconds":939,"important":true,"run_id":"20260516_175709_8245ecb2"}
2026-05-16T17:57:11+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_175709_8245ecb2"}
2026-05-16T17:57:11+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_175709_8245ecb2"}
2026-05-16T17:57:11+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_175709_8245ecb2"}
2026-05-16T17:57:11+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.048,"duration_milliseconds":48,"important":true,"run_id":"20260516_175709_8245ecb2"}
2026-05-16T17:57:11+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":78801,"run_id":"20260516_175709_8245ecb2"}
2026-05-16T17:57:11+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.7,"exec_milliseconds":1700,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":78801,"important":true,"run_id":"20260516_175709_8245ecb2"}
2026-05-16T17:58:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_175802_6068e906"}
2026-05-16T17:58:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_175802_6068e906"}
2026-05-16T17:58:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_175802_6068e906"}
2026-05-16T17:58:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_175802_6068e906"}
2026-05-16T17:58:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_175802_6068e906"}
2026-05-16T17:58:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_175802_6068e906"}
2026-05-16T17:58:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_175802_6068e906"}
2026-05-16T17:58:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_175802_6068e906"}
2026-05-16T17:58:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_175802_6068e906"}
2026-05-16T17:58:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_175802_6068e906"}
2026-05-16T17:58:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3742,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_175802_6068e906"}
2026-05-16T17:58:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_175802_6068e906"}
2026-05-16T17:58:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_175802_6068e906"}
2026-05-16T17:58:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.975,"duration_milliseconds":975,"important":true,"run_id":"20260516_175802_6068e906"}
2026-05-16T17:58:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_175802_6068e906"}
2026-05-16T17:58:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_175802_6068e906"}
2026-05-16T17:58:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_175802_6068e906"}
2026-05-16T17:58:04+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.05,"duration_milliseconds":50,"important":true,"run_id":"20260516_175802_6068e906"}
2026-05-16T17:58:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":79314,"run_id":"20260516_175802_6068e906"}
2026-05-16T17:58:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.83,"exec_milliseconds":1830,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":79314,"important":true,"run_id":"20260516_175802_6068e906"}
2026-05-16T17:59:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_175901_fc73a83e"}
2026-05-16T17:59:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_175901_fc73a83e"}
2026-05-16T17:59:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_175901_fc73a83e"}
2026-05-16T17:59:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_175901_fc73a83e"}
2026-05-16T17:59:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_175901_fc73a83e"}
2026-05-16T17:59:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_175901_fc73a83e"}
2026-05-16T17:59:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_175901_fc73a83e"}
2026-05-16T17:59:02+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_175901_fc73a83e"}
2026-05-16T17:59:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_175901_fc73a83e"}
2026-05-16T17:59:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_175901_fc73a83e"}
2026-05-16T17:59:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3742,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_175901_fc73a83e"}
2026-05-16T17:59:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_175901_fc73a83e"}
2026-05-16T17:59:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_175901_fc73a83e"}
2026-05-16T17:59:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.937,"duration_milliseconds":937,"important":true,"run_id":"20260516_175901_fc73a83e"}
2026-05-16T17:59:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_175901_fc73a83e"}
2026-05-16T17:59:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_175901_fc73a83e"}
2026-05-16T17:59:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_175901_fc73a83e"}
2026-05-16T17:59:03+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.046,"duration_milliseconds":46,"important":true,"run_id":"20260516_175901_fc73a83e"}
2026-05-16T17:59:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":79314,"run_id":"20260516_175901_fc73a83e"}
2026-05-16T17:59:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.754,"exec_milliseconds":1754,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":79314,"important":true,"run_id":"20260516_175901_fc73a83e"}
2026-05-16T18:00:19+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_180019_fb7d8144"}
2026-05-16T18:00:19+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_180019_fb7d8144"}
2026-05-16T18:00:19+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_180019_fb7d8144"}
2026-05-16T18:00:19+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_180019_fb7d8144"}
2026-05-16T18:00:19+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_180019_fb7d8144"}
2026-05-16T18:00:19+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_180019_fb7d8144"}
2026-05-16T18:00:19+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_180019_fb7d8144"}
2026-05-16T18:00:20+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_180019_fb7d8144"}
2026-05-16T18:00:20+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_180019_fb7d8144"}
2026-05-16T18:00:20+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_180019_fb7d8144"}
2026-05-16T18:00:20+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3742,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_180019_fb7d8144"}
2026-05-16T18:00:20+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_180019_fb7d8144"}
2026-05-16T18:00:20+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_180019_fb7d8144"}
2026-05-16T18:00:20+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.943,"duration_milliseconds":943,"important":true,"run_id":"20260516_180019_fb7d8144"}
2026-05-16T18:00:20+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_180019_fb7d8144"}
2026-05-16T18:00:21+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_180019_fb7d8144"}
2026-05-16T18:00:21+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_180019_fb7d8144"}
2026-05-16T18:00:21+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.043,"duration_milliseconds":43,"important":true,"run_id":"20260516_180019_fb7d8144"}
2026-05-16T18:00:21+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":79314,"run_id":"20260516_180019_fb7d8144"}
2026-05-16T18:00:21+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.773,"exec_milliseconds":1773,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":79314,"important":true,"run_id":"20260516_180019_fb7d8144"}
2026-05-16T18:01:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_180101_254910b6"}
2026-05-16T18:01:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_180101_254910b6"}
2026-05-16T18:01:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_180101_254910b6"}
2026-05-16T18:01:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_180101_254910b6"}
2026-05-16T18:01:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_180101_254910b6"}
2026-05-16T18:01:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_180101_254910b6"}
2026-05-16T18:01:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_180101_254910b6"}
2026-05-16T18:01:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_180101_254910b6"}
2026-05-16T18:01:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_180101_254910b6"}
2026-05-16T18:01:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_180101_254910b6"}
2026-05-16T18:01:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3742,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_180101_254910b6"}
2026-05-16T18:01:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_180101_254910b6"}
2026-05-16T18:01:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_180101_254910b6"}
2026-05-16T18:01:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.945,"duration_milliseconds":945,"important":true,"run_id":"20260516_180101_254910b6"}
2026-05-16T18:01:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_180101_254910b6"}
2026-05-16T18:01:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_180101_254910b6"}
2026-05-16T18:01:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_180101_254910b6"}
2026-05-16T18:01:03+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.046,"duration_milliseconds":46,"important":true,"run_id":"20260516_180101_254910b6"}
2026-05-16T18:01:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":79314,"run_id":"20260516_180101_254910b6"}
2026-05-16T18:01:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.758,"exec_milliseconds":1758,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":79314,"important":true,"run_id":"20260516_180101_254910b6"}
2026-05-16T18:02:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_180202_93da060c"}
2026-05-16T18:02:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_180202_93da060c"}
2026-05-16T18:02:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_180202_93da060c"}
2026-05-16T18:02:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_180202_93da060c"}
2026-05-16T18:02:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_180202_93da060c"}
2026-05-16T18:02:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_180202_93da060c"}
2026-05-16T18:02:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_180202_93da060c"}
2026-05-16T18:02:04+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_180202_93da060c"}
2026-05-16T18:02:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_180202_93da060c"}
2026-05-16T18:02:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_180202_93da060c"}
2026-05-16T18:02:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3742,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_180202_93da060c"}
2026-05-16T18:02:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_180202_93da060c"}
2026-05-16T18:02:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_180202_93da060c"}
2026-05-16T18:02:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.944,"duration_milliseconds":944,"important":true,"run_id":"20260516_180202_93da060c"}
2026-05-16T18:02:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_180202_93da060c"}
2026-05-16T18:02:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_180202_93da060c"}
2026-05-16T18:02:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_180202_93da060c"}
2026-05-16T18:02:04+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.049,"duration_milliseconds":49,"important":true,"run_id":"20260516_180202_93da060c"}
2026-05-16T18:02:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":79314,"run_id":"20260516_180202_93da060c"}
2026-05-16T18:02:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.82,"exec_milliseconds":1820,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":79314,"important":true,"run_id":"20260516_180202_93da060c"}
2026-05-16T18:03:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_180301_4fc15b1d"}
2026-05-16T18:03:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_180301_4fc15b1d"}
2026-05-16T18:03:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_180301_4fc15b1d"}
2026-05-16T18:03:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_180301_4fc15b1d"}
2026-05-16T18:03:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_180301_4fc15b1d"}
2026-05-16T18:03:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_180301_4fc15b1d"}
2026-05-16T18:03:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_180301_4fc15b1d"}
2026-05-16T18:03:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_180301_4fc15b1d"}
2026-05-16T18:03:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_180301_4fc15b1d"}
2026-05-16T18:03:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_180301_4fc15b1d"}
2026-05-16T18:03:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3742,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_180301_4fc15b1d"}
2026-05-16T18:03:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_180301_4fc15b1d"}
2026-05-16T18:03:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_180301_4fc15b1d"}
2026-05-16T18:03:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.942,"duration_milliseconds":942,"important":true,"run_id":"20260516_180301_4fc15b1d"}
2026-05-16T18:03:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_180301_4fc15b1d"}
2026-05-16T18:03:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_180301_4fc15b1d"}
2026-05-16T18:03:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_180301_4fc15b1d"}
2026-05-16T18:03:03+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.049,"duration_milliseconds":49,"important":true,"run_id":"20260516_180301_4fc15b1d"}
2026-05-16T18:03:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":79314,"run_id":"20260516_180301_4fc15b1d"}
2026-05-16T18:03:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.763,"exec_milliseconds":1763,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":79314,"important":true,"run_id":"20260516_180301_4fc15b1d"}
2026-05-16T18:04:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_180402_5ec36e32"}
2026-05-16T18:04:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_180402_5ec36e32"}
2026-05-16T18:04:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_180402_5ec36e32"}
2026-05-16T18:04:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_180402_5ec36e32"}
2026-05-16T18:04:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_180402_5ec36e32"}
2026-05-16T18:04:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_180402_5ec36e32"}
2026-05-16T18:04:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_180402_5ec36e32"}
2026-05-16T18:04:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_180402_5ec36e32"}
2026-05-16T18:04:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_180402_5ec36e32"}
2026-05-16T18:04:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_180402_5ec36e32"}
2026-05-16T18:04:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3742,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_180402_5ec36e32"}
2026-05-16T18:04:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_180402_5ec36e32"}
2026-05-16T18:04:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_180402_5ec36e32"}
2026-05-16T18:04:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.954,"duration_milliseconds":954,"important":true,"run_id":"20260516_180402_5ec36e32"}
2026-05-16T18:04:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_180402_5ec36e32"}
2026-05-16T18:04:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_180402_5ec36e32"}
2026-05-16T18:04:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_180402_5ec36e32"}
2026-05-16T18:04:04+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.046,"duration_milliseconds":46,"important":true,"run_id":"20260516_180402_5ec36e32"}
2026-05-16T18:04:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":79314,"run_id":"20260516_180402_5ec36e32"}
2026-05-16T18:04:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.766,"exec_milliseconds":1766,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":79314,"important":true,"run_id":"20260516_180402_5ec36e32"}
2026-05-16T18:05:04+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_180504_cc4f4ad4"}
2026-05-16T18:05:04+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_180504_cc4f4ad4"}
2026-05-16T18:05:05+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_180504_cc4f4ad4"}
2026-05-16T18:05:05+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_180504_cc4f4ad4"}
2026-05-16T18:05:05+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_180504_cc4f4ad4"}
2026-05-16T18:05:05+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_180504_cc4f4ad4"}
2026-05-16T18:05:05+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_180504_cc4f4ad4"}
2026-05-16T18:05:05+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_180504_cc4f4ad4"}
2026-05-16T18:05:05+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_180504_cc4f4ad4"}
2026-05-16T18:05:05+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_180504_cc4f4ad4"}
2026-05-16T18:05:05+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3742,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_180504_cc4f4ad4"}
2026-05-16T18:05:05+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_180504_cc4f4ad4"}
2026-05-16T18:05:06+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_180504_cc4f4ad4"}
2026-05-16T18:05:06+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.923,"duration_milliseconds":923,"important":true,"run_id":"20260516_180504_cc4f4ad4"}
2026-05-16T18:05:06+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_180504_cc4f4ad4"}
2026-05-16T18:05:06+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_180504_cc4f4ad4"}
2026-05-16T18:05:06+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_180504_cc4f4ad4"}
2026-05-16T18:05:06+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.05,"duration_milliseconds":50,"important":true,"run_id":"20260516_180504_cc4f4ad4"}
2026-05-16T18:05:06+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":79314,"run_id":"20260516_180504_cc4f4ad4"}
2026-05-16T18:05:06+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.75,"exec_milliseconds":1750,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":79314,"important":true,"run_id":"20260516_180504_cc4f4ad4"}
2026-05-16T18:06:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_180602_bbf5f1b3"}
2026-05-16T18:06:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_180602_bbf5f1b3"}
2026-05-16T18:06:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_180602_bbf5f1b3"}
2026-05-16T18:06:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_180602_bbf5f1b3"}
2026-05-16T18:06:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_180602_bbf5f1b3"}
2026-05-16T18:06:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_180602_bbf5f1b3"}
2026-05-16T18:06:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_180602_bbf5f1b3"}
2026-05-16T18:06:04+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_180602_bbf5f1b3"}
2026-05-16T18:06:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_180602_bbf5f1b3"}
2026-05-16T18:06:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_180602_bbf5f1b3"}
2026-05-16T18:06:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3742,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_180602_bbf5f1b3"}
2026-05-16T18:06:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_180602_bbf5f1b3"}
2026-05-16T18:06:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_180602_bbf5f1b3"}
2026-05-16T18:06:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.935,"duration_milliseconds":935,"important":true,"run_id":"20260516_180602_bbf5f1b3"}
2026-05-16T18:06:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_180602_bbf5f1b3"}
2026-05-16T18:06:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_180602_bbf5f1b3"}
2026-05-16T18:06:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_180602_bbf5f1b3"}
2026-05-16T18:06:04+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.044,"duration_milliseconds":44,"important":true,"run_id":"20260516_180602_bbf5f1b3"}
2026-05-16T18:06:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":79314,"run_id":"20260516_180602_bbf5f1b3"}
2026-05-16T18:06:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.818,"exec_milliseconds":1818,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":79314,"important":true,"run_id":"20260516_180602_bbf5f1b3"}
2026-05-16T18:07:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_180701_7416f93a"}
2026-05-16T18:07:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_180701_7416f93a"}
2026-05-16T18:07:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_180701_7416f93a"}
2026-05-16T18:07:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_180701_7416f93a"}
2026-05-16T18:07:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_180701_7416f93a"}
2026-05-16T18:07:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_180701_7416f93a"}
2026-05-16T18:07:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_180701_7416f93a"}
2026-05-16T18:07:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_180701_7416f93a"}
2026-05-16T18:07:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_180701_7416f93a"}
2026-05-16T18:07:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_180701_7416f93a"}
2026-05-16T18:07:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3742,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_180701_7416f93a"}
2026-05-16T18:07:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_180701_7416f93a"}
2026-05-16T18:07:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_180701_7416f93a"}
2026-05-16T18:07:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.947,"duration_milliseconds":947,"important":true,"run_id":"20260516_180701_7416f93a"}
2026-05-16T18:07:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_180701_7416f93a"}
2026-05-16T18:07:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_180701_7416f93a"}
2026-05-16T18:07:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_180701_7416f93a"}
2026-05-16T18:07:03+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.047,"duration_milliseconds":47,"important":true,"run_id":"20260516_180701_7416f93a"}
2026-05-16T18:07:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":79314,"run_id":"20260516_180701_7416f93a"}
2026-05-16T18:07:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.826,"exec_milliseconds":1826,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":79314,"important":true,"run_id":"20260516_180701_7416f93a"}
2026-05-16T18:08:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_180802_207f20f9"}
2026-05-16T18:08:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_180802_207f20f9"}
2026-05-16T18:08:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_180802_207f20f9"}
2026-05-16T18:08:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_180802_207f20f9"}
2026-05-16T18:08:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_180802_207f20f9"}
2026-05-16T18:08:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_180802_207f20f9"}
2026-05-16T18:08:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_180802_207f20f9"}
2026-05-16T18:08:04+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_180802_207f20f9"}
2026-05-16T18:08:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_180802_207f20f9"}
2026-05-16T18:08:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_180802_207f20f9"}
2026-05-16T18:08:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3742,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_180802_207f20f9"}
2026-05-16T18:08:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_180802_207f20f9"}
2026-05-16T18:08:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_180802_207f20f9"}
2026-05-16T18:08:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.943,"duration_milliseconds":943,"important":true,"run_id":"20260516_180802_207f20f9"}
2026-05-16T18:08:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_180802_207f20f9"}
2026-05-16T18:08:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_180802_207f20f9"}
2026-05-16T18:08:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_180802_207f20f9"}
2026-05-16T18:08:04+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.05,"duration_milliseconds":50,"important":true,"run_id":"20260516_180802_207f20f9"}
2026-05-16T18:08:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":79314,"run_id":"20260516_180802_207f20f9"}
2026-05-16T18:08:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.753,"exec_milliseconds":1753,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":79314,"important":true,"run_id":"20260516_180802_207f20f9"}
2026-05-16T18:09:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_180901_90417837"}
2026-05-16T18:09:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_180901_90417837"}
2026-05-16T18:09:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_180901_90417837"}
2026-05-16T18:09:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_180901_90417837"}
2026-05-16T18:09:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_180901_90417837"}
2026-05-16T18:09:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_180901_90417837"}
2026-05-16T18:09:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_180901_90417837"}
2026-05-16T18:09:02+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_180901_90417837"}
2026-05-16T18:09:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_180901_90417837"}
2026-05-16T18:09:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_180901_90417837"}
2026-05-16T18:09:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3742,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_180901_90417837"}
2026-05-16T18:09:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_180901_90417837"}
2026-05-16T18:09:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_180901_90417837"}
2026-05-16T18:09:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.916,"duration_milliseconds":916,"important":true,"run_id":"20260516_180901_90417837"}
2026-05-16T18:09:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_180901_90417837"}
2026-05-16T18:09:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_180901_90417837"}
2026-05-16T18:09:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_180901_90417837"}
2026-05-16T18:09:03+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.041,"duration_milliseconds":41,"important":true,"run_id":"20260516_180901_90417837"}
2026-05-16T18:09:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":79314,"run_id":"20260516_180901_90417837"}
2026-05-16T18:09:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.716,"exec_milliseconds":1716,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":79314,"important":true,"run_id":"20260516_180901_90417837"}
2026-05-16T18:10:07+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_181006_72ca39fe"}
2026-05-16T18:10:07+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_181006_72ca39fe"}
2026-05-16T18:10:07+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_181006_72ca39fe"}
2026-05-16T18:10:07+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_181006_72ca39fe"}
2026-05-16T18:10:07+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_181006_72ca39fe"}
2026-05-16T18:10:07+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_181006_72ca39fe"}
2026-05-16T18:10:07+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_181006_72ca39fe"}
2026-05-16T18:10:08+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_181006_72ca39fe"}
2026-05-16T18:10:08+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_181006_72ca39fe"}
2026-05-16T18:10:08+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_181006_72ca39fe"}
2026-05-16T18:10:08+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3742,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_181006_72ca39fe"}
2026-05-16T18:10:08+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_181006_72ca39fe"}
2026-05-16T18:10:08+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_181006_72ca39fe"}
2026-05-16T18:10:08+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.92,"duration_milliseconds":920,"important":true,"run_id":"20260516_181006_72ca39fe"}
2026-05-16T18:10:08+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_181006_72ca39fe"}
2026-05-16T18:10:08+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_181006_72ca39fe"}
2026-05-16T18:10:08+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_181006_72ca39fe"}
2026-05-16T18:10:08+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.045,"duration_milliseconds":45,"important":true,"run_id":"20260516_181006_72ca39fe"}
2026-05-16T18:10:08+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":79314,"run_id":"20260516_181006_72ca39fe"}
2026-05-16T18:10:08+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.718,"exec_milliseconds":1718,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":79314,"important":true,"run_id":"20260516_181006_72ca39fe"}
2026-05-16T18:11:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_181101_b9d2e06a"}
2026-05-16T18:11:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_181101_b9d2e06a"}
2026-05-16T18:11:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_181101_b9d2e06a"}
2026-05-16T18:11:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_181101_b9d2e06a"}
2026-05-16T18:11:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_181101_b9d2e06a"}
2026-05-16T18:11:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_181101_b9d2e06a"}
2026-05-16T18:11:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_181101_b9d2e06a"}
2026-05-16T18:11:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_181101_b9d2e06a"}
2026-05-16T18:11:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_181101_b9d2e06a"}
2026-05-16T18:11:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_181101_b9d2e06a"}
2026-05-16T18:11:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3742,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_181101_b9d2e06a"}
2026-05-16T18:11:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_181101_b9d2e06a"}
2026-05-16T18:11:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_181101_b9d2e06a"}
2026-05-16T18:11:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.932,"duration_milliseconds":932,"important":true,"run_id":"20260516_181101_b9d2e06a"}
2026-05-16T18:11:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_181101_b9d2e06a"}
2026-05-16T18:11:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_181101_b9d2e06a"}
2026-05-16T18:11:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_181101_b9d2e06a"}
2026-05-16T18:11:03+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.046,"duration_milliseconds":46,"important":true,"run_id":"20260516_181101_b9d2e06a"}
2026-05-16T18:11:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":79314,"run_id":"20260516_181101_b9d2e06a"}
2026-05-16T18:11:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.756,"exec_milliseconds":1756,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":79314,"important":true,"run_id":"20260516_181101_b9d2e06a"}
2026-05-16T18:12:03+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_181202_a87c4daf"}
2026-05-16T18:12:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_181202_a87c4daf"}
2026-05-16T18:12:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_181202_a87c4daf"}
2026-05-16T18:12:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_181202_a87c4daf"}
2026-05-16T18:12:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_181202_a87c4daf"}
2026-05-16T18:12:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_181202_a87c4daf"}
2026-05-16T18:12:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_181202_a87c4daf"}
2026-05-16T18:12:04+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_181202_a87c4daf"}
2026-05-16T18:12:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_181202_a87c4daf"}
2026-05-16T18:12:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_181202_a87c4daf"}
2026-05-16T18:12:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3742,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_181202_a87c4daf"}
2026-05-16T18:12:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_181202_a87c4daf"}
2026-05-16T18:12:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_181202_a87c4daf"}
2026-05-16T18:12:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.921,"duration_milliseconds":921,"important":true,"run_id":"20260516_181202_a87c4daf"}
2026-05-16T18:12:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_181202_a87c4daf"}
2026-05-16T18:12:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_181202_a87c4daf"}
2026-05-16T18:12:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_181202_a87c4daf"}
2026-05-16T18:12:04+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.041,"duration_milliseconds":41,"important":true,"run_id":"20260516_181202_a87c4daf"}
2026-05-16T18:12:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":79314,"run_id":"20260516_181202_a87c4daf"}
2026-05-16T18:12:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.755,"exec_milliseconds":1755,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":79314,"important":true,"run_id":"20260516_181202_a87c4daf"}
2026-05-16T18:13:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_181301_c3c3e2bd"}
2026-05-16T18:13:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_181301_c3c3e2bd"}
2026-05-16T18:13:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_181301_c3c3e2bd"}
2026-05-16T18:13:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_181301_c3c3e2bd"}
2026-05-16T18:13:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_181301_c3c3e2bd"}
2026-05-16T18:13:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_181301_c3c3e2bd"}
2026-05-16T18:13:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_181301_c3c3e2bd"}
2026-05-16T18:13:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_181301_c3c3e2bd"}
2026-05-16T18:13:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_181301_c3c3e2bd"}
2026-05-16T18:13:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_181301_c3c3e2bd"}
2026-05-16T18:13:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3742,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_181301_c3c3e2bd"}
2026-05-16T18:13:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_181301_c3c3e2bd"}
2026-05-16T18:13:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_181301_c3c3e2bd"}
2026-05-16T18:13:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.947,"duration_milliseconds":947,"important":true,"run_id":"20260516_181301_c3c3e2bd"}
2026-05-16T18:13:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_181301_c3c3e2bd"}
2026-05-16T18:13:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_181301_c3c3e2bd"}
2026-05-16T18:13:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_181301_c3c3e2bd"}
2026-05-16T18:13:03+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.047,"duration_milliseconds":47,"important":true,"run_id":"20260516_181301_c3c3e2bd"}
2026-05-16T18:13:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":79314,"run_id":"20260516_181301_c3c3e2bd"}
2026-05-16T18:13:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.779,"exec_milliseconds":1779,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":79314,"important":true,"run_id":"20260516_181301_c3c3e2bd"}
2026-05-16T18:14:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_181402_56ceb2b8"}
2026-05-16T18:14:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_181402_56ceb2b8"}
2026-05-16T18:14:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_181402_56ceb2b8"}
2026-05-16T18:14:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_181402_56ceb2b8"}
2026-05-16T18:14:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_181402_56ceb2b8"}
2026-05-16T18:14:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_181402_56ceb2b8"}
2026-05-16T18:14:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_181402_56ceb2b8"}
2026-05-16T18:14:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_181402_56ceb2b8"}
2026-05-16T18:14:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_181402_56ceb2b8"}
2026-05-16T18:14:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_181402_56ceb2b8"}
2026-05-16T18:14:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3742,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_181402_56ceb2b8"}
2026-05-16T18:14:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_181402_56ceb2b8"}
2026-05-16T18:14:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_181402_56ceb2b8"}
2026-05-16T18:14:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.926,"duration_milliseconds":926,"important":true,"run_id":"20260516_181402_56ceb2b8"}
2026-05-16T18:14:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_181402_56ceb2b8"}
2026-05-16T18:14:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_181402_56ceb2b8"}
2026-05-16T18:14:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_181402_56ceb2b8"}
2026-05-16T18:14:04+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.045,"duration_milliseconds":45,"important":true,"run_id":"20260516_181402_56ceb2b8"}
2026-05-16T18:14:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":79314,"run_id":"20260516_181402_56ceb2b8"}
2026-05-16T18:14:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.73,"exec_milliseconds":1730,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":79314,"important":true,"run_id":"20260516_181402_56ceb2b8"}
2026-05-16T18:15:07+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_181507_00647728"}
2026-05-16T18:15:07+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_181507_00647728"}
2026-05-16T18:15:07+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_181507_00647728"}
2026-05-16T18:15:07+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_181507_00647728"}
2026-05-16T18:15:07+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_181507_00647728"}
2026-05-16T18:15:07+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_181507_00647728"}
2026-05-16T18:15:07+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_181507_00647728"}
2026-05-16T18:15:08+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_181507_00647728"}
2026-05-16T18:15:08+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_181507_00647728"}
2026-05-16T18:15:08+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_181507_00647728"}
2026-05-16T18:15:08+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3742,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_181507_00647728"}
2026-05-16T18:15:08+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_181507_00647728"}
2026-05-16T18:15:08+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_181507_00647728"}
2026-05-16T18:15:08+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.91,"duration_milliseconds":910,"important":true,"run_id":"20260516_181507_00647728"}
2026-05-16T18:15:08+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_181507_00647728"}
2026-05-16T18:15:08+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_181507_00647728"}
2026-05-16T18:15:08+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_181507_00647728"}
2026-05-16T18:15:08+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.041,"duration_milliseconds":41,"important":true,"run_id":"20260516_181507_00647728"}
2026-05-16T18:15:08+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":79314,"run_id":"20260516_181507_00647728"}
2026-05-16T18:15:08+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.71,"exec_milliseconds":1710,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":79314,"important":true,"run_id":"20260516_181507_00647728"}
2026-05-16T18:16:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_181602_d18c6f8e"}
2026-05-16T18:16:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_181602_d18c6f8e"}
2026-05-16T18:16:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_181602_d18c6f8e"}
2026-05-16T18:16:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_181602_d18c6f8e"}
2026-05-16T18:16:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_181602_d18c6f8e"}
2026-05-16T18:16:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_181602_d18c6f8e"}
2026-05-16T18:16:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_181602_d18c6f8e"}
2026-05-16T18:16:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_181602_d18c6f8e"}
2026-05-16T18:16:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_181602_d18c6f8e"}
2026-05-16T18:16:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_181602_d18c6f8e"}
2026-05-16T18:16:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3742,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_181602_d18c6f8e"}
2026-05-16T18:16:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_181602_d18c6f8e"}
2026-05-16T18:16:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_181602_d18c6f8e"}
2026-05-16T18:16:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.912,"duration_milliseconds":912,"important":true,"run_id":"20260516_181602_d18c6f8e"}
2026-05-16T18:16:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_181602_d18c6f8e"}
2026-05-16T18:16:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_181602_d18c6f8e"}
2026-05-16T18:16:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_181602_d18c6f8e"}
2026-05-16T18:16:04+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.044,"duration_milliseconds":44,"important":true,"run_id":"20260516_181602_d18c6f8e"}
2026-05-16T18:16:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":79314,"run_id":"20260516_181602_d18c6f8e"}
2026-05-16T18:16:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.741,"exec_milliseconds":1741,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":79314,"important":true,"run_id":"20260516_181602_d18c6f8e"}
2026-05-16T18:17:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_181702_98dcb46f"}
2026-05-16T18:17:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_181702_98dcb46f"}
2026-05-16T18:17:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_181702_98dcb46f"}
2026-05-16T18:17:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_181702_98dcb46f"}
2026-05-16T18:17:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_181702_98dcb46f"}
2026-05-16T18:17:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_181702_98dcb46f"}
2026-05-16T18:17:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_181702_98dcb46f"}
2026-05-16T18:17:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_181702_98dcb46f"}
2026-05-16T18:17:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_181702_98dcb46f"}
2026-05-16T18:17:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_181702_98dcb46f"}
2026-05-16T18:17:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3742,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_181702_98dcb46f"}
2026-05-16T18:17:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_181702_98dcb46f"}
2026-05-16T18:17:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_181702_98dcb46f"}
2026-05-16T18:17:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.921,"duration_milliseconds":921,"important":true,"run_id":"20260516_181702_98dcb46f"}
2026-05-16T18:17:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_181702_98dcb46f"}
2026-05-16T18:17:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_181702_98dcb46f"}
2026-05-16T18:17:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_181702_98dcb46f"}
2026-05-16T18:17:03+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.043,"duration_milliseconds":43,"important":true,"run_id":"20260516_181702_98dcb46f"}
2026-05-16T18:17:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":79314,"run_id":"20260516_181702_98dcb46f"}
2026-05-16T18:17:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.763,"exec_milliseconds":1763,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":79314,"important":true,"run_id":"20260516_181702_98dcb46f"}
2026-05-16T18:18:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_181802_7d2eb2f6"}
2026-05-16T18:18:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_181802_7d2eb2f6"}
2026-05-16T18:18:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_181802_7d2eb2f6"}
2026-05-16T18:18:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_181802_7d2eb2f6"}
2026-05-16T18:18:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_181802_7d2eb2f6"}
2026-05-16T18:18:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_181802_7d2eb2f6"}
2026-05-16T18:18:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_181802_7d2eb2f6"}
2026-05-16T18:18:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_181802_7d2eb2f6"}
2026-05-16T18:18:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_181802_7d2eb2f6"}
2026-05-16T18:18:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_181802_7d2eb2f6"}
2026-05-16T18:18:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3742,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_181802_7d2eb2f6"}
2026-05-16T18:18:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_181802_7d2eb2f6"}
2026-05-16T18:18:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_181802_7d2eb2f6"}
2026-05-16T18:18:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.924,"duration_milliseconds":924,"important":true,"run_id":"20260516_181802_7d2eb2f6"}
2026-05-16T18:18:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_181802_7d2eb2f6"}
2026-05-16T18:18:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_181802_7d2eb2f6"}
2026-05-16T18:18:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_181802_7d2eb2f6"}
2026-05-16T18:18:04+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.046,"duration_milliseconds":46,"important":true,"run_id":"20260516_181802_7d2eb2f6"}
2026-05-16T18:18:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":79314,"run_id":"20260516_181802_7d2eb2f6"}
2026-05-16T18:18:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.751,"exec_milliseconds":1751,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":79314,"important":true,"run_id":"20260516_181802_7d2eb2f6"}
2026-05-16T18:19:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_181901_431a4895"}
2026-05-16T18:19:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_181901_431a4895"}
2026-05-16T18:19:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_181901_431a4895"}
2026-05-16T18:19:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_181901_431a4895"}
2026-05-16T18:19:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_181901_431a4895"}
2026-05-16T18:19:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_181901_431a4895"}
2026-05-16T18:19:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_181901_431a4895"}
2026-05-16T18:19:02+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_181901_431a4895"}
2026-05-16T18:19:02+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_181901_431a4895"}
2026-05-16T18:19:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_181901_431a4895"}
2026-05-16T18:19:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3742,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_181901_431a4895"}
2026-05-16T18:19:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_181901_431a4895"}
2026-05-16T18:19:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_181901_431a4895"}
2026-05-16T18:19:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.947,"duration_milliseconds":947,"important":true,"run_id":"20260516_181901_431a4895"}
2026-05-16T18:19:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_181901_431a4895"}
2026-05-16T18:19:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_181901_431a4895"}
2026-05-16T18:19:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_181901_431a4895"}
2026-05-16T18:19:03+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.046,"duration_milliseconds":46,"important":true,"run_id":"20260516_181901_431a4895"}
2026-05-16T18:19:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":79314,"run_id":"20260516_181901_431a4895"}
2026-05-16T18:19:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.731,"exec_milliseconds":1731,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":79314,"important":true,"run_id":"20260516_181901_431a4895"}
2026-05-16T18:20:06+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_182006_d4c9f9ac"}
2026-05-16T18:20:06+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_182006_d4c9f9ac"}
2026-05-16T18:20:06+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_182006_d4c9f9ac"}
2026-05-16T18:20:06+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_182006_d4c9f9ac"}
2026-05-16T18:20:07+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_182006_d4c9f9ac"}
2026-05-16T18:20:07+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_182006_d4c9f9ac"}
2026-05-16T18:20:07+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_182006_d4c9f9ac"}
2026-05-16T18:20:07+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_182006_d4c9f9ac"}
2026-05-16T18:20:07+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_182006_d4c9f9ac"}
2026-05-16T18:20:07+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_182006_d4c9f9ac"}
2026-05-16T18:20:07+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3742,"mtime":"2026-05-16T17:13:02+02:00","run_id":"20260516_182006_d4c9f9ac"}
2026-05-16T18:20:07+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_182006_d4c9f9ac"}
2026-05-16T18:20:08+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_182006_d4c9f9ac"}
2026-05-16T18:20:08+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.945,"duration_milliseconds":945,"important":true,"run_id":"20260516_182006_d4c9f9ac"}
2026-05-16T18:20:08+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_182006_d4c9f9ac"}
2026-05-16T18:20:08+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_182006_d4c9f9ac"}
2026-05-16T18:20:08+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_182006_d4c9f9ac"}
2026-05-16T18:20:08+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.05,"duration_milliseconds":50,"important":true,"run_id":"20260516_182006_d4c9f9ac"}
2026-05-16T18:20:08+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":79314,"run_id":"20260516_182006_d4c9f9ac"}
2026-05-16T18:20:08+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.77,"exec_milliseconds":1770,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":79314,"important":true,"run_id":"20260516_182006_d4c9f9ac"}
2026-05-16T18:21:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_182101_c849f47e"}
2026-05-16T18:21:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_182101_c849f47e"}
2026-05-16T18:21:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_182101_c849f47e"}
2026-05-16T18:21:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_182101_c849f47e"}
2026-05-16T18:21:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_182101_c849f47e"}
2026-05-16T18:21:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_182101_c849f47e"}
2026-05-16T18:21:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_182101_c849f47e"}
2026-05-16T18:21:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_182101_c849f47e"}
2026-05-16T18:21:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T18:20:25+02:00","run_id":"20260516_182101_c849f47e"}
2026-05-16T18:21:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_182101_c849f47e"}
2026-05-16T18:21:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3752,"mtime":"2026-05-16T18:20:25+02:00","run_id":"20260516_182101_c849f47e"}
2026-05-16T18:21:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_182101_c849f47e"}
2026-05-16T18:21:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_182101_c849f47e"}
2026-05-16T18:21:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.932,"duration_milliseconds":932,"important":true,"run_id":"20260516_182101_c849f47e"}
2026-05-16T18:21:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_182101_c849f47e"}
2026-05-16T18:21:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_182101_c849f47e"}
2026-05-16T18:21:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_182101_c849f47e"}
2026-05-16T18:21:03+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.044,"duration_milliseconds":44,"important":true,"run_id":"20260516_182101_c849f47e"}
2026-05-16T18:21:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":79244,"run_id":"20260516_182101_c849f47e"}
2026-05-16T18:21:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.779,"exec_milliseconds":1779,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":79244,"important":true,"run_id":"20260516_182101_c849f47e"}
2026-05-16T18:22:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_182202_64d0047f"}
2026-05-16T18:22:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_182202_64d0047f"}
2026-05-16T18:22:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_182202_64d0047f"}
2026-05-16T18:22:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_182202_64d0047f"}
2026-05-16T18:22:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_182202_64d0047f"}
2026-05-16T18:22:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_182202_64d0047f"}
2026-05-16T18:22:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_182202_64d0047f"}
2026-05-16T18:22:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_182202_64d0047f"}
2026-05-16T18:22:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T18:21:16+02:00","run_id":"20260516_182202_64d0047f"}
2026-05-16T18:22:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_182202_64d0047f"}
2026-05-16T18:22:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3825,"mtime":"2026-05-16T18:21:16+02:00","run_id":"20260516_182202_64d0047f"}
2026-05-16T18:22:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_182202_64d0047f"}
2026-05-16T18:22:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_182202_64d0047f"}
2026-05-16T18:22:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.963,"duration_milliseconds":963,"important":true,"run_id":"20260516_182202_64d0047f"}
2026-05-16T18:22:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_182202_64d0047f"}
2026-05-16T18:22:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_182202_64d0047f"}
2026-05-16T18:22:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_182202_64d0047f"}
2026-05-16T18:22:04+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.049,"duration_milliseconds":49,"important":true,"run_id":"20260516_182202_64d0047f"}
2026-05-16T18:22:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":79558,"run_id":"20260516_182202_64d0047f"}
2026-05-16T18:22:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.786,"exec_milliseconds":1786,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":79558,"important":true,"run_id":"20260516_182202_64d0047f"}
2026-05-16T18:23:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_182301_2893ef8a"}
2026-05-16T18:23:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_182301_2893ef8a"}
2026-05-16T18:23:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_182301_2893ef8a"}
2026-05-16T18:23:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_182301_2893ef8a"}
2026-05-16T18:23:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_182301_2893ef8a"}
2026-05-16T18:23:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_182301_2893ef8a"}
2026-05-16T18:23:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_182301_2893ef8a"}
2026-05-16T18:23:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_182301_2893ef8a"}
2026-05-16T18:23:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T18:21:16+02:00","run_id":"20260516_182301_2893ef8a"}
2026-05-16T18:23:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_182301_2893ef8a"}
2026-05-16T18:23:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3825,"mtime":"2026-05-16T18:21:16+02:00","run_id":"20260516_182301_2893ef8a"}
2026-05-16T18:23:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_182301_2893ef8a"}
2026-05-16T18:23:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_182301_2893ef8a"}
2026-05-16T18:23:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.967,"duration_milliseconds":967,"important":true,"run_id":"20260516_182301_2893ef8a"}
2026-05-16T18:23:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_182301_2893ef8a"}
2026-05-16T18:23:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_182301_2893ef8a"}
2026-05-16T18:23:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_182301_2893ef8a"}
2026-05-16T18:23:03+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.05,"duration_milliseconds":50,"important":true,"run_id":"20260516_182301_2893ef8a"}
2026-05-16T18:23:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":79658,"run_id":"20260516_182301_2893ef8a"}
2026-05-16T18:23:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.775,"exec_milliseconds":1775,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":79658,"important":true,"run_id":"20260516_182301_2893ef8a"}
2026-05-16T18:24:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_182402_b8f7da47"}
2026-05-16T18:24:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_182402_b8f7da47"}
2026-05-16T18:24:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_182402_b8f7da47"}
2026-05-16T18:24:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_182402_b8f7da47"}
2026-05-16T18:24:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_182402_b8f7da47"}
2026-05-16T18:24:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_182402_b8f7da47"}
2026-05-16T18:24:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_182402_b8f7da47"}
2026-05-16T18:24:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_182402_b8f7da47"}
2026-05-16T18:24:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T18:21:16+02:00","run_id":"20260516_182402_b8f7da47"}
2026-05-16T18:24:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_182402_b8f7da47"}
2026-05-16T18:24:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3825,"mtime":"2026-05-16T18:21:16+02:00","run_id":"20260516_182402_b8f7da47"}
2026-05-16T18:24:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_182402_b8f7da47"}
2026-05-16T18:24:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_182402_b8f7da47"}
2026-05-16T18:24:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.948,"duration_milliseconds":948,"important":true,"run_id":"20260516_182402_b8f7da47"}
2026-05-16T18:24:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_182402_b8f7da47"}
2026-05-16T18:24:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_182402_b8f7da47"}
2026-05-16T18:24:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_182402_b8f7da47"}
2026-05-16T18:24:04+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.052,"duration_milliseconds":52,"important":true,"run_id":"20260516_182402_b8f7da47"}
2026-05-16T18:24:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":79658,"run_id":"20260516_182402_b8f7da47"}
2026-05-16T18:24:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.741,"exec_milliseconds":1741,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":79658,"important":true,"run_id":"20260516_182402_b8f7da47"}
2026-05-16T18:25:03+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_182503_9480be3e"}
2026-05-16T18:25:04+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_182503_9480be3e"}
2026-05-16T18:25:04+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_182503_9480be3e"}
2026-05-16T18:25:04+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_182503_9480be3e"}
2026-05-16T18:25:04+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_182503_9480be3e"}
2026-05-16T18:25:04+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_182503_9480be3e"}
2026-05-16T18:25:04+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_182503_9480be3e"}
2026-05-16T18:25:05+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_182503_9480be3e"}
2026-05-16T18:25:05+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T18:21:16+02:00","run_id":"20260516_182503_9480be3e"}
2026-05-16T18:25:05+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_182503_9480be3e"}
2026-05-16T18:25:05+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3825,"mtime":"2026-05-16T18:21:16+02:00","run_id":"20260516_182503_9480be3e"}
2026-05-16T18:25:05+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_182503_9480be3e"}
2026-05-16T18:25:05+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_182503_9480be3e"}
2026-05-16T18:25:05+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.902,"duration_milliseconds":902,"important":true,"run_id":"20260516_182503_9480be3e"}
2026-05-16T18:25:05+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_182503_9480be3e"}
2026-05-16T18:25:05+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_182503_9480be3e"}
2026-05-16T18:25:05+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_182503_9480be3e"}
2026-05-16T18:25:05+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.042,"duration_milliseconds":42,"important":true,"run_id":"20260516_182503_9480be3e"}
2026-05-16T18:25:05+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":79658,"run_id":"20260516_182503_9480be3e"}
2026-05-16T18:25:05+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.706,"exec_milliseconds":1706,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":79658,"important":true,"run_id":"20260516_182503_9480be3e"}
2026-05-16T18:26:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_182602_c68828cb"}
2026-05-16T18:26:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_182602_c68828cb"}
2026-05-16T18:26:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_182602_c68828cb"}
2026-05-16T18:26:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_182602_c68828cb"}
2026-05-16T18:26:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_182602_c68828cb"}
2026-05-16T18:26:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_182602_c68828cb"}
2026-05-16T18:26:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_182602_c68828cb"}
2026-05-16T18:26:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_182602_c68828cb"}
2026-05-16T18:26:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T18:21:16+02:00","run_id":"20260516_182602_c68828cb"}
2026-05-16T18:26:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_182602_c68828cb"}
2026-05-16T18:26:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3825,"mtime":"2026-05-16T18:21:16+02:00","run_id":"20260516_182602_c68828cb"}
2026-05-16T18:26:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_182602_c68828cb"}
2026-05-16T18:26:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_182602_c68828cb"}
2026-05-16T18:26:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.945,"duration_milliseconds":945,"important":true,"run_id":"20260516_182602_c68828cb"}
2026-05-16T18:26:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_182602_c68828cb"}
2026-05-16T18:26:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_182602_c68828cb"}
2026-05-16T18:26:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_182602_c68828cb"}
2026-05-16T18:26:04+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.051,"duration_milliseconds":51,"important":true,"run_id":"20260516_182602_c68828cb"}
2026-05-16T18:26:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":79658,"run_id":"20260516_182602_c68828cb"}
2026-05-16T18:26:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.767,"exec_milliseconds":1767,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":79658,"important":true,"run_id":"20260516_182602_c68828cb"}
2026-05-16T18:27:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_182701_e17ab1ae"}
2026-05-16T18:27:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_182701_e17ab1ae"}
2026-05-16T18:27:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_182701_e17ab1ae"}
2026-05-16T18:27:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_182701_e17ab1ae"}
2026-05-16T18:27:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_182701_e17ab1ae"}
2026-05-16T18:27:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_182701_e17ab1ae"}
2026-05-16T18:27:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_182701_e17ab1ae"}
2026-05-16T18:27:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_182701_e17ab1ae"}
2026-05-16T18:27:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T18:21:16+02:00","run_id":"20260516_182701_e17ab1ae"}
2026-05-16T18:27:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_182701_e17ab1ae"}
2026-05-16T18:27:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3825,"mtime":"2026-05-16T18:21:16+02:00","run_id":"20260516_182701_e17ab1ae"}
2026-05-16T18:27:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_182701_e17ab1ae"}
2026-05-16T18:27:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_182701_e17ab1ae"}
2026-05-16T18:27:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.966,"duration_milliseconds":966,"important":true,"run_id":"20260516_182701_e17ab1ae"}
2026-05-16T18:27:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_182701_e17ab1ae"}
2026-05-16T18:27:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_182701_e17ab1ae"}
2026-05-16T18:27:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_182701_e17ab1ae"}
2026-05-16T18:27:03+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.051,"duration_milliseconds":51,"important":true,"run_id":"20260516_182701_e17ab1ae"}
2026-05-16T18:27:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":79658,"run_id":"20260516_182701_e17ab1ae"}
2026-05-16T18:27:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.807,"exec_milliseconds":1807,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":79658,"important":true,"run_id":"20260516_182701_e17ab1ae"}
2026-05-16T18:28:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_182802_014a5e98"}
2026-05-16T18:28:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_182802_014a5e98"}
2026-05-16T18:28:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_182802_014a5e98"}
2026-05-16T18:28:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_182802_014a5e98"}
2026-05-16T18:28:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_182802_014a5e98"}
2026-05-16T18:28:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_182802_014a5e98"}
2026-05-16T18:28:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_182802_014a5e98"}
2026-05-16T18:28:04+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_182802_014a5e98"}
2026-05-16T18:28:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T18:21:16+02:00","run_id":"20260516_182802_014a5e98"}
2026-05-16T18:28:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_182802_014a5e98"}
2026-05-16T18:28:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3825,"mtime":"2026-05-16T18:21:16+02:00","run_id":"20260516_182802_014a5e98"}
2026-05-16T18:28:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_182802_014a5e98"}
2026-05-16T18:28:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_182802_014a5e98"}
2026-05-16T18:28:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.931,"duration_milliseconds":931,"important":true,"run_id":"20260516_182802_014a5e98"}
2026-05-16T18:28:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_182802_014a5e98"}
2026-05-16T18:28:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_182802_014a5e98"}
2026-05-16T18:28:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_182802_014a5e98"}
2026-05-16T18:28:04+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.045,"duration_milliseconds":45,"important":true,"run_id":"20260516_182802_014a5e98"}
2026-05-16T18:28:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":79658,"run_id":"20260516_182802_014a5e98"}
2026-05-16T18:28:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.75,"exec_milliseconds":1750,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":79658,"important":true,"run_id":"20260516_182802_014a5e98"}
2026-05-16T18:29:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_182901_b28c70a0"}
2026-05-16T18:29:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_182901_b28c70a0"}
2026-05-16T18:29:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_182901_b28c70a0"}
2026-05-16T18:29:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_182901_b28c70a0"}
2026-05-16T18:29:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_182901_b28c70a0"}
2026-05-16T18:29:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_182901_b28c70a0"}
2026-05-16T18:29:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_182901_b28c70a0"}
2026-05-16T18:29:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_182901_b28c70a0"}
2026-05-16T18:29:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T18:21:16+02:00","run_id":"20260516_182901_b28c70a0"}
2026-05-16T18:29:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_182901_b28c70a0"}
2026-05-16T18:29:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3825,"mtime":"2026-05-16T18:21:16+02:00","run_id":"20260516_182901_b28c70a0"}
2026-05-16T18:29:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_182901_b28c70a0"}
2026-05-16T18:29:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_182901_b28c70a0"}
2026-05-16T18:29:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.94,"duration_milliseconds":940,"important":true,"run_id":"20260516_182901_b28c70a0"}
2026-05-16T18:29:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_182901_b28c70a0"}
2026-05-16T18:29:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_182901_b28c70a0"}
2026-05-16T18:29:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_182901_b28c70a0"}
2026-05-16T18:29:03+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.05,"duration_milliseconds":50,"important":true,"run_id":"20260516_182901_b28c70a0"}
2026-05-16T18:29:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":79658,"run_id":"20260516_182901_b28c70a0"}
2026-05-16T18:29:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.762,"exec_milliseconds":1762,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":79658,"important":true,"run_id":"20260516_182901_b28c70a0"}
2026-05-16T18:30:11+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_183011_119507c7"}
2026-05-16T18:30:12+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_183011_119507c7"}
2026-05-16T18:30:12+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_183011_119507c7"}
2026-05-16T18:30:12+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_183011_119507c7"}
2026-05-16T18:30:12+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_183011_119507c7"}
2026-05-16T18:30:12+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_183011_119507c7"}
2026-05-16T18:30:12+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_183011_119507c7"}
2026-05-16T18:30:13+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_183011_119507c7"}
2026-05-16T18:30:13+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T18:21:16+02:00","run_id":"20260516_183011_119507c7"}
2026-05-16T18:30:13+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_183011_119507c7"}
2026-05-16T18:30:13+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3825,"mtime":"2026-05-16T18:21:16+02:00","run_id":"20260516_183011_119507c7"}
2026-05-16T18:30:13+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_183011_119507c7"}
2026-05-16T18:30:13+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_183011_119507c7"}
2026-05-16T18:30:13+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.949,"duration_milliseconds":949,"important":true,"run_id":"20260516_183011_119507c7"}
2026-05-16T18:30:13+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_183011_119507c7"}
2026-05-16T18:30:13+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_183011_119507c7"}
2026-05-16T18:30:13+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_183011_119507c7"}
2026-05-16T18:30:13+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.046,"duration_milliseconds":46,"important":true,"run_id":"20260516_183011_119507c7"}
2026-05-16T18:30:13+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":79658,"run_id":"20260516_183011_119507c7"}
2026-05-16T18:30:13+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.77,"exec_milliseconds":1770,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":79658,"important":true,"run_id":"20260516_183011_119507c7"}
2026-05-16T18:31:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_183101_3be3d03e"}
2026-05-16T18:31:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_183101_3be3d03e"}
2026-05-16T18:31:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_183101_3be3d03e"}
2026-05-16T18:31:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_183101_3be3d03e"}
2026-05-16T18:31:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_183101_3be3d03e"}
2026-05-16T18:31:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_183101_3be3d03e"}
2026-05-16T18:31:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_183101_3be3d03e"}
2026-05-16T18:31:02+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_183101_3be3d03e"}
2026-05-16T18:31:02+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T18:21:16+02:00","run_id":"20260516_183101_3be3d03e"}
2026-05-16T18:31:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_183101_3be3d03e"}
2026-05-16T18:31:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3825,"mtime":"2026-05-16T18:21:16+02:00","run_id":"20260516_183101_3be3d03e"}
2026-05-16T18:31:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_183101_3be3d03e"}
2026-05-16T18:31:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_183101_3be3d03e"}
2026-05-16T18:31:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.948,"duration_milliseconds":948,"important":true,"run_id":"20260516_183101_3be3d03e"}
2026-05-16T18:31:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_183101_3be3d03e"}
2026-05-16T18:31:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_183101_3be3d03e"}
2026-05-16T18:31:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_183101_3be3d03e"}
2026-05-16T18:31:03+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.046,"duration_milliseconds":46,"important":true,"run_id":"20260516_183101_3be3d03e"}
2026-05-16T18:31:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":79658,"run_id":"20260516_183101_3be3d03e"}
2026-05-16T18:31:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.734,"exec_milliseconds":1734,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":79658,"important":true,"run_id":"20260516_183101_3be3d03e"}
2026-05-16T18:32:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_183202_f33e3c67"}
2026-05-16T18:32:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_183202_f33e3c67"}
2026-05-16T18:32:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_183202_f33e3c67"}
2026-05-16T18:32:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_183202_f33e3c67"}
2026-05-16T18:32:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_183202_f33e3c67"}
2026-05-16T18:32:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_183202_f33e3c67"}
2026-05-16T18:32:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_183202_f33e3c67"}
2026-05-16T18:32:04+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_183202_f33e3c67"}
2026-05-16T18:32:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T18:32:00+02:00","run_id":"20260516_183202_f33e3c67"}
2026-05-16T18:32:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_183202_f33e3c67"}
2026-05-16T18:32:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3875,"mtime":"2026-05-16T18:32:00+02:00","run_id":"20260516_183202_f33e3c67"}
2026-05-16T18:32:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_183202_f33e3c67"}
2026-05-16T18:32:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_183202_f33e3c67"}
2026-05-16T18:32:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.953,"duration_milliseconds":953,"important":true,"run_id":"20260516_183202_f33e3c67"}
2026-05-16T18:32:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_183202_f33e3c67"}
2026-05-16T18:32:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_183202_f33e3c67"}
2026-05-16T18:32:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_183202_f33e3c67"}
2026-05-16T18:32:04+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.046,"duration_milliseconds":46,"important":true,"run_id":"20260516_183202_f33e3c67"}
2026-05-16T18:32:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":79676,"run_id":"20260516_183202_f33e3c67"}
2026-05-16T18:32:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.767,"exec_milliseconds":1767,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":79676,"important":true,"run_id":"20260516_183202_f33e3c67"}
2026-05-16T18:33:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_183301_fcb80317"}
2026-05-16T18:33:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_183301_fcb80317"}
2026-05-16T18:33:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_183301_fcb80317"}
2026-05-16T18:33:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_183301_fcb80317"}
2026-05-16T18:33:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_183301_fcb80317"}
2026-05-16T18:33:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_183301_fcb80317"}
2026-05-16T18:33:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_183301_fcb80317"}
2026-05-16T18:33:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_183301_fcb80317"}
2026-05-16T18:33:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T18:32:00+02:00","run_id":"20260516_183301_fcb80317"}
2026-05-16T18:33:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_183301_fcb80317"}
2026-05-16T18:33:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3875,"mtime":"2026-05-16T18:32:00+02:00","run_id":"20260516_183301_fcb80317"}
2026-05-16T18:33:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_183301_fcb80317"}
2026-05-16T18:33:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_183301_fcb80317"}
2026-05-16T18:33:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.954,"duration_milliseconds":954,"important":true,"run_id":"20260516_183301_fcb80317"}
2026-05-16T18:33:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_183301_fcb80317"}
2026-05-16T18:33:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_183301_fcb80317"}
2026-05-16T18:33:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_183301_fcb80317"}
2026-05-16T18:33:03+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.046,"duration_milliseconds":46,"important":true,"run_id":"20260516_183301_fcb80317"}
2026-05-16T18:33:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":79676,"run_id":"20260516_183301_fcb80317"}
2026-05-16T18:33:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.841,"exec_milliseconds":1841,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":79676,"important":true,"run_id":"20260516_183301_fcb80317"}
2026-05-16T18:34:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_183402_48acf348"}
2026-05-16T18:34:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_183402_48acf348"}
2026-05-16T18:34:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_183402_48acf348"}
2026-05-16T18:34:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_183402_48acf348"}
2026-05-16T18:34:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_183402_48acf348"}
2026-05-16T18:34:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_183402_48acf348"}
2026-05-16T18:34:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_183402_48acf348"}
2026-05-16T18:34:04+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_183402_48acf348"}
2026-05-16T18:34:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T18:32:00+02:00","run_id":"20260516_183402_48acf348"}
2026-05-16T18:34:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_183402_48acf348"}
2026-05-16T18:34:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":3875,"mtime":"2026-05-16T18:32:00+02:00","run_id":"20260516_183402_48acf348"}
2026-05-16T18:34:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":0,"run_id":"20260516_183402_48acf348"}
2026-05-16T18:34:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_183402_48acf348"}
2026-05-16T18:34:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.922,"duration_milliseconds":922,"important":true,"run_id":"20260516_183402_48acf348"}
2026-05-16T18:34:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_183402_48acf348"}
2026-05-16T18:34:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_183402_48acf348"}
2026-05-16T18:34:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_183402_48acf348"}
2026-05-16T18:34:04+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.048,"duration_milliseconds":48,"important":true,"run_id":"20260516_183402_48acf348"}
2026-05-16T18:34:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":79776,"run_id":"20260516_183402_48acf348"}
2026-05-16T18:34:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.741,"exec_milliseconds":1741,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":79776,"important":true,"run_id":"20260516_183402_48acf348"}
2026-05-16T18:35:04+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_183504_3dee1d5c"}
2026-05-16T18:35:04+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_183504_3dee1d5c"}
2026-05-16T18:35:04+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_183504_3dee1d5c"}
2026-05-16T18:35:04+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_183504_3dee1d5c"}
2026-05-16T18:35:04+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_183504_3dee1d5c"}
2026-05-16T18:35:04+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_183504_3dee1d5c"}
2026-05-16T18:35:04+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_183504_3dee1d5c"}
2026-05-16T18:35:05+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_183504_3dee1d5c"}
2026-05-16T18:35:05+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T18:35:01+02:00","run_id":"20260516_183504_3dee1d5c"}
2026-05-16T18:35:05+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_183504_3dee1d5c"}
2026-05-16T18:35:05+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":4228,"mtime":"2026-05-16T18:35:01+02:00","run_id":"20260516_183504_3dee1d5c"}
2026-05-16T18:35:05+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":3,"run_id":"20260516_183504_3dee1d5c"}
2026-05-16T18:35:05+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_183504_3dee1d5c"}
2026-05-16T18:35:05+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.947,"duration_milliseconds":947,"important":true,"run_id":"20260516_183504_3dee1d5c"}
2026-05-16T18:35:05+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_183504_3dee1d5c"}
2026-05-16T18:35:06+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_183504_3dee1d5c"}
2026-05-16T18:35:06+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_183504_3dee1d5c"}
2026-05-16T18:35:06+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.049,"duration_milliseconds":49,"important":true,"run_id":"20260516_183504_3dee1d5c"}
2026-05-16T18:35:06+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":81151,"run_id":"20260516_183504_3dee1d5c"}
2026-05-16T18:35:06+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.74,"exec_milliseconds":1740,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":81151,"important":true,"run_id":"20260516_183504_3dee1d5c"}
2026-05-16T18:36:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_183602_440d0390"}
2026-05-16T18:36:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_183602_440d0390"}
2026-05-16T18:36:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_183602_440d0390"}
2026-05-16T18:36:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_183602_440d0390"}
2026-05-16T18:36:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_183602_440d0390"}
2026-05-16T18:36:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_183602_440d0390"}
2026-05-16T18:36:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_183602_440d0390"}
2026-05-16T18:36:04+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_183602_440d0390"}
2026-05-16T18:36:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T18:35:57+02:00","run_id":"20260516_183602_440d0390"}
2026-05-16T18:36:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_183602_440d0390"}
2026-05-16T18:36:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":4644,"mtime":"2026-05-16T18:35:57+02:00","run_id":"20260516_183602_440d0390"}
2026-05-16T18:36:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":4,"run_id":"20260516_183602_440d0390"}
2026-05-16T18:36:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_183602_440d0390"}
2026-05-16T18:36:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.952,"duration_milliseconds":952,"important":true,"run_id":"20260516_183602_440d0390"}
2026-05-16T18:36:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_183602_440d0390"}
2026-05-16T18:36:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_183602_440d0390"}
2026-05-16T18:36:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_183602_440d0390"}
2026-05-16T18:36:04+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.047,"duration_milliseconds":47,"important":true,"run_id":"20260516_183602_440d0390"}
2026-05-16T18:36:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":83052,"run_id":"20260516_183602_440d0390"}
2026-05-16T18:36:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.787,"exec_milliseconds":1787,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":83052,"important":true,"run_id":"20260516_183602_440d0390"}
2026-05-16T18:37:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_183701_5a10d328"}
2026-05-16T18:37:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_183701_5a10d328"}
2026-05-16T18:37:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_183701_5a10d328"}
2026-05-16T18:37:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_183701_5a10d328"}
2026-05-16T18:37:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_183701_5a10d328"}
2026-05-16T18:37:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_183701_5a10d328"}
2026-05-16T18:37:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_183701_5a10d328"}
2026-05-16T18:37:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_183701_5a10d328"}
2026-05-16T18:37:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T18:36:37+02:00","run_id":"20260516_183701_5a10d328"}
2026-05-16T18:37:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_183701_5a10d328"}
2026-05-16T18:37:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":4899,"mtime":"2026-05-16T18:36:37+02:00","run_id":"20260516_183701_5a10d328"}
2026-05-16T18:37:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":0,"rb":5,"run_id":"20260516_183701_5a10d328"}
2026-05-16T18:37:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_183701_5a10d328"}
2026-05-16T18:37:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.948,"duration_milliseconds":948,"important":true,"run_id":"20260516_183701_5a10d328"}
2026-05-16T18:37:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_183701_5a10d328"}
2026-05-16T18:37:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_183701_5a10d328"}
2026-05-16T18:37:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"--:--","run_id":"20260516_183701_5a10d328"}
2026-05-16T18:37:03+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.048,"duration_milliseconds":48,"important":true,"run_id":"20260516_183701_5a10d328"}
2026-05-16T18:37:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":84147,"run_id":"20260516_183701_5a10d328"}
2026-05-16T18:37:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.856,"exec_milliseconds":1856,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":84147,"important":true,"run_id":"20260516_183701_5a10d328"}
2026-05-16T18:38:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_183802_1bc1976b"}
2026-05-16T18:38:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_183802_1bc1976b"}
2026-05-16T18:38:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_183802_1bc1976b"}
2026-05-16T18:38:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_183802_1bc1976b"}
2026-05-16T18:38:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_183802_1bc1976b"}
2026-05-16T18:38:03+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_183802_1bc1976b"}
2026-05-16T18:38:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_183802_1bc1976b"}
2026-05-16T18:38:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_183802_1bc1976b"}
2026-05-16T18:38:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T18:37:54+02:00","run_id":"20260516_183802_1bc1976b"}
2026-05-16T18:38:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_183802_1bc1976b"}
2026-05-16T18:38:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":5346,"mtime":"2026-05-16T18:37:53+02:00","run_id":"20260516_183802_1bc1976b"}
2026-05-16T18:38:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":2,"rb":5,"run_id":"20260516_183802_1bc1976b"}
2026-05-16T18:38:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_183802_1bc1976b"}
2026-05-16T18:38:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.927,"duration_milliseconds":927,"important":true,"run_id":"20260516_183802_1bc1976b"}
2026-05-16T18:38:04+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_183802_1bc1976b"}
2026-05-16T18:38:04+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_183802_1bc1976b"}
2026-05-16T18:38:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":6597,"mtime":"2026-05-16T18:37:55+02:00","run_id":"20260516_183802_1bc1976b"}
2026-05-16T18:38:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_183802_1bc1976b"}
2026-05-16T18:38:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":6146,"mtime":"2026-05-16T18:37:55+02:00","run_id":"20260516_183802_1bc1976b"}
2026-05-16T18:38:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_183802_1bc1976b"}
2026-05-16T18:38:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_183802_1bc1976b"}
2026-05-16T18:38:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.301,"duration_milliseconds":301,"important":true,"run_id":"20260516_183802_1bc1976b"}
2026-05-16T18:38:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_183802_1bc1976b"}
2026-05-16T18:38:04+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_183802_1bc1976b"}
2026-05-16T18:38:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":150233,"run_id":"20260516_183802_1bc1976b"}
2026-05-16T18:38:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.066,"exec_milliseconds":2066,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":150233,"important":true,"run_id":"20260516_183802_1bc1976b"}
2026-05-16T18:39:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_183901_e061e434"}
2026-05-16T18:39:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_183901_e061e434"}
2026-05-16T18:39:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_183901_e061e434"}
2026-05-16T18:39:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_183901_e061e434"}
2026-05-16T18:39:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_183901_e061e434"}
2026-05-16T18:39:02+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_183901_e061e434"}
2026-05-16T18:39:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_183901_e061e434"}
2026-05-16T18:39:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_183901_e061e434"}
2026-05-16T18:39:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T18:38:58+02:00","run_id":"20260516_183901_e061e434"}
2026-05-16T18:39:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_183901_e061e434"}
2026-05-16T18:39:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":5733,"mtime":"2026-05-16T18:38:58+02:00","run_id":"20260516_183901_e061e434"}
2026-05-16T18:39:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":5,"rb":7,"run_id":"20260516_183901_e061e434"}
2026-05-16T18:39:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_183901_e061e434"}
2026-05-16T18:39:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.934,"duration_milliseconds":934,"important":true,"run_id":"20260516_183901_e061e434"}
2026-05-16T18:39:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_183901_e061e434"}
2026-05-16T18:39:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_183901_e061e434"}
2026-05-16T18:39:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":6597,"mtime":"2026-05-16T18:37:55+02:00","run_id":"20260516_183901_e061e434"}
2026-05-16T18:39:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_183901_e061e434"}
2026-05-16T18:39:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":6146,"mtime":"2026-05-16T18:37:55+02:00","run_id":"20260516_183901_e061e434"}
2026-05-16T18:39:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_183901_e061e434"}
2026-05-16T18:39:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_183901_e061e434"}
2026-05-16T18:39:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.303,"duration_milliseconds":303,"important":true,"run_id":"20260516_183901_e061e434"}
2026-05-16T18:39:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_183901_e061e434"}
2026-05-16T18:39:03+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_183901_e061e434"}
2026-05-16T18:39:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":151836,"run_id":"20260516_183901_e061e434"}
2026-05-16T18:39:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.116,"exec_milliseconds":2116,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":151836,"important":true,"run_id":"20260516_183901_e061e434"}
2026-05-16T18:40:06+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_184006_3d4153fd"}
2026-05-16T18:40:07+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_184006_3d4153fd"}
2026-05-16T18:40:07+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_184006_3d4153fd"}
2026-05-16T18:40:07+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_184006_3d4153fd"}
2026-05-16T18:40:07+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_184006_3d4153fd"}
2026-05-16T18:40:07+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_184006_3d4153fd"}
2026-05-16T18:40:07+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_184006_3d4153fd"}
2026-05-16T18:40:07+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_184006_3d4153fd"}
2026-05-16T18:40:07+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T18:39:19+02:00","run_id":"20260516_184006_3d4153fd"}
2026-05-16T18:40:08+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_184006_3d4153fd"}
2026-05-16T18:40:08+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":5883,"mtime":"2026-05-16T18:39:19+02:00","run_id":"20260516_184006_3d4153fd"}
2026-05-16T18:40:08+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":5,"rb":7,"run_id":"20260516_184006_3d4153fd"}
2026-05-16T18:40:08+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_184006_3d4153fd"}
2026-05-16T18:40:08+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.978,"duration_milliseconds":978,"important":true,"run_id":"20260516_184006_3d4153fd"}
2026-05-16T18:40:08+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_184006_3d4153fd"}
2026-05-16T18:40:08+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_184006_3d4153fd"}
2026-05-16T18:40:08+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":6597,"mtime":"2026-05-16T18:37:55+02:00","run_id":"20260516_184006_3d4153fd"}
2026-05-16T18:40:08+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_184006_3d4153fd"}
2026-05-16T18:40:08+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":6146,"mtime":"2026-05-16T18:37:55+02:00","run_id":"20260516_184006_3d4153fd"}
2026-05-16T18:40:08+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_184006_3d4153fd"}
2026-05-16T18:40:08+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_184006_3d4153fd"}
2026-05-16T18:40:08+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.3,"duration_milliseconds":300,"important":true,"run_id":"20260516_184006_3d4153fd"}
2026-05-16T18:40:08+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_184006_3d4153fd"}
2026-05-16T18:40:08+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_184006_3d4153fd"}
2026-05-16T18:40:08+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":152586,"run_id":"20260516_184006_3d4153fd"}
2026-05-16T18:40:08+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.064,"exec_milliseconds":2064,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":152586,"important":true,"run_id":"20260516_184006_3d4153fd"}
2026-05-16T18:41:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_184101_44734cfa"}
2026-05-16T18:41:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_184101_44734cfa"}
2026-05-16T18:41:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_184101_44734cfa"}
2026-05-16T18:41:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_184101_44734cfa"}
2026-05-16T18:41:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_184101_44734cfa"}
2026-05-16T18:41:02+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_184101_44734cfa"}
2026-05-16T18:41:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_184101_44734cfa"}
2026-05-16T18:41:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_184101_44734cfa"}
2026-05-16T18:41:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T18:40:58+02:00","run_id":"20260516_184101_44734cfa"}
2026-05-16T18:41:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_184101_44734cfa"}
2026-05-16T18:41:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":6070,"mtime":"2026-05-16T18:40:58+02:00","run_id":"20260516_184101_44734cfa"}
2026-05-16T18:41:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":6,"rb":7,"run_id":"20260516_184101_44734cfa"}
2026-05-16T18:41:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_184101_44734cfa"}
2026-05-16T18:41:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.962,"duration_milliseconds":962,"important":true,"run_id":"20260516_184101_44734cfa"}
2026-05-16T18:41:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_184101_44734cfa"}
2026-05-16T18:41:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_184101_44734cfa"}
2026-05-16T18:41:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":6597,"mtime":"2026-05-16T18:37:55+02:00","run_id":"20260516_184101_44734cfa"}
2026-05-16T18:41:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_184101_44734cfa"}
2026-05-16T18:41:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":6146,"mtime":"2026-05-16T18:37:55+02:00","run_id":"20260516_184101_44734cfa"}
2026-05-16T18:41:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_184101_44734cfa"}
2026-05-16T18:41:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_184101_44734cfa"}
2026-05-16T18:41:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.299,"duration_milliseconds":299,"important":true,"run_id":"20260516_184101_44734cfa"}
2026-05-16T18:41:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_184101_44734cfa"}
2026-05-16T18:41:03+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_184101_44734cfa"}
2026-05-16T18:41:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":153375,"run_id":"20260516_184101_44734cfa"}
2026-05-16T18:41:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.041,"exec_milliseconds":2041,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":153375,"important":true,"run_id":"20260516_184101_44734cfa"}
2026-05-16T18:42:03+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_184203_2c895119"}
2026-05-16T18:42:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_184203_2c895119"}
2026-05-16T18:42:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_184203_2c895119"}
2026-05-16T18:42:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_184203_2c895119"}
2026-05-16T18:42:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_184203_2c895119"}
2026-05-16T18:42:03+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_184203_2c895119"}
2026-05-16T18:42:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_184203_2c895119"}
2026-05-16T18:42:04+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_184203_2c895119"}
2026-05-16T18:42:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T18:41:55+02:00","run_id":"20260516_184203_2c895119"}
2026-05-16T18:42:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_184203_2c895119"}
2026-05-16T18:42:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":6486,"mtime":"2026-05-16T18:41:55+02:00","run_id":"20260516_184203_2c895119"}
2026-05-16T18:42:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":6,"rb":9,"run_id":"20260516_184203_2c895119"}
2026-05-16T18:42:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_184203_2c895119"}
2026-05-16T18:42:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.922,"duration_milliseconds":922,"important":true,"run_id":"20260516_184203_2c895119"}
2026-05-16T18:42:04+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_184203_2c895119"}
2026-05-16T18:42:04+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_184203_2c895119"}
2026-05-16T18:42:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":6597,"mtime":"2026-05-16T18:37:55+02:00","run_id":"20260516_184203_2c895119"}
2026-05-16T18:42:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_184203_2c895119"}
2026-05-16T18:42:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":6146,"mtime":"2026-05-16T18:37:55+02:00","run_id":"20260516_184203_2c895119"}
2026-05-16T18:42:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_184203_2c895119"}
2026-05-16T18:42:05+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_184203_2c895119"}
2026-05-16T18:42:05+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.281,"duration_milliseconds":281,"important":true,"run_id":"20260516_184203_2c895119"}
2026-05-16T18:42:05+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_184203_2c895119"}
2026-05-16T18:42:05+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_184203_2c895119"}
2026-05-16T18:42:05+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":155143,"run_id":"20260516_184203_2c895119"}
2026-05-16T18:42:05+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.961,"exec_milliseconds":1961,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":155143,"important":true,"run_id":"20260516_184203_2c895119"}
2026-05-16T18:43:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_184301_d42f5adc"}
2026-05-16T18:43:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_184301_d42f5adc"}
2026-05-16T18:43:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_184301_d42f5adc"}
2026-05-16T18:43:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_184301_d42f5adc"}
2026-05-16T18:43:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_184301_d42f5adc"}
2026-05-16T18:43:02+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_184301_d42f5adc"}
2026-05-16T18:43:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_184301_d42f5adc"}
2026-05-16T18:43:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_184301_d42f5adc"}
2026-05-16T18:43:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T18:42:56+02:00","run_id":"20260516_184301_d42f5adc"}
2026-05-16T18:43:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_184301_d42f5adc"}
2026-05-16T18:43:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":7102,"mtime":"2026-05-16T18:42:56+02:00","run_id":"20260516_184301_d42f5adc"}
2026-05-16T18:43:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":6,"rb":9,"run_id":"20260516_184301_d42f5adc"}
2026-05-16T18:43:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_184301_d42f5adc"}
2026-05-16T18:43:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.946,"duration_milliseconds":946,"important":true,"run_id":"20260516_184301_d42f5adc"}
2026-05-16T18:43:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_184301_d42f5adc"}
2026-05-16T18:43:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_184301_d42f5adc"}
2026-05-16T18:43:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":6597,"mtime":"2026-05-16T18:37:55+02:00","run_id":"20260516_184301_d42f5adc"}
2026-05-16T18:43:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_184301_d42f5adc"}
2026-05-16T18:43:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":6146,"mtime":"2026-05-16T18:37:55+02:00","run_id":"20260516_184301_d42f5adc"}
2026-05-16T18:43:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_184301_d42f5adc"}
2026-05-16T18:43:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_184301_d42f5adc"}
2026-05-16T18:43:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.302,"duration_milliseconds":302,"important":true,"run_id":"20260516_184301_d42f5adc"}
2026-05-16T18:43:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_184301_d42f5adc"}
2026-05-16T18:43:03+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_184301_d42f5adc"}
2026-05-16T18:43:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":157783,"run_id":"20260516_184301_d42f5adc"}
2026-05-16T18:43:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.025,"exec_milliseconds":2025,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":157783,"important":true,"run_id":"20260516_184301_d42f5adc"}
2026-05-16T18:44:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_184402_df3ced35"}
2026-05-16T18:44:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_184402_df3ced35"}
2026-05-16T18:44:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_184402_df3ced35"}
2026-05-16T18:44:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_184402_df3ced35"}
2026-05-16T18:44:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_184402_df3ced35"}
2026-05-16T18:44:03+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_184402_df3ced35"}
2026-05-16T18:44:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_184402_df3ced35"}
2026-05-16T18:44:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_184402_df3ced35"}
2026-05-16T18:44:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T18:43:58+02:00","run_id":"20260516_184402_df3ced35"}
2026-05-16T18:44:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_184402_df3ced35"}
2026-05-16T18:44:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":7392,"mtime":"2026-05-16T18:43:58+02:00","run_id":"20260516_184402_df3ced35"}
2026-05-16T18:44:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":6,"rb":11,"run_id":"20260516_184402_df3ced35"}
2026-05-16T18:44:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_184402_df3ced35"}
2026-05-16T18:44:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.912,"duration_milliseconds":912,"important":true,"run_id":"20260516_184402_df3ced35"}
2026-05-16T18:44:04+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_184402_df3ced35"}
2026-05-16T18:44:04+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_184402_df3ced35"}
2026-05-16T18:44:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":6597,"mtime":"2026-05-16T18:37:55+02:00","run_id":"20260516_184402_df3ced35"}
2026-05-16T18:44:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_184402_df3ced35"}
2026-05-16T18:44:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":6146,"mtime":"2026-05-16T18:37:55+02:00","run_id":"20260516_184402_df3ced35"}
2026-05-16T18:44:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_184402_df3ced35"}
2026-05-16T18:44:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_184402_df3ced35"}
2026-05-16T18:44:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.287,"duration_milliseconds":287,"important":true,"run_id":"20260516_184402_df3ced35"}
2026-05-16T18:44:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_184402_df3ced35"}
2026-05-16T18:44:04+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_184402_df3ced35"}
2026-05-16T18:44:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":159007,"run_id":"20260516_184402_df3ced35"}
2026-05-16T18:44:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.933,"exec_milliseconds":1933,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":159007,"important":true,"run_id":"20260516_184402_df3ced35"}
2026-05-16T18:45:06+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_184506_39592c55"}
2026-05-16T18:45:07+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_184506_39592c55"}
2026-05-16T18:45:07+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_184506_39592c55"}
2026-05-16T18:45:07+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_184506_39592c55"}
2026-05-16T18:45:07+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_184506_39592c55"}
2026-05-16T18:45:07+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_184506_39592c55"}
2026-05-16T18:45:07+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_184506_39592c55"}
2026-05-16T18:45:08+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_184506_39592c55"}
2026-05-16T18:45:08+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T18:45:07+02:00","run_id":"20260516_184506_39592c55"}
2026-05-16T18:45:08+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_184506_39592c55"}
2026-05-16T18:45:08+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":7661,"mtime":"2026-05-16T18:45:07+02:00","run_id":"20260516_184506_39592c55"}
2026-05-16T18:45:08+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":8,"rb":11,"run_id":"20260516_184506_39592c55"}
2026-05-16T18:45:08+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_184506_39592c55"}
2026-05-16T18:45:08+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.939,"duration_milliseconds":939,"important":true,"run_id":"20260516_184506_39592c55"}
2026-05-16T18:45:08+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_184506_39592c55"}
2026-05-16T18:45:08+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_184506_39592c55"}
2026-05-16T18:45:08+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":6597,"mtime":"2026-05-16T18:37:55+02:00","run_id":"20260516_184506_39592c55"}
2026-05-16T18:45:08+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_184506_39592c55"}
2026-05-16T18:45:08+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":6146,"mtime":"2026-05-16T18:37:55+02:00","run_id":"20260516_184506_39592c55"}
2026-05-16T18:45:08+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_184506_39592c55"}
2026-05-16T18:45:08+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_184506_39592c55"}
2026-05-16T18:45:08+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.297,"duration_milliseconds":297,"important":true,"run_id":"20260516_184506_39592c55"}
2026-05-16T18:45:08+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_184506_39592c55"}
2026-05-16T18:45:08+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_184506_39592c55"}
2026-05-16T18:45:08+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":160136,"run_id":"20260516_184506_39592c55"}
2026-05-16T18:45:08+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.057,"exec_milliseconds":2057,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":160136,"important":true,"run_id":"20260516_184506_39592c55"}
2026-05-16T18:46:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_184602_8f9ae80a"}
2026-05-16T18:46:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_184602_8f9ae80a"}
2026-05-16T18:46:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_184602_8f9ae80a"}
2026-05-16T18:46:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_184602_8f9ae80a"}
2026-05-16T18:46:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_184602_8f9ae80a"}
2026-05-16T18:46:02+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_184602_8f9ae80a"}
2026-05-16T18:46:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_184602_8f9ae80a"}
2026-05-16T18:46:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_184602_8f9ae80a"}
2026-05-16T18:46:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T18:45:57+02:00","run_id":"20260516_184602_8f9ae80a"}
2026-05-16T18:46:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_184602_8f9ae80a"}
2026-05-16T18:46:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":8152,"mtime":"2026-05-16T18:45:57+02:00","run_id":"20260516_184602_8f9ae80a"}
2026-05-16T18:46:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":8,"rb":14,"run_id":"20260516_184602_8f9ae80a"}
2026-05-16T18:46:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_184602_8f9ae80a"}
2026-05-16T18:46:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.966,"duration_milliseconds":966,"important":true,"run_id":"20260516_184602_8f9ae80a"}
2026-05-16T18:46:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_184602_8f9ae80a"}
2026-05-16T18:46:04+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_184602_8f9ae80a"}
2026-05-16T18:46:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":6597,"mtime":"2026-05-16T18:37:55+02:00","run_id":"20260516_184602_8f9ae80a"}
2026-05-16T18:46:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_184602_8f9ae80a"}
2026-05-16T18:46:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":6146,"mtime":"2026-05-16T18:37:55+02:00","run_id":"20260516_184602_8f9ae80a"}
2026-05-16T18:46:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_184602_8f9ae80a"}
2026-05-16T18:46:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_184602_8f9ae80a"}
2026-05-16T18:46:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.303,"duration_milliseconds":303,"important":true,"run_id":"20260516_184602_8f9ae80a"}
2026-05-16T18:46:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_184602_8f9ae80a"}
2026-05-16T18:46:04+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_184602_8f9ae80a"}
2026-05-16T18:46:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":162233,"run_id":"20260516_184602_8f9ae80a"}
2026-05-16T18:46:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.025,"exec_milliseconds":2025,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":162233,"important":true,"run_id":"20260516_184602_8f9ae80a"}
2026-05-16T18:47:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_184701_de899b69"}
2026-05-16T18:47:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_184701_de899b69"}
2026-05-16T18:47:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_184701_de899b69"}
2026-05-16T18:47:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_184701_de899b69"}
2026-05-16T18:47:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_184701_de899b69"}
2026-05-16T18:47:02+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_184701_de899b69"}
2026-05-16T18:47:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_184701_de899b69"}
2026-05-16T18:47:02+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_184701_de899b69"}
2026-05-16T18:47:02+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T18:46:52+02:00","run_id":"20260516_184701_de899b69"}
2026-05-16T18:47:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_184701_de899b69"}
2026-05-16T18:47:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":9136,"mtime":"2026-05-16T18:46:52+02:00","run_id":"20260516_184701_de899b69"}
2026-05-16T18:47:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":8,"rb":14,"run_id":"20260516_184701_de899b69"}
2026-05-16T18:47:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_184701_de899b69"}
2026-05-16T18:47:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.96,"duration_milliseconds":960,"important":true,"run_id":"20260516_184701_de899b69"}
2026-05-16T18:47:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_184701_de899b69"}
2026-05-16T18:47:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_184701_de899b69"}
2026-05-16T18:47:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":6597,"mtime":"2026-05-16T18:37:55+02:00","run_id":"20260516_184701_de899b69"}
2026-05-16T18:47:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_184701_de899b69"}
2026-05-16T18:47:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":6146,"mtime":"2026-05-16T18:37:55+02:00","run_id":"20260516_184701_de899b69"}
2026-05-16T18:47:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_184701_de899b69"}
2026-05-16T18:47:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_184701_de899b69"}
2026-05-16T18:47:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.295,"duration_milliseconds":295,"important":true,"run_id":"20260516_184701_de899b69"}
2026-05-16T18:47:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_184701_de899b69"}
2026-05-16T18:47:03+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_184701_de899b69"}
2026-05-16T18:47:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":166479,"run_id":"20260516_184701_de899b69"}
2026-05-16T18:47:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.009,"exec_milliseconds":2009,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":166479,"important":true,"run_id":"20260516_184701_de899b69"}
2026-05-16T18:48:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_184802_381d81ca"}
2026-05-16T18:48:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_184802_381d81ca"}
2026-05-16T18:48:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_184802_381d81ca"}
2026-05-16T18:48:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_184802_381d81ca"}
2026-05-16T18:48:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_184802_381d81ca"}
2026-05-16T18:48:03+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_184802_381d81ca"}
2026-05-16T18:48:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_184802_381d81ca"}
2026-05-16T18:48:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_184802_381d81ca"}
2026-05-16T18:48:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T18:48:02+02:00","run_id":"20260516_184802_381d81ca"}
2026-05-16T18:48:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_184802_381d81ca"}
2026-05-16T18:48:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":9834,"mtime":"2026-05-16T18:48:02+02:00","run_id":"20260516_184802_381d81ca"}
2026-05-16T18:48:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":10,"rb":19,"run_id":"20260516_184802_381d81ca"}
2026-05-16T18:48:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_184802_381d81ca"}
2026-05-16T18:48:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.947,"duration_milliseconds":947,"important":true,"run_id":"20260516_184802_381d81ca"}
2026-05-16T18:48:04+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_184802_381d81ca"}
2026-05-16T18:48:04+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_184802_381d81ca"}
2026-05-16T18:48:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":6597,"mtime":"2026-05-16T18:37:55+02:00","run_id":"20260516_184802_381d81ca"}
2026-05-16T18:48:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_184802_381d81ca"}
2026-05-16T18:48:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":6146,"mtime":"2026-05-16T18:37:55+02:00","run_id":"20260516_184802_381d81ca"}
2026-05-16T18:48:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_184802_381d81ca"}
2026-05-16T18:48:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_184802_381d81ca"}
2026-05-16T18:48:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.288,"duration_milliseconds":288,"important":true,"run_id":"20260516_184802_381d81ca"}
2026-05-16T18:48:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_184802_381d81ca"}
2026-05-16T18:48:04+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_184802_381d81ca"}
2026-05-16T18:48:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":169305,"run_id":"20260516_184802_381d81ca"}
2026-05-16T18:48:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.031,"exec_milliseconds":2031,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":169305,"important":true,"run_id":"20260516_184802_381d81ca"}
2026-05-16T18:49:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_184901_cba093bc"}
2026-05-16T18:49:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_184901_cba093bc"}
2026-05-16T18:49:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_184901_cba093bc"}
2026-05-16T18:49:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_184901_cba093bc"}
2026-05-16T18:49:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_184901_cba093bc"}
2026-05-16T18:49:02+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_184901_cba093bc"}
2026-05-16T18:49:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_184901_cba093bc"}
2026-05-16T18:49:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_184901_cba093bc"}
2026-05-16T18:49:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4140,"mtime":"2026-05-16T18:48:59+02:00","run_id":"20260516_184901_cba093bc"}
2026-05-16T18:49:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_184901_cba093bc"}
2026-05-16T18:49:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":10226,"mtime":"2026-05-16T18:48:59+02:00","run_id":"20260516_184901_cba093bc"}
2026-05-16T18:49:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":10,"rb":19,"run_id":"20260516_184901_cba093bc"}
2026-05-16T18:49:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_184901_cba093bc"}
2026-05-16T18:49:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.955,"duration_milliseconds":955,"important":true,"run_id":"20260516_184901_cba093bc"}
2026-05-16T18:49:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_184901_cba093bc"}
2026-05-16T18:49:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_184901_cba093bc"}
2026-05-16T18:49:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":6597,"mtime":"2026-05-16T18:37:55+02:00","run_id":"20260516_184901_cba093bc"}
2026-05-16T18:49:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_184901_cba093bc"}
2026-05-16T18:49:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":6146,"mtime":"2026-05-16T18:37:55+02:00","run_id":"20260516_184901_cba093bc"}
2026-05-16T18:49:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_184901_cba093bc"}
2026-05-16T18:49:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_184901_cba093bc"}
2026-05-16T18:49:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.293,"duration_milliseconds":293,"important":true,"run_id":"20260516_184901_cba093bc"}
2026-05-16T18:49:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_184901_cba093bc"}
2026-05-16T18:49:03+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_184901_cba093bc"}
2026-05-16T18:49:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":170971,"run_id":"20260516_184901_cba093bc"}
2026-05-16T18:49:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.029,"exec_milliseconds":2029,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":170971,"important":true,"run_id":"20260516_184901_cba093bc"}
2026-05-16T18:50:07+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_185007_ed6a81d0"}
2026-05-16T18:50:07+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_185007_ed6a81d0"}
2026-05-16T18:50:07+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_185007_ed6a81d0"}
2026-05-16T18:50:07+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_185007_ed6a81d0"}
2026-05-16T18:50:07+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_185007_ed6a81d0"}
2026-05-16T18:50:07+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_185007_ed6a81d0"}
2026-05-16T18:50:07+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_185007_ed6a81d0"}
2026-05-16T18:50:08+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_185007_ed6a81d0"}
2026-05-16T18:50:08+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4141,"mtime":"2026-05-16T18:49:04+02:00","run_id":"20260516_185007_ed6a81d0"}
2026-05-16T18:50:08+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_185007_ed6a81d0"}
2026-05-16T18:50:08+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":10299,"mtime":"2026-05-16T18:49:04+02:00","run_id":"20260516_185007_ed6a81d0"}
2026-05-16T18:50:08+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":10,"rb":19,"run_id":"20260516_185007_ed6a81d0"}
2026-05-16T18:50:08+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_185007_ed6a81d0"}
2026-05-16T18:50:08+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.921,"duration_milliseconds":921,"important":true,"run_id":"20260516_185007_ed6a81d0"}
2026-05-16T18:50:08+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_185007_ed6a81d0"}
2026-05-16T18:50:08+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_185007_ed6a81d0"}
2026-05-16T18:50:08+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":6597,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_185007_ed6a81d0"}
2026-05-16T18:50:08+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_185007_ed6a81d0"}
2026-05-16T18:50:08+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":6146,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_185007_ed6a81d0"}
2026-05-16T18:50:08+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_185007_ed6a81d0"}
2026-05-16T18:50:08+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_185007_ed6a81d0"}
2026-05-16T18:50:08+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.287,"duration_milliseconds":287,"important":true,"run_id":"20260516_185007_ed6a81d0"}
2026-05-16T18:50:08+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_185007_ed6a81d0"}
2026-05-16T18:50:09+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_185007_ed6a81d0"}
2026-05-16T18:50:09+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":171195,"run_id":"20260516_185007_ed6a81d0"}
2026-05-16T18:50:09+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.973,"exec_milliseconds":1973,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":171195,"important":true,"run_id":"20260516_185007_ed6a81d0"}
2026-05-16T18:51:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_185101_f2066dc7"}
2026-05-16T18:51:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_185101_f2066dc7"}
2026-05-16T18:51:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_185101_f2066dc7"}
2026-05-16T18:51:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_185101_f2066dc7"}
2026-05-16T18:51:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_185101_f2066dc7"}
2026-05-16T18:51:02+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_185101_f2066dc7"}
2026-05-16T18:51:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_185101_f2066dc7"}
2026-05-16T18:51:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_185101_f2066dc7"}
2026-05-16T18:51:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4141,"mtime":"2026-05-16T18:50:59+02:00","run_id":"20260516_185101_f2066dc7"}
2026-05-16T18:51:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_185101_f2066dc7"}
2026-05-16T18:51:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":10515,"mtime":"2026-05-16T18:50:59+02:00","run_id":"20260516_185101_f2066dc7"}
2026-05-16T18:51:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":10,"rb":21,"run_id":"20260516_185101_f2066dc7"}
2026-05-16T18:51:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_185101_f2066dc7"}
2026-05-16T18:51:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.957,"duration_milliseconds":957,"important":true,"run_id":"20260516_185101_f2066dc7"}
2026-05-16T18:51:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_185101_f2066dc7"}
2026-05-16T18:51:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_185101_f2066dc7"}
2026-05-16T18:51:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":6597,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_185101_f2066dc7"}
2026-05-16T18:51:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_185101_f2066dc7"}
2026-05-16T18:51:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":6146,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_185101_f2066dc7"}
2026-05-16T18:51:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_185101_f2066dc7"}
2026-05-16T18:51:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_185101_f2066dc7"}
2026-05-16T18:51:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.308,"duration_milliseconds":308,"important":true,"run_id":"20260516_185101_f2066dc7"}
2026-05-16T18:51:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_185101_f2066dc7"}
2026-05-16T18:51:03+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_185101_f2066dc7"}
2026-05-16T18:51:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":172199,"run_id":"20260516_185101_f2066dc7"}
2026-05-16T18:51:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.051,"exec_milliseconds":2051,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":172199,"important":true,"run_id":"20260516_185101_f2066dc7"}
2026-05-16T18:52:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_185202_9108bdc0"}
2026-05-16T18:52:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_185202_9108bdc0"}
2026-05-16T18:52:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_185202_9108bdc0"}
2026-05-16T18:52:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_185202_9108bdc0"}
2026-05-16T18:52:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_185202_9108bdc0"}
2026-05-16T18:52:03+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_185202_9108bdc0"}
2026-05-16T18:52:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_185202_9108bdc0"}
2026-05-16T18:52:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_185202_9108bdc0"}
2026-05-16T18:52:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4141,"mtime":"2026-05-16T18:51:54+02:00","run_id":"20260516_185202_9108bdc0"}
2026-05-16T18:52:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_185202_9108bdc0"}
2026-05-16T18:52:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":10955,"mtime":"2026-05-16T18:51:54+02:00","run_id":"20260516_185202_9108bdc0"}
2026-05-16T18:52:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":10,"rb":23,"run_id":"20260516_185202_9108bdc0"}
2026-05-16T18:52:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_185202_9108bdc0"}
2026-05-16T18:52:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.97,"duration_milliseconds":970,"important":true,"run_id":"20260516_185202_9108bdc0"}
2026-05-16T18:52:04+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_185202_9108bdc0"}
2026-05-16T18:52:04+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_185202_9108bdc0"}
2026-05-16T18:52:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":6597,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_185202_9108bdc0"}
2026-05-16T18:52:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_185202_9108bdc0"}
2026-05-16T18:52:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":6146,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_185202_9108bdc0"}
2026-05-16T18:52:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_185202_9108bdc0"}
2026-05-16T18:52:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_185202_9108bdc0"}
2026-05-16T18:52:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.327,"duration_milliseconds":327,"important":true,"run_id":"20260516_185202_9108bdc0"}
2026-05-16T18:52:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_185202_9108bdc0"}
2026-05-16T18:52:04+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_185202_9108bdc0"}
2026-05-16T18:52:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":174027,"run_id":"20260516_185202_9108bdc0"}
2026-05-16T18:52:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.07,"exec_milliseconds":2070,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":174027,"important":true,"run_id":"20260516_185202_9108bdc0"}
2026-05-16T18:53:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_185301_cea19f4d"}
2026-05-16T18:53:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_185301_cea19f4d"}
2026-05-16T18:53:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_185301_cea19f4d"}
2026-05-16T18:53:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_185301_cea19f4d"}
2026-05-16T18:53:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_185301_cea19f4d"}
2026-05-16T18:53:02+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_185301_cea19f4d"}
2026-05-16T18:53:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_185301_cea19f4d"}
2026-05-16T18:53:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_185301_cea19f4d"}
2026-05-16T18:53:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4141,"mtime":"2026-05-16T18:52:57+02:00","run_id":"20260516_185301_cea19f4d"}
2026-05-16T18:53:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_185301_cea19f4d"}
2026-05-16T18:53:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":11276,"mtime":"2026-05-16T18:52:57+02:00","run_id":"20260516_185301_cea19f4d"}
2026-05-16T18:53:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":13,"rb":26,"run_id":"20260516_185301_cea19f4d"}
2026-05-16T18:53:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_185301_cea19f4d"}
2026-05-16T18:53:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.921,"duration_milliseconds":921,"important":true,"run_id":"20260516_185301_cea19f4d"}
2026-05-16T18:53:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_185301_cea19f4d"}
2026-05-16T18:53:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_185301_cea19f4d"}
2026-05-16T18:53:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":6597,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_185301_cea19f4d"}
2026-05-16T18:53:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_185301_cea19f4d"}
2026-05-16T18:53:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":6146,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_185301_cea19f4d"}
2026-05-16T18:53:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_185301_cea19f4d"}
2026-05-16T18:53:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_185301_cea19f4d"}
2026-05-16T18:53:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.269,"duration_milliseconds":269,"important":true,"run_id":"20260516_185301_cea19f4d"}
2026-05-16T18:53:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_185301_cea19f4d"}
2026-05-16T18:53:03+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_185301_cea19f4d"}
2026-05-16T18:53:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":175326,"run_id":"20260516_185301_cea19f4d"}
2026-05-16T18:53:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.962,"exec_milliseconds":1962,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":175326,"important":true,"run_id":"20260516_185301_cea19f4d"}
2026-05-16T18:54:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_185402_484975fb"}
2026-05-16T18:54:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_185402_484975fb"}
2026-05-16T18:54:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_185402_484975fb"}
2026-05-16T18:54:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_185402_484975fb"}
2026-05-16T18:54:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_185402_484975fb"}
2026-05-16T18:54:03+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_185402_484975fb"}
2026-05-16T18:54:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_185402_484975fb"}
2026-05-16T18:54:04+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_185402_484975fb"}
2026-05-16T18:54:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4141,"mtime":"2026-05-16T18:53:54+02:00","run_id":"20260516_185402_484975fb"}
2026-05-16T18:54:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_185402_484975fb"}
2026-05-16T18:54:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":11813,"mtime":"2026-05-16T18:53:54+02:00","run_id":"20260516_185402_484975fb"}
2026-05-16T18:54:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":13,"rb":26,"run_id":"20260516_185402_484975fb"}
2026-05-16T18:54:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_185402_484975fb"}
2026-05-16T18:54:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.925,"duration_milliseconds":925,"important":true,"run_id":"20260516_185402_484975fb"}
2026-05-16T18:54:04+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_185402_484975fb"}
2026-05-16T18:54:04+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_185402_484975fb"}
2026-05-16T18:54:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":6597,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_185402_484975fb"}
2026-05-16T18:54:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_185402_484975fb"}
2026-05-16T18:54:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":6146,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_185402_484975fb"}
2026-05-16T18:54:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_185402_484975fb"}
2026-05-16T18:54:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_185402_484975fb"}
2026-05-16T18:54:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.293,"duration_milliseconds":293,"important":true,"run_id":"20260516_185402_484975fb"}
2026-05-16T18:54:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_185402_484975fb"}
2026-05-16T18:54:04+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_185402_484975fb"}
2026-05-16T18:54:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":177629,"run_id":"20260516_185402_484975fb"}
2026-05-16T18:54:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.996,"exec_milliseconds":1996,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":177629,"important":true,"run_id":"20260516_185402_484975fb"}
2026-05-16T18:55:04+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_185503_d95bbc1a"}
2026-05-16T18:55:04+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_185503_d95bbc1a"}
2026-05-16T18:55:04+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_185503_d95bbc1a"}
2026-05-16T18:55:04+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_185503_d95bbc1a"}
2026-05-16T18:55:04+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_185503_d95bbc1a"}
2026-05-16T18:55:04+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_185503_d95bbc1a"}
2026-05-16T18:55:04+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_185503_d95bbc1a"}
2026-05-16T18:55:05+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_185503_d95bbc1a"}
2026-05-16T18:55:05+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4142,"mtime":"2026-05-16T18:54:14+02:00","run_id":"20260516_185503_d95bbc1a"}
2026-05-16T18:55:05+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_185503_d95bbc1a"}
2026-05-16T18:55:05+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":12000,"mtime":"2026-05-16T18:54:13+02:00","run_id":"20260516_185503_d95bbc1a"}
2026-05-16T18:55:05+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":16,"rb":26,"run_id":"20260516_185503_d95bbc1a"}
2026-05-16T18:55:05+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_185503_d95bbc1a"}
2026-05-16T18:55:05+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.95,"duration_milliseconds":950,"important":true,"run_id":"20260516_185503_d95bbc1a"}
2026-05-16T18:55:05+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_185503_d95bbc1a"}
2026-05-16T18:55:05+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_185503_d95bbc1a"}
2026-05-16T18:55:05+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":6597,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_185503_d95bbc1a"}
2026-05-16T18:55:05+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_185503_d95bbc1a"}
2026-05-16T18:55:05+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":6146,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_185503_d95bbc1a"}
2026-05-16T18:55:05+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_185503_d95bbc1a"}
2026-05-16T18:55:05+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_185503_d95bbc1a"}
2026-05-16T18:55:05+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.303,"duration_milliseconds":303,"important":true,"run_id":"20260516_185503_d95bbc1a"}
2026-05-16T18:55:05+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_185503_d95bbc1a"}
2026-05-16T18:55:05+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_185503_d95bbc1a"}
2026-05-16T18:55:05+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":178415,"run_id":"20260516_185503_d95bbc1a"}
2026-05-16T18:55:05+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.013,"exec_milliseconds":2013,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":178415,"important":true,"run_id":"20260516_185503_d95bbc1a"}
2026-05-16T18:56:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_185602_b1345ac6"}
2026-05-16T18:56:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_185602_b1345ac6"}
2026-05-16T18:56:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_185602_b1345ac6"}
2026-05-16T18:56:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_185602_b1345ac6"}
2026-05-16T18:56:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_185602_b1345ac6"}
2026-05-16T18:56:03+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_185602_b1345ac6"}
2026-05-16T18:56:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_185602_b1345ac6"}
2026-05-16T18:56:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_185602_b1345ac6"}
2026-05-16T18:56:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4142,"mtime":"2026-05-16T18:54:14+02:00","run_id":"20260516_185602_b1345ac6"}
2026-05-16T18:56:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_185602_b1345ac6"}
2026-05-16T18:56:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":12000,"mtime":"2026-05-16T18:54:13+02:00","run_id":"20260516_185602_b1345ac6"}
2026-05-16T18:56:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":16,"rb":26,"run_id":"20260516_185602_b1345ac6"}
2026-05-16T18:56:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_185602_b1345ac6"}
2026-05-16T18:56:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.944,"duration_milliseconds":944,"important":true,"run_id":"20260516_185602_b1345ac6"}
2026-05-16T18:56:04+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_185602_b1345ac6"}
2026-05-16T18:56:04+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_185602_b1345ac6"}
2026-05-16T18:56:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":6597,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_185602_b1345ac6"}
2026-05-16T18:56:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_185602_b1345ac6"}
2026-05-16T18:56:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":6146,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_185602_b1345ac6"}
2026-05-16T18:56:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_185602_b1345ac6"}
2026-05-16T18:56:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_185602_b1345ac6"}
2026-05-16T18:56:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.285,"duration_milliseconds":285,"important":true,"run_id":"20260516_185602_b1345ac6"}
2026-05-16T18:56:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_185602_b1345ac6"}
2026-05-16T18:56:04+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_185602_b1345ac6"}
2026-05-16T18:56:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":178515,"run_id":"20260516_185602_b1345ac6"}
2026-05-16T18:56:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.011,"exec_milliseconds":2011,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":178515,"important":true,"run_id":"20260516_185602_b1345ac6"}
2026-05-16T18:57:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_185701_62c035be"}
2026-05-16T18:57:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_185701_62c035be"}
2026-05-16T18:57:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_185701_62c035be"}
2026-05-16T18:57:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_185701_62c035be"}
2026-05-16T18:57:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_185701_62c035be"}
2026-05-16T18:57:02+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_185701_62c035be"}
2026-05-16T18:57:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_185701_62c035be"}
2026-05-16T18:57:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_185701_62c035be"}
2026-05-16T18:57:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4142,"mtime":"2026-05-16T18:56:58+02:00","run_id":"20260516_185701_62c035be"}
2026-05-16T18:57:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_185701_62c035be"}
2026-05-16T18:57:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":12218,"mtime":"2026-05-16T18:56:58+02:00","run_id":"20260516_185701_62c035be"}
2026-05-16T18:57:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":16,"rb":26,"run_id":"20260516_185701_62c035be"}
2026-05-16T18:57:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_185701_62c035be"}
2026-05-16T18:57:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.964,"duration_milliseconds":964,"important":true,"run_id":"20260516_185701_62c035be"}
2026-05-16T18:57:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_185701_62c035be"}
2026-05-16T18:57:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_185701_62c035be"}
2026-05-16T18:57:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":6597,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_185701_62c035be"}
2026-05-16T18:57:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_185701_62c035be"}
2026-05-16T18:57:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":6146,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_185701_62c035be"}
2026-05-16T18:57:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_185701_62c035be"}
2026-05-16T18:57:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_185701_62c035be"}
2026-05-16T18:57:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.325,"duration_milliseconds":325,"important":true,"run_id":"20260516_185701_62c035be"}
2026-05-16T18:57:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_185701_62c035be"}
2026-05-16T18:57:04+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_185701_62c035be"}
2026-05-16T18:57:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":179375,"run_id":"20260516_185701_62c035be"}
2026-05-16T18:57:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.071,"exec_milliseconds":2071,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":179375,"important":true,"run_id":"20260516_185701_62c035be"}
2026-05-16T18:58:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_185802_de8fb496"}
2026-05-16T18:58:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_185802_de8fb496"}
2026-05-16T18:58:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_185802_de8fb496"}
2026-05-16T18:58:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_185802_de8fb496"}
2026-05-16T18:58:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_185802_de8fb496"}
2026-05-16T18:58:03+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_185802_de8fb496"}
2026-05-16T18:58:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_185802_de8fb496"}
2026-05-16T18:58:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_185802_de8fb496"}
2026-05-16T18:58:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4142,"mtime":"2026-05-16T18:57:52+02:00","run_id":"20260516_185802_de8fb496"}
2026-05-16T18:58:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_185802_de8fb496"}
2026-05-16T18:58:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":12363,"mtime":"2026-05-16T18:57:52+02:00","run_id":"20260516_185802_de8fb496"}
2026-05-16T18:58:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":16,"rb":26,"run_id":"20260516_185802_de8fb496"}
2026-05-16T18:58:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_185802_de8fb496"}
2026-05-16T18:58:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.961,"duration_milliseconds":961,"important":true,"run_id":"20260516_185802_de8fb496"}
2026-05-16T18:58:04+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_185802_de8fb496"}
2026-05-16T18:58:04+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_185802_de8fb496"}
2026-05-16T18:58:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":6597,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_185802_de8fb496"}
2026-05-16T18:58:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_185802_de8fb496"}
2026-05-16T18:58:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":6146,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_185802_de8fb496"}
2026-05-16T18:58:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_185802_de8fb496"}
2026-05-16T18:58:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_185802_de8fb496"}
2026-05-16T18:58:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.296,"duration_milliseconds":296,"important":true,"run_id":"20260516_185802_de8fb496"}
2026-05-16T18:58:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_185802_de8fb496"}
2026-05-16T18:58:04+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_185802_de8fb496"}
2026-05-16T18:58:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":180012,"run_id":"20260516_185802_de8fb496"}
2026-05-16T18:58:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.04,"exec_milliseconds":2040,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":180012,"important":true,"run_id":"20260516_185802_de8fb496"}
2026-05-16T18:59:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_185901_27ae485b"}
2026-05-16T18:59:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_185901_27ae485b"}
2026-05-16T18:59:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_185901_27ae485b"}
2026-05-16T18:59:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_185901_27ae485b"}
2026-05-16T18:59:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_185901_27ae485b"}
2026-05-16T18:59:02+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_185901_27ae485b"}
2026-05-16T18:59:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_185901_27ae485b"}
2026-05-16T18:59:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_185901_27ae485b"}
2026-05-16T18:59:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4142,"mtime":"2026-05-16T18:58:16+02:00","run_id":"20260516_185901_27ae485b"}
2026-05-16T18:59:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_185901_27ae485b"}
2026-05-16T18:59:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":12517,"mtime":"2026-05-16T18:58:16+02:00","run_id":"20260516_185901_27ae485b"}
2026-05-16T18:59:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":16,"rb":26,"run_id":"20260516_185901_27ae485b"}
2026-05-16T18:59:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_185901_27ae485b"}
2026-05-16T18:59:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.938,"duration_milliseconds":938,"important":true,"run_id":"20260516_185901_27ae485b"}
2026-05-16T18:59:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_185901_27ae485b"}
2026-05-16T18:59:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_185901_27ae485b"}
2026-05-16T18:59:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":6597,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_185901_27ae485b"}
2026-05-16T18:59:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_185901_27ae485b"}
2026-05-16T18:59:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":6146,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_185901_27ae485b"}
2026-05-16T18:59:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_185901_27ae485b"}
2026-05-16T18:59:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_185901_27ae485b"}
2026-05-16T18:59:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.286,"duration_milliseconds":286,"important":true,"run_id":"20260516_185901_27ae485b"}
2026-05-16T18:59:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_185901_27ae485b"}
2026-05-16T18:59:03+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_185901_27ae485b"}
2026-05-16T18:59:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":180678,"run_id":"20260516_185901_27ae485b"}
2026-05-16T18:59:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.06,"exec_milliseconds":2060,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":180678,"important":true,"run_id":"20260516_185901_27ae485b"}
2026-05-16T19:00:19+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_190019_0c86e974"}
2026-05-16T19:00:19+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_190019_0c86e974"}
2026-05-16T19:00:19+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_190019_0c86e974"}
2026-05-16T19:00:19+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_190019_0c86e974"}
2026-05-16T19:00:19+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_190019_0c86e974"}
2026-05-16T19:00:19+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_190019_0c86e974"}
2026-05-16T19:00:19+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_190019_0c86e974"}
2026-05-16T19:00:20+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_190019_0c86e974"}
2026-05-16T19:00:20+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4142,"mtime":"2026-05-16T18:59:49+02:00","run_id":"20260516_190019_0c86e974"}
2026-05-16T19:00:20+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_190019_0c86e974"}
2026-05-16T19:00:20+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":12528,"mtime":"2026-05-16T18:59:49+02:00","run_id":"20260516_190019_0c86e974"}
2026-05-16T19:00:20+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":16,"rb":26,"run_id":"20260516_190019_0c86e974"}
2026-05-16T19:00:20+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_190019_0c86e974"}
2026-05-16T19:00:20+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.958,"duration_milliseconds":958,"important":true,"run_id":"20260516_190019_0c86e974"}
2026-05-16T19:00:20+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_190019_0c86e974"}
2026-05-16T19:00:20+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_190019_0c86e974"}
2026-05-16T19:00:20+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":6597,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_190019_0c86e974"}
2026-05-16T19:00:20+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_190019_0c86e974"}
2026-05-16T19:00:20+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":6146,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_190019_0c86e974"}
2026-05-16T19:00:20+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_190019_0c86e974"}
2026-05-16T19:00:21+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_190019_0c86e974"}
2026-05-16T19:00:21+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.296,"duration_milliseconds":296,"important":true,"run_id":"20260516_190019_0c86e974"}
2026-05-16T19:00:21+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_190019_0c86e974"}
2026-05-16T19:00:21+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_190019_0c86e974"}
2026-05-16T19:00:21+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":180707,"run_id":"20260516_190019_0c86e974"}
2026-05-16T19:00:21+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.039,"exec_milliseconds":2039,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":180707,"important":true,"run_id":"20260516_190019_0c86e974"}
2026-05-16T19:01:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_190102_9e0222b9"}
2026-05-16T19:01:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_190102_9e0222b9"}
2026-05-16T19:01:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_190102_9e0222b9"}
2026-05-16T19:01:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_190102_9e0222b9"}
2026-05-16T19:01:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_190102_9e0222b9"}
2026-05-16T19:01:02+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_190102_9e0222b9"}
2026-05-16T19:01:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_190102_9e0222b9"}
2026-05-16T19:01:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_190102_9e0222b9"}
2026-05-16T19:01:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4142,"mtime":"2026-05-16T19:00:31+02:00","run_id":"20260516_190102_9e0222b9"}
2026-05-16T19:01:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_190102_9e0222b9"}
2026-05-16T19:01:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":4814,"mtime":"2026-05-16T19:00:29+02:00","run_id":"20260516_190102_9e0222b9"}
2026-05-16T19:01:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":16,"rb":26,"run_id":"20260516_190102_9e0222b9"}
2026-05-16T19:01:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_190102_9e0222b9"}
2026-05-16T19:01:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.959,"duration_milliseconds":959,"important":true,"run_id":"20260516_190102_9e0222b9"}
2026-05-16T19:01:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_190102_9e0222b9"}
2026-05-16T19:01:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_190102_9e0222b9"}
2026-05-16T19:01:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":6597,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_190102_9e0222b9"}
2026-05-16T19:01:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_190102_9e0222b9"}
2026-05-16T19:01:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":6146,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_190102_9e0222b9"}
2026-05-16T19:01:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_190102_9e0222b9"}
2026-05-16T19:01:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_190102_9e0222b9"}
2026-05-16T19:01:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.309,"duration_milliseconds":309,"important":true,"run_id":"20260516_190102_9e0222b9"}
2026-05-16T19:01:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_190102_9e0222b9"}
2026-05-16T19:01:04+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_190102_9e0222b9"}
2026-05-16T19:01:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":147559,"run_id":"20260516_190102_9e0222b9"}
2026-05-16T19:01:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.049,"exec_milliseconds":2049,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":147559,"important":true,"run_id":"20260516_190102_9e0222b9"}
2026-05-16T19:02:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_190202_f1c6b5e8"}
2026-05-16T19:02:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_190202_f1c6b5e8"}
2026-05-16T19:02:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_190202_f1c6b5e8"}
2026-05-16T19:02:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_190202_f1c6b5e8"}
2026-05-16T19:02:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_190202_f1c6b5e8"}
2026-05-16T19:02:03+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_190202_f1c6b5e8"}
2026-05-16T19:02:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_190202_f1c6b5e8"}
2026-05-16T19:02:04+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_190202_f1c6b5e8"}
2026-05-16T19:02:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4142,"mtime":"2026-05-16T19:01:57+02:00","run_id":"20260516_190202_f1c6b5e8"}
2026-05-16T19:02:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_190202_f1c6b5e8"}
2026-05-16T19:02:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":5236,"mtime":"2026-05-16T19:01:57+02:00","run_id":"20260516_190202_f1c6b5e8"}
2026-05-16T19:02:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":16,"rb":27,"run_id":"20260516_190202_f1c6b5e8"}
2026-05-16T19:02:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_190202_f1c6b5e8"}
2026-05-16T19:02:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.961,"duration_milliseconds":961,"important":true,"run_id":"20260516_190202_f1c6b5e8"}
2026-05-16T19:02:04+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_190202_f1c6b5e8"}
2026-05-16T19:02:04+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_190202_f1c6b5e8"}
2026-05-16T19:02:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":6597,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_190202_f1c6b5e8"}
2026-05-16T19:02:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_190202_f1c6b5e8"}
2026-05-16T19:02:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":6146,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_190202_f1c6b5e8"}
2026-05-16T19:02:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_190202_f1c6b5e8"}
2026-05-16T19:02:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_190202_f1c6b5e8"}
2026-05-16T19:02:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.306,"duration_milliseconds":306,"important":true,"run_id":"20260516_190202_f1c6b5e8"}
2026-05-16T19:02:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_190202_f1c6b5e8"}
2026-05-16T19:02:04+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_190202_f1c6b5e8"}
2026-05-16T19:02:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":149345,"run_id":"20260516_190202_f1c6b5e8"}
2026-05-16T19:02:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.099,"exec_milliseconds":2099,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":149345,"important":true,"run_id":"20260516_190202_f1c6b5e8"}
2026-05-16T19:03:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_190301_c8a175cb"}
2026-05-16T19:03:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_190301_c8a175cb"}
2026-05-16T19:03:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_190301_c8a175cb"}
2026-05-16T19:03:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_190301_c8a175cb"}
2026-05-16T19:03:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_190301_c8a175cb"}
2026-05-16T19:03:02+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_190301_c8a175cb"}
2026-05-16T19:03:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_190301_c8a175cb"}
2026-05-16T19:03:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_190301_c8a175cb"}
2026-05-16T19:03:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4142,"mtime":"2026-05-16T19:03:02+02:00","run_id":"20260516_190301_c8a175cb"}
2026-05-16T19:03:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_190301_c8a175cb"}
2026-05-16T19:03:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":5722,"mtime":"2026-05-16T19:03:02+02:00","run_id":"20260516_190301_c8a175cb"}
2026-05-16T19:03:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":16,"rb":28,"run_id":"20260516_190301_c8a175cb"}
2026-05-16T19:03:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_190301_c8a175cb"}
2026-05-16T19:03:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.964,"duration_milliseconds":964,"important":true,"run_id":"20260516_190301_c8a175cb"}
2026-05-16T19:03:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_190301_c8a175cb"}
2026-05-16T19:03:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_190301_c8a175cb"}
2026-05-16T19:03:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":6597,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_190301_c8a175cb"}
2026-05-16T19:03:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_190301_c8a175cb"}
2026-05-16T19:03:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":6146,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_190301_c8a175cb"}
2026-05-16T19:03:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_190301_c8a175cb"}
2026-05-16T19:03:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_190301_c8a175cb"}
2026-05-16T19:03:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.307,"duration_milliseconds":307,"important":true,"run_id":"20260516_190301_c8a175cb"}
2026-05-16T19:03:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_190301_c8a175cb"}
2026-05-16T19:03:03+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_190301_c8a175cb"}
2026-05-16T19:03:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":151429,"run_id":"20260516_190301_c8a175cb"}
2026-05-16T19:03:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.054,"exec_milliseconds":2054,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":151429,"important":true,"run_id":"20260516_190301_c8a175cb"}
2026-05-16T19:04:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_190402_8443eb74"}
2026-05-16T19:04:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_190402_8443eb74"}
2026-05-16T19:04:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_190402_8443eb74"}
2026-05-16T19:04:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_190402_8443eb74"}
2026-05-16T19:04:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_190402_8443eb74"}
2026-05-16T19:04:03+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_190402_8443eb74"}
2026-05-16T19:04:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_190402_8443eb74"}
2026-05-16T19:04:04+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_190402_8443eb74"}
2026-05-16T19:04:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4142,"mtime":"2026-05-16T19:04:02+02:00","run_id":"20260516_190402_8443eb74"}
2026-05-16T19:04:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_190402_8443eb74"}
2026-05-16T19:04:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":6437,"mtime":"2026-05-16T19:04:02+02:00","run_id":"20260516_190402_8443eb74"}
2026-05-16T19:04:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":19,"rb":30,"run_id":"20260516_190402_8443eb74"}
2026-05-16T19:04:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_190402_8443eb74"}
2026-05-16T19:04:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.942,"duration_milliseconds":942,"important":true,"run_id":"20260516_190402_8443eb74"}
2026-05-16T19:04:04+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_190402_8443eb74"}
2026-05-16T19:04:04+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_190402_8443eb74"}
2026-05-16T19:04:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":6597,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_190402_8443eb74"}
2026-05-16T19:04:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_190402_8443eb74"}
2026-05-16T19:04:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":6146,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_190402_8443eb74"}
2026-05-16T19:04:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_190402_8443eb74"}
2026-05-16T19:04:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_190402_8443eb74"}
2026-05-16T19:04:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.293,"duration_milliseconds":293,"important":true,"run_id":"20260516_190402_8443eb74"}
2026-05-16T19:04:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_190402_8443eb74"}
2026-05-16T19:04:04+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_190402_8443eb74"}
2026-05-16T19:04:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":154446,"run_id":"20260516_190402_8443eb74"}
2026-05-16T19:04:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.004,"exec_milliseconds":2004,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":154446,"important":true,"run_id":"20260516_190402_8443eb74"}
2026-05-16T19:05:04+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_190504_fbf4393d"}
2026-05-16T19:05:04+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_190504_fbf4393d"}
2026-05-16T19:05:04+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_190504_fbf4393d"}
2026-05-16T19:05:04+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_190504_fbf4393d"}
2026-05-16T19:05:04+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_190504_fbf4393d"}
2026-05-16T19:05:04+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_190504_fbf4393d"}
2026-05-16T19:05:04+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_190504_fbf4393d"}
2026-05-16T19:05:05+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_190504_fbf4393d"}
2026-05-16T19:05:05+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4142,"mtime":"2026-05-16T19:04:48+02:00","run_id":"20260516_190504_fbf4393d"}
2026-05-16T19:05:05+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_190504_fbf4393d"}
2026-05-16T19:05:05+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":6666,"mtime":"2026-05-16T19:04:48+02:00","run_id":"20260516_190504_fbf4393d"}
2026-05-16T19:05:05+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":19,"rb":30,"run_id":"20260516_190504_fbf4393d"}
2026-05-16T19:05:05+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_190504_fbf4393d"}
2026-05-16T19:05:05+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.94,"duration_milliseconds":940,"important":true,"run_id":"20260516_190504_fbf4393d"}
2026-05-16T19:05:05+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_190504_fbf4393d"}
2026-05-16T19:05:05+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_190504_fbf4393d"}
2026-05-16T19:05:05+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":6597,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_190504_fbf4393d"}
2026-05-16T19:05:05+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_190504_fbf4393d"}
2026-05-16T19:05:05+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":6146,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_190504_fbf4393d"}
2026-05-16T19:05:05+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_190504_fbf4393d"}
2026-05-16T19:05:06+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_190504_fbf4393d"}
2026-05-16T19:05:06+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.298,"duration_milliseconds":298,"important":true,"run_id":"20260516_190504_fbf4393d"}
2026-05-16T19:05:06+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_190504_fbf4393d"}
2026-05-16T19:05:06+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_190504_fbf4393d"}
2026-05-16T19:05:06+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":155429,"run_id":"20260516_190504_fbf4393d"}
2026-05-16T19:05:06+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.038,"exec_milliseconds":2038,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":155429,"important":true,"run_id":"20260516_190504_fbf4393d"}
2026-05-16T19:06:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_190602_ec02c68d"}
2026-05-16T19:06:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_190602_ec02c68d"}
2026-05-16T19:06:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_190602_ec02c68d"}
2026-05-16T19:06:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_190602_ec02c68d"}
2026-05-16T19:06:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_190602_ec02c68d"}
2026-05-16T19:06:03+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_190602_ec02c68d"}
2026-05-16T19:06:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_190602_ec02c68d"}
2026-05-16T19:06:04+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_190602_ec02c68d"}
2026-05-16T19:06:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4142,"mtime":"2026-05-16T19:05:48+02:00","run_id":"20260516_190602_ec02c68d"}
2026-05-16T19:06:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_190602_ec02c68d"}
2026-05-16T19:06:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":6810,"mtime":"2026-05-16T19:05:48+02:00","run_id":"20260516_190602_ec02c68d"}
2026-05-16T19:06:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":19,"rb":30,"run_id":"20260516_190602_ec02c68d"}
2026-05-16T19:06:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_190602_ec02c68d"}
2026-05-16T19:06:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.952,"duration_milliseconds":952,"important":true,"run_id":"20260516_190602_ec02c68d"}
2026-05-16T19:06:04+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_190602_ec02c68d"}
2026-05-16T19:06:04+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_190602_ec02c68d"}
2026-05-16T19:06:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":6597,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_190602_ec02c68d"}
2026-05-16T19:06:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_190602_ec02c68d"}
2026-05-16T19:06:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":6146,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_190602_ec02c68d"}
2026-05-16T19:06:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_190602_ec02c68d"}
2026-05-16T19:06:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_190602_ec02c68d"}
2026-05-16T19:06:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.296,"duration_milliseconds":296,"important":true,"run_id":"20260516_190602_ec02c68d"}
2026-05-16T19:06:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_190602_ec02c68d"}
2026-05-16T19:06:04+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_190602_ec02c68d"}
2026-05-16T19:06:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":156067,"run_id":"20260516_190602_ec02c68d"}
2026-05-16T19:06:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.055,"exec_milliseconds":2055,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":156067,"important":true,"run_id":"20260516_190602_ec02c68d"}
2026-05-16T19:07:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_190701_d03dafd6"}
2026-05-16T19:07:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_190701_d03dafd6"}
2026-05-16T19:07:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_190701_d03dafd6"}
2026-05-16T19:07:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_190701_d03dafd6"}
2026-05-16T19:07:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_190701_d03dafd6"}
2026-05-16T19:07:02+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_190701_d03dafd6"}
2026-05-16T19:07:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_190701_d03dafd6"}
2026-05-16T19:07:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_190701_d03dafd6"}
2026-05-16T19:07:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4142,"mtime":"2026-05-16T19:06:34+02:00","run_id":"20260516_190701_d03dafd6"}
2026-05-16T19:07:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_190701_d03dafd6"}
2026-05-16T19:07:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":7009,"mtime":"2026-05-16T19:06:34+02:00","run_id":"20260516_190701_d03dafd6"}
2026-05-16T19:07:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":22,"rb":30,"run_id":"20260516_190701_d03dafd6"}
2026-05-16T19:07:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_190701_d03dafd6"}
2026-05-16T19:07:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.987,"duration_milliseconds":987,"important":true,"run_id":"20260516_190701_d03dafd6"}
2026-05-16T19:07:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_190701_d03dafd6"}
2026-05-16T19:07:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_190701_d03dafd6"}
2026-05-16T19:07:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":6597,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_190701_d03dafd6"}
2026-05-16T19:07:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_190701_d03dafd6"}
2026-05-16T19:07:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":6146,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_190701_d03dafd6"}
2026-05-16T19:07:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_190701_d03dafd6"}
2026-05-16T19:07:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_190701_d03dafd6"}
2026-05-16T19:07:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.308,"duration_milliseconds":308,"important":true,"run_id":"20260516_190701_d03dafd6"}
2026-05-16T19:07:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_190701_d03dafd6"}
2026-05-16T19:07:03+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_190701_d03dafd6"}
2026-05-16T19:07:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":156884,"run_id":"20260516_190701_d03dafd6"}
2026-05-16T19:07:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.055,"exec_milliseconds":2055,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":156884,"important":true,"run_id":"20260516_190701_d03dafd6"}
2026-05-16T19:08:03+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_190803_3c32e7af"}
2026-05-16T19:08:04+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_190803_3c32e7af"}
2026-05-16T19:08:04+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_190803_3c32e7af"}
2026-05-16T19:08:04+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_190803_3c32e7af"}
2026-05-16T19:08:04+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_190803_3c32e7af"}
2026-05-16T19:08:04+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_190803_3c32e7af"}
2026-05-16T19:08:04+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_190803_3c32e7af"}
2026-05-16T19:08:05+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_190803_3c32e7af"}
2026-05-16T19:08:05+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4142,"mtime":"2026-05-16T19:08:00+02:00","run_id":"20260516_190803_3c32e7af"}
2026-05-16T19:08:05+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_190803_3c32e7af"}
2026-05-16T19:08:05+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":7534,"mtime":"2026-05-16T19:08:00+02:00","run_id":"20260516_190803_3c32e7af"}
2026-05-16T19:08:05+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":22,"rb":31,"run_id":"20260516_190803_3c32e7af"}
2026-05-16T19:08:05+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_190803_3c32e7af"}
2026-05-16T19:08:05+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.939,"duration_milliseconds":939,"important":true,"run_id":"20260516_190803_3c32e7af"}
2026-05-16T19:08:05+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_190803_3c32e7af"}
2026-05-16T19:08:05+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_190803_3c32e7af"}
2026-05-16T19:08:05+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":6597,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_190803_3c32e7af"}
2026-05-16T19:08:05+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_190803_3c32e7af"}
2026-05-16T19:08:05+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":6146,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_190803_3c32e7af"}
2026-05-16T19:08:05+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_190803_3c32e7af"}
2026-05-16T19:08:05+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_190803_3c32e7af"}
2026-05-16T19:08:05+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.305,"duration_milliseconds":305,"important":true,"run_id":"20260516_190803_3c32e7af"}
2026-05-16T19:08:05+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_190803_3c32e7af"}
2026-05-16T19:08:05+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_190803_3c32e7af"}
2026-05-16T19:08:05+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":159059,"run_id":"20260516_190803_3c32e7af"}
2026-05-16T19:08:05+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.052,"exec_milliseconds":2052,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":159059,"important":true,"run_id":"20260516_190803_3c32e7af"}
2026-05-16T19:09:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_190901_77b1f6d0"}
2026-05-16T19:09:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_190901_77b1f6d0"}
2026-05-16T19:09:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_190901_77b1f6d0"}
2026-05-16T19:09:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_190901_77b1f6d0"}
2026-05-16T19:09:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_190901_77b1f6d0"}
2026-05-16T19:09:02+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_190901_77b1f6d0"}
2026-05-16T19:09:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_190901_77b1f6d0"}
2026-05-16T19:09:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_190901_77b1f6d0"}
2026-05-16T19:09:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4142,"mtime":"2026-05-16T19:09:01+02:00","run_id":"20260516_190901_77b1f6d0"}
2026-05-16T19:09:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_190901_77b1f6d0"}
2026-05-16T19:09:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":7883,"mtime":"2026-05-16T19:09:01+02:00","run_id":"20260516_190901_77b1f6d0"}
2026-05-16T19:09:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":22,"rb":34,"run_id":"20260516_190901_77b1f6d0"}
2026-05-16T19:09:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_190901_77b1f6d0"}
2026-05-16T19:09:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.96,"duration_milliseconds":960,"important":true,"run_id":"20260516_190901_77b1f6d0"}
2026-05-16T19:09:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_190901_77b1f6d0"}
2026-05-16T19:09:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_190901_77b1f6d0"}
2026-05-16T19:09:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":6597,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_190901_77b1f6d0"}
2026-05-16T19:09:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_190901_77b1f6d0"}
2026-05-16T19:09:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":6146,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_190901_77b1f6d0"}
2026-05-16T19:09:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_190901_77b1f6d0"}
2026-05-16T19:09:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_190901_77b1f6d0"}
2026-05-16T19:09:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.316,"duration_milliseconds":316,"important":true,"run_id":"20260516_190901_77b1f6d0"}
2026-05-16T19:09:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_190901_77b1f6d0"}
2026-05-16T19:09:03+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_190901_77b1f6d0"}
2026-05-16T19:09:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":160522,"run_id":"20260516_190901_77b1f6d0"}
2026-05-16T19:09:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.111,"exec_milliseconds":2111,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":160522,"important":true,"run_id":"20260516_190901_77b1f6d0"}
2026-05-16T19:10:06+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_191006_a5f04420"}
2026-05-16T19:10:06+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_191006_a5f04420"}
2026-05-16T19:10:06+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_191006_a5f04420"}
2026-05-16T19:10:06+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_191006_a5f04420"}
2026-05-16T19:10:06+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_191006_a5f04420"}
2026-05-16T19:10:06+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_191006_a5f04420"}
2026-05-16T19:10:06+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_191006_a5f04420"}
2026-05-16T19:10:07+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_191006_a5f04420"}
2026-05-16T19:10:07+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4142,"mtime":"2026-05-16T19:09:44+02:00","run_id":"20260516_191006_a5f04420"}
2026-05-16T19:10:07+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_191006_a5f04420"}
2026-05-16T19:10:07+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":8309,"mtime":"2026-05-16T19:09:44+02:00","run_id":"20260516_191006_a5f04420"}
2026-05-16T19:10:07+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":24,"rb":34,"run_id":"20260516_191006_a5f04420"}
2026-05-16T19:10:07+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_191006_a5f04420"}
2026-05-16T19:10:07+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.993,"duration_milliseconds":993,"important":true,"run_id":"20260516_191006_a5f04420"}
2026-05-16T19:10:07+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_191006_a5f04420"}
2026-05-16T19:10:07+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_191006_a5f04420"}
2026-05-16T19:10:07+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":6597,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_191006_a5f04420"}
2026-05-16T19:10:07+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_191006_a5f04420"}
2026-05-16T19:10:07+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":6146,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_191006_a5f04420"}
2026-05-16T19:10:07+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_191006_a5f04420"}
2026-05-16T19:10:08+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_191006_a5f04420"}
2026-05-16T19:10:08+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.301,"duration_milliseconds":301,"important":true,"run_id":"20260516_191006_a5f04420"}
2026-05-16T19:10:08+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_191006_a5f04420"}
2026-05-16T19:10:08+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_191006_a5f04420"}
2026-05-16T19:10:08+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":162316,"run_id":"20260516_191006_a5f04420"}
2026-05-16T19:10:08+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.115,"exec_milliseconds":2115,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":162316,"important":true,"run_id":"20260516_191006_a5f04420"}
2026-05-16T19:11:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_191101_0dd23387"}
2026-05-16T19:11:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_191101_0dd23387"}
2026-05-16T19:11:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_191101_0dd23387"}
2026-05-16T19:11:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_191101_0dd23387"}
2026-05-16T19:11:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_191101_0dd23387"}
2026-05-16T19:11:02+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_191101_0dd23387"}
2026-05-16T19:11:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_191101_0dd23387"}
2026-05-16T19:11:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_191101_0dd23387"}
2026-05-16T19:11:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4142,"mtime":"2026-05-16T19:11:00+02:00","run_id":"20260516_191101_0dd23387"}
2026-05-16T19:11:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_191101_0dd23387"}
2026-05-16T19:11:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":8873,"mtime":"2026-05-16T19:11:00+02:00","run_id":"20260516_191101_0dd23387"}
2026-05-16T19:11:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":26,"rb":34,"run_id":"20260516_191101_0dd23387"}
2026-05-16T19:11:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_191101_0dd23387"}
2026-05-16T19:11:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.963,"duration_milliseconds":963,"important":true,"run_id":"20260516_191101_0dd23387"}
2026-05-16T19:11:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_191101_0dd23387"}
2026-05-16T19:11:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_191101_0dd23387"}
2026-05-16T19:11:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":6597,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_191101_0dd23387"}
2026-05-16T19:11:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_191101_0dd23387"}
2026-05-16T19:11:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":6146,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_191101_0dd23387"}
2026-05-16T19:11:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_191101_0dd23387"}
2026-05-16T19:11:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_191101_0dd23387"}
2026-05-16T19:11:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.314,"duration_milliseconds":314,"important":true,"run_id":"20260516_191101_0dd23387"}
2026-05-16T19:11:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_191101_0dd23387"}
2026-05-16T19:11:03+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_191101_0dd23387"}
2026-05-16T19:11:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":164732,"run_id":"20260516_191101_0dd23387"}
2026-05-16T19:11:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.084,"exec_milliseconds":2084,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":164732,"important":true,"run_id":"20260516_191101_0dd23387"}
2026-05-16T19:12:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_191202_590d2a92"}
2026-05-16T19:12:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_191202_590d2a92"}
2026-05-16T19:12:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_191202_590d2a92"}
2026-05-16T19:12:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_191202_590d2a92"}
2026-05-16T19:12:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_191202_590d2a92"}
2026-05-16T19:12:03+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_191202_590d2a92"}
2026-05-16T19:12:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_191202_590d2a92"}
2026-05-16T19:12:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_191202_590d2a92"}
2026-05-16T19:12:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4142,"mtime":"2026-05-16T19:12:01+02:00","run_id":"20260516_191202_590d2a92"}
2026-05-16T19:12:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_191202_590d2a92"}
2026-05-16T19:12:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":9276,"mtime":"2026-05-16T19:12:01+02:00","run_id":"20260516_191202_590d2a92"}
2026-05-16T19:12:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":27,"rb":34,"run_id":"20260516_191202_590d2a92"}
2026-05-16T19:12:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_191202_590d2a92"}
2026-05-16T19:12:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.952,"duration_milliseconds":952,"important":true,"run_id":"20260516_191202_590d2a92"}
2026-05-16T19:12:04+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_191202_590d2a92"}
2026-05-16T19:12:04+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_191202_590d2a92"}
2026-05-16T19:12:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":6597,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_191202_590d2a92"}
2026-05-16T19:12:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_191202_590d2a92"}
2026-05-16T19:12:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":6146,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_191202_590d2a92"}
2026-05-16T19:12:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_191202_590d2a92"}
2026-05-16T19:12:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_191202_590d2a92"}
2026-05-16T19:12:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.302,"duration_milliseconds":302,"important":true,"run_id":"20260516_191202_590d2a92"}
2026-05-16T19:12:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_191202_590d2a92"}
2026-05-16T19:12:04+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_191202_590d2a92"}
2026-05-16T19:12:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":166471,"run_id":"20260516_191202_590d2a92"}
2026-05-16T19:12:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.035,"exec_milliseconds":2035,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":166471,"important":true,"run_id":"20260516_191202_590d2a92"}
2026-05-16T19:13:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_191301_1c4bb45f"}
2026-05-16T19:13:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_191301_1c4bb45f"}
2026-05-16T19:13:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_191301_1c4bb45f"}
2026-05-16T19:13:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_191301_1c4bb45f"}
2026-05-16T19:13:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_191301_1c4bb45f"}
2026-05-16T19:13:02+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_191301_1c4bb45f"}
2026-05-16T19:13:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_191301_1c4bb45f"}
2026-05-16T19:13:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_191301_1c4bb45f"}
2026-05-16T19:13:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4142,"mtime":"2026-05-16T19:13:01+02:00","run_id":"20260516_191301_1c4bb45f"}
2026-05-16T19:13:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_191301_1c4bb45f"}
2026-05-16T19:13:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":9463,"mtime":"2026-05-16T19:12:59+02:00","run_id":"20260516_191301_1c4bb45f"}
2026-05-16T19:13:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":29,"rb":34,"run_id":"20260516_191301_1c4bb45f"}
2026-05-16T19:13:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_191301_1c4bb45f"}
2026-05-16T19:13:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.952,"duration_milliseconds":952,"important":true,"run_id":"20260516_191301_1c4bb45f"}
2026-05-16T19:13:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_191301_1c4bb45f"}
2026-05-16T19:13:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_191301_1c4bb45f"}
2026-05-16T19:13:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":6597,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_191301_1c4bb45f"}
2026-05-16T19:13:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_191301_1c4bb45f"}
2026-05-16T19:13:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":6146,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_191301_1c4bb45f"}
2026-05-16T19:13:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_191301_1c4bb45f"}
2026-05-16T19:13:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_191301_1c4bb45f"}
2026-05-16T19:13:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.319,"duration_milliseconds":319,"important":true,"run_id":"20260516_191301_1c4bb45f"}
2026-05-16T19:13:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_191301_1c4bb45f"}
2026-05-16T19:13:03+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_191301_1c4bb45f"}
2026-05-16T19:13:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":167260,"run_id":"20260516_191301_1c4bb45f"}
2026-05-16T19:13:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.034,"exec_milliseconds":2034,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":167260,"important":true,"run_id":"20260516_191301_1c4bb45f"}
2026-05-16T19:14:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_191402_9ecbaa8f"}
2026-05-16T19:14:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_191402_9ecbaa8f"}
2026-05-16T19:14:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_191402_9ecbaa8f"}
2026-05-16T19:14:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_191402_9ecbaa8f"}
2026-05-16T19:14:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_191402_9ecbaa8f"}
2026-05-16T19:14:03+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_191402_9ecbaa8f"}
2026-05-16T19:14:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_191402_9ecbaa8f"}
2026-05-16T19:14:04+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_191402_9ecbaa8f"}
2026-05-16T19:14:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4142,"mtime":"2026-05-16T19:13:50+02:00","run_id":"20260516_191402_9ecbaa8f"}
2026-05-16T19:14:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_191402_9ecbaa8f"}
2026-05-16T19:14:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":9459,"mtime":"2026-05-16T19:13:50+02:00","run_id":"20260516_191402_9ecbaa8f"}
2026-05-16T19:14:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":29,"rb":34,"run_id":"20260516_191402_9ecbaa8f"}
2026-05-16T19:14:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_191402_9ecbaa8f"}
2026-05-16T19:14:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.92,"duration_milliseconds":920,"important":true,"run_id":"20260516_191402_9ecbaa8f"}
2026-05-16T19:14:04+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_191402_9ecbaa8f"}
2026-05-16T19:14:04+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_191402_9ecbaa8f"}
2026-05-16T19:14:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":6597,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_191402_9ecbaa8f"}
2026-05-16T19:14:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_191402_9ecbaa8f"}
2026-05-16T19:14:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":6146,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_191402_9ecbaa8f"}
2026-05-16T19:14:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_191402_9ecbaa8f"}
2026-05-16T19:14:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_191402_9ecbaa8f"}
2026-05-16T19:14:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.268,"duration_milliseconds":268,"important":true,"run_id":"20260516_191402_9ecbaa8f"}
2026-05-16T19:14:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_191402_9ecbaa8f"}
2026-05-16T19:14:04+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_191402_9ecbaa8f"}
2026-05-16T19:14:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":167248,"run_id":"20260516_191402_9ecbaa8f"}
2026-05-16T19:14:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.922,"exec_milliseconds":1922,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":167248,"important":true,"run_id":"20260516_191402_9ecbaa8f"}
2026-05-16T19:15:06+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_191506_5b78460b"}
2026-05-16T19:15:07+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_191506_5b78460b"}
2026-05-16T19:15:07+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_191506_5b78460b"}
2026-05-16T19:15:07+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_191506_5b78460b"}
2026-05-16T19:15:07+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_191506_5b78460b"}
2026-05-16T19:15:07+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_191506_5b78460b"}
2026-05-16T19:15:07+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_191506_5b78460b"}
2026-05-16T19:15:08+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_191506_5b78460b"}
2026-05-16T19:15:08+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4142,"mtime":"2026-05-16T19:14:27+02:00","run_id":"20260516_191506_5b78460b"}
2026-05-16T19:15:08+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_191506_5b78460b"}
2026-05-16T19:15:08+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":9538,"mtime":"2026-05-16T19:14:27+02:00","run_id":"20260516_191506_5b78460b"}
2026-05-16T19:15:08+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":29,"rb":34,"run_id":"20260516_191506_5b78460b"}
2026-05-16T19:15:08+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_191506_5b78460b"}
2026-05-16T19:15:08+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.949,"duration_milliseconds":949,"important":true,"run_id":"20260516_191506_5b78460b"}
2026-05-16T19:15:08+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_191506_5b78460b"}
2026-05-16T19:15:08+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_191506_5b78460b"}
2026-05-16T19:15:08+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":6597,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_191506_5b78460b"}
2026-05-16T19:15:08+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_191506_5b78460b"}
2026-05-16T19:15:08+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":6146,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_191506_5b78460b"}
2026-05-16T19:15:08+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_191506_5b78460b"}
2026-05-16T19:15:08+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_191506_5b78460b"}
2026-05-16T19:15:08+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.304,"duration_milliseconds":304,"important":true,"run_id":"20260516_191506_5b78460b"}
2026-05-16T19:15:08+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_191506_5b78460b"}
2026-05-16T19:15:08+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_191506_5b78460b"}
2026-05-16T19:15:08+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":167585,"run_id":"20260516_191506_5b78460b"}
2026-05-16T19:15:08+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.006,"exec_milliseconds":2006,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":167585,"important":true,"run_id":"20260516_191506_5b78460b"}
2026-05-16T19:16:03+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_191602_df548346"}
2026-05-16T19:16:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_191602_df548346"}
2026-05-16T19:16:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_191602_df548346"}
2026-05-16T19:16:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_191602_df548346"}
2026-05-16T19:16:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_191602_df548346"}
2026-05-16T19:16:03+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_191602_df548346"}
2026-05-16T19:16:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_191602_df548346"}
2026-05-16T19:16:04+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_191602_df548346"}
2026-05-16T19:16:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4142,"mtime":"2026-05-16T19:16:00+02:00","run_id":"20260516_191602_df548346"}
2026-05-16T19:16:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_191602_df548346"}
2026-05-16T19:16:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":9766,"mtime":"2026-05-16T19:16:00+02:00","run_id":"20260516_191602_df548346"}
2026-05-16T19:16:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":29,"rb":34,"run_id":"20260516_191602_df548346"}
2026-05-16T19:16:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_191602_df548346"}
2026-05-16T19:16:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.956,"duration_milliseconds":956,"important":true,"run_id":"20260516_191602_df548346"}
2026-05-16T19:16:04+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_191602_df548346"}
2026-05-16T19:16:04+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_191602_df548346"}
2026-05-16T19:16:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":6597,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_191602_df548346"}
2026-05-16T19:16:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_191602_df548346"}
2026-05-16T19:16:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":6146,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_191602_df548346"}
2026-05-16T19:16:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_191602_df548346"}
2026-05-16T19:16:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_191602_df548346"}
2026-05-16T19:16:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.307,"duration_milliseconds":307,"important":true,"run_id":"20260516_191602_df548346"}
2026-05-16T19:16:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_191602_df548346"}
2026-05-16T19:16:04+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_191602_df548346"}
2026-05-16T19:16:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":168567,"run_id":"20260516_191602_df548346"}
2026-05-16T19:16:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.082,"exec_milliseconds":2082,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":168567,"important":true,"run_id":"20260516_191602_df548346"}
2026-05-16T19:17:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_191701_909fcd06"}
2026-05-16T19:17:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_191701_909fcd06"}
2026-05-16T19:17:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_191701_909fcd06"}
2026-05-16T19:17:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_191701_909fcd06"}
2026-05-16T19:17:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_191701_909fcd06"}
2026-05-16T19:17:02+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_191701_909fcd06"}
2026-05-16T19:17:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_191701_909fcd06"}
2026-05-16T19:17:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_191701_909fcd06"}
2026-05-16T19:17:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4142,"mtime":"2026-05-16T19:16:43+02:00","run_id":"20260516_191701_909fcd06"}
2026-05-16T19:17:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_191701_909fcd06"}
2026-05-16T19:17:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":9998,"mtime":"2026-05-16T19:16:43+02:00","run_id":"20260516_191701_909fcd06"}
2026-05-16T19:17:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":29,"rb":34,"run_id":"20260516_191701_909fcd06"}
2026-05-16T19:17:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_191701_909fcd06"}
2026-05-16T19:17:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.963,"duration_milliseconds":963,"important":true,"run_id":"20260516_191701_909fcd06"}
2026-05-16T19:17:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_191701_909fcd06"}
2026-05-16T19:17:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_191701_909fcd06"}
2026-05-16T19:17:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":6597,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_191701_909fcd06"}
2026-05-16T19:17:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_191701_909fcd06"}
2026-05-16T19:17:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":6146,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_191701_909fcd06"}
2026-05-16T19:17:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_191701_909fcd06"}
2026-05-16T19:17:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_191701_909fcd06"}
2026-05-16T19:17:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.326,"duration_milliseconds":326,"important":true,"run_id":"20260516_191701_909fcd06"}
2026-05-16T19:17:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_191701_909fcd06"}
2026-05-16T19:17:03+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_191701_909fcd06"}
2026-05-16T19:17:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":169557,"run_id":"20260516_191701_909fcd06"}
2026-05-16T19:17:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.078,"exec_milliseconds":2078,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":169557,"important":true,"run_id":"20260516_191701_909fcd06"}
2026-05-16T19:18:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_191802_214d42db"}
2026-05-16T19:18:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_191802_214d42db"}
2026-05-16T19:18:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_191802_214d42db"}
2026-05-16T19:18:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_191802_214d42db"}
2026-05-16T19:18:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_191802_214d42db"}
2026-05-16T19:18:03+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_191802_214d42db"}
2026-05-16T19:18:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_191802_214d42db"}
2026-05-16T19:18:04+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_191802_214d42db"}
2026-05-16T19:18:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4142,"mtime":"2026-05-16T19:17:45+02:00","run_id":"20260516_191802_214d42db"}
2026-05-16T19:18:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_191802_214d42db"}
2026-05-16T19:18:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":10296,"mtime":"2026-05-16T19:17:45+02:00","run_id":"20260516_191802_214d42db"}
2026-05-16T19:18:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":29,"rb":34,"run_id":"20260516_191802_214d42db"}
2026-05-16T19:18:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_191802_214d42db"}
2026-05-16T19:18:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.943,"duration_milliseconds":943,"important":true,"run_id":"20260516_191802_214d42db"}
2026-05-16T19:18:04+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_191802_214d42db"}
2026-05-16T19:18:04+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_191802_214d42db"}
2026-05-16T19:18:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":6597,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_191802_214d42db"}
2026-05-16T19:18:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_191802_214d42db"}
2026-05-16T19:18:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":6146,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_191802_214d42db"}
2026-05-16T19:18:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_191802_214d42db"}
2026-05-16T19:18:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_191802_214d42db"}
2026-05-16T19:18:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.296,"duration_milliseconds":296,"important":true,"run_id":"20260516_191802_214d42db"}
2026-05-16T19:18:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_191802_214d42db"}
2026-05-16T19:18:04+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_191802_214d42db"}
2026-05-16T19:18:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":170851,"run_id":"20260516_191802_214d42db"}
2026-05-16T19:18:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.011,"exec_milliseconds":2011,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":170851,"important":true,"run_id":"20260516_191802_214d42db"}
2026-05-16T19:19:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_191901_0e05b792"}
2026-05-16T19:19:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_191901_0e05b792"}
2026-05-16T19:19:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_191901_0e05b792"}
2026-05-16T19:19:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_191901_0e05b792"}
2026-05-16T19:19:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_191901_0e05b792"}
2026-05-16T19:19:02+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_191901_0e05b792"}
2026-05-16T19:19:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_191901_0e05b792"}
2026-05-16T19:19:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_191901_0e05b792"}
2026-05-16T19:19:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4142,"mtime":"2026-05-16T19:18:51+02:00","run_id":"20260516_191901_0e05b792"}
2026-05-16T19:19:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_191901_0e05b792"}
2026-05-16T19:19:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":10670,"mtime":"2026-05-16T19:18:51+02:00","run_id":"20260516_191901_0e05b792"}
2026-05-16T19:19:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":29,"rb":34,"run_id":"20260516_191901_0e05b792"}
2026-05-16T19:19:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_191901_0e05b792"}
2026-05-16T19:19:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.928,"duration_milliseconds":928,"important":true,"run_id":"20260516_191901_0e05b792"}
2026-05-16T19:19:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_191901_0e05b792"}
2026-05-16T19:19:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_191901_0e05b792"}
2026-05-16T19:19:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":6597,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_191901_0e05b792"}
2026-05-16T19:19:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_191901_0e05b792"}
2026-05-16T19:19:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":6146,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_191901_0e05b792"}
2026-05-16T19:19:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_191901_0e05b792"}
2026-05-16T19:19:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_191901_0e05b792"}
2026-05-16T19:19:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.307,"duration_milliseconds":307,"important":true,"run_id":"20260516_191901_0e05b792"}
2026-05-16T19:19:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_191901_0e05b792"}
2026-05-16T19:19:03+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_191901_0e05b792"}
2026-05-16T19:19:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":172475,"run_id":"20260516_191901_0e05b792"}
2026-05-16T19:19:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.004,"exec_milliseconds":2004,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":172475,"important":true,"run_id":"20260516_191901_0e05b792"}
2026-05-16T19:20:06+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_192006_24628e8a"}
2026-05-16T19:20:07+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_192006_24628e8a"}
2026-05-16T19:20:07+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_192006_24628e8a"}
2026-05-16T19:20:07+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_192006_24628e8a"}
2026-05-16T19:20:07+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_192006_24628e8a"}
2026-05-16T19:20:07+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_192006_24628e8a"}
2026-05-16T19:20:07+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_192006_24628e8a"}
2026-05-16T19:20:08+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_192006_24628e8a"}
2026-05-16T19:20:08+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4142,"mtime":"2026-05-16T19:20:04+02:00","run_id":"20260516_192006_24628e8a"}
2026-05-16T19:20:08+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_192006_24628e8a"}
2026-05-16T19:20:08+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":11168,"mtime":"2026-05-16T19:20:07+02:00","run_id":"20260516_192006_24628e8a"}
2026-05-16T19:20:08+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":31,"rb":34,"run_id":"20260516_192006_24628e8a"}
2026-05-16T19:20:08+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_192006_24628e8a"}
2026-05-16T19:20:08+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.972,"duration_milliseconds":972,"important":true,"run_id":"20260516_192006_24628e8a"}
2026-05-16T19:20:08+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_192006_24628e8a"}
2026-05-16T19:20:08+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_192006_24628e8a"}
2026-05-16T19:20:08+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":6597,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_192006_24628e8a"}
2026-05-16T19:20:08+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_192006_24628e8a"}
2026-05-16T19:20:08+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":6146,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_192006_24628e8a"}
2026-05-16T19:20:08+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_192006_24628e8a"}
2026-05-16T19:20:08+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_192006_24628e8a"}
2026-05-16T19:20:08+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.305,"duration_milliseconds":305,"important":true,"run_id":"20260516_192006_24628e8a"}
2026-05-16T19:20:08+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_192006_24628e8a"}
2026-05-16T19:20:08+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_192006_24628e8a"}
2026-05-16T19:20:08+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":174587,"run_id":"20260516_192006_24628e8a"}
2026-05-16T19:20:08+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.052,"exec_milliseconds":2052,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":174587,"important":true,"run_id":"20260516_192006_24628e8a"}
2026-05-16T19:21:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_192101_47d3adce"}
2026-05-16T19:21:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_192101_47d3adce"}
2026-05-16T19:21:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_192101_47d3adce"}
2026-05-16T19:21:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_192101_47d3adce"}
2026-05-16T19:21:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_192101_47d3adce"}
2026-05-16T19:21:02+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_192101_47d3adce"}
2026-05-16T19:21:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_192101_47d3adce"}
2026-05-16T19:21:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_192101_47d3adce"}
2026-05-16T19:21:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4142,"mtime":"2026-05-16T19:20:58+02:00","run_id":"20260516_192101_47d3adce"}
2026-05-16T19:21:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_192101_47d3adce"}
2026-05-16T19:21:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":11558,"mtime":"2026-05-16T19:20:58+02:00","run_id":"20260516_192101_47d3adce"}
2026-05-16T19:21:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":31,"rb":34,"run_id":"20260516_192101_47d3adce"}
2026-05-16T19:21:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_192101_47d3adce"}
2026-05-16T19:21:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.967,"duration_milliseconds":967,"important":true,"run_id":"20260516_192101_47d3adce"}
2026-05-16T19:21:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_192101_47d3adce"}
2026-05-16T19:21:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_192101_47d3adce"}
2026-05-16T19:21:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":6597,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_192101_47d3adce"}
2026-05-16T19:21:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_192101_47d3adce"}
2026-05-16T19:21:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":6146,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_192101_47d3adce"}
2026-05-16T19:21:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_192101_47d3adce"}
2026-05-16T19:21:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_192101_47d3adce"}
2026-05-16T19:21:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.317,"duration_milliseconds":317,"important":true,"run_id":"20260516_192101_47d3adce"}
2026-05-16T19:21:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_192101_47d3adce"}
2026-05-16T19:21:03+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_192101_47d3adce"}
2026-05-16T19:21:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":176247,"run_id":"20260516_192101_47d3adce"}
2026-05-16T19:21:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.076,"exec_milliseconds":2076,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":176247,"important":true,"run_id":"20260516_192101_47d3adce"}
2026-05-16T19:22:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_192202_4811d777"}
2026-05-16T19:22:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_192202_4811d777"}
2026-05-16T19:22:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_192202_4811d777"}
2026-05-16T19:22:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_192202_4811d777"}
2026-05-16T19:22:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_192202_4811d777"}
2026-05-16T19:22:03+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_192202_4811d777"}
2026-05-16T19:22:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_192202_4811d777"}
2026-05-16T19:22:04+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_192202_4811d777"}
2026-05-16T19:22:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4142,"mtime":"2026-05-16T19:21:57+02:00","run_id":"20260516_192202_4811d777"}
2026-05-16T19:22:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_192202_4811d777"}
2026-05-16T19:22:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":11966,"mtime":"2026-05-16T19:21:57+02:00","run_id":"20260516_192202_4811d777"}
2026-05-16T19:22:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":32,"rb":34,"run_id":"20260516_192202_4811d777"}
2026-05-16T19:22:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_192202_4811d777"}
2026-05-16T19:22:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.972,"duration_milliseconds":972,"important":true,"run_id":"20260516_192202_4811d777"}
2026-05-16T19:22:04+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_192202_4811d777"}
2026-05-16T19:22:04+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_192202_4811d777"}
2026-05-16T19:22:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":6597,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_192202_4811d777"}
2026-05-16T19:22:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_192202_4811d777"}
2026-05-16T19:22:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":6146,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_192202_4811d777"}
2026-05-16T19:22:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_192202_4811d777"}
2026-05-16T19:22:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_192202_4811d777"}
2026-05-16T19:22:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.317,"duration_milliseconds":317,"important":true,"run_id":"20260516_192202_4811d777"}
2026-05-16T19:22:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_192202_4811d777"}
2026-05-16T19:22:04+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_192202_4811d777"}
2026-05-16T19:22:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":177999,"run_id":"20260516_192202_4811d777"}
2026-05-16T19:22:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.061,"exec_milliseconds":2061,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":177999,"important":true,"run_id":"20260516_192202_4811d777"}
2026-05-16T19:23:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_192301_91084db5"}
2026-05-16T19:23:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_192301_91084db5"}
2026-05-16T19:23:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_192301_91084db5"}
2026-05-16T19:23:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_192301_91084db5"}
2026-05-16T19:23:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_192301_91084db5"}
2026-05-16T19:23:02+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_192301_91084db5"}
2026-05-16T19:23:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_192301_91084db5"}
2026-05-16T19:23:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_192301_91084db5"}
2026-05-16T19:23:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4142,"mtime":"2026-05-16T19:22:56+02:00","run_id":"20260516_192301_91084db5"}
2026-05-16T19:23:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_192301_91084db5"}
2026-05-16T19:23:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":12236,"mtime":"2026-05-16T19:22:56+02:00","run_id":"20260516_192301_91084db5"}
2026-05-16T19:23:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":32,"rb":36,"run_id":"20260516_192301_91084db5"}
2026-05-16T19:23:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_192301_91084db5"}
2026-05-16T19:23:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.941,"duration_milliseconds":941,"important":true,"run_id":"20260516_192301_91084db5"}
2026-05-16T19:23:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_192301_91084db5"}
2026-05-16T19:23:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_192301_91084db5"}
2026-05-16T19:23:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":6597,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_192301_91084db5"}
2026-05-16T19:23:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_192301_91084db5"}
2026-05-16T19:23:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":6146,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_192301_91084db5"}
2026-05-16T19:23:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_192301_91084db5"}
2026-05-16T19:23:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_192301_91084db5"}
2026-05-16T19:23:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.307,"duration_milliseconds":307,"important":true,"run_id":"20260516_192301_91084db5"}
2026-05-16T19:23:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_192301_91084db5"}
2026-05-16T19:23:03+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_192301_91084db5"}
2026-05-16T19:23:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":179129,"run_id":"20260516_192301_91084db5"}
2026-05-16T19:23:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.029,"exec_milliseconds":2029,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":179129,"important":true,"run_id":"20260516_192301_91084db5"}
2026-05-16T19:24:03+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_192402_a2bfd1bb"}
2026-05-16T19:24:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_192402_a2bfd1bb"}
2026-05-16T19:24:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_192402_a2bfd1bb"}
2026-05-16T19:24:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_192402_a2bfd1bb"}
2026-05-16T19:24:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_192402_a2bfd1bb"}
2026-05-16T19:24:03+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_192402_a2bfd1bb"}
2026-05-16T19:24:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_192402_a2bfd1bb"}
2026-05-16T19:24:04+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_192402_a2bfd1bb"}
2026-05-16T19:24:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4142,"mtime":"2026-05-16T19:23:22+02:00","run_id":"20260516_192402_a2bfd1bb"}
2026-05-16T19:24:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_192402_a2bfd1bb"}
2026-05-16T19:24:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":12570,"mtime":"2026-05-16T19:23:22+02:00","run_id":"20260516_192402_a2bfd1bb"}
2026-05-16T19:24:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":32,"rb":38,"run_id":"20260516_192402_a2bfd1bb"}
2026-05-16T19:24:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_192402_a2bfd1bb"}
2026-05-16T19:24:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.944,"duration_milliseconds":944,"important":true,"run_id":"20260516_192402_a2bfd1bb"}
2026-05-16T19:24:04+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_192402_a2bfd1bb"}
2026-05-16T19:24:04+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_192402_a2bfd1bb"}
2026-05-16T19:24:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":6597,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_192402_a2bfd1bb"}
2026-05-16T19:24:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_192402_a2bfd1bb"}
2026-05-16T19:24:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":6146,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_192402_a2bfd1bb"}
2026-05-16T19:24:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_192402_a2bfd1bb"}
2026-05-16T19:24:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_192402_a2bfd1bb"}
2026-05-16T19:24:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.288,"duration_milliseconds":288,"important":true,"run_id":"20260516_192402_a2bfd1bb"}
2026-05-16T19:24:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_192402_a2bfd1bb"}
2026-05-16T19:24:04+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_192402_a2bfd1bb"}
2026-05-16T19:24:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":180557,"run_id":"20260516_192402_a2bfd1bb"}
2026-05-16T19:24:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.992,"exec_milliseconds":1992,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":180557,"important":true,"run_id":"20260516_192402_a2bfd1bb"}
2026-05-16T19:25:03+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_192503_201f100e"}
2026-05-16T19:25:04+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_192503_201f100e"}
2026-05-16T19:25:04+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_192503_201f100e"}
2026-05-16T19:25:04+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_192503_201f100e"}
2026-05-16T19:25:04+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_192503_201f100e"}
2026-05-16T19:25:04+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_192503_201f100e"}
2026-05-16T19:25:04+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_192503_201f100e"}
2026-05-16T19:25:05+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_192503_201f100e"}
2026-05-16T19:25:05+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4142,"mtime":"2026-05-16T19:24:39+02:00","run_id":"20260516_192503_201f100e"}
2026-05-16T19:25:05+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_192503_201f100e"}
2026-05-16T19:25:05+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":12645,"mtime":"2026-05-16T19:24:39+02:00","run_id":"20260516_192503_201f100e"}
2026-05-16T19:25:05+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":32,"rb":38,"run_id":"20260516_192503_201f100e"}
2026-05-16T19:25:05+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_192503_201f100e"}
2026-05-16T19:25:05+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.938,"duration_milliseconds":938,"important":true,"run_id":"20260516_192503_201f100e"}
2026-05-16T19:25:05+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_192503_201f100e"}
2026-05-16T19:25:05+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_192503_201f100e"}
2026-05-16T19:25:05+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":6597,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_192503_201f100e"}
2026-05-16T19:25:05+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_192503_201f100e"}
2026-05-16T19:25:05+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":6146,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_192503_201f100e"}
2026-05-16T19:25:05+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_192503_201f100e"}
2026-05-16T19:25:05+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_192503_201f100e"}
2026-05-16T19:25:05+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.25,"duration_milliseconds":250,"important":true,"run_id":"20260516_192503_201f100e"}
2026-05-16T19:25:05+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_192503_201f100e"}
2026-05-16T19:25:05+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_192503_201f100e"}
2026-05-16T19:25:05+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":180882,"run_id":"20260516_192503_201f100e"}
2026-05-16T19:25:05+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.941,"exec_milliseconds":1941,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":180882,"important":true,"run_id":"20260516_192503_201f100e"}
2026-05-16T19:26:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_192602_d64d7692"}
2026-05-16T19:26:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_192602_d64d7692"}
2026-05-16T19:26:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_192602_d64d7692"}
2026-05-16T19:26:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_192602_d64d7692"}
2026-05-16T19:26:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_192602_d64d7692"}
2026-05-16T19:26:02+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_192602_d64d7692"}
2026-05-16T19:26:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_192602_d64d7692"}
2026-05-16T19:26:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_192602_d64d7692"}
2026-05-16T19:26:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4142,"mtime":"2026-05-16T19:25:54+02:00","run_id":"20260516_192602_d64d7692"}
2026-05-16T19:26:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_192602_d64d7692"}
2026-05-16T19:26:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":12965,"mtime":"2026-05-16T19:25:53+02:00","run_id":"20260516_192602_d64d7692"}
2026-05-16T19:26:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":32,"rb":38,"run_id":"20260516_192602_d64d7692"}
2026-05-16T19:26:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_192602_d64d7692"}
2026-05-16T19:26:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.948,"duration_milliseconds":948,"important":true,"run_id":"20260516_192602_d64d7692"}
2026-05-16T19:26:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_192602_d64d7692"}
2026-05-16T19:26:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_192602_d64d7692"}
2026-05-16T19:26:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":6597,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_192602_d64d7692"}
2026-05-16T19:26:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_192602_d64d7692"}
2026-05-16T19:26:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":6146,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_192602_d64d7692"}
2026-05-16T19:26:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_192602_d64d7692"}
2026-05-16T19:26:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_192602_d64d7692"}
2026-05-16T19:26:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.305,"duration_milliseconds":305,"important":true,"run_id":"20260516_192602_d64d7692"}
2026-05-16T19:26:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_192602_d64d7692"}
2026-05-16T19:26:04+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_192602_d64d7692"}
2026-05-16T19:26:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":182230,"run_id":"20260516_192602_d64d7692"}
2026-05-16T19:26:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.017,"exec_milliseconds":2017,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":182230,"important":true,"run_id":"20260516_192602_d64d7692"}
2026-05-16T19:27:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_192701_de12f47c"}
2026-05-16T19:27:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_192701_de12f47c"}
2026-05-16T19:27:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_192701_de12f47c"}
2026-05-16T19:27:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_192701_de12f47c"}
2026-05-16T19:27:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_192701_de12f47c"}
2026-05-16T19:27:02+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_192701_de12f47c"}
2026-05-16T19:27:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_192701_de12f47c"}
2026-05-16T19:27:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_192701_de12f47c"}
2026-05-16T19:27:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4142,"mtime":"2026-05-16T19:27:02+02:00","run_id":"20260516_192701_de12f47c"}
2026-05-16T19:27:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_192701_de12f47c"}
2026-05-16T19:27:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":13320,"mtime":"2026-05-16T19:27:02+02:00","run_id":"20260516_192701_de12f47c"}
2026-05-16T19:27:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":35,"rb":38,"run_id":"20260516_192701_de12f47c"}
2026-05-16T19:27:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_192701_de12f47c"}
2026-05-16T19:27:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.95,"duration_milliseconds":950,"important":true,"run_id":"20260516_192701_de12f47c"}
2026-05-16T19:27:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_192701_de12f47c"}
2026-05-16T19:27:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_192701_de12f47c"}
2026-05-16T19:27:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":6597,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_192701_de12f47c"}
2026-05-16T19:27:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_192701_de12f47c"}
2026-05-16T19:27:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":6146,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_192701_de12f47c"}
2026-05-16T19:27:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_192701_de12f47c"}
2026-05-16T19:27:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_192701_de12f47c"}
2026-05-16T19:27:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.312,"duration_milliseconds":312,"important":true,"run_id":"20260516_192701_de12f47c"}
2026-05-16T19:27:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_192701_de12f47c"}
2026-05-16T19:27:03+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_192701_de12f47c"}
2026-05-16T19:27:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":183707,"run_id":"20260516_192701_de12f47c"}
2026-05-16T19:27:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.054,"exec_milliseconds":2054,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":183707,"important":true,"run_id":"20260516_192701_de12f47c"}
2026-05-16T19:28:03+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_192802_1a387454"}
2026-05-16T19:28:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_192802_1a387454"}
2026-05-16T19:28:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_192802_1a387454"}
2026-05-16T19:28:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_192802_1a387454"}
2026-05-16T19:28:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_192802_1a387454"}
2026-05-16T19:28:03+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_192802_1a387454"}
2026-05-16T19:28:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_192802_1a387454"}
2026-05-16T19:28:04+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_192802_1a387454"}
2026-05-16T19:28:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4142,"mtime":"2026-05-16T19:27:58+02:00","run_id":"20260516_192802_1a387454"}
2026-05-16T19:28:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_192802_1a387454"}
2026-05-16T19:28:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":13588,"mtime":"2026-05-16T19:27:58+02:00","run_id":"20260516_192802_1a387454"}
2026-05-16T19:28:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":35,"rb":40,"run_id":"20260516_192802_1a387454"}
2026-05-16T19:28:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_192802_1a387454"}
2026-05-16T19:28:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.952,"duration_milliseconds":952,"important":true,"run_id":"20260516_192802_1a387454"}
2026-05-16T19:28:04+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_192802_1a387454"}
2026-05-16T19:28:04+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_192802_1a387454"}
2026-05-16T19:28:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":6597,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_192802_1a387454"}
2026-05-16T19:28:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_192802_1a387454"}
2026-05-16T19:28:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":6146,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_192802_1a387454"}
2026-05-16T19:28:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_192802_1a387454"}
2026-05-16T19:28:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_192802_1a387454"}
2026-05-16T19:28:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.308,"duration_milliseconds":308,"important":true,"run_id":"20260516_192802_1a387454"}
2026-05-16T19:28:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_192802_1a387454"}
2026-05-16T19:28:05+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_192802_1a387454"}
2026-05-16T19:28:05+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":184835,"run_id":"20260516_192802_1a387454"}
2026-05-16T19:28:05+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.044,"exec_milliseconds":2044,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":184835,"important":true,"run_id":"20260516_192802_1a387454"}
2026-05-16T19:29:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_192901_23b36e03"}
2026-05-16T19:29:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_192901_23b36e03"}
2026-05-16T19:29:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_192901_23b36e03"}
2026-05-16T19:29:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_192901_23b36e03"}
2026-05-16T19:29:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_192901_23b36e03"}
2026-05-16T19:29:02+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_192901_23b36e03"}
2026-05-16T19:29:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_192901_23b36e03"}
2026-05-16T19:29:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_192901_23b36e03"}
2026-05-16T19:29:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4142,"mtime":"2026-05-16T19:28:41+02:00","run_id":"20260516_192901_23b36e03"}
2026-05-16T19:29:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_192901_23b36e03"}
2026-05-16T19:29:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":13773,"mtime":"2026-05-16T19:28:41+02:00","run_id":"20260516_192901_23b36e03"}
2026-05-16T19:29:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":36,"rb":40,"run_id":"20260516_192901_23b36e03"}
2026-05-16T19:29:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_192901_23b36e03"}
2026-05-16T19:29:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.935,"duration_milliseconds":935,"important":true,"run_id":"20260516_192901_23b36e03"}
2026-05-16T19:29:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_192901_23b36e03"}
2026-05-16T19:29:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_192901_23b36e03"}
2026-05-16T19:29:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":6597,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_192901_23b36e03"}
2026-05-16T19:29:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_192901_23b36e03"}
2026-05-16T19:29:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":6146,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_192901_23b36e03"}
2026-05-16T19:29:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_192901_23b36e03"}
2026-05-16T19:29:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_192901_23b36e03"}
2026-05-16T19:29:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.315,"duration_milliseconds":315,"important":true,"run_id":"20260516_192901_23b36e03"}
2026-05-16T19:29:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_192901_23b36e03"}
2026-05-16T19:29:03+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_192901_23b36e03"}
2026-05-16T19:29:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":185614,"run_id":"20260516_192901_23b36e03"}
2026-05-16T19:29:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.034,"exec_milliseconds":2034,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":185614,"important":true,"run_id":"20260516_192901_23b36e03"}
2026-05-16T19:30:12+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_193012_311467fe"}
2026-05-16T19:30:12+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_193012_311467fe"}
2026-05-16T19:30:12+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_193012_311467fe"}
2026-05-16T19:30:12+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_193012_311467fe"}
2026-05-16T19:30:12+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_193012_311467fe"}
2026-05-16T19:30:12+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_193012_311467fe"}
2026-05-16T19:30:13+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_193012_311467fe"}
2026-05-16T19:30:13+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_193012_311467fe"}
2026-05-16T19:30:13+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4142,"mtime":"2026-05-16T19:28:41+02:00","run_id":"20260516_193012_311467fe"}
2026-05-16T19:30:13+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_193012_311467fe"}
2026-05-16T19:30:13+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":13773,"mtime":"2026-05-16T19:28:41+02:00","run_id":"20260516_193012_311467fe"}
2026-05-16T19:30:13+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":36,"rb":40,"run_id":"20260516_193012_311467fe"}
2026-05-16T19:30:13+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_193012_311467fe"}
2026-05-16T19:30:13+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.965,"duration_milliseconds":965,"important":true,"run_id":"20260516_193012_311467fe"}
2026-05-16T19:30:13+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_193012_311467fe"}
2026-05-16T19:30:14+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_193012_311467fe"}
2026-05-16T19:30:14+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":6597,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_193012_311467fe"}
2026-05-16T19:30:14+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_193012_311467fe"}
2026-05-16T19:30:14+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":6146,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_193012_311467fe"}
2026-05-16T19:30:14+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_193012_311467fe"}
2026-05-16T19:30:14+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_193012_311467fe"}
2026-05-16T19:30:14+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.324,"duration_milliseconds":324,"important":true,"run_id":"20260516_193012_311467fe"}
2026-05-16T19:30:14+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_193012_311467fe"}
2026-05-16T19:30:14+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_193012_311467fe"}
2026-05-16T19:30:14+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":185712,"run_id":"20260516_193012_311467fe"}
2026-05-16T19:30:14+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.076,"exec_milliseconds":2076,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":185712,"important":true,"run_id":"20260516_193012_311467fe"}
2026-05-16T19:31:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_193101_214068f2"}
2026-05-16T19:31:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_193101_214068f2"}
2026-05-16T19:31:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_193101_214068f2"}
2026-05-16T19:31:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_193101_214068f2"}
2026-05-16T19:31:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_193101_214068f2"}
2026-05-16T19:31:02+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_193101_214068f2"}
2026-05-16T19:31:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_193101_214068f2"}
2026-05-16T19:31:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_193101_214068f2"}
2026-05-16T19:31:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4142,"mtime":"2026-05-16T19:28:41+02:00","run_id":"20260516_193101_214068f2"}
2026-05-16T19:31:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_193101_214068f2"}
2026-05-16T19:31:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":13773,"mtime":"2026-05-16T19:28:41+02:00","run_id":"20260516_193101_214068f2"}
2026-05-16T19:31:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":36,"rb":40,"run_id":"20260516_193101_214068f2"}
2026-05-16T19:31:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_193101_214068f2"}
2026-05-16T19:31:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.947,"duration_milliseconds":947,"important":true,"run_id":"20260516_193101_214068f2"}
2026-05-16T19:31:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_193101_214068f2"}
2026-05-16T19:31:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_193101_214068f2"}
2026-05-16T19:31:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":6597,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_193101_214068f2"}
2026-05-16T19:31:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_193101_214068f2"}
2026-05-16T19:31:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":6146,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_193101_214068f2"}
2026-05-16T19:31:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_193101_214068f2"}
2026-05-16T19:31:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_193101_214068f2"}
2026-05-16T19:31:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.321,"duration_milliseconds":321,"important":true,"run_id":"20260516_193101_214068f2"}
2026-05-16T19:31:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_193101_214068f2"}
2026-05-16T19:31:03+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_193101_214068f2"}
2026-05-16T19:31:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":185714,"run_id":"20260516_193101_214068f2"}
2026-05-16T19:31:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.057,"exec_milliseconds":2057,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":185714,"important":true,"run_id":"20260516_193101_214068f2"}
2026-05-16T19:32:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_193202_2e25be2e"}
2026-05-16T19:32:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_193202_2e25be2e"}
2026-05-16T19:32:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_193202_2e25be2e"}
2026-05-16T19:32:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_193202_2e25be2e"}
2026-05-16T19:32:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_193202_2e25be2e"}
2026-05-16T19:32:03+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_193202_2e25be2e"}
2026-05-16T19:32:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_193202_2e25be2e"}
2026-05-16T19:32:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_193202_2e25be2e"}
2026-05-16T19:32:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4142,"mtime":"2026-05-16T19:31:49+02:00","run_id":"20260516_193202_2e25be2e"}
2026-05-16T19:32:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_193202_2e25be2e"}
2026-05-16T19:32:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":13664,"mtime":"2026-05-16T19:31:48+02:00","run_id":"20260516_193202_2e25be2e"}
2026-05-16T19:32:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":35,"rb":40,"run_id":"20260516_193202_2e25be2e"}
2026-05-16T19:32:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_193202_2e25be2e"}
2026-05-16T19:32:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.937,"duration_milliseconds":937,"important":true,"run_id":"20260516_193202_2e25be2e"}
2026-05-16T19:32:04+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_193202_2e25be2e"}
2026-05-16T19:32:04+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_193202_2e25be2e"}
2026-05-16T19:32:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":6597,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_193202_2e25be2e"}
2026-05-16T19:32:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_193202_2e25be2e"}
2026-05-16T19:32:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":6146,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_193202_2e25be2e"}
2026-05-16T19:32:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_193202_2e25be2e"}
2026-05-16T19:32:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_193202_2e25be2e"}
2026-05-16T19:32:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.286,"duration_milliseconds":286,"important":true,"run_id":"20260516_193202_2e25be2e"}
2026-05-16T19:32:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_193202_2e25be2e"}
2026-05-16T19:32:04+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_193202_2e25be2e"}
2026-05-16T19:32:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":185161,"run_id":"20260516_193202_2e25be2e"}
2026-05-16T19:32:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.052,"exec_milliseconds":2052,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":185161,"important":true,"run_id":"20260516_193202_2e25be2e"}
2026-05-16T19:33:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_193301_023821c5"}
2026-05-16T19:33:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_193301_023821c5"}
2026-05-16T19:33:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_193301_023821c5"}
2026-05-16T19:33:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_193301_023821c5"}
2026-05-16T19:33:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_193301_023821c5"}
2026-05-16T19:33:02+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_193301_023821c5"}
2026-05-16T19:33:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_193301_023821c5"}
2026-05-16T19:33:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_193301_023821c5"}
2026-05-16T19:33:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4142,"mtime":"2026-05-16T19:32:35+02:00","run_id":"20260516_193301_023821c5"}
2026-05-16T19:33:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_193301_023821c5"}
2026-05-16T19:33:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":14035,"mtime":"2026-05-16T19:32:35+02:00","run_id":"20260516_193301_023821c5"}
2026-05-16T19:33:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":35,"rb":40,"run_id":"20260516_193301_023821c5"}
2026-05-16T19:33:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_193301_023821c5"}
2026-05-16T19:33:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.964,"duration_milliseconds":964,"important":true,"run_id":"20260516_193301_023821c5"}
2026-05-16T19:33:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_193301_023821c5"}
2026-05-16T19:33:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_193301_023821c5"}
2026-05-16T19:33:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":6597,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_193301_023821c5"}
2026-05-16T19:33:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_193301_023821c5"}
2026-05-16T19:33:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":6146,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_193301_023821c5"}
2026-05-16T19:33:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_193301_023821c5"}
2026-05-16T19:33:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_193301_023821c5"}
2026-05-16T19:33:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.294,"duration_milliseconds":294,"important":true,"run_id":"20260516_193301_023821c5"}
2026-05-16T19:33:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_193301_023821c5"}
2026-05-16T19:33:03+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_193301_023821c5"}
2026-05-16T19:33:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":186778,"run_id":"20260516_193301_023821c5"}
2026-05-16T19:33:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.026,"exec_milliseconds":2026,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":186778,"important":true,"run_id":"20260516_193301_023821c5"}
2026-05-16T19:34:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_193402_9eef0535"}
2026-05-16T19:34:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_193402_9eef0535"}
2026-05-16T19:34:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_193402_9eef0535"}
2026-05-16T19:34:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_193402_9eef0535"}
2026-05-16T19:34:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_193402_9eef0535"}
2026-05-16T19:34:03+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_193402_9eef0535"}
2026-05-16T19:34:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_193402_9eef0535"}
2026-05-16T19:34:04+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_193402_9eef0535"}
2026-05-16T19:34:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4142,"mtime":"2026-05-16T19:34:00+02:00","run_id":"20260516_193402_9eef0535"}
2026-05-16T19:34:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_193402_9eef0535"}
2026-05-16T19:34:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":14413,"mtime":"2026-05-16T19:34:00+02:00","run_id":"20260516_193402_9eef0535"}
2026-05-16T19:34:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":35,"rb":40,"run_id":"20260516_193402_9eef0535"}
2026-05-16T19:34:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_193402_9eef0535"}
2026-05-16T19:34:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.953,"duration_milliseconds":953,"important":true,"run_id":"20260516_193402_9eef0535"}
2026-05-16T19:34:04+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_193402_9eef0535"}
2026-05-16T19:34:04+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_193402_9eef0535"}
2026-05-16T19:34:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":6597,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_193402_9eef0535"}
2026-05-16T19:34:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_193402_9eef0535"}
2026-05-16T19:34:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":6146,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_193402_9eef0535"}
2026-05-16T19:34:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_193402_9eef0535"}
2026-05-16T19:34:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_193402_9eef0535"}
2026-05-16T19:34:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.302,"duration_milliseconds":302,"important":true,"run_id":"20260516_193402_9eef0535"}
2026-05-16T19:34:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_193402_9eef0535"}
2026-05-16T19:34:04+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_193402_9eef0535"}
2026-05-16T19:34:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":188410,"run_id":"20260516_193402_9eef0535"}
2026-05-16T19:34:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.02,"exec_milliseconds":2020,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":188410,"important":true,"run_id":"20260516_193402_9eef0535"}
2026-05-16T19:35:04+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_193504_9aa86ab7"}
2026-05-16T19:35:04+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_193504_9aa86ab7"}
2026-05-16T19:35:04+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_193504_9aa86ab7"}
2026-05-16T19:35:04+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_193504_9aa86ab7"}
2026-05-16T19:35:04+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_193504_9aa86ab7"}
2026-05-16T19:35:04+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_193504_9aa86ab7"}
2026-05-16T19:35:04+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_193504_9aa86ab7"}
2026-05-16T19:35:05+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_193504_9aa86ab7"}
2026-05-16T19:35:05+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4142,"mtime":"2026-05-16T19:35:02+02:00","run_id":"20260516_193504_9aa86ab7"}
2026-05-16T19:35:05+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_193504_9aa86ab7"}
2026-05-16T19:35:05+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":14890,"mtime":"2026-05-16T19:35:02+02:00","run_id":"20260516_193504_9aa86ab7"}
2026-05-16T19:35:05+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":35,"rb":41,"run_id":"20260516_193504_9aa86ab7"}
2026-05-16T19:35:05+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_193504_9aa86ab7"}
2026-05-16T19:35:05+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.966,"duration_milliseconds":966,"important":true,"run_id":"20260516_193504_9aa86ab7"}
2026-05-16T19:35:05+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_193504_9aa86ab7"}
2026-05-16T19:35:05+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_193504_9aa86ab7"}
2026-05-16T19:35:05+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":6597,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_193504_9aa86ab7"}
2026-05-16T19:35:05+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_193504_9aa86ab7"}
2026-05-16T19:35:05+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":6146,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_193504_9aa86ab7"}
2026-05-16T19:35:05+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_193504_9aa86ab7"}
2026-05-16T19:35:06+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_193504_9aa86ab7"}
2026-05-16T19:35:06+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.313,"duration_milliseconds":313,"important":true,"run_id":"20260516_193504_9aa86ab7"}
2026-05-16T19:35:06+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_193504_9aa86ab7"}
2026-05-16T19:35:06+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_193504_9aa86ab7"}
2026-05-16T19:35:06+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":190473,"run_id":"20260516_193504_9aa86ab7"}
2026-05-16T19:35:06+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.057,"exec_milliseconds":2057,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":190473,"important":true,"run_id":"20260516_193504_9aa86ab7"}
2026-05-16T19:36:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_193602_0d023297"}
2026-05-16T19:36:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_193602_0d023297"}
2026-05-16T19:36:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_193602_0d023297"}
2026-05-16T19:36:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_193602_0d023297"}
2026-05-16T19:36:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_193602_0d023297"}
2026-05-16T19:36:03+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_193602_0d023297"}
2026-05-16T19:36:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_193602_0d023297"}
2026-05-16T19:36:04+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_193602_0d023297"}
2026-05-16T19:36:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4142,"mtime":"2026-05-16T19:35:18+02:00","run_id":"20260516_193602_0d023297"}
2026-05-16T19:36:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_193602_0d023297"}
2026-05-16T19:36:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":15055,"mtime":"2026-05-16T19:35:18+02:00","run_id":"20260516_193602_0d023297"}
2026-05-16T19:36:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":35,"rb":41,"run_id":"20260516_193602_0d023297"}
2026-05-16T19:36:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_193602_0d023297"}
2026-05-16T19:36:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.957,"duration_milliseconds":957,"important":true,"run_id":"20260516_193602_0d023297"}
2026-05-16T19:36:04+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_193602_0d023297"}
2026-05-16T19:36:04+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_193602_0d023297"}
2026-05-16T19:36:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":6597,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_193602_0d023297"}
2026-05-16T19:36:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_193602_0d023297"}
2026-05-16T19:36:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":6146,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_193602_0d023297"}
2026-05-16T19:36:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_193602_0d023297"}
2026-05-16T19:36:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_193602_0d023297"}
2026-05-16T19:36:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.299,"duration_milliseconds":299,"important":true,"run_id":"20260516_193602_0d023297"}
2026-05-16T19:36:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_193602_0d023297"}
2026-05-16T19:36:04+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_193602_0d023297"}
2026-05-16T19:36:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":191158,"run_id":"20260516_193602_0d023297"}
2026-05-16T19:36:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.078,"exec_milliseconds":2078,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":191158,"important":true,"run_id":"20260516_193602_0d023297"}
2026-05-16T19:37:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_193701_bb309d06"}
2026-05-16T19:37:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_193701_bb309d06"}
2026-05-16T19:37:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_193701_bb309d06"}
2026-05-16T19:37:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_193701_bb309d06"}
2026-05-16T19:37:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_193701_bb309d06"}
2026-05-16T19:37:02+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_193701_bb309d06"}
2026-05-16T19:37:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_193701_bb309d06"}
2026-05-16T19:37:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_193701_bb309d06"}
2026-05-16T19:37:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4142,"mtime":"2026-05-16T19:36:30+02:00","run_id":"20260516_193701_bb309d06"}
2026-05-16T19:37:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_193701_bb309d06"}
2026-05-16T19:37:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":15119,"mtime":"2026-05-16T19:36:30+02:00","run_id":"20260516_193701_bb309d06"}
2026-05-16T19:37:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":35,"rb":41,"run_id":"20260516_193701_bb309d06"}
2026-05-16T19:37:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_193701_bb309d06"}
2026-05-16T19:37:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.959,"duration_milliseconds":959,"important":true,"run_id":"20260516_193701_bb309d06"}
2026-05-16T19:37:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_193701_bb309d06"}
2026-05-16T19:37:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_193701_bb309d06"}
2026-05-16T19:37:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":6597,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_193701_bb309d06"}
2026-05-16T19:37:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_193701_bb309d06"}
2026-05-16T19:37:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":6146,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_193701_bb309d06"}
2026-05-16T19:37:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_193701_bb309d06"}
2026-05-16T19:37:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_193701_bb309d06"}
2026-05-16T19:37:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.301,"duration_milliseconds":301,"important":true,"run_id":"20260516_193701_bb309d06"}
2026-05-16T19:37:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_193701_bb309d06"}
2026-05-16T19:37:03+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_193701_bb309d06"}
2026-05-16T19:37:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":191459,"run_id":"20260516_193701_bb309d06"}
2026-05-16T19:37:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.037,"exec_milliseconds":2037,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":191459,"important":true,"run_id":"20260516_193701_bb309d06"}
2026-05-16T19:38:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_193802_29ba853a"}
2026-05-16T19:38:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_193802_29ba853a"}
2026-05-16T19:38:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_193802_29ba853a"}
2026-05-16T19:38:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_193802_29ba853a"}
2026-05-16T19:38:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_193802_29ba853a"}
2026-05-16T19:38:03+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_193802_29ba853a"}
2026-05-16T19:38:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_193802_29ba853a"}
2026-05-16T19:38:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_193802_29ba853a"}
2026-05-16T19:38:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4142,"mtime":"2026-05-16T19:36:30+02:00","run_id":"20260516_193802_29ba853a"}
2026-05-16T19:38:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_193802_29ba853a"}
2026-05-16T19:38:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":15119,"mtime":"2026-05-16T19:36:30+02:00","run_id":"20260516_193802_29ba853a"}
2026-05-16T19:38:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":35,"rb":41,"run_id":"20260516_193802_29ba853a"}
2026-05-16T19:38:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_193802_29ba853a"}
2026-05-16T19:38:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.958,"duration_milliseconds":958,"important":true,"run_id":"20260516_193802_29ba853a"}
2026-05-16T19:38:04+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_193802_29ba853a"}
2026-05-16T19:38:04+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_193802_29ba853a"}
2026-05-16T19:38:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":6597,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_193802_29ba853a"}
2026-05-16T19:38:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_193802_29ba853a"}
2026-05-16T19:38:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":6146,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_193802_29ba853a"}
2026-05-16T19:38:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_193802_29ba853a"}
2026-05-16T19:38:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_193802_29ba853a"}
2026-05-16T19:38:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.313,"duration_milliseconds":313,"important":true,"run_id":"20260516_193802_29ba853a"}
2026-05-16T19:38:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_193802_29ba853a"}
2026-05-16T19:38:04+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_193802_29ba853a"}
2026-05-16T19:38:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":191459,"run_id":"20260516_193802_29ba853a"}
2026-05-16T19:38:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.039,"exec_milliseconds":2039,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":191459,"important":true,"run_id":"20260516_193802_29ba853a"}
2026-05-16T19:39:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_193901_c5b92640"}
2026-05-16T19:39:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_193901_c5b92640"}
2026-05-16T19:39:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_193901_c5b92640"}
2026-05-16T19:39:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_193901_c5b92640"}
2026-05-16T19:39:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_193901_c5b92640"}
2026-05-16T19:39:02+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_193901_c5b92640"}
2026-05-16T19:39:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_193901_c5b92640"}
2026-05-16T19:39:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_193901_c5b92640"}
2026-05-16T19:39:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4142,"mtime":"2026-05-16T19:36:30+02:00","run_id":"20260516_193901_c5b92640"}
2026-05-16T19:39:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_193901_c5b92640"}
2026-05-16T19:39:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":15119,"mtime":"2026-05-16T19:36:30+02:00","run_id":"20260516_193901_c5b92640"}
2026-05-16T19:39:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":35,"rb":41,"run_id":"20260516_193901_c5b92640"}
2026-05-16T19:39:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_193901_c5b92640"}
2026-05-16T19:39:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.964,"duration_milliseconds":964,"important":true,"run_id":"20260516_193901_c5b92640"}
2026-05-16T19:39:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_193901_c5b92640"}
2026-05-16T19:39:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_193901_c5b92640"}
2026-05-16T19:39:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":6597,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_193901_c5b92640"}
2026-05-16T19:39:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_193901_c5b92640"}
2026-05-16T19:39:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":6146,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_193901_c5b92640"}
2026-05-16T19:39:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_193901_c5b92640"}
2026-05-16T19:39:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_193901_c5b92640"}
2026-05-16T19:39:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.32,"duration_milliseconds":320,"important":true,"run_id":"20260516_193901_c5b92640"}
2026-05-16T19:39:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_193901_c5b92640"}
2026-05-16T19:39:03+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_193901_c5b92640"}
2026-05-16T19:39:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":191459,"run_id":"20260516_193901_c5b92640"}
2026-05-16T19:39:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.096,"exec_milliseconds":2096,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":191459,"important":true,"run_id":"20260516_193901_c5b92640"}
2026-05-16T19:40:06+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_194006_14e4a89b"}
2026-05-16T19:40:06+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_194006_14e4a89b"}
2026-05-16T19:40:06+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_194006_14e4a89b"}
2026-05-16T19:40:06+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_194006_14e4a89b"}
2026-05-16T19:40:06+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_194006_14e4a89b"}
2026-05-16T19:40:07+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_194006_14e4a89b"}
2026-05-16T19:40:07+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_194006_14e4a89b"}
2026-05-16T19:40:07+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_194006_14e4a89b"}
2026-05-16T19:40:07+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4142,"mtime":"2026-05-16T19:36:30+02:00","run_id":"20260516_194006_14e4a89b"}
2026-05-16T19:40:07+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_194006_14e4a89b"}
2026-05-16T19:40:07+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":15119,"mtime":"2026-05-16T19:36:30+02:00","run_id":"20260516_194006_14e4a89b"}
2026-05-16T19:40:07+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":35,"rb":41,"run_id":"20260516_194006_14e4a89b"}
2026-05-16T19:40:07+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_194006_14e4a89b"}
2026-05-16T19:40:07+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.947,"duration_milliseconds":947,"important":true,"run_id":"20260516_194006_14e4a89b"}
2026-05-16T19:40:07+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_194006_14e4a89b"}
2026-05-16T19:40:08+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_194006_14e4a89b"}
2026-05-16T19:40:08+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":6597,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_194006_14e4a89b"}
2026-05-16T19:40:08+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_194006_14e4a89b"}
2026-05-16T19:40:08+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":6146,"mtime":"2026-05-16T18:49:19+02:00","run_id":"20260516_194006_14e4a89b"}
2026-05-16T19:40:08+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_194006_14e4a89b"}
2026-05-16T19:40:08+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_194006_14e4a89b"}
2026-05-16T19:40:08+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.314,"duration_milliseconds":314,"important":true,"run_id":"20260516_194006_14e4a89b"}
2026-05-16T19:40:08+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_194006_14e4a89b"}
2026-05-16T19:40:08+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_194006_14e4a89b"}
2026-05-16T19:40:08+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":191459,"run_id":"20260516_194006_14e4a89b"}
2026-05-16T19:40:08+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.014,"exec_milliseconds":2014,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":191459,"important":true,"run_id":"20260516_194006_14e4a89b"}
2026-05-16T19:41:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_194101_c0c5d1d4"}
2026-05-16T19:41:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_194101_c0c5d1d4"}
2026-05-16T19:41:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_194101_c0c5d1d4"}
2026-05-16T19:41:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_194101_c0c5d1d4"}
2026-05-16T19:41:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_194101_c0c5d1d4"}
2026-05-16T19:41:02+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_194101_c0c5d1d4"}
2026-05-16T19:41:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_194101_c0c5d1d4"}
2026-05-16T19:41:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_194101_c0c5d1d4"}
2026-05-16T19:41:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4142,"mtime":"2026-05-16T19:36:30+02:00","run_id":"20260516_194101_c0c5d1d4"}
2026-05-16T19:41:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_194101_c0c5d1d4"}
2026-05-16T19:41:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":15119,"mtime":"2026-05-16T19:36:30+02:00","run_id":"20260516_194101_c0c5d1d4"}
2026-05-16T19:41:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":35,"rb":41,"run_id":"20260516_194101_c0c5d1d4"}
2026-05-16T19:41:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_194101_c0c5d1d4"}
2026-05-16T19:41:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.962,"duration_milliseconds":962,"important":true,"run_id":"20260516_194101_c0c5d1d4"}
2026-05-16T19:41:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_194101_c0c5d1d4"}
2026-05-16T19:41:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_194101_c0c5d1d4"}
2026-05-16T19:41:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4285,"mtime":"2026-05-16T19:40:13+02:00","run_id":"20260516_194101_c0c5d1d4"}
2026-05-16T19:41:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_194101_c0c5d1d4"}
2026-05-16T19:41:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":3872,"mtime":"2026-05-16T19:40:13+02:00","run_id":"20260516_194101_c0c5d1d4"}
2026-05-16T19:41:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_194101_c0c5d1d4"}
2026-05-16T19:41:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_194101_c0c5d1d4"}
2026-05-16T19:41:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.316,"duration_milliseconds":316,"important":true,"run_id":"20260516_194101_c0c5d1d4"}
2026-05-16T19:41:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_194101_c0c5d1d4"}
2026-05-16T19:41:04+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_194101_c0c5d1d4"}
2026-05-16T19:41:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":170672,"run_id":"20260516_194101_c0c5d1d4"}
2026-05-16T19:41:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.2,"exec_milliseconds":2200,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":170672,"important":true,"run_id":"20260516_194101_c0c5d1d4"}
2026-05-16T19:42:03+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_194202_cef0722a"}
2026-05-16T19:42:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_194202_cef0722a"}
2026-05-16T19:42:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_194202_cef0722a"}
2026-05-16T19:42:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_194202_cef0722a"}
2026-05-16T19:42:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_194202_cef0722a"}
2026-05-16T19:42:03+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_194202_cef0722a"}
2026-05-16T19:42:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_194202_cef0722a"}
2026-05-16T19:42:04+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_194202_cef0722a"}
2026-05-16T19:42:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4142,"mtime":"2026-05-16T19:36:30+02:00","run_id":"20260516_194202_cef0722a"}
2026-05-16T19:42:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_194202_cef0722a"}
2026-05-16T19:42:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":15119,"mtime":"2026-05-16T19:36:30+02:00","run_id":"20260516_194202_cef0722a"}
2026-05-16T19:42:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":35,"rb":41,"run_id":"20260516_194202_cef0722a"}
2026-05-16T19:42:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_194202_cef0722a"}
2026-05-16T19:42:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.974,"duration_milliseconds":974,"important":true,"run_id":"20260516_194202_cef0722a"}
2026-05-16T19:42:04+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_194202_cef0722a"}
2026-05-16T19:42:04+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_194202_cef0722a"}
2026-05-16T19:42:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4285,"mtime":"2026-05-16T19:40:13+02:00","run_id":"20260516_194202_cef0722a"}
2026-05-16T19:43:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_194301_722a2e55"}
2026-05-16T19:43:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_194301_722a2e55"}
2026-05-16T19:43:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_194301_722a2e55"}
2026-05-16T19:43:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_194301_722a2e55"}
2026-05-16T19:43:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_194301_722a2e55"}
2026-05-16T19:43:02+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_194301_722a2e55"}
2026-05-16T19:43:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_194301_722a2e55"}
2026-05-16T19:43:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_194301_722a2e55"}
2026-05-16T19:43:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4142,"mtime":"2026-05-16T19:36:30+02:00","run_id":"20260516_194301_722a2e55"}
2026-05-16T19:43:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_194301_722a2e55"}
2026-05-16T19:43:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":15119,"mtime":"2026-05-16T19:36:30+02:00","run_id":"20260516_194301_722a2e55"}
2026-05-16T19:43:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":35,"rb":41,"run_id":"20260516_194301_722a2e55"}
2026-05-16T19:43:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_194301_722a2e55"}
2026-05-16T19:43:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.939,"duration_milliseconds":939,"important":true,"run_id":"20260516_194301_722a2e55"}
2026-05-16T19:43:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_194301_722a2e55"}
2026-05-16T19:43:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_194301_722a2e55"}
2026-05-16T19:43:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4285,"mtime":"2026-05-16T19:40:13+02:00","run_id":"20260516_194301_722a2e55"}
2026-05-16T19:43:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_194301_722a2e55"}
2026-05-16T19:43:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":3872,"mtime":"2026-05-16T19:40:13+02:00","run_id":"20260516_194301_722a2e55"}
2026-05-16T19:43:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_194301_722a2e55"}
2026-05-16T19:43:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_194301_722a2e55"}
2026-05-16T19:43:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.29,"duration_milliseconds":290,"important":true,"run_id":"20260516_194301_722a2e55"}
2026-05-16T19:43:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_194301_722a2e55"}
2026-05-16T19:43:03+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_194301_722a2e55"}
2026-05-16T19:43:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":170772,"run_id":"20260516_194301_722a2e55"}
2026-05-16T19:43:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.113,"exec_milliseconds":2113,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":170772,"important":true,"run_id":"20260516_194301_722a2e55"}
2026-05-16T19:44:03+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_194402_29ff13a0"}
2026-05-16T19:44:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_194402_29ff13a0"}
2026-05-16T19:44:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_194402_29ff13a0"}
2026-05-16T19:44:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_194402_29ff13a0"}
2026-05-16T19:44:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_194402_29ff13a0"}
2026-05-16T19:44:03+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_194402_29ff13a0"}
2026-05-16T19:44:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_194402_29ff13a0"}
2026-05-16T19:44:04+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_194402_29ff13a0"}
2026-05-16T19:44:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4142,"mtime":"2026-05-16T19:36:30+02:00","run_id":"20260516_194402_29ff13a0"}
2026-05-16T19:44:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_194402_29ff13a0"}
2026-05-16T19:44:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":15119,"mtime":"2026-05-16T19:36:30+02:00","run_id":"20260516_194402_29ff13a0"}
2026-05-16T19:44:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":35,"rb":41,"run_id":"20260516_194402_29ff13a0"}
2026-05-16T19:44:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_194402_29ff13a0"}
2026-05-16T19:44:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.965,"duration_milliseconds":965,"important":true,"run_id":"20260516_194402_29ff13a0"}
2026-05-16T19:44:04+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_194402_29ff13a0"}
2026-05-16T19:44:04+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_194402_29ff13a0"}
2026-05-16T19:44:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4285,"mtime":"2026-05-16T19:40:13+02:00","run_id":"20260516_194402_29ff13a0"}
2026-05-16T19:44:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_194402_29ff13a0"}
2026-05-16T19:44:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":3872,"mtime":"2026-05-16T19:40:13+02:00","run_id":"20260516_194402_29ff13a0"}
2026-05-16T19:44:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_194402_29ff13a0"}
2026-05-16T19:44:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_194402_29ff13a0"}
2026-05-16T19:44:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.31,"duration_milliseconds":310,"important":true,"run_id":"20260516_194402_29ff13a0"}
2026-05-16T19:44:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_194402_29ff13a0"}
2026-05-16T19:44:04+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_194402_29ff13a0"}
2026-05-16T19:44:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":170772,"run_id":"20260516_194402_29ff13a0"}
2026-05-16T19:44:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.052,"exec_milliseconds":2052,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":170772,"important":true,"run_id":"20260516_194402_29ff13a0"}
2026-05-16T19:45:06+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_194506_2f88a724"}
2026-05-16T19:45:07+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_194506_2f88a724"}
2026-05-16T19:45:07+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_194506_2f88a724"}
2026-05-16T19:45:07+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_194506_2f88a724"}
2026-05-16T19:45:07+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_194506_2f88a724"}
2026-05-16T19:45:07+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_194506_2f88a724"}
2026-05-16T19:45:07+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_194506_2f88a724"}
2026-05-16T19:45:07+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_194506_2f88a724"}
2026-05-16T19:45:07+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4146,"mtime":"2026-05-16T19:44:34+02:00","run_id":"20260516_194506_2f88a724"}
2026-05-16T19:45:08+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":5586,"run_id":"20260516_194506_2f88a724"}
2026-05-16T19:45:08+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":15119,"mtime":"2026-05-16T19:44:34+02:00","run_id":"20260516_194506_2f88a724"}
2026-05-16T19:45:08+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":35,"rb":41,"run_id":"20260516_194506_2f88a724"}
2026-05-16T19:45:08+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_194506_2f88a724"}
2026-05-16T19:45:08+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.925,"duration_milliseconds":925,"important":true,"run_id":"20260516_194506_2f88a724"}
2026-05-16T19:45:08+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_194506_2f88a724"}
2026-05-16T19:45:08+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_194506_2f88a724"}
2026-05-16T19:45:08+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4285,"mtime":"2026-05-16T19:40:13+02:00","run_id":"20260516_194506_2f88a724"}
2026-05-16T19:45:08+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_194506_2f88a724"}
2026-05-16T19:45:08+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":3872,"mtime":"2026-05-16T19:40:13+02:00","run_id":"20260516_194506_2f88a724"}
2026-05-16T19:45:08+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_194506_2f88a724"}
2026-05-16T19:45:08+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_194506_2f88a724"}
2026-05-16T19:45:08+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.299,"duration_milliseconds":299,"important":true,"run_id":"20260516_194506_2f88a724"}
2026-05-16T19:45:08+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_194506_2f88a724"}
2026-05-16T19:45:08+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_194506_2f88a724"}
2026-05-16T19:45:08+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":170613,"run_id":"20260516_194506_2f88a724"}
2026-05-16T19:45:08+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2,"exec_milliseconds":2000,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":170613,"important":true,"run_id":"20260516_194506_2f88a724"}
2026-05-16T19:46:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_194602_f5196060"}
2026-05-16T19:46:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_194602_f5196060"}
2026-05-16T19:46:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_194602_f5196060"}
2026-05-16T19:46:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_194602_f5196060"}
2026-05-16T19:46:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_194602_f5196060"}
2026-05-16T19:46:03+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_194602_f5196060"}
2026-05-16T19:46:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_194602_f5196060"}
2026-05-16T19:46:04+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_194602_f5196060"}
2026-05-16T19:46:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4146,"mtime":"2026-05-16T19:44:34+02:00","run_id":"20260516_194602_f5196060"}
2026-05-16T19:46:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":5586,"run_id":"20260516_194602_f5196060"}
2026-05-16T19:46:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":15119,"mtime":"2026-05-16T19:44:34+02:00","run_id":"20260516_194602_f5196060"}
2026-05-16T19:46:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":35,"rb":41,"run_id":"20260516_194602_f5196060"}
2026-05-16T19:46:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_194602_f5196060"}
2026-05-16T19:46:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.974,"duration_milliseconds":974,"important":true,"run_id":"20260516_194602_f5196060"}
2026-05-16T19:46:04+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_194602_f5196060"}
2026-05-16T19:46:04+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_194602_f5196060"}
2026-05-16T19:46:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4285,"mtime":"2026-05-16T19:40:13+02:00","run_id":"20260516_194602_f5196060"}
2026-05-16T19:46:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_194602_f5196060"}
2026-05-16T19:46:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":3872,"mtime":"2026-05-16T19:40:13+02:00","run_id":"20260516_194602_f5196060"}
2026-05-16T19:46:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_194602_f5196060"}
2026-05-16T19:46:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_194602_f5196060"}
2026-05-16T19:46:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.305,"duration_milliseconds":305,"important":true,"run_id":"20260516_194602_f5196060"}
2026-05-16T19:46:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_194602_f5196060"}
2026-05-16T19:46:04+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_194602_f5196060"}
2026-05-16T19:46:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":170613,"run_id":"20260516_194602_f5196060"}
2026-05-16T19:46:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.026,"exec_milliseconds":2026,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":170613,"important":true,"run_id":"20260516_194602_f5196060"}
2026-05-16T19:47:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_194701_9ca1bb62"}
2026-05-16T19:47:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_194701_9ca1bb62"}
2026-05-16T19:47:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_194701_9ca1bb62"}
2026-05-16T19:47:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_194701_9ca1bb62"}
2026-05-16T19:47:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_194701_9ca1bb62"}
2026-05-16T19:47:02+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_194701_9ca1bb62"}
2026-05-16T19:47:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_194701_9ca1bb62"}
2026-05-16T19:47:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_194701_9ca1bb62"}
2026-05-16T19:47:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4146,"mtime":"2026-05-16T19:44:34+02:00","run_id":"20260516_194701_9ca1bb62"}
2026-05-16T19:47:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":5586,"run_id":"20260516_194701_9ca1bb62"}
2026-05-16T19:47:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":15119,"mtime":"2026-05-16T19:44:34+02:00","run_id":"20260516_194701_9ca1bb62"}
2026-05-16T19:47:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":35,"rb":41,"run_id":"20260516_194701_9ca1bb62"}
2026-05-16T19:47:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_194701_9ca1bb62"}
2026-05-16T19:47:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.947,"duration_milliseconds":947,"important":true,"run_id":"20260516_194701_9ca1bb62"}
2026-05-16T19:47:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_194701_9ca1bb62"}
2026-05-16T19:47:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_194701_9ca1bb62"}
2026-05-16T19:47:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4285,"mtime":"2026-05-16T19:40:13+02:00","run_id":"20260516_194701_9ca1bb62"}
2026-05-16T19:47:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_194701_9ca1bb62"}
2026-05-16T19:47:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":3872,"mtime":"2026-05-16T19:40:13+02:00","run_id":"20260516_194701_9ca1bb62"}
2026-05-16T19:47:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_194701_9ca1bb62"}
2026-05-16T19:47:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_194701_9ca1bb62"}
2026-05-16T19:47:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.314,"duration_milliseconds":314,"important":true,"run_id":"20260516_194701_9ca1bb62"}
2026-05-16T19:47:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_194701_9ca1bb62"}
2026-05-16T19:47:03+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_194701_9ca1bb62"}
2026-05-16T19:47:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":170613,"run_id":"20260516_194701_9ca1bb62"}
2026-05-16T19:47:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.117,"exec_milliseconds":2117,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":170613,"important":true,"run_id":"20260516_194701_9ca1bb62"}
2026-05-16T19:48:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_194802_700168dd"}
2026-05-16T19:48:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_194802_700168dd"}
2026-05-16T19:48:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_194802_700168dd"}
2026-05-16T19:48:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_194802_700168dd"}
2026-05-16T19:48:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_194802_700168dd"}
2026-05-16T19:48:03+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_194802_700168dd"}
2026-05-16T19:48:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_194802_700168dd"}
2026-05-16T19:48:04+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_194802_700168dd"}
2026-05-16T19:48:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4146,"mtime":"2026-05-16T19:44:34+02:00","run_id":"20260516_194802_700168dd"}
2026-05-16T19:48:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":5586,"run_id":"20260516_194802_700168dd"}
2026-05-16T19:48:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":15119,"mtime":"2026-05-16T19:44:34+02:00","run_id":"20260516_194802_700168dd"}
2026-05-16T19:48:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":35,"rb":41,"run_id":"20260516_194802_700168dd"}
2026-05-16T19:48:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_194802_700168dd"}
2026-05-16T19:48:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.943,"duration_milliseconds":943,"important":true,"run_id":"20260516_194802_700168dd"}
2026-05-16T19:48:04+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_194802_700168dd"}
2026-05-16T19:48:04+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_194802_700168dd"}
2026-05-16T19:48:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4285,"mtime":"2026-05-16T19:40:13+02:00","run_id":"20260516_194802_700168dd"}
2026-05-16T19:48:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_194802_700168dd"}
2026-05-16T19:48:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":3872,"mtime":"2026-05-16T19:40:13+02:00","run_id":"20260516_194802_700168dd"}
2026-05-16T19:48:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_194802_700168dd"}
2026-05-16T19:48:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_194802_700168dd"}
2026-05-16T19:48:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.267,"duration_milliseconds":267,"important":true,"run_id":"20260516_194802_700168dd"}
2026-05-16T19:48:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_194802_700168dd"}
2026-05-16T19:48:04+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_194802_700168dd"}
2026-05-16T19:48:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":170613,"run_id":"20260516_194802_700168dd"}
2026-05-16T19:48:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.97,"exec_milliseconds":1970,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":170613,"important":true,"run_id":"20260516_194802_700168dd"}
2026-05-16T19:49:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_194902_7583ce26"}
2026-05-16T19:49:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_194902_7583ce26"}
2026-05-16T19:49:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_194902_7583ce26"}
2026-05-16T19:49:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_194902_7583ce26"}
2026-05-16T19:49:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_194902_7583ce26"}
2026-05-16T19:49:02+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_194902_7583ce26"}
2026-05-16T19:49:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_194902_7583ce26"}
2026-05-16T19:49:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_194902_7583ce26"}
2026-05-16T19:49:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4146,"mtime":"2026-05-16T19:44:34+02:00","run_id":"20260516_194902_7583ce26"}
2026-05-16T19:49:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":5586,"run_id":"20260516_194902_7583ce26"}
2026-05-16T19:49:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":15119,"mtime":"2026-05-16T19:44:34+02:00","run_id":"20260516_194902_7583ce26"}
2026-05-16T19:49:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":35,"rb":41,"run_id":"20260516_194902_7583ce26"}
2026-05-16T19:49:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_194902_7583ce26"}
2026-05-16T19:49:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.941,"duration_milliseconds":941,"important":true,"run_id":"20260516_194902_7583ce26"}
2026-05-16T19:49:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_194902_7583ce26"}
2026-05-16T19:49:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_194902_7583ce26"}
2026-05-16T19:49:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4285,"mtime":"2026-05-16T19:40:13+02:00","run_id":"20260516_194902_7583ce26"}
2026-05-16T19:49:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_194902_7583ce26"}
2026-05-16T19:49:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":3872,"mtime":"2026-05-16T19:40:13+02:00","run_id":"20260516_194902_7583ce26"}
2026-05-16T19:49:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_194902_7583ce26"}
2026-05-16T19:49:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_194902_7583ce26"}
2026-05-16T19:49:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.284,"duration_milliseconds":284,"important":true,"run_id":"20260516_194902_7583ce26"}
2026-05-16T19:49:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_194902_7583ce26"}
2026-05-16T19:49:04+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_194902_7583ce26"}
2026-05-16T19:49:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":170613,"run_id":"20260516_194902_7583ce26"}
2026-05-16T19:49:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.003,"exec_milliseconds":2003,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":170613,"important":true,"run_id":"20260516_194902_7583ce26"}
2026-05-16T19:50:06+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_195006_69b3d731"}
2026-05-16T19:50:07+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_195006_69b3d731"}
2026-05-16T19:50:07+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_195006_69b3d731"}
2026-05-16T19:50:07+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_195006_69b3d731"}
2026-05-16T19:50:07+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_195006_69b3d731"}
2026-05-16T19:50:07+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_195006_69b3d731"}
2026-05-16T19:50:07+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_195006_69b3d731"}
2026-05-16T19:50:07+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_195006_69b3d731"}
2026-05-16T19:50:07+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4146,"mtime":"2026-05-16T19:44:34+02:00","run_id":"20260516_195006_69b3d731"}
2026-05-16T19:50:08+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":5586,"run_id":"20260516_195006_69b3d731"}
2026-05-16T19:50:08+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":15119,"mtime":"2026-05-16T19:44:34+02:00","run_id":"20260516_195006_69b3d731"}
2026-05-16T19:50:08+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":35,"rb":41,"run_id":"20260516_195006_69b3d731"}
2026-05-16T19:50:08+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_195006_69b3d731"}
2026-05-16T19:50:08+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.936,"duration_milliseconds":936,"important":true,"run_id":"20260516_195006_69b3d731"}
2026-05-16T19:50:08+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_195006_69b3d731"}
2026-05-16T19:50:08+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_195006_69b3d731"}
2026-05-16T19:50:08+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4285,"mtime":"2026-05-16T19:40:13+02:00","run_id":"20260516_195006_69b3d731"}
2026-05-16T19:50:08+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_195006_69b3d731"}
2026-05-16T19:50:08+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":3872,"mtime":"2026-05-16T19:40:13+02:00","run_id":"20260516_195006_69b3d731"}
2026-05-16T19:50:08+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_195006_69b3d731"}
2026-05-16T19:50:08+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_195006_69b3d731"}
2026-05-16T19:50:08+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.283,"duration_milliseconds":283,"important":true,"run_id":"20260516_195006_69b3d731"}
2026-05-16T19:50:08+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_195006_69b3d731"}
2026-05-16T19:50:08+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_195006_69b3d731"}
2026-05-16T19:50:08+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":170613,"run_id":"20260516_195006_69b3d731"}
2026-05-16T19:50:08+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.008,"exec_milliseconds":2008,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":170613,"important":true,"run_id":"20260516_195006_69b3d731"}
2026-05-16T19:51:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_195101_b492c90c"}
2026-05-16T19:51:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_195101_b492c90c"}
2026-05-16T19:51:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_195101_b492c90c"}
2026-05-16T19:51:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_195101_b492c90c"}
2026-05-16T19:51:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_195101_b492c90c"}
2026-05-16T19:51:02+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_195101_b492c90c"}
2026-05-16T19:51:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_195101_b492c90c"}
2026-05-16T19:51:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_195101_b492c90c"}
2026-05-16T19:51:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4146,"mtime":"2026-05-16T19:50:51+02:00","run_id":"20260516_195101_b492c90c"}
2026-05-16T19:51:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":5586,"run_id":"20260516_195101_b492c90c"}
2026-05-16T19:51:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":5592,"mtime":"2026-05-16T19:50:50+02:00","run_id":"20260516_195101_b492c90c"}
2026-05-16T19:51:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":35,"rb":41,"run_id":"20260516_195101_b492c90c"}
2026-05-16T19:51:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_195101_b492c90c"}
2026-05-16T19:51:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.938,"duration_milliseconds":938,"important":true,"run_id":"20260516_195101_b492c90c"}
2026-05-16T19:51:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_195101_b492c90c"}
2026-05-16T19:51:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_195101_b492c90c"}
2026-05-16T19:51:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4285,"mtime":"2026-05-16T19:40:13+02:00","run_id":"20260516_195101_b492c90c"}
2026-05-16T19:51:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_195101_b492c90c"}
2026-05-16T19:51:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":3872,"mtime":"2026-05-16T19:40:13+02:00","run_id":"20260516_195101_b492c90c"}
2026-05-16T19:51:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_195101_b492c90c"}
2026-05-16T19:51:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_195101_b492c90c"}
2026-05-16T19:51:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.31,"duration_milliseconds":310,"important":true,"run_id":"20260516_195101_b492c90c"}
2026-05-16T19:51:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_195101_b492c90c"}
2026-05-16T19:51:03+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_195101_b492c90c"}
2026-05-16T19:51:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":129489,"run_id":"20260516_195101_b492c90c"}
2026-05-16T19:51:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.993,"exec_milliseconds":1993,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":129489,"important":true,"run_id":"20260516_195101_b492c90c"}
2026-05-16T19:52:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_195202_40b418f8"}
2026-05-16T19:52:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_195202_40b418f8"}
2026-05-16T19:52:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_195202_40b418f8"}
2026-05-16T19:52:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_195202_40b418f8"}
2026-05-16T19:52:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_195202_40b418f8"}
2026-05-16T19:52:03+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_195202_40b418f8"}
2026-05-16T19:52:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_195202_40b418f8"}
2026-05-16T19:52:04+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_195202_40b418f8"}
2026-05-16T19:52:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4146,"mtime":"2026-05-16T19:51:58+02:00","run_id":"20260516_195202_40b418f8"}
2026-05-16T19:52:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":5586,"run_id":"20260516_195202_40b418f8"}
2026-05-16T19:52:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":6013,"mtime":"2026-05-16T19:51:58+02:00","run_id":"20260516_195202_40b418f8"}
2026-05-16T19:52:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":35,"rb":43,"run_id":"20260516_195202_40b418f8"}
2026-05-16T19:52:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_195202_40b418f8"}
2026-05-16T19:52:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.962,"duration_milliseconds":962,"important":true,"run_id":"20260516_195202_40b418f8"}
2026-05-16T19:52:04+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_195202_40b418f8"}
2026-05-16T19:52:04+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_195202_40b418f8"}
2026-05-16T19:52:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4285,"mtime":"2026-05-16T19:40:13+02:00","run_id":"20260516_195202_40b418f8"}
2026-05-16T19:52:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_195202_40b418f8"}
2026-05-16T19:52:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":3872,"mtime":"2026-05-16T19:40:13+02:00","run_id":"20260516_195202_40b418f8"}
2026-05-16T19:52:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_195202_40b418f8"}
2026-05-16T19:52:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_195202_40b418f8"}
2026-05-16T19:52:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.296,"duration_milliseconds":296,"important":true,"run_id":"20260516_195202_40b418f8"}
2026-05-16T19:52:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_195202_40b418f8"}
2026-05-16T19:52:04+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_195202_40b418f8"}
2026-05-16T19:52:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":131274,"run_id":"20260516_195202_40b418f8"}
2026-05-16T19:52:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.195,"exec_milliseconds":2195,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":131274,"important":true,"run_id":"20260516_195202_40b418f8"}
2026-05-16T19:53:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_195301_07d84711"}
2026-05-16T19:53:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_195301_07d84711"}
2026-05-16T19:53:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_195301_07d84711"}
2026-05-16T19:53:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_195301_07d84711"}
2026-05-16T19:53:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_195301_07d84711"}
2026-05-16T19:53:02+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_195301_07d84711"}
2026-05-16T19:53:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_195301_07d84711"}
2026-05-16T19:53:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_195301_07d84711"}
2026-05-16T19:53:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4146,"mtime":"2026-05-16T19:53:02+02:00","run_id":"20260516_195301_07d84711"}
2026-05-16T19:53:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":5586,"run_id":"20260516_195301_07d84711"}
2026-05-16T19:53:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":6390,"mtime":"2026-05-16T19:53:02+02:00","run_id":"20260516_195301_07d84711"}
2026-05-16T19:53:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":35,"rb":43,"run_id":"20260516_195301_07d84711"}
2026-05-16T19:53:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_195301_07d84711"}
2026-05-16T19:53:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.969,"duration_milliseconds":969,"important":true,"run_id":"20260516_195301_07d84711"}
2026-05-16T19:53:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_195301_07d84711"}
2026-05-16T19:53:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_195301_07d84711"}
2026-05-16T19:53:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4285,"mtime":"2026-05-16T19:40:13+02:00","run_id":"20260516_195301_07d84711"}
2026-05-16T19:53:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_195301_07d84711"}
2026-05-16T19:53:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":3872,"mtime":"2026-05-16T19:40:13+02:00","run_id":"20260516_195301_07d84711"}
2026-05-16T19:53:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_195301_07d84711"}
2026-05-16T19:53:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_195301_07d84711"}
2026-05-16T19:53:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.325,"duration_milliseconds":325,"important":true,"run_id":"20260516_195301_07d84711"}
2026-05-16T19:53:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_195301_07d84711"}
2026-05-16T19:53:03+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_195301_07d84711"}
2026-05-16T19:53:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":132901,"run_id":"20260516_195301_07d84711"}
2026-05-16T19:53:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.111,"exec_milliseconds":2111,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":132901,"important":true,"run_id":"20260516_195301_07d84711"}
2026-05-16T19:54:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_195402_34a2b603"}
2026-05-16T19:54:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_195402_34a2b603"}
2026-05-16T19:54:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_195402_34a2b603"}
2026-05-16T19:54:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_195402_34a2b603"}
2026-05-16T19:54:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_195402_34a2b603"}
2026-05-16T19:54:03+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_195402_34a2b603"}
2026-05-16T19:54:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_195402_34a2b603"}
2026-05-16T19:54:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_195402_34a2b603"}
2026-05-16T19:54:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4146,"mtime":"2026-05-16T19:53:59+02:00","run_id":"20260516_195402_34a2b603"}
2026-05-16T19:54:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":5586,"run_id":"20260516_195402_34a2b603"}
2026-05-16T19:54:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":6770,"mtime":"2026-05-16T19:53:59+02:00","run_id":"20260516_195402_34a2b603"}
2026-05-16T19:54:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":37,"rb":46,"run_id":"20260516_195402_34a2b603"}
2026-05-16T19:54:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_195402_34a2b603"}
2026-05-16T19:54:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.964,"duration_milliseconds":964,"important":true,"run_id":"20260516_195402_34a2b603"}
2026-05-16T19:54:04+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_195402_34a2b603"}
2026-05-16T19:54:04+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_195402_34a2b603"}
2026-05-16T19:54:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4285,"mtime":"2026-05-16T19:40:13+02:00","run_id":"20260516_195402_34a2b603"}
2026-05-16T19:54:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_195402_34a2b603"}
2026-05-16T19:54:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":3872,"mtime":"2026-05-16T19:40:13+02:00","run_id":"20260516_195402_34a2b603"}
2026-05-16T19:54:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_195402_34a2b603"}
2026-05-16T19:54:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_195402_34a2b603"}
2026-05-16T19:54:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.294,"duration_milliseconds":294,"important":true,"run_id":"20260516_195402_34a2b603"}
2026-05-16T19:54:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_195402_34a2b603"}
2026-05-16T19:54:04+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_195402_34a2b603"}
2026-05-16T19:54:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":134489,"run_id":"20260516_195402_34a2b603"}
2026-05-16T19:54:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.995,"exec_milliseconds":1995,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":134489,"important":true,"run_id":"20260516_195402_34a2b603"}
2026-05-16T19:55:04+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_195504_96c62e47"}
2026-05-16T19:55:04+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_195504_96c62e47"}
2026-05-16T19:55:04+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_195504_96c62e47"}
2026-05-16T19:55:04+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_195504_96c62e47"}
2026-05-16T19:55:04+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_195504_96c62e47"}
2026-05-16T19:55:04+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_195504_96c62e47"}
2026-05-16T19:55:04+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_195504_96c62e47"}
2026-05-16T19:55:05+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_195504_96c62e47"}
2026-05-16T19:55:05+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4146,"mtime":"2026-05-16T19:55:05+02:00","run_id":"20260516_195504_96c62e47"}
2026-05-16T19:55:05+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":5586,"run_id":"20260516_195504_96c62e47"}
2026-05-16T19:55:05+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":7152,"mtime":"2026-05-16T19:55:05+02:00","run_id":"20260516_195504_96c62e47"}
2026-05-16T19:55:05+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":39,"rb":48,"run_id":"20260516_195504_96c62e47"}
2026-05-16T19:55:05+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_195504_96c62e47"}
2026-05-16T19:55:05+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.94,"duration_milliseconds":940,"important":true,"run_id":"20260516_195504_96c62e47"}
2026-05-16T19:55:05+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_195504_96c62e47"}
2026-05-16T19:55:05+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_195504_96c62e47"}
2026-05-16T19:55:05+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4285,"mtime":"2026-05-16T19:40:13+02:00","run_id":"20260516_195504_96c62e47"}
2026-05-16T19:55:05+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_195504_96c62e47"}
2026-05-16T19:55:05+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":3872,"mtime":"2026-05-16T19:40:13+02:00","run_id":"20260516_195504_96c62e47"}
2026-05-16T19:55:05+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_195504_96c62e47"}
2026-05-16T19:55:06+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_195504_96c62e47"}
2026-05-16T19:55:06+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.287,"duration_milliseconds":287,"important":true,"run_id":"20260516_195504_96c62e47"}
2026-05-16T19:55:06+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_195504_96c62e47"}
2026-05-16T19:55:06+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_195504_96c62e47"}
2026-05-16T19:55:06+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":136079,"run_id":"20260516_195504_96c62e47"}
2026-05-16T19:55:06+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.999,"exec_milliseconds":1999,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":136079,"important":true,"run_id":"20260516_195504_96c62e47"}
2026-05-16T19:56:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_195602_a6d1a38c"}
2026-05-16T19:56:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_195602_a6d1a38c"}
2026-05-16T19:56:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_195602_a6d1a38c"}
2026-05-16T19:56:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_195602_a6d1a38c"}
2026-05-16T19:56:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_195602_a6d1a38c"}
2026-05-16T19:56:03+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_195602_a6d1a38c"}
2026-05-16T19:56:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_195602_a6d1a38c"}
2026-05-16T19:56:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_195602_a6d1a38c"}
2026-05-16T19:56:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4146,"mtime":"2026-05-16T19:55:47+02:00","run_id":"20260516_195602_a6d1a38c"}
2026-05-16T19:56:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":5586,"run_id":"20260516_195602_a6d1a38c"}
2026-05-16T19:56:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":7410,"mtime":"2026-05-16T19:55:47+02:00","run_id":"20260516_195602_a6d1a38c"}
2026-05-16T19:56:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":41,"rb":48,"run_id":"20260516_195602_a6d1a38c"}
2026-05-16T19:56:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_195602_a6d1a38c"}
2026-05-16T19:56:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.942,"duration_milliseconds":942,"important":true,"run_id":"20260516_195602_a6d1a38c"}
2026-05-16T19:56:04+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_195602_a6d1a38c"}
2026-05-16T19:56:04+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_195602_a6d1a38c"}
2026-05-16T19:56:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4285,"mtime":"2026-05-16T19:40:13+02:00","run_id":"20260516_195602_a6d1a38c"}
2026-05-16T19:56:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_195602_a6d1a38c"}
2026-05-16T19:56:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":3872,"mtime":"2026-05-16T19:40:13+02:00","run_id":"20260516_195602_a6d1a38c"}
2026-05-16T19:56:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_195602_a6d1a38c"}
2026-05-16T19:56:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_195602_a6d1a38c"}
2026-05-16T19:56:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.32,"duration_milliseconds":320,"important":true,"run_id":"20260516_195602_a6d1a38c"}
2026-05-16T19:56:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_195602_a6d1a38c"}
2026-05-16T19:56:04+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_195602_a6d1a38c"}
2026-05-16T19:56:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":137181,"run_id":"20260516_195602_a6d1a38c"}
2026-05-16T19:56:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.057,"exec_milliseconds":2057,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":137181,"important":true,"run_id":"20260516_195602_a6d1a38c"}
2026-05-16T19:57:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_195701_05df89a9"}
2026-05-16T19:57:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_195701_05df89a9"}
2026-05-16T19:57:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_195701_05df89a9"}
2026-05-16T19:57:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_195701_05df89a9"}
2026-05-16T19:57:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_195701_05df89a9"}
2026-05-16T19:57:02+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_195701_05df89a9"}
2026-05-16T19:57:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_195701_05df89a9"}
2026-05-16T19:57:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_195701_05df89a9"}
2026-05-16T19:57:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4146,"mtime":"2026-05-16T19:57:01+02:00","run_id":"20260516_195701_05df89a9"}
2026-05-16T19:57:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":5586,"run_id":"20260516_195701_05df89a9"}
2026-05-16T19:57:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":7902,"mtime":"2026-05-16T19:57:00+02:00","run_id":"20260516_195701_05df89a9"}
2026-05-16T19:57:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":41,"rb":50,"run_id":"20260516_195701_05df89a9"}
2026-05-16T19:57:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_195701_05df89a9"}
2026-05-16T19:57:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.94,"duration_milliseconds":940,"important":true,"run_id":"20260516_195701_05df89a9"}
2026-05-16T19:57:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_195701_05df89a9"}
2026-05-16T19:57:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_195701_05df89a9"}
2026-05-16T19:57:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4285,"mtime":"2026-05-16T19:40:13+02:00","run_id":"20260516_195701_05df89a9"}
2026-05-16T19:57:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_195701_05df89a9"}
2026-05-16T19:57:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":3872,"mtime":"2026-05-16T19:40:13+02:00","run_id":"20260516_195701_05df89a9"}
2026-05-16T19:57:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_195701_05df89a9"}
2026-05-16T19:57:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_195701_05df89a9"}
2026-05-16T19:57:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.281,"duration_milliseconds":281,"important":true,"run_id":"20260516_195701_05df89a9"}
2026-05-16T19:57:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_195701_05df89a9"}
2026-05-16T19:57:03+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_195701_05df89a9"}
2026-05-16T19:57:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":139281,"run_id":"20260516_195701_05df89a9"}
2026-05-16T19:57:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.022,"exec_milliseconds":2022,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":139281,"important":true,"run_id":"20260516_195701_05df89a9"}
2026-05-16T19:58:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_195802_971521df"}
2026-05-16T19:58:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_195802_971521df"}
2026-05-16T19:58:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_195802_971521df"}
2026-05-16T19:58:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_195802_971521df"}
2026-05-16T19:58:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_195802_971521df"}
2026-05-16T19:58:03+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_195802_971521df"}
2026-05-16T19:58:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_195802_971521df"}
2026-05-16T19:58:04+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_195802_971521df"}
2026-05-16T19:58:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4146,"mtime":"2026-05-16T19:57:21+02:00","run_id":"20260516_195802_971521df"}
2026-05-16T19:58:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":5586,"run_id":"20260516_195802_971521df"}
2026-05-16T19:58:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":8018,"mtime":"2026-05-16T19:57:20+02:00","run_id":"20260516_195802_971521df"}
2026-05-16T19:58:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":44,"rb":50,"run_id":"20260516_195802_971521df"}
2026-05-16T19:58:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_195802_971521df"}
2026-05-16T19:58:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.952,"duration_milliseconds":952,"important":true,"run_id":"20260516_195802_971521df"}
2026-05-16T19:58:04+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_195802_971521df"}
2026-05-16T19:58:04+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_195802_971521df"}
2026-05-16T19:58:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4285,"mtime":"2026-05-16T19:40:13+02:00","run_id":"20260516_195802_971521df"}
2026-05-16T19:58:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_195802_971521df"}
2026-05-16T19:58:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":3872,"mtime":"2026-05-16T19:40:13+02:00","run_id":"20260516_195802_971521df"}
2026-05-16T19:58:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_195802_971521df"}
2026-05-16T19:58:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_195802_971521df"}
2026-05-16T19:58:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.314,"duration_milliseconds":314,"important":true,"run_id":"20260516_195802_971521df"}
2026-05-16T19:58:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_195802_971521df"}
2026-05-16T19:58:04+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_195802_971521df"}
2026-05-16T19:58:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":139753,"run_id":"20260516_195802_971521df"}
2026-05-16T19:58:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.041,"exec_milliseconds":2041,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":139753,"important":true,"run_id":"20260516_195802_971521df"}
2026-05-16T19:59:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_195901_2b9d6e3b"}
2026-05-16T19:59:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_195901_2b9d6e3b"}
2026-05-16T19:59:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_195901_2b9d6e3b"}
2026-05-16T19:59:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_195901_2b9d6e3b"}
2026-05-16T19:59:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_195901_2b9d6e3b"}
2026-05-16T19:59:02+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_195901_2b9d6e3b"}
2026-05-16T19:59:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_195901_2b9d6e3b"}
2026-05-16T19:59:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_195901_2b9d6e3b"}
2026-05-16T19:59:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4146,"mtime":"2026-05-16T19:58:55+02:00","run_id":"20260516_195901_2b9d6e3b"}
2026-05-16T19:59:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":5586,"run_id":"20260516_195901_2b9d6e3b"}
2026-05-16T19:59:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":8511,"mtime":"2026-05-16T19:58:55+02:00","run_id":"20260516_195901_2b9d6e3b"}
2026-05-16T19:59:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":44,"rb":51,"run_id":"20260516_195901_2b9d6e3b"}
2026-05-16T19:59:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_195901_2b9d6e3b"}
2026-05-16T19:59:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.965,"duration_milliseconds":965,"important":true,"run_id":"20260516_195901_2b9d6e3b"}
2026-05-16T19:59:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_195901_2b9d6e3b"}
2026-05-16T19:59:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_195901_2b9d6e3b"}
2026-05-16T19:59:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4285,"mtime":"2026-05-16T19:40:13+02:00","run_id":"20260516_195901_2b9d6e3b"}
2026-05-16T19:59:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_195901_2b9d6e3b"}
2026-05-16T19:59:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":3872,"mtime":"2026-05-16T19:40:13+02:00","run_id":"20260516_195901_2b9d6e3b"}
2026-05-16T19:59:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_195901_2b9d6e3b"}
2026-05-16T19:59:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_195901_2b9d6e3b"}
2026-05-16T19:59:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.298,"duration_milliseconds":298,"important":true,"run_id":"20260516_195901_2b9d6e3b"}
2026-05-16T19:59:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_195901_2b9d6e3b"}
2026-05-16T19:59:03+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_195901_2b9d6e3b"}
2026-05-16T19:59:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":141852,"run_id":"20260516_195901_2b9d6e3b"}
2026-05-16T19:59:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.033,"exec_milliseconds":2033,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":141852,"important":true,"run_id":"20260516_195901_2b9d6e3b"}
2026-05-16T20:00:17+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_200017_9f7ba6bf"}
2026-05-16T20:00:17+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_200017_9f7ba6bf"}
2026-05-16T20:00:17+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_200017_9f7ba6bf"}
2026-05-16T20:00:17+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_200017_9f7ba6bf"}
2026-05-16T20:00:18+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_200017_9f7ba6bf"}
2026-05-16T20:00:18+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_200017_9f7ba6bf"}
2026-05-16T20:00:18+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_200017_9f7ba6bf"}
2026-05-16T20:00:18+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_200017_9f7ba6bf"}
2026-05-16T20:00:18+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4146,"mtime":"2026-05-16T20:00:18+02:00","run_id":"20260516_200017_9f7ba6bf"}
2026-05-16T20:00:18+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":5586,"run_id":"20260516_200017_9f7ba6bf"}
2026-05-16T20:00:18+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":8854,"mtime":"2026-05-16T20:00:18+02:00","run_id":"20260516_200017_9f7ba6bf"}
2026-05-16T20:00:18+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":44,"rb":52,"run_id":"20260516_200017_9f7ba6bf"}
2026-05-16T20:00:19+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_200017_9f7ba6bf"}
2026-05-16T20:00:19+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.943,"duration_milliseconds":943,"important":true,"run_id":"20260516_200017_9f7ba6bf"}
2026-05-16T20:00:19+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_200017_9f7ba6bf"}
2026-05-16T20:00:19+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_200017_9f7ba6bf"}
2026-05-16T20:00:19+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4285,"mtime":"2026-05-16T19:40:13+02:00","run_id":"20260516_200017_9f7ba6bf"}
2026-05-16T20:00:19+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_200017_9f7ba6bf"}
2026-05-16T20:00:19+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":3872,"mtime":"2026-05-16T19:40:13+02:00","run_id":"20260516_200017_9f7ba6bf"}
2026-05-16T20:00:19+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_200017_9f7ba6bf"}
2026-05-16T20:00:19+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_200017_9f7ba6bf"}
2026-05-16T20:00:19+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.445,"duration_milliseconds":445,"important":true,"run_id":"20260516_200017_9f7ba6bf"}
2026-05-16T20:00:19+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_200017_9f7ba6bf"}
2026-05-16T20:00:19+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_200017_9f7ba6bf"}
2026-05-16T20:00:19+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":143305,"run_id":"20260516_200017_9f7ba6bf"}
2026-05-16T20:00:19+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.227,"exec_milliseconds":2227,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":143305,"important":true,"run_id":"20260516_200017_9f7ba6bf"}
2026-05-16T20:01:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_200101_dabae617"}
2026-05-16T20:01:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_200101_dabae617"}
2026-05-16T20:01:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_200101_dabae617"}
2026-05-16T20:01:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_200101_dabae617"}
2026-05-16T20:01:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_200101_dabae617"}
2026-05-16T20:01:02+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_200101_dabae617"}
2026-05-16T20:01:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_200101_dabae617"}
2026-05-16T20:01:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_200101_dabae617"}
2026-05-16T20:01:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4146,"mtime":"2026-05-16T20:00:29+02:00","run_id":"20260516_200101_dabae617"}
2026-05-16T20:01:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":5586,"run_id":"20260516_200101_dabae617"}
2026-05-16T20:01:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":9041,"mtime":"2026-05-16T20:00:29+02:00","run_id":"20260516_200101_dabae617"}
2026-05-16T20:01:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":44,"rb":54,"run_id":"20260516_200101_dabae617"}
2026-05-16T20:01:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_200101_dabae617"}
2026-05-16T20:01:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.951,"duration_milliseconds":951,"important":true,"run_id":"20260516_200101_dabae617"}
2026-05-16T20:01:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_200101_dabae617"}
2026-05-16T20:01:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_200101_dabae617"}
2026-05-16T20:01:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4285,"mtime":"2026-05-16T19:40:13+02:00","run_id":"20260516_200101_dabae617"}
2026-05-16T20:01:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_200101_dabae617"}
2026-05-16T20:01:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":3872,"mtime":"2026-05-16T19:40:13+02:00","run_id":"20260516_200101_dabae617"}
2026-05-16T20:01:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_200101_dabae617"}
2026-05-16T20:01:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_200101_dabae617"}
2026-05-16T20:01:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.312,"duration_milliseconds":312,"important":true,"run_id":"20260516_200101_dabae617"}
2026-05-16T20:01:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_200101_dabae617"}
2026-05-16T20:01:04+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_200101_dabae617"}
2026-05-16T20:01:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":144090,"run_id":"20260516_200101_dabae617"}
2026-05-16T20:01:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.022,"exec_milliseconds":2022,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":144090,"important":true,"run_id":"20260516_200101_dabae617"}
2026-05-16T20:02:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_200202_c8ab3d53"}
2026-05-16T20:02:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_200202_c8ab3d53"}
2026-05-16T20:02:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_200202_c8ab3d53"}
2026-05-16T20:02:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_200202_c8ab3d53"}
2026-05-16T20:02:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_200202_c8ab3d53"}
2026-05-16T20:02:03+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_200202_c8ab3d53"}
2026-05-16T20:02:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_200202_c8ab3d53"}
2026-05-16T20:02:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_200202_c8ab3d53"}
2026-05-16T20:02:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4146,"mtime":"2026-05-16T20:00:29+02:00","run_id":"20260516_200202_c8ab3d53"}
2026-05-16T20:02:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":5586,"run_id":"20260516_200202_c8ab3d53"}
2026-05-16T20:02:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":9041,"mtime":"2026-05-16T20:00:29+02:00","run_id":"20260516_200202_c8ab3d53"}
2026-05-16T20:02:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":44,"rb":54,"run_id":"20260516_200202_c8ab3d53"}
2026-05-16T20:02:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_200202_c8ab3d53"}
2026-05-16T20:02:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.964,"duration_milliseconds":964,"important":true,"run_id":"20260516_200202_c8ab3d53"}
2026-05-16T20:02:04+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_200202_c8ab3d53"}
2026-05-16T20:02:04+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_200202_c8ab3d53"}
2026-05-16T20:02:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4285,"mtime":"2026-05-16T19:40:13+02:00","run_id":"20260516_200202_c8ab3d53"}
2026-05-16T20:02:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_200202_c8ab3d53"}
2026-05-16T20:02:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":3872,"mtime":"2026-05-16T19:40:13+02:00","run_id":"20260516_200202_c8ab3d53"}
2026-05-16T20:02:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_200202_c8ab3d53"}
2026-05-16T20:02:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_200202_c8ab3d53"}
2026-05-16T20:02:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.31,"duration_milliseconds":310,"important":true,"run_id":"20260516_200202_c8ab3d53"}
2026-05-16T20:02:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_200202_c8ab3d53"}
2026-05-16T20:02:04+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_200202_c8ab3d53"}
2026-05-16T20:02:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":144188,"run_id":"20260516_200202_c8ab3d53"}
2026-05-16T20:02:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.006,"exec_milliseconds":2006,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":144188,"important":true,"run_id":"20260516_200202_c8ab3d53"}
2026-05-16T20:03:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_200302_0279bfa8"}
2026-05-16T20:03:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_200302_0279bfa8"}
2026-05-16T20:03:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_200302_0279bfa8"}
2026-05-16T20:03:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_200302_0279bfa8"}
2026-05-16T20:03:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_200302_0279bfa8"}
2026-05-16T20:03:02+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_200302_0279bfa8"}
2026-05-16T20:03:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_200302_0279bfa8"}
2026-05-16T20:03:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_200302_0279bfa8"}
2026-05-16T20:03:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4146,"mtime":"2026-05-16T20:02:41+02:00","run_id":"20260516_200302_0279bfa8"}
2026-05-16T20:03:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":5586,"run_id":"20260516_200302_0279bfa8"}
2026-05-16T20:03:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":9340,"mtime":"2026-05-16T20:02:41+02:00","run_id":"20260516_200302_0279bfa8"}
2026-05-16T20:03:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":44,"rb":54,"run_id":"20260516_200302_0279bfa8"}
2026-05-16T20:03:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_200302_0279bfa8"}
2026-05-16T20:03:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.961,"duration_milliseconds":961,"important":true,"run_id":"20260516_200302_0279bfa8"}
2026-05-16T20:03:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_200302_0279bfa8"}
2026-05-16T20:03:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_200302_0279bfa8"}
2026-05-16T20:03:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4285,"mtime":"2026-05-16T19:40:13+02:00","run_id":"20260516_200302_0279bfa8"}
2026-05-16T20:03:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_200302_0279bfa8"}
2026-05-16T20:03:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":3872,"mtime":"2026-05-16T19:40:13+02:00","run_id":"20260516_200302_0279bfa8"}
2026-05-16T20:03:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_200302_0279bfa8"}
2026-05-16T20:03:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_200302_0279bfa8"}
2026-05-16T20:03:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.317,"duration_milliseconds":317,"important":true,"run_id":"20260516_200302_0279bfa8"}
2026-05-16T20:03:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_200302_0279bfa8"}
2026-05-16T20:03:04+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_200302_0279bfa8"}
2026-05-16T20:03:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":145389,"run_id":"20260516_200302_0279bfa8"}
2026-05-16T20:03:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.038,"exec_milliseconds":2038,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":145389,"important":true,"run_id":"20260516_200302_0279bfa8"}
2026-05-16T20:04:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_200402_92a07a11"}
2026-05-16T20:04:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_200402_92a07a11"}
2026-05-16T20:04:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_200402_92a07a11"}
2026-05-16T20:04:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_200402_92a07a11"}
2026-05-16T20:04:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_200402_92a07a11"}
2026-05-16T20:04:03+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_200402_92a07a11"}
2026-05-16T20:04:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_200402_92a07a11"}
2026-05-16T20:04:04+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_200402_92a07a11"}
2026-05-16T20:04:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4146,"mtime":"2026-05-16T20:03:56+02:00","run_id":"20260516_200402_92a07a11"}
2026-05-16T20:04:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":5586,"run_id":"20260516_200402_92a07a11"}
2026-05-16T20:04:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":10180,"mtime":"2026-05-16T20:03:56+02:00","run_id":"20260516_200402_92a07a11"}
2026-05-16T20:04:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":44,"rb":54,"run_id":"20260516_200402_92a07a11"}
2026-05-16T20:04:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_200402_92a07a11"}
2026-05-16T20:04:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.958,"duration_milliseconds":958,"important":true,"run_id":"20260516_200402_92a07a11"}
2026-05-16T20:04:04+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_200402_92a07a11"}
2026-05-16T20:04:04+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_200402_92a07a11"}
2026-05-16T20:04:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4285,"mtime":"2026-05-16T19:40:13+02:00","run_id":"20260516_200402_92a07a11"}
2026-05-16T20:04:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_200402_92a07a11"}
2026-05-16T20:04:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":3872,"mtime":"2026-05-16T19:40:13+02:00","run_id":"20260516_200402_92a07a11"}
2026-05-16T20:04:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_200402_92a07a11"}
2026-05-16T20:04:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_200402_92a07a11"}
2026-05-16T20:04:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.303,"duration_milliseconds":303,"important":true,"run_id":"20260516_200402_92a07a11"}
2026-05-16T20:04:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_200402_92a07a11"}
2026-05-16T20:04:04+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_200402_92a07a11"}
2026-05-16T20:04:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":148999,"run_id":"20260516_200402_92a07a11"}
2026-05-16T20:04:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.026,"exec_milliseconds":2026,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":148999,"important":true,"run_id":"20260516_200402_92a07a11"}
2026-05-16T20:05:04+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_200504_5c32d8a1"}
2026-05-16T20:05:05+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_200504_5c32d8a1"}
2026-05-16T20:05:05+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_200504_5c32d8a1"}
2026-05-16T20:05:05+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_200504_5c32d8a1"}
2026-05-16T20:05:05+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_200504_5c32d8a1"}
2026-05-16T20:05:05+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_200504_5c32d8a1"}
2026-05-16T20:05:05+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_200504_5c32d8a1"}
2026-05-16T20:05:06+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_200504_5c32d8a1"}
2026-05-16T20:05:06+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4146,"mtime":"2026-05-16T20:04:47+02:00","run_id":"20260516_200504_5c32d8a1"}
2026-05-16T20:05:06+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":5586,"run_id":"20260516_200504_5c32d8a1"}
2026-05-16T20:05:06+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":10703,"mtime":"2026-05-16T20:04:46+02:00","run_id":"20260516_200504_5c32d8a1"}
2026-05-16T20:05:06+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":44,"rb":54,"run_id":"20260516_200504_5c32d8a1"}
2026-05-16T20:05:06+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_200504_5c32d8a1"}
2026-05-16T20:05:06+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.954,"duration_milliseconds":954,"important":true,"run_id":"20260516_200504_5c32d8a1"}
2026-05-16T20:05:06+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_200504_5c32d8a1"}
2026-05-16T20:05:06+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_200504_5c32d8a1"}
2026-05-16T20:05:06+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4285,"mtime":"2026-05-16T19:40:13+02:00","run_id":"20260516_200504_5c32d8a1"}
2026-05-16T20:05:06+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_200504_5c32d8a1"}
2026-05-16T20:05:06+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":3872,"mtime":"2026-05-16T19:40:13+02:00","run_id":"20260516_200504_5c32d8a1"}
2026-05-16T20:05:06+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_200504_5c32d8a1"}
2026-05-16T20:05:06+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_200504_5c32d8a1"}
2026-05-16T20:05:06+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.297,"duration_milliseconds":297,"important":true,"run_id":"20260516_200504_5c32d8a1"}
2026-05-16T20:05:06+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_200504_5c32d8a1"}
2026-05-16T20:05:06+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_200504_5c32d8a1"}
2026-05-16T20:05:06+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":151268,"run_id":"20260516_200504_5c32d8a1"}
2026-05-16T20:05:06+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.028,"exec_milliseconds":2028,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":151268,"important":true,"run_id":"20260516_200504_5c32d8a1"}
2026-05-16T20:06:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_200602_d34cb127"}
2026-05-16T20:06:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_200602_d34cb127"}
2026-05-16T20:06:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_200602_d34cb127"}
2026-05-16T20:06:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_200602_d34cb127"}
2026-05-16T20:06:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_200602_d34cb127"}
2026-05-16T20:06:03+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_200602_d34cb127"}
2026-05-16T20:06:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_200602_d34cb127"}
2026-05-16T20:06:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_200602_d34cb127"}
2026-05-16T20:06:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4146,"mtime":"2026-05-16T20:05:45+02:00","run_id":"20260516_200602_d34cb127"}
2026-05-16T20:06:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":5586,"run_id":"20260516_200602_d34cb127"}
2026-05-16T20:06:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":11235,"mtime":"2026-05-16T20:05:45+02:00","run_id":"20260516_200602_d34cb127"}
2026-05-16T20:07:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_200701_bce87a2c"}
2026-05-16T20:07:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_200701_bce87a2c"}
2026-05-16T20:07:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_200701_bce87a2c"}
2026-05-16T20:07:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_200701_bce87a2c"}
2026-05-16T20:07:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_200701_bce87a2c"}
2026-05-16T20:07:02+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_200701_bce87a2c"}
2026-05-16T20:07:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_200701_bce87a2c"}
2026-05-16T20:07:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_200701_bce87a2c"}
2026-05-16T20:07:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4146,"mtime":"2026-05-16T20:06:53+02:00","run_id":"20260516_200701_bce87a2c"}
2026-05-16T20:07:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":5586,"run_id":"20260516_200701_bce87a2c"}
2026-05-16T20:07:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":11700,"mtime":"2026-05-16T20:06:52+02:00","run_id":"20260516_200701_bce87a2c"}
2026-05-16T20:07:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":48,"rb":54,"run_id":"20260516_200701_bce87a2c"}
2026-05-16T20:07:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_200701_bce87a2c"}
2026-05-16T20:07:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.944,"duration_milliseconds":944,"important":true,"run_id":"20260516_200701_bce87a2c"}
2026-05-16T20:07:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_200701_bce87a2c"}
2026-05-16T20:07:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_200701_bce87a2c"}
2026-05-16T20:07:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4285,"mtime":"2026-05-16T19:40:13+02:00","run_id":"20260516_200701_bce87a2c"}
2026-05-16T20:07:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_200701_bce87a2c"}
2026-05-16T20:07:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":3872,"mtime":"2026-05-16T19:40:13+02:00","run_id":"20260516_200701_bce87a2c"}
2026-05-16T20:07:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_200701_bce87a2c"}
2026-05-16T20:07:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_200701_bce87a2c"}
2026-05-16T20:07:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.304,"duration_milliseconds":304,"important":true,"run_id":"20260516_200701_bce87a2c"}
2026-05-16T20:07:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_200701_bce87a2c"}
2026-05-16T20:07:03+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_200701_bce87a2c"}
2026-05-16T20:07:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":155493,"run_id":"20260516_200701_bce87a2c"}
2026-05-16T20:07:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.005,"exec_milliseconds":2005,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":155493,"important":true,"run_id":"20260516_200701_bce87a2c"}
2026-05-16T20:08:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_200802_4ef54361"}
2026-05-16T20:08:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_200802_4ef54361"}
2026-05-16T20:08:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_200802_4ef54361"}
2026-05-16T20:08:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_200802_4ef54361"}
2026-05-16T20:08:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_200802_4ef54361"}
2026-05-16T20:08:03+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_200802_4ef54361"}
2026-05-16T20:08:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_200802_4ef54361"}
2026-05-16T20:08:04+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_200802_4ef54361"}
2026-05-16T20:08:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4146,"mtime":"2026-05-16T20:06:53+02:00","run_id":"20260516_200802_4ef54361"}
2026-05-16T20:08:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":5586,"run_id":"20260516_200802_4ef54361"}
2026-05-16T20:08:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":11700,"mtime":"2026-05-16T20:06:52+02:00","run_id":"20260516_200802_4ef54361"}
2026-05-16T20:08:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":48,"rb":54,"run_id":"20260516_200802_4ef54361"}
2026-05-16T20:08:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_200802_4ef54361"}
2026-05-16T20:08:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.983,"duration_milliseconds":983,"important":true,"run_id":"20260516_200802_4ef54361"}
2026-05-16T20:08:04+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_200802_4ef54361"}
2026-05-16T20:08:04+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_200802_4ef54361"}
2026-05-16T20:08:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4285,"mtime":"2026-05-16T19:40:13+02:00","run_id":"20260516_200802_4ef54361"}
2026-05-16T20:08:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_200802_4ef54361"}
2026-05-16T20:08:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":3872,"mtime":"2026-05-16T19:40:13+02:00","run_id":"20260516_200802_4ef54361"}
2026-05-16T20:08:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_200802_4ef54361"}
2026-05-16T20:08:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_200802_4ef54361"}
2026-05-16T20:08:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.301,"duration_milliseconds":301,"important":true,"run_id":"20260516_200802_4ef54361"}
2026-05-16T20:08:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_200802_4ef54361"}
2026-05-16T20:08:04+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_200802_4ef54361"}
2026-05-16T20:08:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":155493,"run_id":"20260516_200802_4ef54361"}
2026-05-16T20:08:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.037,"exec_milliseconds":2037,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":155493,"important":true,"run_id":"20260516_200802_4ef54361"}
2026-05-16T20:09:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_200901_ca1ffa37"}
2026-05-16T20:09:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_200901_ca1ffa37"}
2026-05-16T20:09:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_200901_ca1ffa37"}
2026-05-16T20:09:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_200901_ca1ffa37"}
2026-05-16T20:09:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_200901_ca1ffa37"}
2026-05-16T20:09:02+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_200901_ca1ffa37"}
2026-05-16T20:09:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_200901_ca1ffa37"}
2026-05-16T20:09:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_200901_ca1ffa37"}
2026-05-16T20:09:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4146,"mtime":"2026-05-16T20:08:59+02:00","run_id":"20260516_200901_ca1ffa37"}
2026-05-16T20:09:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":5586,"run_id":"20260516_200901_ca1ffa37"}
2026-05-16T20:09:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":11928,"mtime":"2026-05-16T20:08:59+02:00","run_id":"20260516_200901_ca1ffa37"}
2026-05-16T20:09:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":48,"rb":54,"run_id":"20260516_200901_ca1ffa37"}
2026-05-16T20:09:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_200901_ca1ffa37"}
2026-05-16T20:09:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.936,"duration_milliseconds":936,"important":true,"run_id":"20260516_200901_ca1ffa37"}
2026-05-16T20:09:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_200901_ca1ffa37"}
2026-05-16T20:09:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_200901_ca1ffa37"}
2026-05-16T20:09:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4285,"mtime":"2026-05-16T19:40:13+02:00","run_id":"20260516_200901_ca1ffa37"}
2026-05-16T20:09:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_200901_ca1ffa37"}
2026-05-16T20:09:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":3872,"mtime":"2026-05-16T19:40:13+02:00","run_id":"20260516_200901_ca1ffa37"}
2026-05-16T20:09:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_200901_ca1ffa37"}
2026-05-16T20:09:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_200901_ca1ffa37"}
2026-05-16T20:09:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.289,"duration_milliseconds":289,"important":true,"run_id":"20260516_200901_ca1ffa37"}
2026-05-16T20:09:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_200901_ca1ffa37"}
2026-05-16T20:09:03+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_200901_ca1ffa37"}
2026-05-16T20:09:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":156475,"run_id":"20260516_200901_ca1ffa37"}
2026-05-16T20:09:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.031,"exec_milliseconds":2031,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":156475,"important":true,"run_id":"20260516_200901_ca1ffa37"}
2026-05-16T20:10:06+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_201006_4cd03cf5"}
2026-05-16T20:10:06+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_201006_4cd03cf5"}
2026-05-16T20:10:06+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_201006_4cd03cf5"}
2026-05-16T20:10:06+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_201006_4cd03cf5"}
2026-05-16T20:10:06+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_201006_4cd03cf5"}
2026-05-16T20:10:06+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_201006_4cd03cf5"}
2026-05-16T20:10:06+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_201006_4cd03cf5"}
2026-05-16T20:10:07+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_201006_4cd03cf5"}
2026-05-16T20:10:07+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4146,"mtime":"2026-05-16T20:10:04+02:00","run_id":"20260516_201006_4cd03cf5"}
2026-05-16T20:10:07+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":5586,"run_id":"20260516_201006_4cd03cf5"}
2026-05-16T20:10:07+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":12154,"mtime":"2026-05-16T20:10:04+02:00","run_id":"20260516_201006_4cd03cf5"}
2026-05-16T20:10:07+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":48,"rb":54,"run_id":"20260516_201006_4cd03cf5"}
2026-05-16T20:10:07+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_201006_4cd03cf5"}
2026-05-16T20:10:07+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.959,"duration_milliseconds":959,"important":true,"run_id":"20260516_201006_4cd03cf5"}
2026-05-16T20:10:07+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_201006_4cd03cf5"}
2026-05-16T20:10:07+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_201006_4cd03cf5"}
2026-05-16T20:10:07+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4285,"mtime":"2026-05-16T19:40:13+02:00","run_id":"20260516_201006_4cd03cf5"}
2026-05-16T20:10:08+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_201006_4cd03cf5"}
2026-05-16T20:10:08+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":3872,"mtime":"2026-05-16T19:40:13+02:00","run_id":"20260516_201006_4cd03cf5"}
2026-05-16T20:10:08+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_201006_4cd03cf5"}
2026-05-16T20:10:08+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_201006_4cd03cf5"}
2026-05-16T20:10:08+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.302,"duration_milliseconds":302,"important":true,"run_id":"20260516_201006_4cd03cf5"}
2026-05-16T20:10:08+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_201006_4cd03cf5"}
2026-05-16T20:10:08+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_201006_4cd03cf5"}
2026-05-16T20:10:08+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":157455,"run_id":"20260516_201006_4cd03cf5"}
2026-05-16T20:10:08+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.017,"exec_milliseconds":2017,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":157455,"important":true,"run_id":"20260516_201006_4cd03cf5"}
2026-05-16T20:11:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_201101_f636fb7a"}
2026-05-16T20:11:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_201101_f636fb7a"}
2026-05-16T20:11:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_201101_f636fb7a"}
2026-05-16T20:11:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_201101_f636fb7a"}
2026-05-16T20:11:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_201101_f636fb7a"}
2026-05-16T20:11:02+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_201101_f636fb7a"}
2026-05-16T20:11:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_201101_f636fb7a"}
2026-05-16T20:11:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_201101_f636fb7a"}
2026-05-16T20:11:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4146,"mtime":"2026-05-16T20:10:49+02:00","run_id":"20260516_201101_f636fb7a"}
2026-05-16T20:11:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":5586,"run_id":"20260516_201101_f636fb7a"}
2026-05-16T20:11:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":12340,"mtime":"2026-05-16T20:10:49+02:00","run_id":"20260516_201101_f636fb7a"}
2026-05-16T20:11:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":49,"rb":54,"run_id":"20260516_201101_f636fb7a"}
2026-05-16T20:11:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_201101_f636fb7a"}
2026-05-16T20:11:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.961,"duration_milliseconds":961,"important":true,"run_id":"20260516_201101_f636fb7a"}
2026-05-16T20:11:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_201101_f636fb7a"}
2026-05-16T20:11:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_201101_f636fb7a"}
2026-05-16T20:11:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4285,"mtime":"2026-05-16T19:40:13+02:00","run_id":"20260516_201101_f636fb7a"}
2026-05-16T20:11:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_201101_f636fb7a"}
2026-05-16T20:11:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":3872,"mtime":"2026-05-16T19:40:13+02:00","run_id":"20260516_201101_f636fb7a"}
2026-05-16T20:11:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_201101_f636fb7a"}
2026-05-16T20:11:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_201101_f636fb7a"}
2026-05-16T20:11:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.295,"duration_milliseconds":295,"important":true,"run_id":"20260516_201101_f636fb7a"}
2026-05-16T20:11:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_201101_f636fb7a"}
2026-05-16T20:11:04+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_201101_f636fb7a"}
2026-05-16T20:11:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":158239,"run_id":"20260516_201101_f636fb7a"}
2026-05-16T20:11:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.039,"exec_milliseconds":2039,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":158239,"important":true,"run_id":"20260516_201101_f636fb7a"}
2026-05-16T20:12:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_201202_0812e9fc"}
2026-05-16T20:12:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_201202_0812e9fc"}
2026-05-16T20:12:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_201202_0812e9fc"}
2026-05-16T20:12:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_201202_0812e9fc"}
2026-05-16T20:12:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_201202_0812e9fc"}
2026-05-16T20:12:03+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_201202_0812e9fc"}
2026-05-16T20:12:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_201202_0812e9fc"}
2026-05-16T20:12:04+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_201202_0812e9fc"}
2026-05-16T20:12:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4146,"mtime":"2026-05-16T20:11:45+02:00","run_id":"20260516_201202_0812e9fc"}
2026-05-16T20:12:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":5586,"run_id":"20260516_201202_0812e9fc"}
2026-05-16T20:12:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":12762,"mtime":"2026-05-16T20:11:45+02:00","run_id":"20260516_201202_0812e9fc"}
2026-05-16T20:12:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":49,"rb":57,"run_id":"20260516_201202_0812e9fc"}
2026-05-16T20:12:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_201202_0812e9fc"}
2026-05-16T20:12:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":1.036,"duration_milliseconds":1036,"important":true,"run_id":"20260516_201202_0812e9fc"}
2026-05-16T20:12:04+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_201202_0812e9fc"}
2026-05-16T20:12:04+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_201202_0812e9fc"}
2026-05-16T20:12:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4285,"mtime":"2026-05-16T19:40:13+02:00","run_id":"20260516_201202_0812e9fc"}
2026-05-16T20:12:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_201202_0812e9fc"}
2026-05-16T20:12:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":3872,"mtime":"2026-05-16T19:40:13+02:00","run_id":"20260516_201202_0812e9fc"}
2026-05-16T20:12:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_201202_0812e9fc"}
2026-05-16T20:12:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_201202_0812e9fc"}
2026-05-16T20:12:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.314,"duration_milliseconds":314,"important":true,"run_id":"20260516_201202_0812e9fc"}
2026-05-16T20:12:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_201202_0812e9fc"}
2026-05-16T20:12:04+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_201202_0812e9fc"}
2026-05-16T20:12:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":160022,"run_id":"20260516_201202_0812e9fc"}
2026-05-16T20:12:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.128,"exec_milliseconds":2128,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":160022,"important":true,"run_id":"20260516_201202_0812e9fc"}
2026-05-16T20:13:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_201301_c4ab995e"}
2026-05-16T20:13:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_201301_c4ab995e"}
2026-05-16T20:13:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_201301_c4ab995e"}
2026-05-16T20:13:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_201301_c4ab995e"}
2026-05-16T20:13:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_201301_c4ab995e"}
2026-05-16T20:13:02+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_201301_c4ab995e"}
2026-05-16T20:13:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_201301_c4ab995e"}
2026-05-16T20:13:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_201301_c4ab995e"}
2026-05-16T20:13:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4146,"mtime":"2026-05-16T20:12:58+02:00","run_id":"20260516_201301_c4ab995e"}
2026-05-16T20:13:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":5586,"run_id":"20260516_201301_c4ab995e"}
2026-05-16T20:13:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":13284,"mtime":"2026-05-16T20:12:58+02:00","run_id":"20260516_201301_c4ab995e"}
2026-05-16T20:13:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":51,"rb":57,"run_id":"20260516_201301_c4ab995e"}
2026-05-16T20:13:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_201301_c4ab995e"}
2026-05-16T20:13:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.938,"duration_milliseconds":938,"important":true,"run_id":"20260516_201301_c4ab995e"}
2026-05-16T20:13:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_201301_c4ab995e"}
2026-05-16T20:13:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_201301_c4ab995e"}
2026-05-16T20:13:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4285,"mtime":"2026-05-16T19:40:13+02:00","run_id":"20260516_201301_c4ab995e"}
2026-05-16T20:13:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_201301_c4ab995e"}
2026-05-16T20:13:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":3872,"mtime":"2026-05-16T19:40:13+02:00","run_id":"20260516_201301_c4ab995e"}
2026-05-16T20:13:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_201301_c4ab995e"}
2026-05-16T20:13:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_201301_c4ab995e"}
2026-05-16T20:13:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.288,"duration_milliseconds":288,"important":true,"run_id":"20260516_201301_c4ab995e"}
2026-05-16T20:13:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_201301_c4ab995e"}
2026-05-16T20:13:03+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_201301_c4ab995e"}
2026-05-16T20:13:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":162239,"run_id":"20260516_201301_c4ab995e"}
2026-05-16T20:13:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.98,"exec_milliseconds":1980,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":162239,"important":true,"run_id":"20260516_201301_c4ab995e"}
2026-05-16T20:14:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_201402_39872d82"}
2026-05-16T20:14:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_201402_39872d82"}
2026-05-16T20:14:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_201402_39872d82"}
2026-05-16T20:14:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_201402_39872d82"}
2026-05-16T20:14:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_201402_39872d82"}
2026-05-16T20:14:03+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_201402_39872d82"}
2026-05-16T20:14:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_201402_39872d82"}
2026-05-16T20:14:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_201402_39872d82"}
2026-05-16T20:14:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4146,"mtime":"2026-05-16T20:13:52+02:00","run_id":"20260516_201402_39872d82"}
2026-05-16T20:14:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":5586,"run_id":"20260516_201402_39872d82"}
2026-05-16T20:14:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":13697,"mtime":"2026-05-16T20:13:52+02:00","run_id":"20260516_201402_39872d82"}
2026-05-16T20:14:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":53,"rb":57,"run_id":"20260516_201402_39872d82"}
2026-05-16T20:14:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_201402_39872d82"}
2026-05-16T20:14:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.958,"duration_milliseconds":958,"important":true,"run_id":"20260516_201402_39872d82"}
2026-05-16T20:14:04+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_201402_39872d82"}
2026-05-16T20:14:04+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_201402_39872d82"}
2026-05-16T20:14:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4285,"mtime":"2026-05-16T19:40:13+02:00","run_id":"20260516_201402_39872d82"}
2026-05-16T20:14:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_201402_39872d82"}
2026-05-16T20:14:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":3872,"mtime":"2026-05-16T19:40:13+02:00","run_id":"20260516_201402_39872d82"}
2026-05-16T20:14:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_201402_39872d82"}
2026-05-16T20:14:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_201402_39872d82"}
2026-05-16T20:14:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.306,"duration_milliseconds":306,"important":true,"run_id":"20260516_201402_39872d82"}
2026-05-16T20:14:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_201402_39872d82"}
2026-05-16T20:14:04+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_201402_39872d82"}
2026-05-16T20:14:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":164004,"run_id":"20260516_201402_39872d82"}
2026-05-16T20:14:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.023,"exec_milliseconds":2023,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":164004,"important":true,"run_id":"20260516_201402_39872d82"}
2026-05-16T20:15:06+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_201506_503727a7"}
2026-05-16T20:15:06+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_201506_503727a7"}
2026-05-16T20:15:06+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_201506_503727a7"}
2026-05-16T20:15:06+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_201506_503727a7"}
2026-05-16T20:15:06+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_201506_503727a7"}
2026-05-16T20:15:06+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_201506_503727a7"}
2026-05-16T20:15:06+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_201506_503727a7"}
2026-05-16T20:15:07+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_201506_503727a7"}
2026-05-16T20:15:07+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4146,"mtime":"2026-05-16T20:14:26+02:00","run_id":"20260516_201506_503727a7"}
2026-05-16T20:15:07+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":5586,"run_id":"20260516_201506_503727a7"}
2026-05-16T20:15:07+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":13839,"mtime":"2026-05-16T20:14:26+02:00","run_id":"20260516_201506_503727a7"}
2026-05-16T20:15:07+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":53,"rb":57,"run_id":"20260516_201506_503727a7"}
2026-05-16T20:15:07+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_201506_503727a7"}
2026-05-16T20:15:07+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.92,"duration_milliseconds":920,"important":true,"run_id":"20260516_201506_503727a7"}
2026-05-16T20:15:07+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_201506_503727a7"}
2026-05-16T20:15:07+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_201506_503727a7"}
2026-05-16T20:15:07+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4285,"mtime":"2026-05-16T19:40:13+02:00","run_id":"20260516_201506_503727a7"}
2026-05-16T20:15:08+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_201506_503727a7"}
2026-05-16T20:15:08+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":3872,"mtime":"2026-05-16T19:40:13+02:00","run_id":"20260516_201506_503727a7"}
2026-05-16T20:15:08+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_201506_503727a7"}
2026-05-16T20:15:08+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_201506_503727a7"}
2026-05-16T20:15:08+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.288,"duration_milliseconds":288,"important":true,"run_id":"20260516_201506_503727a7"}
2026-05-16T20:15:08+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_201506_503727a7"}
2026-05-16T20:15:08+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_201506_503727a7"}
2026-05-16T20:15:08+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":164638,"run_id":"20260516_201506_503727a7"}
2026-05-16T20:15:08+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.951,"exec_milliseconds":1951,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":164638,"important":true,"run_id":"20260516_201506_503727a7"}
2026-05-16T20:16:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_201602_e9881c46"}
2026-05-16T20:16:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_201602_e9881c46"}
2026-05-16T20:16:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_201602_e9881c46"}
2026-05-16T20:16:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_201602_e9881c46"}
2026-05-16T20:16:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_201602_e9881c46"}
2026-05-16T20:16:03+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_201602_e9881c46"}
2026-05-16T20:16:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_201602_e9881c46"}
2026-05-16T20:16:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_201602_e9881c46"}
2026-05-16T20:16:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4146,"mtime":"2026-05-16T20:15:54+02:00","run_id":"20260516_201602_e9881c46"}
2026-05-16T20:16:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":5586,"run_id":"20260516_201602_e9881c46"}
2026-05-16T20:16:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":13850,"mtime":"2026-05-16T20:15:52+02:00","run_id":"20260516_201602_e9881c46"}
2026-05-16T20:16:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":53,"rb":57,"run_id":"20260516_201602_e9881c46"}
2026-05-16T20:16:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_201602_e9881c46"}
2026-05-16T20:16:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.921,"duration_milliseconds":921,"important":true,"run_id":"20260516_201602_e9881c46"}
2026-05-16T20:16:04+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_201602_e9881c46"}
2026-05-16T20:16:04+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_201602_e9881c46"}
2026-05-16T20:16:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4285,"mtime":"2026-05-16T19:40:13+02:00","run_id":"20260516_201602_e9881c46"}
2026-05-16T20:16:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_201602_e9881c46"}
2026-05-16T20:16:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":3872,"mtime":"2026-05-16T19:40:13+02:00","run_id":"20260516_201602_e9881c46"}
2026-05-16T20:16:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_201602_e9881c46"}
2026-05-16T20:16:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_201602_e9881c46"}
2026-05-16T20:16:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.278,"duration_milliseconds":278,"important":true,"run_id":"20260516_201602_e9881c46"}
2026-05-16T20:16:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_201602_e9881c46"}
2026-05-16T20:16:04+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_201602_e9881c46"}
2026-05-16T20:16:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":164671,"run_id":"20260516_201602_e9881c46"}
2026-05-16T20:16:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.97,"exec_milliseconds":1970,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":164671,"important":true,"run_id":"20260516_201602_e9881c46"}
2026-05-16T20:17:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_201701_04e1f29d"}
2026-05-16T20:17:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_201701_04e1f29d"}
2026-05-16T20:17:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_201701_04e1f29d"}
2026-05-16T20:17:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_201701_04e1f29d"}
2026-05-16T20:17:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_201701_04e1f29d"}
2026-05-16T20:17:02+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_201701_04e1f29d"}
2026-05-16T20:17:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_201701_04e1f29d"}
2026-05-16T20:17:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_201701_04e1f29d"}
2026-05-16T20:17:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4146,"mtime":"2026-05-16T20:16:43+02:00","run_id":"20260516_201701_04e1f29d"}
2026-05-16T20:17:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":5586,"run_id":"20260516_201701_04e1f29d"}
2026-05-16T20:17:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":6190,"mtime":"2026-05-16T20:16:43+02:00","run_id":"20260516_201701_04e1f29d"}
2026-05-16T20:17:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":53,"rb":57,"run_id":"20260516_201701_04e1f29d"}
2026-05-16T20:17:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_201701_04e1f29d"}
2026-05-16T20:17:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.921,"duration_milliseconds":921,"important":true,"run_id":"20260516_201701_04e1f29d"}
2026-05-16T20:17:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_201701_04e1f29d"}
2026-05-16T20:17:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_201701_04e1f29d"}
2026-05-16T20:17:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4285,"mtime":"2026-05-16T19:40:13+02:00","run_id":"20260516_201701_04e1f29d"}
2026-05-16T20:17:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_201701_04e1f29d"}
2026-05-16T20:17:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":3872,"mtime":"2026-05-16T19:40:13+02:00","run_id":"20260516_201701_04e1f29d"}
2026-05-16T20:17:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_201701_04e1f29d"}
2026-05-16T20:17:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_201701_04e1f29d"}
2026-05-16T20:17:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.28,"duration_milliseconds":280,"important":true,"run_id":"20260516_201701_04e1f29d"}
2026-05-16T20:17:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_201701_04e1f29d"}
2026-05-16T20:17:03+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_201701_04e1f29d"}
2026-05-16T20:17:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":131799,"run_id":"20260516_201701_04e1f29d"}
2026-05-16T20:17:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.979,"exec_milliseconds":1979,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":131799,"important":true,"run_id":"20260516_201701_04e1f29d"}
2026-05-16T20:18:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_201802_efed4db6"}
2026-05-16T20:18:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_201802_efed4db6"}
2026-05-16T20:18:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_201802_efed4db6"}
2026-05-16T20:18:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_201802_efed4db6"}
2026-05-16T20:18:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_201802_efed4db6"}
2026-05-16T20:18:03+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_201802_efed4db6"}
2026-05-16T20:18:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_201802_efed4db6"}
2026-05-16T20:18:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_201802_efed4db6"}
2026-05-16T20:18:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4146,"mtime":"2026-05-16T20:17:56+02:00","run_id":"20260516_201802_efed4db6"}
2026-05-16T20:18:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":5586,"run_id":"20260516_201802_efed4db6"}
2026-05-16T20:18:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":6642,"mtime":"2026-05-16T20:17:55+02:00","run_id":"20260516_201802_efed4db6"}
2026-05-16T20:18:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":53,"rb":57,"run_id":"20260516_201802_efed4db6"}
2026-05-16T20:18:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_201802_efed4db6"}
2026-05-16T20:18:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.987,"duration_milliseconds":987,"important":true,"run_id":"20260516_201802_efed4db6"}
2026-05-16T20:18:04+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_201802_efed4db6"}
2026-05-16T20:18:04+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_201802_efed4db6"}
2026-05-16T20:18:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4285,"mtime":"2026-05-16T19:40:13+02:00","run_id":"20260516_201802_efed4db6"}
2026-05-16T20:18:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_201802_efed4db6"}
2026-05-16T20:18:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":3872,"mtime":"2026-05-16T19:40:13+02:00","run_id":"20260516_201802_efed4db6"}
2026-05-16T20:18:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_201802_efed4db6"}
2026-05-16T20:18:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_201802_efed4db6"}
2026-05-16T20:18:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.304,"duration_milliseconds":304,"important":true,"run_id":"20260516_201802_efed4db6"}
2026-05-16T20:18:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_201802_efed4db6"}
2026-05-16T20:18:04+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_201802_efed4db6"}
2026-05-16T20:18:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":133751,"run_id":"20260516_201802_efed4db6"}
2026-05-16T20:18:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.077,"exec_milliseconds":2077,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":133751,"important":true,"run_id":"20260516_201802_efed4db6"}
2026-05-16T20:19:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_201901_6e944cc1"}
2026-05-16T20:19:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_201901_6e944cc1"}
2026-05-16T20:19:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_201901_6e944cc1"}
2026-05-16T20:19:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_201901_6e944cc1"}
2026-05-16T20:19:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_201901_6e944cc1"}
2026-05-16T20:19:02+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_201901_6e944cc1"}
2026-05-16T20:19:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_201901_6e944cc1"}
2026-05-16T20:19:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_201901_6e944cc1"}
2026-05-16T20:19:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4146,"mtime":"2026-05-16T20:19:01+02:00","run_id":"20260516_201901_6e944cc1"}
2026-05-16T20:19:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":5586,"run_id":"20260516_201901_6e944cc1"}
2026-05-16T20:19:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":7208,"mtime":"2026-05-16T20:19:01+02:00","run_id":"20260516_201901_6e944cc1"}
2026-05-16T20:19:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":56,"rb":57,"run_id":"20260516_201901_6e944cc1"}
2026-05-16T20:19:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_201901_6e944cc1"}
2026-05-16T20:19:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.919,"duration_milliseconds":919,"important":true,"run_id":"20260516_201901_6e944cc1"}
2026-05-16T20:19:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_201901_6e944cc1"}
2026-05-16T20:19:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_201901_6e944cc1"}
2026-05-16T20:19:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4285,"mtime":"2026-05-16T19:40:13+02:00","run_id":"20260516_201901_6e944cc1"}
2026-05-16T20:19:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_201901_6e944cc1"}
2026-05-16T20:19:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":3872,"mtime":"2026-05-16T19:40:13+02:00","run_id":"20260516_201901_6e944cc1"}
2026-05-16T20:19:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_201901_6e944cc1"}
2026-05-16T20:19:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_201901_6e944cc1"}
2026-05-16T20:19:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.283,"duration_milliseconds":283,"important":true,"run_id":"20260516_201901_6e944cc1"}
2026-05-16T20:19:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_201901_6e944cc1"}
2026-05-16T20:19:03+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_201901_6e944cc1"}
2026-05-16T20:19:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":136173,"run_id":"20260516_201901_6e944cc1"}
2026-05-16T20:19:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.958,"exec_milliseconds":1958,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":136173,"important":true,"run_id":"20260516_201901_6e944cc1"}
2026-05-16T20:20:06+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_202006_a553daf2"}
2026-05-16T20:20:06+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_202006_a553daf2"}
2026-05-16T20:20:06+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_202006_a553daf2"}
2026-05-16T20:20:06+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_202006_a553daf2"}
2026-05-16T20:20:07+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_202006_a553daf2"}
2026-05-16T20:20:07+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_202006_a553daf2"}
2026-05-16T20:20:07+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_202006_a553daf2"}
2026-05-16T20:20:07+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_202006_a553daf2"}
2026-05-16T20:20:07+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4146,"mtime":"2026-05-16T20:19:46+02:00","run_id":"20260516_202006_a553daf2"}
2026-05-16T20:20:07+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":5586,"run_id":"20260516_202006_a553daf2"}
2026-05-16T20:20:07+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":7694,"mtime":"2026-05-16T20:19:46+02:00","run_id":"20260516_202006_a553daf2"}
2026-05-16T20:20:08+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":59,"rb":57,"run_id":"20260516_202006_a553daf2"}
2026-05-16T20:20:08+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_202006_a553daf2"}
2026-05-16T20:20:08+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.926,"duration_milliseconds":926,"important":true,"run_id":"20260516_202006_a553daf2"}
2026-05-16T20:20:08+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_202006_a553daf2"}
2026-05-16T20:20:08+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_202006_a553daf2"}
2026-05-16T20:20:08+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4285,"mtime":"2026-05-16T20:19:19+02:00","run_id":"20260516_202006_a553daf2"}
2026-05-16T20:20:08+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_202006_a553daf2"}
2026-05-16T20:20:08+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":3882,"mtime":"2026-05-16T20:19:19+02:00","run_id":"20260516_202006_a553daf2"}
2026-05-16T20:20:08+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_202006_a553daf2"}
2026-05-16T20:20:08+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_202006_a553daf2"}
2026-05-16T20:20:08+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.282,"duration_milliseconds":282,"important":true,"run_id":"20260516_202006_a553daf2"}
2026-05-16T20:20:08+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_202006_a553daf2"}
2026-05-16T20:20:08+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_202006_a553daf2"}
2026-05-16T20:20:08+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":138187,"run_id":"20260516_202006_a553daf2"}
2026-05-16T20:20:08+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.974,"exec_milliseconds":1974,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":138187,"important":true,"run_id":"20260516_202006_a553daf2"}
2026-05-16T20:21:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_202101_5958446d"}
2026-05-16T20:21:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_202101_5958446d"}
2026-05-16T20:21:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_202101_5958446d"}
2026-05-16T20:21:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_202101_5958446d"}
2026-05-16T20:21:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_202101_5958446d"}
2026-05-16T20:21:02+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_202101_5958446d"}
2026-05-16T20:21:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_202101_5958446d"}
2026-05-16T20:21:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_202101_5958446d"}
2026-05-16T20:21:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4146,"mtime":"2026-05-16T20:19:46+02:00","run_id":"20260516_202101_5958446d"}
2026-05-16T20:21:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":5586,"run_id":"20260516_202101_5958446d"}
2026-05-16T20:21:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":7694,"mtime":"2026-05-16T20:19:46+02:00","run_id":"20260516_202101_5958446d"}
2026-05-16T20:21:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":59,"rb":57,"run_id":"20260516_202101_5958446d"}
2026-05-16T20:21:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_202101_5958446d"}
2026-05-16T20:21:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.939,"duration_milliseconds":939,"important":true,"run_id":"20260516_202101_5958446d"}
2026-05-16T20:21:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_202101_5958446d"}
2026-05-16T20:21:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_202101_5958446d"}
2026-05-16T20:21:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4285,"mtime":"2026-05-16T20:19:19+02:00","run_id":"20260516_202101_5958446d"}
2026-05-16T20:21:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_202101_5958446d"}
2026-05-16T20:21:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":3882,"mtime":"2026-05-16T20:19:19+02:00","run_id":"20260516_202101_5958446d"}
2026-05-16T20:21:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_202101_5958446d"}
2026-05-16T20:21:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_202101_5958446d"}
2026-05-16T20:21:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.322,"duration_milliseconds":322,"important":true,"run_id":"20260516_202101_5958446d"}
2026-05-16T20:21:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_202101_5958446d"}
2026-05-16T20:21:03+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_202101_5958446d"}
2026-05-16T20:21:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":138287,"run_id":"20260516_202101_5958446d"}
2026-05-16T20:21:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.019,"exec_milliseconds":2019,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":138287,"important":true,"run_id":"20260516_202101_5958446d"}
2026-05-16T20:22:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_202202_81f0cfab"}
2026-05-16T20:22:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_202202_81f0cfab"}
2026-05-16T20:22:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_202202_81f0cfab"}
2026-05-16T20:22:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_202202_81f0cfab"}
2026-05-16T20:22:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_202202_81f0cfab"}
2026-05-16T20:22:03+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_202202_81f0cfab"}
2026-05-16T20:22:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_202202_81f0cfab"}
2026-05-16T20:22:04+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_202202_81f0cfab"}
2026-05-16T20:22:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4146,"mtime":"2026-05-16T20:21:46+02:00","run_id":"20260516_202202_81f0cfab"}
2026-05-16T20:22:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":5586,"run_id":"20260516_202202_81f0cfab"}
2026-05-16T20:22:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":7996,"mtime":"2026-05-16T20:21:46+02:00","run_id":"20260516_202202_81f0cfab"}
2026-05-16T20:22:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":59,"rb":57,"run_id":"20260516_202202_81f0cfab"}
2026-05-16T20:22:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_202202_81f0cfab"}
2026-05-16T20:22:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.96,"duration_milliseconds":960,"important":true,"run_id":"20260516_202202_81f0cfab"}
2026-05-16T20:22:04+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_202202_81f0cfab"}
2026-05-16T20:22:04+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_202202_81f0cfab"}
2026-05-16T20:22:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4285,"mtime":"2026-05-16T20:21:39+02:00","run_id":"20260516_202202_81f0cfab"}
2026-05-16T20:22:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_202202_81f0cfab"}
2026-05-16T20:22:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":3882,"mtime":"2026-05-16T20:21:39+02:00","run_id":"20260516_202202_81f0cfab"}
2026-05-16T20:22:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_202202_81f0cfab"}
2026-05-16T20:22:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_202202_81f0cfab"}
2026-05-16T20:22:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.324,"duration_milliseconds":324,"important":true,"run_id":"20260516_202202_81f0cfab"}
2026-05-16T20:22:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_202202_81f0cfab"}
2026-05-16T20:22:04+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_202202_81f0cfab"}
2026-05-16T20:22:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":139493,"run_id":"20260516_202202_81f0cfab"}
2026-05-16T20:22:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.116,"exec_milliseconds":2116,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":139493,"important":true,"run_id":"20260516_202202_81f0cfab"}
2026-05-16T20:23:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_202301_8233216d"}
2026-05-16T20:23:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_202301_8233216d"}
2026-05-16T20:23:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_202301_8233216d"}
2026-05-16T20:23:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_202301_8233216d"}
2026-05-16T20:23:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_202301_8233216d"}
2026-05-16T20:23:02+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_202301_8233216d"}
2026-05-16T20:23:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_202301_8233216d"}
2026-05-16T20:23:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_202301_8233216d"}
2026-05-16T20:23:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4146,"mtime":"2026-05-16T20:22:37+02:00","run_id":"20260516_202301_8233216d"}
2026-05-16T20:23:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":5586,"run_id":"20260516_202301_8233216d"}
2026-05-16T20:23:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":8407,"mtime":"2026-05-16T20:22:37+02:00","run_id":"20260516_202301_8233216d"}
2026-05-16T20:23:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":61,"rb":57,"run_id":"20260516_202301_8233216d"}
2026-05-16T20:23:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_202301_8233216d"}
2026-05-16T20:23:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.952,"duration_milliseconds":952,"important":true,"run_id":"20260516_202301_8233216d"}
2026-05-16T20:23:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_202301_8233216d"}
2026-05-16T20:23:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_202301_8233216d"}
2026-05-16T20:23:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4285,"mtime":"2026-05-16T20:21:39+02:00","run_id":"20260516_202301_8233216d"}
2026-05-16T20:23:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_202301_8233216d"}
2026-05-16T20:23:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":3882,"mtime":"2026-05-16T20:21:39+02:00","run_id":"20260516_202301_8233216d"}
2026-05-16T20:23:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_202301_8233216d"}
2026-05-16T20:23:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_202301_8233216d"}
2026-05-16T20:23:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.315,"duration_milliseconds":315,"important":true,"run_id":"20260516_202301_8233216d"}
2026-05-16T20:23:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_202301_8233216d"}
2026-05-16T20:23:03+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_202301_8233216d"}
2026-05-16T20:23:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":141385,"run_id":"20260516_202301_8233216d"}
2026-05-16T20:23:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.077,"exec_milliseconds":2077,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":141385,"important":true,"run_id":"20260516_202301_8233216d"}
2026-05-16T20:24:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_202402_241c001e"}
2026-05-16T20:24:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_202402_241c001e"}
2026-05-16T20:24:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_202402_241c001e"}
2026-05-16T20:24:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_202402_241c001e"}
2026-05-16T20:24:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_202402_241c001e"}
2026-05-16T20:24:03+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_202402_241c001e"}
2026-05-16T20:24:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_202402_241c001e"}
2026-05-16T20:24:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_202402_241c001e"}
2026-05-16T20:24:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4146,"mtime":"2026-05-16T20:23:49+02:00","run_id":"20260516_202402_241c001e"}
2026-05-16T20:24:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":5586,"run_id":"20260516_202402_241c001e"}
2026-05-16T20:24:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":8861,"mtime":"2026-05-16T20:23:49+02:00","run_id":"20260516_202402_241c001e"}
2026-05-16T20:24:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":61,"rb":57,"run_id":"20260516_202402_241c001e"}
2026-05-16T20:24:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_202402_241c001e"}
2026-05-16T20:24:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.934,"duration_milliseconds":934,"important":true,"run_id":"20260516_202402_241c001e"}
2026-05-16T20:24:04+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_202402_241c001e"}
2026-05-16T20:24:04+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_202402_241c001e"}
2026-05-16T20:24:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4285,"mtime":"2026-05-16T20:21:39+02:00","run_id":"20260516_202402_241c001e"}
2026-05-16T20:24:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_202402_241c001e"}
2026-05-16T20:24:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":3882,"mtime":"2026-05-16T20:21:39+02:00","run_id":"20260516_202402_241c001e"}
2026-05-16T20:24:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_202402_241c001e"}
2026-05-16T20:24:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_202402_241c001e"}
2026-05-16T20:24:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.304,"duration_milliseconds":304,"important":true,"run_id":"20260516_202402_241c001e"}
2026-05-16T20:24:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_202402_241c001e"}
2026-05-16T20:24:04+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_202402_241c001e"}
2026-05-16T20:24:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":143443,"run_id":"20260516_202402_241c001e"}
2026-05-16T20:24:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.019,"exec_milliseconds":2019,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":143443,"important":true,"run_id":"20260516_202402_241c001e"}
2026-05-16T20:25:04+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_202504_23707112"}
2026-05-16T20:25:04+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_202504_23707112"}
2026-05-16T20:25:04+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_202504_23707112"}
2026-05-16T20:25:04+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_202504_23707112"}
2026-05-16T20:25:04+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_202504_23707112"}
2026-05-16T20:25:04+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_202504_23707112"}
2026-05-16T20:25:04+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_202504_23707112"}
2026-05-16T20:25:05+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_202504_23707112"}
2026-05-16T20:25:05+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4146,"mtime":"2026-05-16T20:25:01+02:00","run_id":"20260516_202504_23707112"}
2026-05-16T20:25:05+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":5586,"run_id":"20260516_202504_23707112"}
2026-05-16T20:25:05+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":9412,"mtime":"2026-05-16T20:25:01+02:00","run_id":"20260516_202504_23707112"}
2026-05-16T20:25:05+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":65,"rb":57,"run_id":"20260516_202504_23707112"}
2026-05-16T20:25:05+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_202504_23707112"}
2026-05-16T20:25:05+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.951,"duration_milliseconds":951,"important":true,"run_id":"20260516_202504_23707112"}
2026-05-16T20:25:05+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_202504_23707112"}
2026-05-16T20:25:05+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_202504_23707112"}
2026-05-16T20:25:05+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4285,"mtime":"2026-05-16T20:21:39+02:00","run_id":"20260516_202504_23707112"}
2026-05-16T20:25:05+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_202504_23707112"}
2026-05-16T20:25:05+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":3882,"mtime":"2026-05-16T20:21:39+02:00","run_id":"20260516_202504_23707112"}
2026-05-16T20:25:05+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_202504_23707112"}
2026-05-16T20:25:05+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_202504_23707112"}
2026-05-16T20:25:05+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.295,"duration_milliseconds":295,"important":true,"run_id":"20260516_202504_23707112"}
2026-05-16T20:25:06+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_202504_23707112"}
2026-05-16T20:25:06+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_202504_23707112"}
2026-05-16T20:25:06+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":145780,"run_id":"20260516_202504_23707112"}
2026-05-16T20:25:06+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.992,"exec_milliseconds":1992,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":145780,"important":true,"run_id":"20260516_202504_23707112"}
2026-05-16T20:26:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_202602_7a657380"}
2026-05-16T20:26:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_202602_7a657380"}
2026-05-16T20:26:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_202602_7a657380"}
2026-05-16T20:26:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_202602_7a657380"}
2026-05-16T20:26:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_202602_7a657380"}
2026-05-16T20:26:03+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_202602_7a657380"}
2026-05-16T20:26:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_202602_7a657380"}
2026-05-16T20:26:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_202602_7a657380"}
2026-05-16T20:26:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4146,"mtime":"2026-05-16T20:25:53+02:00","run_id":"20260516_202602_7a657380"}
2026-05-16T20:26:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":5586,"run_id":"20260516_202602_7a657380"}
2026-05-16T20:26:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":9751,"mtime":"2026-05-16T20:25:53+02:00","run_id":"20260516_202602_7a657380"}
2026-05-16T20:26:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":65,"rb":59,"run_id":"20260516_202602_7a657380"}
2026-05-16T20:26:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_202602_7a657380"}
2026-05-16T20:26:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.948,"duration_milliseconds":948,"important":true,"run_id":"20260516_202602_7a657380"}
2026-05-16T20:26:04+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_202602_7a657380"}
2026-05-16T20:26:04+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_202602_7a657380"}
2026-05-16T20:26:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4285,"mtime":"2026-05-16T20:21:39+02:00","run_id":"20260516_202602_7a657380"}
2026-05-16T20:26:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_202602_7a657380"}
2026-05-16T20:26:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":3882,"mtime":"2026-05-16T20:21:39+02:00","run_id":"20260516_202602_7a657380"}
2026-05-16T20:26:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_202602_7a657380"}
2026-05-16T20:26:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_202602_7a657380"}
2026-05-16T20:26:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.299,"duration_milliseconds":299,"important":true,"run_id":"20260516_202602_7a657380"}
2026-05-16T20:26:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_202602_7a657380"}
2026-05-16T20:26:04+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_202602_7a657380"}
2026-05-16T20:26:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":147221,"run_id":"20260516_202602_7a657380"}
2026-05-16T20:26:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.041,"exec_milliseconds":2041,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":147221,"important":true,"run_id":"20260516_202602_7a657380"}
2026-05-16T20:27:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_202701_fc5618c0"}
2026-05-16T20:27:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_202701_fc5618c0"}
2026-05-16T20:27:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_202701_fc5618c0"}
2026-05-16T20:27:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_202701_fc5618c0"}
2026-05-16T20:27:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_202701_fc5618c0"}
2026-05-16T20:27:02+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_202701_fc5618c0"}
2026-05-16T20:27:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_202701_fc5618c0"}
2026-05-16T20:27:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_202701_fc5618c0"}
2026-05-16T20:27:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4146,"mtime":"2026-05-16T20:26:49+02:00","run_id":"20260516_202701_fc5618c0"}
2026-05-16T20:27:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":5586,"run_id":"20260516_202701_fc5618c0"}
2026-05-16T20:27:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":10046,"mtime":"2026-05-16T20:26:48+02:00","run_id":"20260516_202701_fc5618c0"}
2026-05-16T20:27:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":65,"rb":59,"run_id":"20260516_202701_fc5618c0"}
2026-05-16T20:27:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_202701_fc5618c0"}
2026-05-16T20:27:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.955,"duration_milliseconds":955,"important":true,"run_id":"20260516_202701_fc5618c0"}
2026-05-16T20:27:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_202701_fc5618c0"}
2026-05-16T20:27:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_202701_fc5618c0"}
2026-05-16T20:27:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4285,"mtime":"2026-05-16T20:21:39+02:00","run_id":"20260516_202701_fc5618c0"}
2026-05-16T20:27:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_202701_fc5618c0"}
2026-05-16T20:27:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":3882,"mtime":"2026-05-16T20:21:39+02:00","run_id":"20260516_202701_fc5618c0"}
2026-05-16T20:27:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_202701_fc5618c0"}
2026-05-16T20:27:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_202701_fc5618c0"}
2026-05-16T20:27:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.306,"duration_milliseconds":306,"important":true,"run_id":"20260516_202701_fc5618c0"}
2026-05-16T20:27:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_202701_fc5618c0"}
2026-05-16T20:27:03+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_202701_fc5618c0"}
2026-05-16T20:27:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":148508,"run_id":"20260516_202701_fc5618c0"}
2026-05-16T20:27:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.091,"exec_milliseconds":2091,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":148508,"important":true,"run_id":"20260516_202701_fc5618c0"}
2026-05-16T20:28:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_202802_d4a1bd5a"}
2026-05-16T20:28:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_202802_d4a1bd5a"}
2026-05-16T20:28:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_202802_d4a1bd5a"}
2026-05-16T20:28:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_202802_d4a1bd5a"}
2026-05-16T20:28:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_202802_d4a1bd5a"}
2026-05-16T20:28:03+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_202802_d4a1bd5a"}
2026-05-16T20:28:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_202802_d4a1bd5a"}
2026-05-16T20:28:04+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_202802_d4a1bd5a"}
2026-05-16T20:28:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4146,"mtime":"2026-05-16T20:27:52+02:00","run_id":"20260516_202802_d4a1bd5a"}
2026-05-16T20:28:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":5586,"run_id":"20260516_202802_d4a1bd5a"}
2026-05-16T20:28:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":10278,"mtime":"2026-05-16T20:27:50+02:00","run_id":"20260516_202802_d4a1bd5a"}
2026-05-16T20:28:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":65,"rb":59,"run_id":"20260516_202802_d4a1bd5a"}
2026-05-16T20:28:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_202802_d4a1bd5a"}
2026-05-16T20:28:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.952,"duration_milliseconds":952,"important":true,"run_id":"20260516_202802_d4a1bd5a"}
2026-05-16T20:28:04+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_202802_d4a1bd5a"}
2026-05-16T20:28:04+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_202802_d4a1bd5a"}
2026-05-16T20:28:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4285,"mtime":"2026-05-16T20:21:39+02:00","run_id":"20260516_202802_d4a1bd5a"}
2026-05-16T20:28:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_202802_d4a1bd5a"}
2026-05-16T20:28:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":3882,"mtime":"2026-05-16T20:21:39+02:00","run_id":"20260516_202802_d4a1bd5a"}
2026-05-16T20:28:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_202802_d4a1bd5a"}
2026-05-16T20:28:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_202802_d4a1bd5a"}
2026-05-16T20:28:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.3,"duration_milliseconds":300,"important":true,"run_id":"20260516_202802_d4a1bd5a"}
2026-05-16T20:28:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_202802_d4a1bd5a"}
2026-05-16T20:28:04+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_202802_d4a1bd5a"}
2026-05-16T20:28:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":149498,"run_id":"20260516_202802_d4a1bd5a"}
2026-05-16T20:28:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.012,"exec_milliseconds":2012,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":149498,"important":true,"run_id":"20260516_202802_d4a1bd5a"}
2026-05-16T20:29:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_202901_32dca2ae"}
2026-05-16T20:29:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_202901_32dca2ae"}
2026-05-16T20:29:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_202901_32dca2ae"}
2026-05-16T20:29:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_202901_32dca2ae"}
2026-05-16T20:29:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_202901_32dca2ae"}
2026-05-16T20:29:02+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_202901_32dca2ae"}
2026-05-16T20:29:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_202901_32dca2ae"}
2026-05-16T20:29:02+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_202901_32dca2ae"}
2026-05-16T20:29:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4146,"mtime":"2026-05-16T20:28:52+02:00","run_id":"20260516_202901_32dca2ae"}
2026-05-16T20:29:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":5586,"run_id":"20260516_202901_32dca2ae"}
2026-05-16T20:29:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":10762,"mtime":"2026-05-16T20:28:52+02:00","run_id":"20260516_202901_32dca2ae"}
2026-05-16T20:29:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":66,"rb":59,"run_id":"20260516_202901_32dca2ae"}
2026-05-16T20:29:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_202901_32dca2ae"}
2026-05-16T20:29:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.937,"duration_milliseconds":937,"important":true,"run_id":"20260516_202901_32dca2ae"}
2026-05-16T20:29:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_202901_32dca2ae"}
2026-05-16T20:29:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_202901_32dca2ae"}
2026-05-16T20:29:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4285,"mtime":"2026-05-16T20:21:39+02:00","run_id":"20260516_202901_32dca2ae"}
2026-05-16T20:29:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_202901_32dca2ae"}
2026-05-16T20:29:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":3882,"mtime":"2026-05-16T20:21:39+02:00","run_id":"20260516_202901_32dca2ae"}
2026-05-16T20:29:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_202901_32dca2ae"}
2026-05-16T20:29:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_202901_32dca2ae"}
2026-05-16T20:29:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.306,"duration_milliseconds":306,"important":true,"run_id":"20260516_202901_32dca2ae"}
2026-05-16T20:29:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_202901_32dca2ae"}
2026-05-16T20:29:03+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_202901_32dca2ae"}
2026-05-16T20:29:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":151580,"run_id":"20260516_202901_32dca2ae"}
2026-05-16T20:29:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.009,"exec_milliseconds":2009,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":151580,"important":true,"run_id":"20260516_202901_32dca2ae"}
2026-05-16T20:30:12+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_203011_b04d4b89"}
2026-05-16T20:30:12+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_203011_b04d4b89"}
2026-05-16T20:30:12+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_203011_b04d4b89"}
2026-05-16T20:30:12+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_203011_b04d4b89"}
2026-05-16T20:30:12+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_203011_b04d4b89"}
2026-05-16T20:30:12+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_203011_b04d4b89"}
2026-05-16T20:30:12+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_203011_b04d4b89"}
2026-05-16T20:30:13+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_203011_b04d4b89"}
2026-05-16T20:30:13+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4146,"mtime":"2026-05-16T20:30:09+02:00","run_id":"20260516_203011_b04d4b89"}
2026-05-16T20:30:13+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":5586,"run_id":"20260516_203011_b04d4b89"}
2026-05-16T20:30:13+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":11601,"mtime":"2026-05-16T20:30:10+02:00","run_id":"20260516_203011_b04d4b89"}
2026-05-16T20:30:13+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":66,"rb":59,"run_id":"20260516_203011_b04d4b89"}
2026-05-16T20:30:13+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_203011_b04d4b89"}
2026-05-16T20:30:13+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.964,"duration_milliseconds":964,"important":true,"run_id":"20260516_203011_b04d4b89"}
2026-05-16T20:30:13+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_203011_b04d4b89"}
2026-05-16T20:30:13+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_203011_b04d4b89"}
2026-05-16T20:30:13+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4285,"mtime":"2026-05-16T20:21:39+02:00","run_id":"20260516_203011_b04d4b89"}
2026-05-16T20:30:13+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_203011_b04d4b89"}
2026-05-16T20:30:13+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":3882,"mtime":"2026-05-16T20:21:39+02:00","run_id":"20260516_203011_b04d4b89"}
2026-05-16T20:30:13+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_203011_b04d4b89"}
2026-05-16T20:30:13+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_203011_b04d4b89"}
2026-05-16T20:30:13+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.306,"duration_milliseconds":306,"important":true,"run_id":"20260516_203011_b04d4b89"}
2026-05-16T20:30:13+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_203011_b04d4b89"}
2026-05-16T20:30:13+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_203011_b04d4b89"}
2026-05-16T20:30:13+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":155185,"run_id":"20260516_203011_b04d4b89"}
2026-05-16T20:30:13+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.01,"exec_milliseconds":2010,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":155185,"important":true,"run_id":"20260516_203011_b04d4b89"}
2026-05-16T20:31:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_203101_3f36e619"}
2026-05-16T20:31:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_203101_3f36e619"}
2026-05-16T20:31:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_203101_3f36e619"}
2026-05-16T20:31:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_203101_3f36e619"}
2026-05-16T20:31:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_203101_3f36e619"}
2026-05-16T20:31:02+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_203101_3f36e619"}
2026-05-16T20:31:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_203101_3f36e619"}
2026-05-16T20:31:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_203101_3f36e619"}
2026-05-16T20:31:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4146,"mtime":"2026-05-16T20:30:50+02:00","run_id":"20260516_203101_3f36e619"}
2026-05-16T20:31:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":5586,"run_id":"20260516_203101_3f36e619"}
2026-05-16T20:31:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":12049,"mtime":"2026-05-16T20:30:50+02:00","run_id":"20260516_203101_3f36e619"}
2026-05-16T20:31:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":69,"rb":61,"run_id":"20260516_203101_3f36e619"}
2026-05-16T20:31:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_203101_3f36e619"}
2026-05-16T20:31:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.939,"duration_milliseconds":939,"important":true,"run_id":"20260516_203101_3f36e619"}
2026-05-16T20:31:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_203101_3f36e619"}
2026-05-16T20:31:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_203101_3f36e619"}
2026-05-16T20:31:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4285,"mtime":"2026-05-16T20:21:39+02:00","run_id":"20260516_203101_3f36e619"}
2026-05-16T20:31:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_203101_3f36e619"}
2026-05-16T20:31:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":3882,"mtime":"2026-05-16T20:21:39+02:00","run_id":"20260516_203101_3f36e619"}
2026-05-16T20:31:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_203101_3f36e619"}
2026-05-16T20:31:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_203101_3f36e619"}
2026-05-16T20:31:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.28,"duration_milliseconds":280,"important":true,"run_id":"20260516_203101_3f36e619"}
2026-05-16T20:31:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_203101_3f36e619"}
2026-05-16T20:31:03+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_203101_3f36e619"}
2026-05-16T20:31:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":157083,"run_id":"20260516_203101_3f36e619"}
2026-05-16T20:31:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.978,"exec_milliseconds":1978,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":157083,"important":true,"run_id":"20260516_203101_3f36e619"}
2026-05-16T20:32:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_203202_00b29e1e"}
2026-05-16T20:32:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_203202_00b29e1e"}
2026-05-16T20:32:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_203202_00b29e1e"}
2026-05-16T20:32:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_203202_00b29e1e"}
2026-05-16T20:32:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_203202_00b29e1e"}
2026-05-16T20:32:03+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_203202_00b29e1e"}
2026-05-16T20:32:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_203202_00b29e1e"}
2026-05-16T20:32:04+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_203202_00b29e1e"}
2026-05-16T20:32:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4146,"mtime":"2026-05-16T20:32:03+02:00","run_id":"20260516_203202_00b29e1e"}
2026-05-16T20:32:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":5586,"run_id":"20260516_203202_00b29e1e"}
2026-05-16T20:32:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":12506,"mtime":"2026-05-16T20:32:03+02:00","run_id":"20260516_203202_00b29e1e"}
2026-05-16T20:32:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":72,"rb":63,"run_id":"20260516_203202_00b29e1e"}
2026-05-16T20:32:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_203202_00b29e1e"}
2026-05-16T20:32:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.954,"duration_milliseconds":954,"important":true,"run_id":"20260516_203202_00b29e1e"}
2026-05-16T20:32:04+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_203202_00b29e1e"}
2026-05-16T20:32:04+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_203202_00b29e1e"}
2026-05-16T20:32:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4285,"mtime":"2026-05-16T20:21:39+02:00","run_id":"20260516_203202_00b29e1e"}
2026-05-16T20:32:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_203202_00b29e1e"}
2026-05-16T20:32:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":3882,"mtime":"2026-05-16T20:21:39+02:00","run_id":"20260516_203202_00b29e1e"}
2026-05-16T20:32:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_203202_00b29e1e"}
2026-05-16T20:32:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_203202_00b29e1e"}
2026-05-16T20:32:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.325,"duration_milliseconds":325,"important":true,"run_id":"20260516_203202_00b29e1e"}
2026-05-16T20:32:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_203202_00b29e1e"}
2026-05-16T20:32:04+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_203202_00b29e1e"}
2026-05-16T20:32:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":158998,"run_id":"20260516_203202_00b29e1e"}
2026-05-16T20:32:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.052,"exec_milliseconds":2052,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":158998,"important":true,"run_id":"20260516_203202_00b29e1e"}
2026-05-16T20:33:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_203301_56eee452"}
2026-05-16T20:33:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_203301_56eee452"}
2026-05-16T20:33:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_203301_56eee452"}
2026-05-16T20:33:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_203301_56eee452"}
2026-05-16T20:33:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_203301_56eee452"}
2026-05-16T20:33:02+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_203301_56eee452"}
2026-05-16T20:33:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_203301_56eee452"}
2026-05-16T20:33:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_203301_56eee452"}
2026-05-16T20:33:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4146,"mtime":"2026-05-16T20:32:59+02:00","run_id":"20260516_203301_56eee452"}
2026-05-16T20:33:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":5586,"run_id":"20260516_203301_56eee452"}
2026-05-16T20:33:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":12987,"mtime":"2026-05-16T20:32:59+02:00","run_id":"20260516_203301_56eee452"}
2026-05-16T20:33:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":72,"rb":64,"run_id":"20260516_203301_56eee452"}
2026-05-16T20:33:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_203301_56eee452"}
2026-05-16T20:33:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.942,"duration_milliseconds":942,"important":true,"run_id":"20260516_203301_56eee452"}
2026-05-16T20:33:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_203301_56eee452"}
2026-05-16T20:33:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_203301_56eee452"}
2026-05-16T20:33:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4285,"mtime":"2026-05-16T20:21:39+02:00","run_id":"20260516_203301_56eee452"}
2026-05-16T20:33:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_203301_56eee452"}
2026-05-16T20:33:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":3882,"mtime":"2026-05-16T20:21:39+02:00","run_id":"20260516_203301_56eee452"}
2026-05-16T20:33:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_203301_56eee452"}
2026-05-16T20:33:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_203301_56eee452"}
2026-05-16T20:33:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.31,"duration_milliseconds":310,"important":true,"run_id":"20260516_203301_56eee452"}
2026-05-16T20:33:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_203301_56eee452"}
2026-05-16T20:33:04+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_203301_56eee452"}
2026-05-16T20:33:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":161069,"run_id":"20260516_203301_56eee452"}
2026-05-16T20:33:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.065,"exec_milliseconds":2065,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":161069,"important":true,"run_id":"20260516_203301_56eee452"}
2026-05-16T20:34:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_203402_dd4606ef"}
2026-05-16T20:34:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_203402_dd4606ef"}
2026-05-16T20:34:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_203402_dd4606ef"}
2026-05-16T20:34:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_203402_dd4606ef"}
2026-05-16T20:34:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_203402_dd4606ef"}
2026-05-16T20:34:03+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_203402_dd4606ef"}
2026-05-16T20:34:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_203402_dd4606ef"}
2026-05-16T20:34:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_203402_dd4606ef"}
2026-05-16T20:34:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4146,"mtime":"2026-05-16T20:33:31+02:00","run_id":"20260516_203402_dd4606ef"}
2026-05-16T20:34:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":5586,"run_id":"20260516_203402_dd4606ef"}
2026-05-16T20:34:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":13245,"mtime":"2026-05-16T20:33:31+02:00","run_id":"20260516_203402_dd4606ef"}
2026-05-16T20:34:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":72,"rb":65,"run_id":"20260516_203402_dd4606ef"}
2026-05-16T20:34:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_203402_dd4606ef"}
2026-05-16T20:34:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.946,"duration_milliseconds":946,"important":true,"run_id":"20260516_203402_dd4606ef"}
2026-05-16T20:34:04+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_203402_dd4606ef"}
2026-05-16T20:34:04+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_203402_dd4606ef"}
2026-05-16T20:34:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4285,"mtime":"2026-05-16T20:21:39+02:00","run_id":"20260516_203402_dd4606ef"}
2026-05-16T20:34:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_203402_dd4606ef"}
2026-05-16T20:34:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":3882,"mtime":"2026-05-16T20:21:39+02:00","run_id":"20260516_203402_dd4606ef"}
2026-05-16T20:34:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_203402_dd4606ef"}
2026-05-16T20:34:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_203402_dd4606ef"}
2026-05-16T20:34:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.304,"duration_milliseconds":304,"important":true,"run_id":"20260516_203402_dd4606ef"}
2026-05-16T20:34:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_203402_dd4606ef"}
2026-05-16T20:34:04+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_203402_dd4606ef"}
2026-05-16T20:34:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":162171,"run_id":"20260516_203402_dd4606ef"}
2026-05-16T20:34:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.043,"exec_milliseconds":2043,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":162171,"important":true,"run_id":"20260516_203402_dd4606ef"}
2026-05-16T20:34:49+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_203449_d7167447"}
2026-05-16T20:34:49+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_203449_d7167447"}
2026-05-16T20:34:49+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_203449_d7167447"}
2026-05-16T20:34:49+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_203449_d7167447"}
2026-05-16T20:34:50+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_203449_d7167447"}
2026-05-16T20:34:50+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_203449_d7167447"}
2026-05-16T20:34:50+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_203449_d7167447"}
2026-05-16T20:34:50+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_203449_d7167447"}
2026-05-16T20:34:50+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4146,"mtime":"2026-05-16T20:34:48+02:00","run_id":"20260516_203449_d7167447"}
2026-05-16T20:34:50+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":5586,"run_id":"20260516_203449_d7167447"}
2026-05-16T20:34:50+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":13654,"mtime":"2026-05-16T20:34:49+02:00","run_id":"20260516_203449_d7167447"}
2026-05-16T20:34:50+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":73,"rb":65,"run_id":"20260516_203449_d7167447"}
2026-05-16T20:34:51+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_203449_d7167447"}
2026-05-16T20:34:51+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.958,"duration_milliseconds":958,"important":true,"run_id":"20260516_203449_d7167447"}
2026-05-16T20:34:51+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_203449_d7167447"}
2026-05-16T20:34:51+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_203449_d7167447"}
2026-05-16T20:34:51+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4285,"mtime":"2026-05-16T20:34:44+02:00","run_id":"20260516_203449_d7167447"}
2026-05-16T20:34:51+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_203449_d7167447"}
2026-05-16T20:34:51+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":4068,"mtime":"2026-05-16T20:34:44+02:00","run_id":"20260516_203449_d7167447"}
2026-05-16T20:34:51+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":0,"rb":0,"run_id":"20260516_203449_d7167447"}
2026-05-16T20:34:51+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_203449_d7167447"}
2026-05-16T20:34:51+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.3,"duration_milliseconds":300,"important":true,"run_id":"20260516_203449_d7167447"}
2026-05-16T20:34:51+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_203449_d7167447"}
2026-05-16T20:34:51+02:00 [INFO] Fallback row rendered {"spiel_id":2005742,"result":"--:--","run_id":"20260516_203449_d7167447"}
2026-05-16T20:34:51+02:00 [INFO] Fallback game timing {"spiel_id":2005742,"duration_seconds":0.05,"duration_milliseconds":50,"important":true,"run_id":"20260516_203449_d7167447"}
2026-05-16T20:34:51+02:00 [INFO] Fallback row rendered {"spiel_id":2005757,"result":"--:--","run_id":"20260516_203449_d7167447"}
2026-05-16T20:34:51+02:00 [INFO] Fallback game timing {"spiel_id":2005757,"duration_seconds":0.049,"duration_milliseconds":49,"important":true,"run_id":"20260516_203449_d7167447"}
2026-05-16T20:34:51+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":127140,"run_id":"20260516_203449_d7167447"}
2026-05-16T20:34:51+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.12,"exec_milliseconds":2120,"live_games":2,"fallback_games":2,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":127140,"important":true,"run_id":"20260516_203449_d7167447"}
2026-05-16T20:35:04+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_203504_8ba9c4a8"}
2026-05-16T20:35:04+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_203504_8ba9c4a8"}
2026-05-16T20:35:04+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_203504_8ba9c4a8"}
2026-05-16T20:35:04+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_203504_8ba9c4a8"}
2026-05-16T20:35:04+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_203504_8ba9c4a8"}
2026-05-16T20:35:04+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_203504_8ba9c4a8"}
2026-05-16T20:35:04+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_203504_8ba9c4a8"}
2026-05-16T20:35:05+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_203504_8ba9c4a8"}
2026-05-16T20:35:05+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4146,"mtime":"2026-05-16T20:34:55+02:00","run_id":"20260516_203504_8ba9c4a8"}
2026-05-16T20:35:05+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":5586,"run_id":"20260516_203504_8ba9c4a8"}
2026-05-16T20:35:05+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":13767,"mtime":"2026-05-16T20:35:05+02:00","run_id":"20260516_203504_8ba9c4a8"}
2026-05-16T20:35:05+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":73,"rb":68,"run_id":"20260516_203504_8ba9c4a8"}
2026-05-16T20:35:05+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_203504_8ba9c4a8"}
2026-05-16T20:35:05+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.918,"duration_milliseconds":918,"important":true,"run_id":"20260516_203504_8ba9c4a8"}
2026-05-16T20:35:05+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_203504_8ba9c4a8"}
2026-05-16T20:35:05+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_203504_8ba9c4a8"}
2026-05-16T20:35:05+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4285,"mtime":"2026-05-16T20:35:05+02:00","run_id":"20260516_203504_8ba9c4a8"}
2026-05-16T20:35:05+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_203504_8ba9c4a8"}
2026-05-16T20:35:05+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":4191,"mtime":"2026-05-16T20:35:05+02:00","run_id":"20260516_203504_8ba9c4a8"}
2026-05-16T20:35:05+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":2,"rb":0,"run_id":"20260516_203504_8ba9c4a8"}
2026-05-16T20:35:06+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_203504_8ba9c4a8"}
2026-05-16T20:35:06+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.3,"duration_milliseconds":300,"important":true,"run_id":"20260516_203504_8ba9c4a8"}
2026-05-16T20:35:06+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_203504_8ba9c4a8"}
2026-05-16T20:35:06+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_203504_8ba9c4a8"}
2026-05-16T20:35:06+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":165505,"run_id":"20260516_203504_8ba9c4a8"}
2026-05-16T20:35:06+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.003,"exec_milliseconds":2003,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":165505,"important":true,"run_id":"20260516_203504_8ba9c4a8"}
2026-05-16T20:36:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_203602_4cd25b4c"}
2026-05-16T20:36:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_203602_4cd25b4c"}
2026-05-16T20:36:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_203602_4cd25b4c"}
2026-05-16T20:36:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_203602_4cd25b4c"}
2026-05-16T20:36:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_203602_4cd25b4c"}
2026-05-16T20:36:03+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_203602_4cd25b4c"}
2026-05-16T20:36:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_203602_4cd25b4c"}
2026-05-16T20:36:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_203602_4cd25b4c"}
2026-05-16T20:36:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4146,"mtime":"2026-05-16T20:35:57+02:00","run_id":"20260516_203602_4cd25b4c"}
2026-05-16T20:36:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":5586,"run_id":"20260516_203602_4cd25b4c"}
2026-05-16T20:36:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":14190,"mtime":"2026-05-16T20:35:58+02:00","run_id":"20260516_203602_4cd25b4c"}
2026-05-16T20:36:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":75,"rb":68,"run_id":"20260516_203602_4cd25b4c"}
2026-05-16T20:36:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_203602_4cd25b4c"}
2026-05-16T20:36:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.96,"duration_milliseconds":960,"important":true,"run_id":"20260516_203602_4cd25b4c"}
2026-05-16T20:36:04+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_203602_4cd25b4c"}
2026-05-16T20:36:04+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_203602_4cd25b4c"}
2026-05-16T20:36:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4285,"mtime":"2026-05-16T20:35:58+02:00","run_id":"20260516_203602_4cd25b4c"}
2026-05-16T20:36:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_203602_4cd25b4c"}
2026-05-16T20:36:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":4588,"mtime":"2026-05-16T20:35:58+02:00","run_id":"20260516_203602_4cd25b4c"}
2026-05-16T20:36:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":4,"rb":3,"run_id":"20260516_203602_4cd25b4c"}
2026-05-16T20:36:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_203602_4cd25b4c"}
2026-05-16T20:36:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.302,"duration_milliseconds":302,"important":true,"run_id":"20260516_203602_4cd25b4c"}
2026-05-16T20:36:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_203602_4cd25b4c"}
2026-05-16T20:36:04+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_203602_4cd25b4c"}
2026-05-16T20:36:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":168921,"run_id":"20260516_203602_4cd25b4c"}
2026-05-16T20:36:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.062,"exec_milliseconds":2062,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":168921,"important":true,"run_id":"20260516_203602_4cd25b4c"}
2026-05-16T20:37:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_203701_90142f20"}
2026-05-16T20:37:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_203701_90142f20"}
2026-05-16T20:37:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_203701_90142f20"}
2026-05-16T20:37:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_203701_90142f20"}
2026-05-16T20:37:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_203701_90142f20"}
2026-05-16T20:37:02+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_203701_90142f20"}
2026-05-16T20:37:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_203701_90142f20"}
2026-05-16T20:37:02+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_203701_90142f20"}
2026-05-16T20:37:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4146,"mtime":"2026-05-16T20:37:02+02:00","run_id":"20260516_203701_90142f20"}
2026-05-16T20:37:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":5586,"run_id":"20260516_203701_90142f20"}
2026-05-16T20:37:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":14636,"mtime":"2026-05-16T20:37:02+02:00","run_id":"20260516_203701_90142f20"}
2026-05-16T20:37:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":75,"rb":68,"run_id":"20260516_203701_90142f20"}
2026-05-16T20:37:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_203701_90142f20"}
2026-05-16T20:37:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":1.019,"duration_milliseconds":1019,"important":true,"run_id":"20260516_203701_90142f20"}
2026-05-16T20:37:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_203701_90142f20"}
2026-05-16T20:37:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_203701_90142f20"}
2026-05-16T20:37:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4285,"mtime":"2026-05-16T20:37:03+02:00","run_id":"20260516_203701_90142f20"}
2026-05-16T20:37:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_203701_90142f20"}
2026-05-16T20:37:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":4871,"mtime":"2026-05-16T20:37:02+02:00","run_id":"20260516_203701_90142f20"}
2026-05-16T20:37:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":4,"rb":5,"run_id":"20260516_203701_90142f20"}
2026-05-16T20:37:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_203701_90142f20"}
2026-05-16T20:37:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.337,"duration_milliseconds":337,"important":true,"run_id":"20260516_203701_90142f20"}
2026-05-16T20:37:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_203701_90142f20"}
2026-05-16T20:37:03+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_203701_90142f20"}
2026-05-16T20:37:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":172023,"run_id":"20260516_203701_90142f20"}
2026-05-16T20:37:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.213,"exec_milliseconds":2213,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":172023,"important":true,"run_id":"20260516_203701_90142f20"}
2026-05-16T20:38:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_203802_756a296e"}
2026-05-16T20:38:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_203802_756a296e"}
2026-05-16T20:38:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_203802_756a296e"}
2026-05-16T20:38:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_203802_756a296e"}
2026-05-16T20:38:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_203802_756a296e"}
2026-05-16T20:38:03+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_203802_756a296e"}
2026-05-16T20:38:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_203802_756a296e"}
2026-05-16T20:38:04+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_203802_756a296e"}
2026-05-16T20:38:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4146,"mtime":"2026-05-16T20:38:01+02:00","run_id":"20260516_203802_756a296e"}
2026-05-16T20:38:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":5586,"run_id":"20260516_203802_756a296e"}
2026-05-16T20:38:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":14921,"mtime":"2026-05-16T20:38:01+02:00","run_id":"20260516_203802_756a296e"}
2026-05-16T20:38:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":77,"rb":68,"run_id":"20260516_203802_756a296e"}
2026-05-16T20:38:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_203802_756a296e"}
2026-05-16T20:38:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.947,"duration_milliseconds":947,"important":true,"run_id":"20260516_203802_756a296e"}
2026-05-16T20:38:04+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_203802_756a296e"}
2026-05-16T20:38:04+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_203802_756a296e"}
2026-05-16T20:38:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4285,"mtime":"2026-05-16T20:37:47+02:00","run_id":"20260516_203802_756a296e"}
2026-05-16T20:38:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_203802_756a296e"}
2026-05-16T20:38:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":5022,"mtime":"2026-05-16T20:37:47+02:00","run_id":"20260516_203802_756a296e"}
2026-05-16T20:38:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":4,"rb":5,"run_id":"20260516_203802_756a296e"}
2026-05-16T20:38:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_203802_756a296e"}
2026-05-16T20:38:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.301,"duration_milliseconds":301,"important":true,"run_id":"20260516_203802_756a296e"}
2026-05-16T20:38:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_203802_756a296e"}
2026-05-16T20:38:04+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_203802_756a296e"}
2026-05-16T20:38:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":173888,"run_id":"20260516_203802_756a296e"}
2026-05-16T20:38:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.043,"exec_milliseconds":2043,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":173888,"important":true,"run_id":"20260516_203802_756a296e"}
2026-05-16T20:39:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_203901_2ec7d897"}
2026-05-16T20:39:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_203901_2ec7d897"}
2026-05-16T20:39:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_203901_2ec7d897"}
2026-05-16T20:39:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_203901_2ec7d897"}
2026-05-16T20:39:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_203901_2ec7d897"}
2026-05-16T20:39:02+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_203901_2ec7d897"}
2026-05-16T20:39:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_203901_2ec7d897"}
2026-05-16T20:39:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_203901_2ec7d897"}
2026-05-16T20:39:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4146,"mtime":"2026-05-16T20:38:01+02:00","run_id":"20260516_203901_2ec7d897"}
2026-05-16T20:39:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":5586,"run_id":"20260516_203901_2ec7d897"}
2026-05-16T20:39:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":14921,"mtime":"2026-05-16T20:38:01+02:00","run_id":"20260516_203901_2ec7d897"}
2026-05-16T20:39:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":77,"rb":68,"run_id":"20260516_203901_2ec7d897"}
2026-05-16T20:39:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_203901_2ec7d897"}
2026-05-16T20:39:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.935,"duration_milliseconds":935,"important":true,"run_id":"20260516_203901_2ec7d897"}
2026-05-16T20:39:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_203901_2ec7d897"}
2026-05-16T20:39:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_203901_2ec7d897"}
2026-05-16T20:39:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4285,"mtime":"2026-05-16T20:39:01+02:00","run_id":"20260516_203901_2ec7d897"}
2026-05-16T20:39:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_203901_2ec7d897"}
2026-05-16T20:39:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":5288,"mtime":"2026-05-16T20:39:00+02:00","run_id":"20260516_203901_2ec7d897"}
2026-05-16T20:39:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":6,"rb":5,"run_id":"20260516_203901_2ec7d897"}
2026-05-16T20:39:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_203901_2ec7d897"}
2026-05-16T20:39:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.298,"duration_milliseconds":298,"important":true,"run_id":"20260516_203901_2ec7d897"}
2026-05-16T20:39:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_203901_2ec7d897"}
2026-05-16T20:39:03+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_203901_2ec7d897"}
2026-05-16T20:39:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":175010,"run_id":"20260516_203901_2ec7d897"}
2026-05-16T20:39:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.053,"exec_milliseconds":2053,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":175010,"important":true,"run_id":"20260516_203901_2ec7d897"}
2026-05-16T20:40:07+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_204007_6a4f1d1d"}
2026-05-16T20:40:07+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_204007_6a4f1d1d"}
2026-05-16T20:40:07+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_204007_6a4f1d1d"}
2026-05-16T20:40:07+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_204007_6a4f1d1d"}
2026-05-16T20:40:07+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_204007_6a4f1d1d"}
2026-05-16T20:40:07+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_204007_6a4f1d1d"}
2026-05-16T20:40:07+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_204007_6a4f1d1d"}
2026-05-16T20:40:08+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_204007_6a4f1d1d"}
2026-05-16T20:40:08+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4146,"mtime":"2026-05-16T20:38:01+02:00","run_id":"20260516_204007_6a4f1d1d"}
2026-05-16T20:40:08+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":5586,"run_id":"20260516_204007_6a4f1d1d"}
2026-05-16T20:40:08+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":14921,"mtime":"2026-05-16T20:38:01+02:00","run_id":"20260516_204007_6a4f1d1d"}
2026-05-16T20:40:08+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":77,"rb":68,"run_id":"20260516_204007_6a4f1d1d"}
2026-05-16T20:40:08+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_204007_6a4f1d1d"}
2026-05-16T20:40:08+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.945,"duration_milliseconds":945,"important":true,"run_id":"20260516_204007_6a4f1d1d"}
2026-05-16T20:40:08+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_204007_6a4f1d1d"}
2026-05-16T20:40:08+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_204007_6a4f1d1d"}
2026-05-16T20:40:08+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4285,"mtime":"2026-05-16T20:39:46+02:00","run_id":"20260516_204007_6a4f1d1d"}
2026-05-16T20:40:08+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_204007_6a4f1d1d"}
2026-05-16T20:40:08+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":5676,"mtime":"2026-05-16T20:39:46+02:00","run_id":"20260516_204007_6a4f1d1d"}
2026-05-16T20:40:08+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":9,"rb":8,"run_id":"20260516_204007_6a4f1d1d"}
2026-05-16T20:40:08+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_204007_6a4f1d1d"}
2026-05-16T20:40:08+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.316,"duration_milliseconds":316,"important":true,"run_id":"20260516_204007_6a4f1d1d"}
2026-05-16T20:40:08+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_204007_6a4f1d1d"}
2026-05-16T20:40:09+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_204007_6a4f1d1d"}
2026-05-16T20:40:09+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":176714,"run_id":"20260516_204007_6a4f1d1d"}
2026-05-16T20:40:09+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.047,"exec_milliseconds":2047,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":176714,"important":true,"run_id":"20260516_204007_6a4f1d1d"}
2026-05-16T20:41:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_204101_5b2ff183"}
2026-05-16T20:41:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_204101_5b2ff183"}
2026-05-16T20:41:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_204101_5b2ff183"}
2026-05-16T20:41:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_204101_5b2ff183"}
2026-05-16T20:41:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_204101_5b2ff183"}
2026-05-16T20:41:02+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_204101_5b2ff183"}
2026-05-16T20:41:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_204101_5b2ff183"}
2026-05-16T20:41:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_204101_5b2ff183"}
2026-05-16T20:41:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4146,"mtime":"2026-05-16T20:40:36+02:00","run_id":"20260516_204101_5b2ff183"}
2026-05-16T20:41:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":5586,"run_id":"20260516_204101_5b2ff183"}
2026-05-16T20:41:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":15405,"mtime":"2026-05-16T20:40:36+02:00","run_id":"20260516_204101_5b2ff183"}
2026-05-16T20:41:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":77,"rb":70,"run_id":"20260516_204101_5b2ff183"}
2026-05-16T20:41:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_204101_5b2ff183"}
2026-05-16T20:41:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.93,"duration_milliseconds":930,"important":true,"run_id":"20260516_204101_5b2ff183"}
2026-05-16T20:41:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_204101_5b2ff183"}
2026-05-16T20:41:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_204101_5b2ff183"}
2026-05-16T20:41:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4285,"mtime":"2026-05-16T20:40:45+02:00","run_id":"20260516_204101_5b2ff183"}
2026-05-16T20:41:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_204101_5b2ff183"}
2026-05-16T20:41:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":6128,"mtime":"2026-05-16T20:40:43+02:00","run_id":"20260516_204101_5b2ff183"}
2026-05-16T20:41:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":9,"rb":8,"run_id":"20260516_204101_5b2ff183"}
2026-05-16T20:41:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_204101_5b2ff183"}
2026-05-16T20:41:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.273,"duration_milliseconds":273,"important":true,"run_id":"20260516_204101_5b2ff183"}
2026-05-16T20:41:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_204101_5b2ff183"}
2026-05-16T20:41:03+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_204101_5b2ff183"}
2026-05-16T20:41:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":180648,"run_id":"20260516_204101_5b2ff183"}
2026-05-16T20:41:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.955,"exec_milliseconds":1955,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":180648,"important":true,"run_id":"20260516_204101_5b2ff183"}
2026-05-16T20:42:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_204202_bd9935d8"}
2026-05-16T20:42:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_204202_bd9935d8"}
2026-05-16T20:42:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_204202_bd9935d8"}
2026-05-16T20:42:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_204202_bd9935d8"}
2026-05-16T20:42:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_204202_bd9935d8"}
2026-05-16T20:42:03+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_204202_bd9935d8"}
2026-05-16T20:42:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_204202_bd9935d8"}
2026-05-16T20:42:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_204202_bd9935d8"}
2026-05-16T20:42:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4146,"mtime":"2026-05-16T20:40:36+02:00","run_id":"20260516_204202_bd9935d8"}
2026-05-16T20:42:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":5586,"run_id":"20260516_204202_bd9935d8"}
2026-05-16T20:42:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":15405,"mtime":"2026-05-16T20:40:36+02:00","run_id":"20260516_204202_bd9935d8"}
2026-05-16T20:42:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":77,"rb":70,"run_id":"20260516_204202_bd9935d8"}
2026-05-16T20:42:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_204202_bd9935d8"}
2026-05-16T20:42:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.964,"duration_milliseconds":964,"important":true,"run_id":"20260516_204202_bd9935d8"}
2026-05-16T20:42:04+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_204202_bd9935d8"}
2026-05-16T20:42:04+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_204202_bd9935d8"}
2026-05-16T20:42:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4285,"mtime":"2026-05-16T20:41:55+02:00","run_id":"20260516_204202_bd9935d8"}
2026-05-16T20:42:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_204202_bd9935d8"}
2026-05-16T20:42:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":6597,"mtime":"2026-05-16T20:41:54+02:00","run_id":"20260516_204202_bd9935d8"}
2026-05-16T20:42:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":12,"rb":10,"run_id":"20260516_204202_bd9935d8"}
2026-05-16T20:42:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_204202_bd9935d8"}
2026-05-16T20:42:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.315,"duration_milliseconds":315,"important":true,"run_id":"20260516_204202_bd9935d8"}
2026-05-16T20:42:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_204202_bd9935d8"}
2026-05-16T20:42:04+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_204202_bd9935d8"}
2026-05-16T20:42:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":182591,"run_id":"20260516_204202_bd9935d8"}
2026-05-16T20:42:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.039,"exec_milliseconds":2039,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":182591,"important":true,"run_id":"20260516_204202_bd9935d8"}
2026-05-16T20:43:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_204301_50c7af6c"}
2026-05-16T20:43:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_204301_50c7af6c"}
2026-05-16T20:43:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_204301_50c7af6c"}
2026-05-16T20:43:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_204301_50c7af6c"}
2026-05-16T20:43:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_204301_50c7af6c"}
2026-05-16T20:43:02+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_204301_50c7af6c"}
2026-05-16T20:43:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_204301_50c7af6c"}
2026-05-16T20:43:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_204301_50c7af6c"}
2026-05-16T20:43:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4146,"mtime":"2026-05-16T20:42:46+02:00","run_id":"20260516_204301_50c7af6c"}
2026-05-16T20:43:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":5586,"run_id":"20260516_204301_50c7af6c"}
2026-05-16T20:43:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":15743,"mtime":"2026-05-16T20:42:46+02:00","run_id":"20260516_204301_50c7af6c"}
2026-05-16T20:43:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":77,"rb":72,"run_id":"20260516_204301_50c7af6c"}
2026-05-16T20:43:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_204301_50c7af6c"}
2026-05-16T20:43:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.931,"duration_milliseconds":931,"important":true,"run_id":"20260516_204301_50c7af6c"}
2026-05-16T20:43:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_204301_50c7af6c"}
2026-05-16T20:43:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_204301_50c7af6c"}
2026-05-16T20:43:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4285,"mtime":"2026-05-16T20:42:58+02:00","run_id":"20260516_204301_50c7af6c"}
2026-05-16T20:43:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_204301_50c7af6c"}
2026-05-16T20:43:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":7143,"mtime":"2026-05-16T20:42:57+02:00","run_id":"20260516_204301_50c7af6c"}
2026-05-16T20:43:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":14,"rb":12,"run_id":"20260516_204301_50c7af6c"}
2026-05-16T20:43:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_204301_50c7af6c"}
2026-05-16T20:43:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.288,"duration_milliseconds":288,"important":true,"run_id":"20260516_204301_50c7af6c"}
2026-05-16T20:43:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_204301_50c7af6c"}
2026-05-16T20:43:04+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_204301_50c7af6c"}
2026-05-16T20:43:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":186305,"run_id":"20260516_204301_50c7af6c"}
2026-05-16T20:43:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.05,"exec_milliseconds":2050,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":186305,"important":true,"run_id":"20260516_204301_50c7af6c"}
2026-05-16T20:44:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_204402_f61fdb89"}
2026-05-16T20:44:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_204402_f61fdb89"}
2026-05-16T20:44:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_204402_f61fdb89"}
2026-05-16T20:44:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_204402_f61fdb89"}
2026-05-16T20:44:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_204402_f61fdb89"}
2026-05-16T20:44:03+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_204402_f61fdb89"}
2026-05-16T20:44:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_204402_f61fdb89"}
2026-05-16T20:44:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_204402_f61fdb89"}
2026-05-16T20:44:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4146,"mtime":"2026-05-16T20:42:46+02:00","run_id":"20260516_204402_f61fdb89"}
2026-05-16T20:44:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":5586,"run_id":"20260516_204402_f61fdb89"}
2026-05-16T20:44:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":15743,"mtime":"2026-05-16T20:42:46+02:00","run_id":"20260516_204402_f61fdb89"}
2026-05-16T20:44:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":77,"rb":72,"run_id":"20260516_204402_f61fdb89"}
2026-05-16T20:44:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_204402_f61fdb89"}
2026-05-16T20:44:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.965,"duration_milliseconds":965,"important":true,"run_id":"20260516_204402_f61fdb89"}
2026-05-16T20:44:04+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_204402_f61fdb89"}
2026-05-16T20:44:04+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_204402_f61fdb89"}
2026-05-16T20:44:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4285,"mtime":"2026-05-16T20:44:00+02:00","run_id":"20260516_204402_f61fdb89"}
2026-05-16T20:44:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_204402_f61fdb89"}
2026-05-16T20:44:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":7789,"mtime":"2026-05-16T20:44:00+02:00","run_id":"20260516_204402_f61fdb89"}
2026-05-16T20:44:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":16,"rb":12,"run_id":"20260516_204402_f61fdb89"}
2026-05-16T20:44:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_204402_f61fdb89"}
2026-05-16T20:44:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.308,"duration_milliseconds":308,"important":true,"run_id":"20260516_204402_f61fdb89"}
2026-05-16T20:44:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_204402_f61fdb89"}
2026-05-16T20:44:04+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_204402_f61fdb89"}
2026-05-16T20:44:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":189065,"run_id":"20260516_204402_f61fdb89"}
2026-05-16T20:44:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.074,"exec_milliseconds":2074,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":189065,"important":true,"run_id":"20260516_204402_f61fdb89"}
2026-05-16T20:45:06+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_204506_1a94058b"}
2026-05-16T20:45:07+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_204506_1a94058b"}
2026-05-16T20:45:07+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_204506_1a94058b"}
2026-05-16T20:45:07+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_204506_1a94058b"}
2026-05-16T20:45:07+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_204506_1a94058b"}
2026-05-16T20:45:07+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_204506_1a94058b"}
2026-05-16T20:45:07+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_204506_1a94058b"}
2026-05-16T20:45:08+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_204506_1a94058b"}
2026-05-16T20:45:08+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4146,"mtime":"2026-05-16T20:45:02+02:00","run_id":"20260516_204506_1a94058b"}
2026-05-16T20:45:08+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":5586,"run_id":"20260516_204506_1a94058b"}
2026-05-16T20:45:08+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":16120,"mtime":"2026-05-16T20:45:01+02:00","run_id":"20260516_204506_1a94058b"}
2026-05-16T20:45:08+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":77,"rb":72,"run_id":"20260516_204506_1a94058b"}
2026-05-16T20:45:08+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_204506_1a94058b"}
2026-05-16T20:45:08+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.96,"duration_milliseconds":960,"important":true,"run_id":"20260516_204506_1a94058b"}
2026-05-16T20:45:08+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_204506_1a94058b"}
2026-05-16T20:45:08+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_204506_1a94058b"}
2026-05-16T20:45:08+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4285,"mtime":"2026-05-16T20:44:50+02:00","run_id":"20260516_204506_1a94058b"}
2026-05-16T20:45:08+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_204506_1a94058b"}
2026-05-16T20:45:08+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":8327,"mtime":"2026-05-16T20:44:49+02:00","run_id":"20260516_204506_1a94058b"}
2026-05-16T20:46:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_204602_d55dadb7"}
2026-05-16T20:46:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_204602_d55dadb7"}
2026-05-16T20:46:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_204602_d55dadb7"}
2026-05-16T20:46:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_204602_d55dadb7"}
2026-05-16T20:46:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_204602_d55dadb7"}
2026-05-16T20:46:03+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_204602_d55dadb7"}
2026-05-16T20:46:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_204602_d55dadb7"}
2026-05-16T20:46:04+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_204602_d55dadb7"}
2026-05-16T20:46:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4146,"mtime":"2026-05-16T20:45:58+02:00","run_id":"20260516_204602_d55dadb7"}
2026-05-16T20:46:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":5586,"run_id":"20260516_204602_d55dadb7"}
2026-05-16T20:46:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":16520,"mtime":"2026-05-16T20:45:57+02:00","run_id":"20260516_204602_d55dadb7"}
2026-05-16T20:46:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":78,"rb":72,"run_id":"20260516_204602_d55dadb7"}
2026-05-16T20:46:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_204602_d55dadb7"}
2026-05-16T20:46:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.959,"duration_milliseconds":959,"important":true,"run_id":"20260516_204602_d55dadb7"}
2026-05-16T20:46:04+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_204602_d55dadb7"}
2026-05-16T20:46:04+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_204602_d55dadb7"}
2026-05-16T20:46:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4285,"mtime":"2026-05-16T20:45:47+02:00","run_id":"20260516_204602_d55dadb7"}
2026-05-16T20:46:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_204602_d55dadb7"}
2026-05-16T20:46:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":8785,"mtime":"2026-05-16T20:45:46+02:00","run_id":"20260516_204602_d55dadb7"}
2026-05-16T20:46:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":16,"rb":12,"run_id":"20260516_204602_d55dadb7"}
2026-05-16T20:46:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_204602_d55dadb7"}
2026-05-16T20:46:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.303,"duration_milliseconds":303,"important":true,"run_id":"20260516_204602_d55dadb7"}
2026-05-16T20:46:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_204602_d55dadb7"}
2026-05-16T20:46:04+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_204602_d55dadb7"}
2026-05-16T20:46:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":196702,"run_id":"20260516_204602_d55dadb7"}
2026-05-16T20:46:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.06,"exec_milliseconds":2060,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":196702,"important":true,"run_id":"20260516_204602_d55dadb7"}
2026-05-16T20:47:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_204701_1a09d928"}
2026-05-16T20:47:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_204701_1a09d928"}
2026-05-16T20:47:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_204701_1a09d928"}
2026-05-16T20:47:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_204701_1a09d928"}
2026-05-16T20:47:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_204701_1a09d928"}
2026-05-16T20:47:02+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_204701_1a09d928"}
2026-05-16T20:47:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_204701_1a09d928"}
2026-05-16T20:47:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_204701_1a09d928"}
2026-05-16T20:47:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4146,"mtime":"2026-05-16T20:46:58+02:00","run_id":"20260516_204701_1a09d928"}
2026-05-16T20:47:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":5586,"run_id":"20260516_204701_1a09d928"}
2026-05-16T20:47:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":17069,"mtime":"2026-05-16T20:46:58+02:00","run_id":"20260516_204701_1a09d928"}
2026-05-16T20:47:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":79,"rb":72,"run_id":"20260516_204701_1a09d928"}
2026-05-16T20:47:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_204701_1a09d928"}
2026-05-16T20:47:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.985,"duration_milliseconds":985,"important":true,"run_id":"20260516_204701_1a09d928"}
2026-05-16T20:47:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_204701_1a09d928"}
2026-05-16T20:47:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_204701_1a09d928"}
2026-05-16T20:47:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4285,"mtime":"2026-05-16T20:46:51+02:00","run_id":"20260516_204701_1a09d928"}
2026-05-16T20:47:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_204701_1a09d928"}
2026-05-16T20:47:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":9471,"mtime":"2026-05-16T20:46:51+02:00","run_id":"20260516_204701_1a09d928"}
2026-05-16T20:47:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":16,"rb":12,"run_id":"20260516_204701_1a09d928"}
2026-05-16T20:47:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_204701_1a09d928"}
2026-05-16T20:47:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.286,"duration_milliseconds":286,"important":true,"run_id":"20260516_204701_1a09d928"}
2026-05-16T20:47:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_204701_1a09d928"}
2026-05-16T20:47:03+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_204701_1a09d928"}
2026-05-16T20:47:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":202031,"run_id":"20260516_204701_1a09d928"}
2026-05-16T20:47:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.054,"exec_milliseconds":2054,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":202031,"important":true,"run_id":"20260516_204701_1a09d928"}
2026-05-16T20:48:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_204802_50fc635d"}
2026-05-16T20:48:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_204802_50fc635d"}
2026-05-16T20:48:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_204802_50fc635d"}
2026-05-16T20:48:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_204802_50fc635d"}
2026-05-16T20:48:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_204802_50fc635d"}
2026-05-16T20:48:03+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_204802_50fc635d"}
2026-05-16T20:48:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_204802_50fc635d"}
2026-05-16T20:48:04+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_204802_50fc635d"}
2026-05-16T20:48:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4146,"mtime":"2026-05-16T20:47:38+02:00","run_id":"20260516_204802_50fc635d"}
2026-05-16T20:48:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":5586,"run_id":"20260516_204802_50fc635d"}
2026-05-16T20:48:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":17289,"mtime":"2026-05-16T20:47:38+02:00","run_id":"20260516_204802_50fc635d"}
2026-05-16T20:48:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":80,"rb":74,"run_id":"20260516_204802_50fc635d"}
2026-05-16T20:48:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_204802_50fc635d"}
2026-05-16T20:48:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.947,"duration_milliseconds":947,"important":true,"run_id":"20260516_204802_50fc635d"}
2026-05-16T20:48:04+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_204802_50fc635d"}
2026-05-16T20:48:04+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_204802_50fc635d"}
2026-05-16T20:48:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4285,"mtime":"2026-05-16T20:46:51+02:00","run_id":"20260516_204802_50fc635d"}
2026-05-16T20:48:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_204802_50fc635d"}
2026-05-16T20:48:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":9471,"mtime":"2026-05-16T20:46:51+02:00","run_id":"20260516_204802_50fc635d"}
2026-05-16T20:48:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":16,"rb":12,"run_id":"20260516_204802_50fc635d"}
2026-05-16T20:48:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_204802_50fc635d"}
2026-05-16T20:48:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.289,"duration_milliseconds":289,"important":true,"run_id":"20260516_204802_50fc635d"}
2026-05-16T20:48:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_204802_50fc635d"}
2026-05-16T20:48:04+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_204802_50fc635d"}
2026-05-16T20:48:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":202943,"run_id":"20260516_204802_50fc635d"}
2026-05-16T20:48:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.997,"exec_milliseconds":1997,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":202943,"important":true,"run_id":"20260516_204802_50fc635d"}
2026-05-16T20:49:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_204901_06b349c8"}
2026-05-16T20:49:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_204901_06b349c8"}
2026-05-16T20:49:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_204901_06b349c8"}
2026-05-16T20:49:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_204901_06b349c8"}
2026-05-16T20:49:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_204901_06b349c8"}
2026-05-16T20:49:02+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_204901_06b349c8"}
2026-05-16T20:49:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_204901_06b349c8"}
2026-05-16T20:49:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_204901_06b349c8"}
2026-05-16T20:49:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4146,"mtime":"2026-05-16T20:48:59+02:00","run_id":"20260516_204901_06b349c8"}
2026-05-16T20:49:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":5586,"run_id":"20260516_204901_06b349c8"}
2026-05-16T20:49:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":17352,"mtime":"2026-05-16T20:48:58+02:00","run_id":"20260516_204901_06b349c8"}
2026-05-16T20:49:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":80,"rb":74,"run_id":"20260516_204901_06b349c8"}
2026-05-16T20:49:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_204901_06b349c8"}
2026-05-16T20:49:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.94,"duration_milliseconds":940,"important":true,"run_id":"20260516_204901_06b349c8"}
2026-05-16T20:49:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_204901_06b349c8"}
2026-05-16T20:49:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_204901_06b349c8"}
2026-05-16T20:49:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4285,"mtime":"2026-05-16T20:48:56+02:00","run_id":"20260516_204901_06b349c8"}
2026-05-16T20:49:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_204901_06b349c8"}
2026-05-16T20:49:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":9587,"mtime":"2026-05-16T20:48:55+02:00","run_id":"20260516_204901_06b349c8"}
2026-05-16T20:49:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":18,"rb":12,"run_id":"20260516_204901_06b349c8"}
2026-05-16T20:49:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_204901_06b349c8"}
2026-05-16T20:49:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.299,"duration_milliseconds":299,"important":true,"run_id":"20260516_204901_06b349c8"}
2026-05-16T20:49:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_204901_06b349c8"}
2026-05-16T20:49:03+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_204901_06b349c8"}
2026-05-16T20:49:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":203710,"run_id":"20260516_204901_06b349c8"}
2026-05-16T20:49:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.043,"exec_milliseconds":2043,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":203710,"important":true,"run_id":"20260516_204901_06b349c8"}
2026-05-16T20:50:07+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_205006_c81fb28f"}
2026-05-16T20:50:07+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_205006_c81fb28f"}
2026-05-16T20:50:07+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_205006_c81fb28f"}
2026-05-16T20:50:07+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_205006_c81fb28f"}
2026-05-16T20:50:07+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_205006_c81fb28f"}
2026-05-16T20:50:07+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_205006_c81fb28f"}
2026-05-16T20:50:07+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_205006_c81fb28f"}
2026-05-16T20:50:08+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_205006_c81fb28f"}
2026-05-16T20:50:08+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4146,"mtime":"2026-05-16T20:48:59+02:00","run_id":"20260516_205006_c81fb28f"}
2026-05-16T20:50:08+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":5586,"run_id":"20260516_205006_c81fb28f"}
2026-05-16T20:50:08+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":17352,"mtime":"2026-05-16T20:48:58+02:00","run_id":"20260516_205006_c81fb28f"}
2026-05-16T20:50:08+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":80,"rb":74,"run_id":"20260516_205006_c81fb28f"}
2026-05-16T20:50:08+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_205006_c81fb28f"}
2026-05-16T20:50:08+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.961,"duration_milliseconds":961,"important":true,"run_id":"20260516_205006_c81fb28f"}
2026-05-16T20:50:08+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_205006_c81fb28f"}
2026-05-16T20:50:08+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_205006_c81fb28f"}
2026-05-16T20:50:08+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4285,"mtime":"2026-05-16T20:50:07+02:00","run_id":"20260516_205006_c81fb28f"}
2026-05-16T20:50:08+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_205006_c81fb28f"}
2026-05-16T20:50:08+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":9997,"mtime":"2026-05-16T20:50:07+02:00","run_id":"20260516_205006_c81fb28f"}
2026-05-16T20:50:08+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":22,"rb":12,"run_id":"20260516_205006_c81fb28f"}
2026-05-16T20:50:08+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_205006_c81fb28f"}
2026-05-16T20:50:08+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.305,"duration_milliseconds":305,"important":true,"run_id":"20260516_205006_c81fb28f"}
2026-05-16T20:50:08+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_205006_c81fb28f"}
2026-05-16T20:50:09+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_205006_c81fb28f"}
2026-05-16T20:50:09+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":205368,"run_id":"20260516_205006_c81fb28f"}
2026-05-16T20:50:09+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.104,"exec_milliseconds":2104,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":205368,"important":true,"run_id":"20260516_205006_c81fb28f"}
2026-05-16T20:51:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_205101_a620d0af"}
2026-05-16T20:51:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_205101_a620d0af"}
2026-05-16T20:51:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_205101_a620d0af"}
2026-05-16T20:51:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_205101_a620d0af"}
2026-05-16T20:51:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_205101_a620d0af"}
2026-05-16T20:51:02+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_205101_a620d0af"}
2026-05-16T20:51:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_205101_a620d0af"}
2026-05-16T20:51:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_205101_a620d0af"}
2026-05-16T20:51:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4146,"mtime":"2026-05-16T20:48:59+02:00","run_id":"20260516_205101_a620d0af"}
2026-05-16T20:51:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":5586,"run_id":"20260516_205101_a620d0af"}
2026-05-16T20:51:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":17352,"mtime":"2026-05-16T20:48:58+02:00","run_id":"20260516_205101_a620d0af"}
2026-05-16T20:51:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":80,"rb":74,"run_id":"20260516_205101_a620d0af"}
2026-05-16T20:51:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_205101_a620d0af"}
2026-05-16T20:51:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.962,"duration_milliseconds":962,"important":true,"run_id":"20260516_205101_a620d0af"}
2026-05-16T20:51:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_205101_a620d0af"}
2026-05-16T20:51:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_205101_a620d0af"}
2026-05-16T20:51:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4286,"mtime":"2026-05-16T20:50:32+02:00","run_id":"20260516_205101_a620d0af"}
2026-05-16T20:51:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_205101_a620d0af"}
2026-05-16T20:51:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":10070,"mtime":"2026-05-16T20:50:32+02:00","run_id":"20260516_205101_a620d0af"}
2026-05-16T20:51:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":22,"rb":12,"run_id":"20260516_205101_a620d0af"}
2026-05-16T20:51:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_205101_a620d0af"}
2026-05-16T20:51:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.322,"duration_milliseconds":322,"important":true,"run_id":"20260516_205101_a620d0af"}
2026-05-16T20:51:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_205101_a620d0af"}
2026-05-16T20:51:03+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_205101_a620d0af"}
2026-05-16T20:51:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":205688,"run_id":"20260516_205101_a620d0af"}
2026-05-16T20:51:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.068,"exec_milliseconds":2068,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":205688,"important":true,"run_id":"20260516_205101_a620d0af"}
2026-05-16T20:52:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_205202_2bac4083"}
2026-05-16T20:52:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_205202_2bac4083"}
2026-05-16T20:52:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_205202_2bac4083"}
2026-05-16T20:52:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_205202_2bac4083"}
2026-05-16T20:52:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_205202_2bac4083"}
2026-05-16T20:52:03+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_205202_2bac4083"}
2026-05-16T20:52:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_205202_2bac4083"}
2026-05-16T20:52:04+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_205202_2bac4083"}
2026-05-16T20:52:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4146,"mtime":"2026-05-16T20:51:37+02:00","run_id":"20260516_205202_2bac4083"}
2026-05-16T20:52:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":5586,"run_id":"20260516_205202_2bac4083"}
2026-05-16T20:52:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":17352,"mtime":"2026-05-16T20:51:36+02:00","run_id":"20260516_205202_2bac4083"}
2026-05-16T20:52:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":80,"rb":74,"run_id":"20260516_205202_2bac4083"}
2026-05-16T20:52:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_205202_2bac4083"}
2026-05-16T20:52:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.967,"duration_milliseconds":967,"important":true,"run_id":"20260516_205202_2bac4083"}
2026-05-16T20:52:04+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_205202_2bac4083"}
2026-05-16T20:52:04+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_205202_2bac4083"}
2026-05-16T20:52:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4286,"mtime":"2026-05-16T20:51:37+02:00","run_id":"20260516_205202_2bac4083"}
2026-05-16T20:52:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_205202_2bac4083"}
2026-05-16T20:52:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":10220,"mtime":"2026-05-16T20:51:37+02:00","run_id":"20260516_205202_2bac4083"}
2026-05-16T20:52:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":22,"rb":12,"run_id":"20260516_205202_2bac4083"}
2026-05-16T20:52:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_205202_2bac4083"}
2026-05-16T20:52:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.312,"duration_milliseconds":312,"important":true,"run_id":"20260516_205202_2bac4083"}
2026-05-16T20:52:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_205202_2bac4083"}
2026-05-16T20:52:04+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_205202_2bac4083"}
2026-05-16T20:52:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":206338,"run_id":"20260516_205202_2bac4083"}
2026-05-16T20:52:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.026,"exec_milliseconds":2026,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":206338,"important":true,"run_id":"20260516_205202_2bac4083"}
2026-05-16T20:53:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_205301_3b429ae6"}
2026-05-16T20:53:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_205301_3b429ae6"}
2026-05-16T20:53:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_205301_3b429ae6"}
2026-05-16T20:53:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_205301_3b429ae6"}
2026-05-16T20:53:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_205301_3b429ae6"}
2026-05-16T20:53:02+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_205301_3b429ae6"}
2026-05-16T20:53:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_205301_3b429ae6"}
2026-05-16T20:53:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_205301_3b429ae6"}
2026-05-16T20:53:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4146,"mtime":"2026-05-16T20:51:37+02:00","run_id":"20260516_205301_3b429ae6"}
2026-05-16T20:53:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":5586,"run_id":"20260516_205301_3b429ae6"}
2026-05-16T20:53:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":17352,"mtime":"2026-05-16T20:51:36+02:00","run_id":"20260516_205301_3b429ae6"}
2026-05-16T20:53:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":80,"rb":74,"run_id":"20260516_205301_3b429ae6"}
2026-05-16T20:53:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_205301_3b429ae6"}
2026-05-16T20:53:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.945,"duration_milliseconds":945,"important":true,"run_id":"20260516_205301_3b429ae6"}
2026-05-16T20:53:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_205301_3b429ae6"}
2026-05-16T20:53:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_205301_3b429ae6"}
2026-05-16T20:53:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4286,"mtime":"2026-05-16T20:52:51+02:00","run_id":"20260516_205301_3b429ae6"}
2026-05-16T20:53:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_205301_3b429ae6"}
2026-05-16T20:53:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":10551,"mtime":"2026-05-16T20:52:51+02:00","run_id":"20260516_205301_3b429ae6"}
2026-05-16T20:53:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":22,"rb":14,"run_id":"20260516_205301_3b429ae6"}
2026-05-16T20:53:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_205301_3b429ae6"}
2026-05-16T20:53:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.302,"duration_milliseconds":302,"important":true,"run_id":"20260516_205301_3b429ae6"}
2026-05-16T20:53:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_205301_3b429ae6"}
2026-05-16T20:53:03+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_205301_3b429ae6"}
2026-05-16T20:53:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":207759,"run_id":"20260516_205301_3b429ae6"}
2026-05-16T20:53:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.007,"exec_milliseconds":2007,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":207759,"important":true,"run_id":"20260516_205301_3b429ae6"}
2026-05-16T20:54:03+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_205402_4b5d4e3a"}
2026-05-16T20:54:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_205402_4b5d4e3a"}
2026-05-16T20:54:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_205402_4b5d4e3a"}
2026-05-16T20:54:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_205402_4b5d4e3a"}
2026-05-16T20:54:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_205402_4b5d4e3a"}
2026-05-16T20:54:03+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_205402_4b5d4e3a"}
2026-05-16T20:54:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_205402_4b5d4e3a"}
2026-05-16T20:54:04+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_205402_4b5d4e3a"}
2026-05-16T20:54:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4146,"mtime":"2026-05-16T20:53:32+02:00","run_id":"20260516_205402_4b5d4e3a"}
2026-05-16T20:54:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":5586,"run_id":"20260516_205402_4b5d4e3a"}
2026-05-16T20:54:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":17352,"mtime":"2026-05-16T20:53:32+02:00","run_id":"20260516_205402_4b5d4e3a"}
2026-05-16T20:54:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":80,"rb":74,"run_id":"20260516_205402_4b5d4e3a"}
2026-05-16T20:54:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_205402_4b5d4e3a"}
2026-05-16T20:54:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.97,"duration_milliseconds":970,"important":true,"run_id":"20260516_205402_4b5d4e3a"}
2026-05-16T20:54:04+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_205402_4b5d4e3a"}
2026-05-16T20:54:04+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_205402_4b5d4e3a"}
2026-05-16T20:54:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4286,"mtime":"2026-05-16T20:53:44+02:00","run_id":"20260516_205402_4b5d4e3a"}
2026-05-16T20:54:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_205402_4b5d4e3a"}
2026-05-16T20:54:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":11007,"mtime":"2026-05-16T20:53:44+02:00","run_id":"20260516_205402_4b5d4e3a"}
2026-05-16T20:54:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":22,"rb":14,"run_id":"20260516_205402_4b5d4e3a"}
2026-05-16T20:54:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_205402_4b5d4e3a"}
2026-05-16T20:54:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.31,"duration_milliseconds":310,"important":true,"run_id":"20260516_205402_4b5d4e3a"}
2026-05-16T20:54:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_205402_4b5d4e3a"}
2026-05-16T20:54:05+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_205402_4b5d4e3a"}
2026-05-16T20:54:05+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":209723,"run_id":"20260516_205402_4b5d4e3a"}
2026-05-16T20:54:05+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.09,"exec_milliseconds":2090,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":209723,"important":true,"run_id":"20260516_205402_4b5d4e3a"}
2026-05-16T20:55:04+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_205504_d5439d2e"}
2026-05-16T20:55:04+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_205504_d5439d2e"}
2026-05-16T20:55:04+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_205504_d5439d2e"}
2026-05-16T20:55:04+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_205504_d5439d2e"}
2026-05-16T20:55:04+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_205504_d5439d2e"}
2026-05-16T20:55:04+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_205504_d5439d2e"}
2026-05-16T20:55:04+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_205504_d5439d2e"}
2026-05-16T20:55:05+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_205504_d5439d2e"}
2026-05-16T20:55:05+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4146,"mtime":"2026-05-16T20:54:20+02:00","run_id":"20260516_205504_d5439d2e"}
2026-05-16T20:55:05+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":5586,"run_id":"20260516_205504_d5439d2e"}
2026-05-16T20:55:05+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":17352,"mtime":"2026-05-16T20:54:20+02:00","run_id":"20260516_205504_d5439d2e"}
2026-05-16T20:55:05+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":80,"rb":74,"run_id":"20260516_205504_d5439d2e"}
2026-05-16T20:55:05+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_205504_d5439d2e"}
2026-05-16T20:55:05+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.97,"duration_milliseconds":970,"important":true,"run_id":"20260516_205504_d5439d2e"}
2026-05-16T20:55:05+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_205504_d5439d2e"}
2026-05-16T20:55:05+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_205504_d5439d2e"}
2026-05-16T20:55:05+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4286,"mtime":"2026-05-16T20:54:47+02:00","run_id":"20260516_205504_d5439d2e"}
2026-05-16T20:55:06+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_205504_d5439d2e"}
2026-05-16T20:55:06+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":11340,"mtime":"2026-05-16T20:54:47+02:00","run_id":"20260516_205504_d5439d2e"}
2026-05-16T20:55:06+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":23,"rb":14,"run_id":"20260516_205504_d5439d2e"}
2026-05-16T20:55:06+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_205504_d5439d2e"}
2026-05-16T20:55:06+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.302,"duration_milliseconds":302,"important":true,"run_id":"20260516_205504_d5439d2e"}
2026-05-16T20:55:06+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_205504_d5439d2e"}
2026-05-16T20:55:06+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_205504_d5439d2e"}
2026-05-16T20:55:06+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":211150,"run_id":"20260516_205504_d5439d2e"}
2026-05-16T20:55:06+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.056,"exec_milliseconds":2056,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":211150,"important":true,"run_id":"20260516_205504_d5439d2e"}
2026-05-16T20:56:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_205602_1727f59b"}
2026-05-16T20:56:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_205602_1727f59b"}
2026-05-16T20:56:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_205602_1727f59b"}
2026-05-16T20:56:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_205602_1727f59b"}
2026-05-16T20:56:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_205602_1727f59b"}
2026-05-16T20:56:03+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_205602_1727f59b"}
2026-05-16T20:56:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_205602_1727f59b"}
2026-05-16T20:56:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_205602_1727f59b"}
2026-05-16T20:56:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4146,"mtime":"2026-05-16T20:54:20+02:00","run_id":"20260516_205602_1727f59b"}
2026-05-16T20:56:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":5586,"run_id":"20260516_205602_1727f59b"}
2026-05-16T20:56:04+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":17352,"mtime":"2026-05-16T20:54:20+02:00","run_id":"20260516_205602_1727f59b"}
2026-05-16T20:56:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":80,"rb":74,"run_id":"20260516_205602_1727f59b"}
2026-05-16T20:56:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_205602_1727f59b"}
2026-05-16T20:56:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.931,"duration_milliseconds":931,"important":true,"run_id":"20260516_205602_1727f59b"}
2026-05-16T20:56:04+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_205602_1727f59b"}
2026-05-16T20:56:04+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_205602_1727f59b"}
2026-05-16T20:56:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4286,"mtime":"2026-05-16T20:55:40+02:00","run_id":"20260516_205602_1727f59b"}
2026-05-16T20:56:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_205602_1727f59b"}
2026-05-16T20:56:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":11642,"mtime":"2026-05-16T20:55:40+02:00","run_id":"20260516_205602_1727f59b"}
2026-05-16T20:56:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":23,"rb":14,"run_id":"20260516_205602_1727f59b"}
2026-05-16T20:56:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_205602_1727f59b"}
2026-05-16T20:56:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.289,"duration_milliseconds":289,"important":true,"run_id":"20260516_205602_1727f59b"}
2026-05-16T20:56:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_205602_1727f59b"}
2026-05-16T20:56:04+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_205602_1727f59b"}
2026-05-16T20:56:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":212456,"run_id":"20260516_205602_1727f59b"}
2026-05-16T20:56:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.06,"exec_milliseconds":2060,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":212456,"important":true,"run_id":"20260516_205602_1727f59b"}
2026-05-16T20:56:21+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_205621_3fc4225d"}
2026-05-16T20:56:21+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_205621_3fc4225d"}
2026-05-16T20:56:21+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_205621_3fc4225d"}
2026-05-16T20:56:21+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_205621_3fc4225d"}
2026-05-16T20:56:22+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_205621_3fc4225d"}
2026-05-16T20:56:22+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_205621_3fc4225d"}
2026-05-16T20:56:22+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_205621_3fc4225d"}
2026-05-16T20:56:22+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_205621_3fc4225d"}
2026-05-16T20:56:22+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4146,"mtime":"2026-05-16T20:54:20+02:00","run_id":"20260516_205621_3fc4225d"}
2026-05-16T20:56:22+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":5586,"run_id":"20260516_205621_3fc4225d"}
2026-05-16T20:56:22+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":17352,"mtime":"2026-05-16T20:54:20+02:00","run_id":"20260516_205621_3fc4225d"}
2026-05-16T20:56:22+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":80,"rb":74,"run_id":"20260516_205621_3fc4225d"}
2026-05-16T20:56:23+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_205621_3fc4225d"}
2026-05-16T20:56:23+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.92,"duration_milliseconds":920,"important":true,"run_id":"20260516_205621_3fc4225d"}
2026-05-16T20:56:23+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_205621_3fc4225d"}
2026-05-16T20:56:23+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_205621_3fc4225d"}
2026-05-16T20:56:23+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4286,"mtime":"2026-05-16T20:56:21+02:00","run_id":"20260516_205621_3fc4225d"}
2026-05-16T20:56:23+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_205621_3fc4225d"}
2026-05-16T20:56:23+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":11935,"mtime":"2026-05-16T20:56:21+02:00","run_id":"20260516_205621_3fc4225d"}
2026-05-16T20:56:23+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":23,"rb":14,"run_id":"20260516_205621_3fc4225d"}
2026-05-16T20:56:23+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_205621_3fc4225d"}
2026-05-16T20:56:23+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.272,"duration_milliseconds":272,"important":true,"run_id":"20260516_205621_3fc4225d"}
2026-05-16T20:56:23+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_205621_3fc4225d"}
2026-05-16T20:56:23+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_205621_3fc4225d"}
2026-05-16T20:56:23+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":213745,"run_id":"20260516_205621_3fc4225d"}
2026-05-16T20:56:23+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.996,"exec_milliseconds":1996,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":213745,"important":true,"run_id":"20260516_205621_3fc4225d"}
2026-05-16T20:57:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_205701_a442c2e2"}
2026-05-16T20:57:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_205701_a442c2e2"}
2026-05-16T20:57:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_205701_a442c2e2"}
2026-05-16T20:57:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_205701_a442c2e2"}
2026-05-16T20:57:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_205701_a442c2e2"}
2026-05-16T20:57:02+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_205701_a442c2e2"}
2026-05-16T20:57:02+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_205701_a442c2e2"}
2026-05-16T20:57:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_205701_a442c2e2"}
2026-05-16T20:57:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4146,"mtime":"2026-05-16T20:54:20+02:00","run_id":"20260516_205701_a442c2e2"}
2026-05-16T20:57:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":5586,"run_id":"20260516_205701_a442c2e2"}
2026-05-16T20:57:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":17352,"mtime":"2026-05-16T20:54:20+02:00","run_id":"20260516_205701_a442c2e2"}
2026-05-16T20:57:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":80,"rb":74,"run_id":"20260516_205701_a442c2e2"}
2026-05-16T20:57:03+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_205701_a442c2e2"}
2026-05-16T20:57:03+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.966,"duration_milliseconds":966,"important":true,"run_id":"20260516_205701_a442c2e2"}
2026-05-16T20:57:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_205701_a442c2e2"}
2026-05-16T20:57:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_205701_a442c2e2"}
2026-05-16T20:57:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4286,"mtime":"2026-05-16T20:56:21+02:00","run_id":"20260516_205701_a442c2e2"}
2026-05-16T20:57:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_205701_a442c2e2"}
2026-05-16T20:57:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":11935,"mtime":"2026-05-16T20:56:21+02:00","run_id":"20260516_205701_a442c2e2"}
2026-05-16T20:57:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":23,"rb":14,"run_id":"20260516_205701_a442c2e2"}
2026-05-16T20:57:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_205701_a442c2e2"}
2026-05-16T20:57:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.324,"duration_milliseconds":324,"important":true,"run_id":"20260516_205701_a442c2e2"}
2026-05-16T20:57:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_205701_a442c2e2"}
2026-05-16T20:57:03+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_205701_a442c2e2"}
2026-05-16T20:57:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":213745,"run_id":"20260516_205701_a442c2e2"}
2026-05-16T20:57:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.074,"exec_milliseconds":2074,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":213745,"important":true,"run_id":"20260516_205701_a442c2e2"}
2026-05-16T20:58:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_205802_8ac4a34d"}
2026-05-16T20:58:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_205802_8ac4a34d"}
2026-05-16T20:58:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_205802_8ac4a34d"}
2026-05-16T20:58:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_205802_8ac4a34d"}
2026-05-16T20:58:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_205802_8ac4a34d"}
2026-05-16T20:58:03+02:00 [INFO] Live games query successful {"count":2,"run_id":"20260516_205802_8ac4a34d"}
2026-05-16T20:58:03+02:00 [INFO] Processing live game {"spiel_id":2005752,"team_id":420,"league":"BBL","run_id":"20260516_205802_8ac4a34d"}
2026-05-16T20:58:03+02:00 [INFO] SFTP upload directory reachable {"team_id":420,"spiel_id":2005752,"run_id":"20260516_205802_8ac4a34d"}
2026-05-16T20:58:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752_INIT.JSN","size":4146,"mtime":"2026-05-16T20:54:20+02:00","run_id":"20260516_205802_8ac4a34d"}
2026-05-16T20:58:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005752,"file":"2005752_INIT.JSN","referee_count":4,"spect":5586,"run_id":"20260516_205802_8ac4a34d"}
2026-05-16T20:58:03+02:00 [INFO] SFTP file found {"spiel_id":2005752,"file":"2005752.JSN","size":17352,"mtime":"2026-05-16T20:54:20+02:00","run_id":"20260516_205802_8ac4a34d"}
2026-05-16T20:58:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005752,"file":"2005752.JSN","ra":80,"rb":74,"run_id":"20260516_205802_8ac4a34d"}
2026-05-16T20:58:04+02:00 [INFO] Live row rendered {"spiel_id":2005752,"run_id":"20260516_205802_8ac4a34d"}
2026-05-16T20:58:04+02:00 [INFO] Live game timing {"spiel_id":2005752,"duration_seconds":0.943,"duration_milliseconds":943,"important":true,"run_id":"20260516_205802_8ac4a34d"}
2026-05-16T20:58:04+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_205802_8ac4a34d"}
2026-05-16T20:58:04+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_205802_8ac4a34d"}
2026-05-16T20:58:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4286,"mtime":"2026-05-16T20:57:12+02:00","run_id":"20260516_205802_8ac4a34d"}
2026-05-16T20:58:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_205802_8ac4a34d"}
2026-05-16T20:58:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":11946,"mtime":"2026-05-16T20:57:12+02:00","run_id":"20260516_205802_8ac4a34d"}
2026-05-16T20:58:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":23,"rb":14,"run_id":"20260516_205802_8ac4a34d"}
2026-05-16T20:58:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_205802_8ac4a34d"}
2026-05-16T20:58:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.304,"duration_milliseconds":304,"important":true,"run_id":"20260516_205802_8ac4a34d"}
2026-05-16T20:58:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_205802_8ac4a34d"}
2026-05-16T20:58:04+02:00 [INFO] Fallback query executed {"remaining_slots":7,"run_id":"20260516_205802_8ac4a34d"}
2026-05-16T20:58:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":213774,"run_id":"20260516_205802_8ac4a34d"}
2026-05-16T20:58:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":2.035,"exec_milliseconds":2035,"live_games":2,"fallback_games":0,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":213774,"important":true,"run_id":"20260516_205802_8ac4a34d"}
2026-05-16T20:59:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_205902_70ca256f"}
2026-05-16T20:59:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_205902_70ca256f"}
2026-05-16T20:59:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_205902_70ca256f"}
2026-05-16T20:59:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_205902_70ca256f"}
2026-05-16T20:59:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_205902_70ca256f"}
2026-05-16T20:59:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_205902_70ca256f"}
2026-05-16T20:59:02+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_205902_70ca256f"}
2026-05-16T20:59:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_205902_70ca256f"}
2026-05-16T20:59:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4286,"mtime":"2026-05-16T20:58:49+02:00","run_id":"20260516_205902_70ca256f"}
2026-05-16T20:59:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_205902_70ca256f"}
2026-05-16T20:59:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":5061,"mtime":"2026-05-16T20:58:49+02:00","run_id":"20260516_205902_70ca256f"}
2026-05-16T20:59:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":25,"rb":14,"run_id":"20260516_205902_70ca256f"}
2026-05-16T20:59:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_205902_70ca256f"}
2026-05-16T20:59:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.914,"duration_milliseconds":914,"important":true,"run_id":"20260516_205902_70ca256f"}
2026-05-16T20:59:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_205902_70ca256f"}
2026-05-16T20:59:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_205902_70ca256f"}
2026-05-16T20:59:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_205902_70ca256f"}
2026-05-16T20:59:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.083,"duration_milliseconds":83,"important":true,"run_id":"20260516_205902_70ca256f"}
2026-05-16T20:59:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":86922,"run_id":"20260516_205902_70ca256f"}
2026-05-16T20:59:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.751,"exec_milliseconds":1751,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":86922,"important":true,"run_id":"20260516_205902_70ca256f"}
2026-05-16T21:00:18+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_210018_704d6abb"}
2026-05-16T21:00:18+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_210018_704d6abb"}
2026-05-16T21:00:18+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_210018_704d6abb"}
2026-05-16T21:00:18+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_210018_704d6abb"}
2026-05-16T21:00:18+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_210018_704d6abb"}
2026-05-16T21:00:18+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_210018_704d6abb"}
2026-05-16T21:00:18+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_210018_704d6abb"}
2026-05-16T21:00:19+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_210018_704d6abb"}
2026-05-16T21:00:19+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4286,"mtime":"2026-05-16T20:59:56+02:00","run_id":"20260516_210018_704d6abb"}
2026-05-16T21:00:19+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_210018_704d6abb"}
2026-05-16T21:00:19+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":5611,"mtime":"2026-05-16T20:59:56+02:00","run_id":"20260516_210018_704d6abb"}
2026-05-16T21:00:19+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":27,"rb":16,"run_id":"20260516_210018_704d6abb"}
2026-05-16T21:00:19+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_210018_704d6abb"}
2026-05-16T21:00:19+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.935,"duration_milliseconds":935,"important":true,"run_id":"20260516_210018_704d6abb"}
2026-05-16T21:00:19+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_210018_704d6abb"}
2026-05-16T21:00:19+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_210018_704d6abb"}
2026-05-16T21:00:19+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_210018_704d6abb"}
2026-05-16T21:00:19+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.092,"duration_milliseconds":92,"important":true,"run_id":"20260516_210018_704d6abb"}
2026-05-16T21:00:19+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":89208,"run_id":"20260516_210018_704d6abb"}
2026-05-16T21:00:19+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.803,"exec_milliseconds":1803,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":89208,"important":true,"run_id":"20260516_210018_704d6abb"}
2026-05-16T21:01:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_210101_a2b42faa"}
2026-05-16T21:01:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_210101_a2b42faa"}
2026-05-16T21:01:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_210101_a2b42faa"}
2026-05-16T21:01:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_210101_a2b42faa"}
2026-05-16T21:01:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_210101_a2b42faa"}
2026-05-16T21:01:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_210101_a2b42faa"}
2026-05-16T21:01:02+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_210101_a2b42faa"}
2026-05-16T21:01:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_210101_a2b42faa"}
2026-05-16T21:01:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4286,"mtime":"2026-05-16T21:00:31+02:00","run_id":"20260516_210101_a2b42faa"}
2026-05-16T21:01:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_210101_a2b42faa"}
2026-05-16T21:01:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":5805,"mtime":"2026-05-16T21:00:31+02:00","run_id":"20260516_210101_a2b42faa"}
2026-05-16T21:01:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":27,"rb":16,"run_id":"20260516_210101_a2b42faa"}
2026-05-16T21:01:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_210101_a2b42faa"}
2026-05-16T21:01:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.944,"duration_milliseconds":944,"important":true,"run_id":"20260516_210101_a2b42faa"}
2026-05-16T21:01:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_210101_a2b42faa"}
2026-05-16T21:01:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_210101_a2b42faa"}
2026-05-16T21:01:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_210101_a2b42faa"}
2026-05-16T21:01:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.097,"duration_milliseconds":97,"important":true,"run_id":"20260516_210101_a2b42faa"}
2026-05-16T21:01:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":89958,"run_id":"20260516_210101_a2b42faa"}
2026-05-16T21:01:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.822,"exec_milliseconds":1822,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":89958,"important":true,"run_id":"20260516_210101_a2b42faa"}
2026-05-16T21:02:03+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_210202_fcd90419"}
2026-05-16T21:02:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_210202_fcd90419"}
2026-05-16T21:02:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_210202_fcd90419"}
2026-05-16T21:02:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_210202_fcd90419"}
2026-05-16T21:02:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_210202_fcd90419"}
2026-05-16T21:02:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_210202_fcd90419"}
2026-05-16T21:02:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_210202_fcd90419"}
2026-05-16T21:02:04+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_210202_fcd90419"}
2026-05-16T21:02:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4286,"mtime":"2026-05-16T21:01:59+02:00","run_id":"20260516_210202_fcd90419"}
2026-05-16T21:02:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_210202_fcd90419"}
2026-05-16T21:02:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":6226,"mtime":"2026-05-16T21:01:59+02:00","run_id":"20260516_210202_fcd90419"}
2026-05-16T21:02:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":27,"rb":17,"run_id":"20260516_210202_fcd90419"}
2026-05-16T21:02:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_210202_fcd90419"}
2026-05-16T21:02:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.967,"duration_milliseconds":967,"important":true,"run_id":"20260516_210202_fcd90419"}
2026-05-16T21:02:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_210202_fcd90419"}
2026-05-16T21:02:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_210202_fcd90419"}
2026-05-16T21:02:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_210202_fcd90419"}
2026-05-16T21:02:04+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.101,"duration_milliseconds":101,"important":true,"run_id":"20260516_210202_fcd90419"}
2026-05-16T21:02:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":91785,"run_id":"20260516_210202_fcd90419"}
2026-05-16T21:02:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.867,"exec_milliseconds":1867,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":91785,"important":true,"run_id":"20260516_210202_fcd90419"}
2026-05-16T21:03:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_210302_345d4707"}
2026-05-16T21:03:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_210302_345d4707"}
2026-05-16T21:03:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_210302_345d4707"}
2026-05-16T21:03:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_210302_345d4707"}
2026-05-16T21:03:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_210302_345d4707"}
2026-05-16T21:03:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_210302_345d4707"}
2026-05-16T21:03:02+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_210302_345d4707"}
2026-05-16T21:03:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_210302_345d4707"}
2026-05-16T21:03:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4287,"mtime":"2026-05-16T21:02:45+02:00","run_id":"20260516_210302_345d4707"}
2026-05-16T21:03:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_210302_345d4707"}
2026-05-16T21:03:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":6563,"mtime":"2026-05-16T21:02:44+02:00","run_id":"20260516_210302_345d4707"}
2026-05-16T21:03:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":27,"rb":20,"run_id":"20260516_210302_345d4707"}
2026-05-16T21:03:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_210302_345d4707"}
2026-05-16T21:03:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.98,"duration_milliseconds":980,"important":true,"run_id":"20260516_210302_345d4707"}
2026-05-16T21:03:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_210302_345d4707"}
2026-05-16T21:03:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_210302_345d4707"}
2026-05-16T21:04:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_210402_abbe49cb"}
2026-05-16T21:04:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_210402_abbe49cb"}
2026-05-16T21:04:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_210402_abbe49cb"}
2026-05-16T21:04:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_210402_abbe49cb"}
2026-05-16T21:04:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_210402_abbe49cb"}
2026-05-16T21:04:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_210402_abbe49cb"}
2026-05-16T21:04:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_210402_abbe49cb"}
2026-05-16T21:04:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_210402_abbe49cb"}
2026-05-16T21:04:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4287,"mtime":"2026-05-16T21:04:03+02:00","run_id":"20260516_210402_abbe49cb"}
2026-05-16T21:04:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_210402_abbe49cb"}
2026-05-16T21:04:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":6712,"mtime":"2026-05-16T21:04:03+02:00","run_id":"20260516_210402_abbe49cb"}
2026-05-16T21:04:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":27,"rb":20,"run_id":"20260516_210402_abbe49cb"}
2026-05-16T21:04:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_210402_abbe49cb"}
2026-05-16T21:04:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.949,"duration_milliseconds":949,"important":true,"run_id":"20260516_210402_abbe49cb"}
2026-05-16T21:04:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_210402_abbe49cb"}
2026-05-16T21:04:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_210402_abbe49cb"}
2026-05-16T21:05:04+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_210504_2501b335"}
2026-05-16T21:05:04+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_210504_2501b335"}
2026-05-16T21:05:04+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_210504_2501b335"}
2026-05-16T21:05:04+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_210504_2501b335"}
2026-05-16T21:05:04+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_210504_2501b335"}
2026-05-16T21:05:04+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_210504_2501b335"}
2026-05-16T21:05:05+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_210504_2501b335"}
2026-05-16T21:05:05+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_210504_2501b335"}
2026-05-16T21:05:05+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4287,"mtime":"2026-05-16T21:05:03+02:00","run_id":"20260516_210504_2501b335"}
2026-05-16T21:05:05+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_210504_2501b335"}
2026-05-16T21:05:05+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":6913,"mtime":"2026-05-16T21:05:03+02:00","run_id":"20260516_210504_2501b335"}
2026-05-16T21:05:05+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":29,"rb":20,"run_id":"20260516_210504_2501b335"}
2026-05-16T21:05:05+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_210504_2501b335"}
2026-05-16T21:05:05+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.941,"duration_milliseconds":941,"important":true,"run_id":"20260516_210504_2501b335"}
2026-05-16T21:05:05+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_210504_2501b335"}
2026-05-16T21:05:06+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_210504_2501b335"}
2026-05-16T21:05:06+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_210504_2501b335"}
2026-05-16T21:05:06+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.089,"duration_milliseconds":89,"important":true,"run_id":"20260516_210504_2501b335"}
2026-05-16T21:05:06+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":94647,"run_id":"20260516_210504_2501b335"}
2026-05-16T21:05:06+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.819,"exec_milliseconds":1819,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":94647,"important":true,"run_id":"20260516_210504_2501b335"}
2026-05-16T21:06:03+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_210602_4ebb96e3"}
2026-05-16T21:06:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_210602_4ebb96e3"}
2026-05-16T21:06:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_210602_4ebb96e3"}
2026-05-16T21:06:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_210602_4ebb96e3"}
2026-05-16T21:06:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_210602_4ebb96e3"}
2026-05-16T21:06:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_210602_4ebb96e3"}
2026-05-16T21:06:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_210602_4ebb96e3"}
2026-05-16T21:06:04+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_210602_4ebb96e3"}
2026-05-16T21:06:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4287,"mtime":"2026-05-16T21:05:24+02:00","run_id":"20260516_210602_4ebb96e3"}
2026-05-16T21:06:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_210602_4ebb96e3"}
2026-05-16T21:06:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":7296,"mtime":"2026-05-16T21:05:24+02:00","run_id":"20260516_210602_4ebb96e3"}
2026-05-16T21:06:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":29,"rb":20,"run_id":"20260516_210602_4ebb96e3"}
2026-05-16T21:06:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_210602_4ebb96e3"}
2026-05-16T21:06:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.957,"duration_milliseconds":957,"important":true,"run_id":"20260516_210602_4ebb96e3"}
2026-05-16T21:06:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_210602_4ebb96e3"}
2026-05-16T21:06:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_210602_4ebb96e3"}
2026-05-16T21:06:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_210602_4ebb96e3"}
2026-05-16T21:06:04+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.095,"duration_milliseconds":95,"important":true,"run_id":"20260516_210602_4ebb96e3"}
2026-05-16T21:06:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":96330,"run_id":"20260516_210602_4ebb96e3"}
2026-05-16T21:06:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.864,"exec_milliseconds":1864,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":96330,"important":true,"run_id":"20260516_210602_4ebb96e3"}
2026-05-16T21:07:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_210702_7e3c049e"}
2026-05-16T21:07:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_210702_7e3c049e"}
2026-05-16T21:07:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_210702_7e3c049e"}
2026-05-16T21:07:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_210702_7e3c049e"}
2026-05-16T21:07:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_210702_7e3c049e"}
2026-05-16T21:07:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_210702_7e3c049e"}
2026-05-16T21:07:02+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_210702_7e3c049e"}
2026-05-16T21:07:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_210702_7e3c049e"}
2026-05-16T21:07:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4287,"mtime":"2026-05-16T21:07:00+02:00","run_id":"20260516_210702_7e3c049e"}
2026-05-16T21:07:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_210702_7e3c049e"}
2026-05-16T21:07:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":7904,"mtime":"2026-05-16T21:07:00+02:00","run_id":"20260516_210702_7e3c049e"}
2026-05-16T21:07:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":29,"rb":20,"run_id":"20260516_210702_7e3c049e"}
2026-05-16T21:07:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_210702_7e3c049e"}
2026-05-16T21:07:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.973,"duration_milliseconds":973,"important":true,"run_id":"20260516_210702_7e3c049e"}
2026-05-16T21:07:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_210702_7e3c049e"}
2026-05-16T21:07:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_210702_7e3c049e"}
2026-05-16T21:07:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_210702_7e3c049e"}
2026-05-16T21:07:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.1,"duration_milliseconds":100,"important":true,"run_id":"20260516_210702_7e3c049e"}
2026-05-16T21:07:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":98950,"run_id":"20260516_210702_7e3c049e"}
2026-05-16T21:07:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.854,"exec_milliseconds":1854,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":98950,"important":true,"run_id":"20260516_210702_7e3c049e"}
2026-05-16T21:08:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_210802_38657ca8"}
2026-05-16T21:08:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_210802_38657ca8"}
2026-05-16T21:08:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_210802_38657ca8"}
2026-05-16T21:08:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_210802_38657ca8"}
2026-05-16T21:08:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_210802_38657ca8"}
2026-05-16T21:08:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_210802_38657ca8"}
2026-05-16T21:08:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_210802_38657ca8"}
2026-05-16T21:08:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_210802_38657ca8"}
2026-05-16T21:08:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4287,"mtime":"2026-05-16T21:07:41+02:00","run_id":"20260516_210802_38657ca8"}
2026-05-16T21:08:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_210802_38657ca8"}
2026-05-16T21:08:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":8393,"mtime":"2026-05-16T21:07:41+02:00","run_id":"20260516_210802_38657ca8"}
2026-05-16T21:08:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":29,"rb":22,"run_id":"20260516_210802_38657ca8"}
2026-05-16T21:08:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_210802_38657ca8"}
2026-05-16T21:08:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.943,"duration_milliseconds":943,"important":true,"run_id":"20260516_210802_38657ca8"}
2026-05-16T21:08:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_210802_38657ca8"}
2026-05-16T21:08:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_210802_38657ca8"}
2026-05-16T21:08:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_210802_38657ca8"}
2026-05-16T21:08:04+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.096,"duration_milliseconds":96,"important":true,"run_id":"20260516_210802_38657ca8"}
2026-05-16T21:08:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":101041,"run_id":"20260516_210802_38657ca8"}
2026-05-16T21:08:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.828,"exec_milliseconds":1828,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":101041,"important":true,"run_id":"20260516_210802_38657ca8"}
2026-05-16T21:09:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_210901_48a81e01"}
2026-05-16T21:09:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_210901_48a81e01"}
2026-05-16T21:09:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_210901_48a81e01"}
2026-05-16T21:09:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_210901_48a81e01"}
2026-05-16T21:09:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_210901_48a81e01"}
2026-05-16T21:09:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_210901_48a81e01"}
2026-05-16T21:09:02+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_210901_48a81e01"}
2026-05-16T21:09:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_210901_48a81e01"}
2026-05-16T21:09:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4287,"mtime":"2026-05-16T21:08:51+02:00","run_id":"20260516_210901_48a81e01"}
2026-05-16T21:09:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_210901_48a81e01"}
2026-05-16T21:09:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":8806,"mtime":"2026-05-16T21:08:51+02:00","run_id":"20260516_210901_48a81e01"}
2026-05-16T21:09:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":29,"rb":23,"run_id":"20260516_210901_48a81e01"}
2026-05-16T21:09:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_210901_48a81e01"}
2026-05-16T21:09:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.964,"duration_milliseconds":964,"important":true,"run_id":"20260516_210901_48a81e01"}
2026-05-16T21:09:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_210901_48a81e01"}
2026-05-16T21:09:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_210901_48a81e01"}
2026-05-16T21:09:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_210901_48a81e01"}
2026-05-16T21:09:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.1,"duration_milliseconds":100,"important":true,"run_id":"20260516_210901_48a81e01"}
2026-05-16T21:09:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":102806,"run_id":"20260516_210901_48a81e01"}
2026-05-16T21:09:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.945,"exec_milliseconds":1945,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":102806,"important":true,"run_id":"20260516_210901_48a81e01"}
2026-05-16T21:10:06+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_211006_2c02eddd"}
2026-05-16T21:10:06+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_211006_2c02eddd"}
2026-05-16T21:10:06+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_211006_2c02eddd"}
2026-05-16T21:10:06+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_211006_2c02eddd"}
2026-05-16T21:10:07+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_211006_2c02eddd"}
2026-05-16T21:10:07+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_211006_2c02eddd"}
2026-05-16T21:10:07+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_211006_2c02eddd"}
2026-05-16T21:10:07+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_211006_2c02eddd"}
2026-05-16T21:10:07+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4287,"mtime":"2026-05-16T21:09:55+02:00","run_id":"20260516_211006_2c02eddd"}
2026-05-16T21:10:07+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_211006_2c02eddd"}
2026-05-16T21:10:07+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":9163,"mtime":"2026-05-16T21:09:54+02:00","run_id":"20260516_211006_2c02eddd"}
2026-05-16T21:10:07+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":30,"rb":23,"run_id":"20260516_211006_2c02eddd"}
2026-05-16T21:10:08+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_211006_2c02eddd"}
2026-05-16T21:10:08+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.952,"duration_milliseconds":952,"important":true,"run_id":"20260516_211006_2c02eddd"}
2026-05-16T21:10:08+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_211006_2c02eddd"}
2026-05-16T21:10:08+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_211006_2c02eddd"}
2026-05-16T21:11:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_211101_223bc863"}
2026-05-16T21:11:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_211101_223bc863"}
2026-05-16T21:11:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_211101_223bc863"}
2026-05-16T21:11:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_211101_223bc863"}
2026-05-16T21:11:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_211101_223bc863"}
2026-05-16T21:11:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_211101_223bc863"}
2026-05-16T21:11:02+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_211101_223bc863"}
2026-05-16T21:11:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_211101_223bc863"}
2026-05-16T21:11:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4287,"mtime":"2026-05-16T21:11:02+02:00","run_id":"20260516_211101_223bc863"}
2026-05-16T21:11:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_211101_223bc863"}
2026-05-16T21:11:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":9540,"mtime":"2026-05-16T21:11:01+02:00","run_id":"20260516_211101_223bc863"}
2026-05-16T21:11:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":30,"rb":23,"run_id":"20260516_211101_223bc863"}
2026-05-16T21:11:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_211101_223bc863"}
2026-05-16T21:11:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.972,"duration_milliseconds":972,"important":true,"run_id":"20260516_211101_223bc863"}
2026-05-16T21:11:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_211101_223bc863"}
2026-05-16T21:11:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_211101_223bc863"}
2026-05-16T21:12:03+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_211203_dbe69cdf"}
2026-05-16T21:12:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_211203_dbe69cdf"}
2026-05-16T21:12:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_211203_dbe69cdf"}
2026-05-16T21:12:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_211203_dbe69cdf"}
2026-05-16T21:12:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_211203_dbe69cdf"}
2026-05-16T21:12:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_211203_dbe69cdf"}
2026-05-16T21:12:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_211203_dbe69cdf"}
2026-05-16T21:12:04+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_211203_dbe69cdf"}
2026-05-16T21:12:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4287,"mtime":"2026-05-16T21:11:52+02:00","run_id":"20260516_211203_dbe69cdf"}
2026-05-16T21:12:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_211203_dbe69cdf"}
2026-05-16T21:12:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":10009,"mtime":"2026-05-16T21:11:52+02:00","run_id":"20260516_211203_dbe69cdf"}
2026-05-16T21:12:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":30,"rb":23,"run_id":"20260516_211203_dbe69cdf"}
2026-05-16T21:12:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_211203_dbe69cdf"}
2026-05-16T21:12:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.956,"duration_milliseconds":956,"important":true,"run_id":"20260516_211203_dbe69cdf"}
2026-05-16T21:12:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_211203_dbe69cdf"}
2026-05-16T21:12:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_211203_dbe69cdf"}
2026-05-16T21:12:05+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_211203_dbe69cdf"}
2026-05-16T21:12:05+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.099,"duration_milliseconds":99,"important":true,"run_id":"20260516_211203_dbe69cdf"}
2026-05-16T21:12:05+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":107913,"run_id":"20260516_211203_dbe69cdf"}
2026-05-16T21:12:05+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.852,"exec_milliseconds":1852,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":107913,"important":true,"run_id":"20260516_211203_dbe69cdf"}
2026-05-16T21:13:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_211301_3b011b49"}
2026-05-16T21:13:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_211301_3b011b49"}
2026-05-16T21:13:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_211301_3b011b49"}
2026-05-16T21:13:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_211301_3b011b49"}
2026-05-16T21:13:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_211301_3b011b49"}
2026-05-16T21:13:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_211301_3b011b49"}
2026-05-16T21:13:02+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_211301_3b011b49"}
2026-05-16T21:13:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_211301_3b011b49"}
2026-05-16T21:13:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4287,"mtime":"2026-05-16T21:12:52+02:00","run_id":"20260516_211301_3b011b49"}
2026-05-16T21:13:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_211301_3b011b49"}
2026-05-16T21:13:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":10436,"mtime":"2026-05-16T21:12:52+02:00","run_id":"20260516_211301_3b011b49"}
2026-05-16T21:13:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":30,"rb":25,"run_id":"20260516_211301_3b011b49"}
2026-05-16T21:13:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_211301_3b011b49"}
2026-05-16T21:13:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.982,"duration_milliseconds":982,"important":true,"run_id":"20260516_211301_3b011b49"}
2026-05-16T21:13:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_211301_3b011b49"}
2026-05-16T21:13:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_211301_3b011b49"}
2026-05-16T21:14:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_211402_7fe36f61"}
2026-05-16T21:14:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_211402_7fe36f61"}
2026-05-16T21:14:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_211402_7fe36f61"}
2026-05-16T21:14:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_211402_7fe36f61"}
2026-05-16T21:14:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_211402_7fe36f61"}
2026-05-16T21:14:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_211402_7fe36f61"}
2026-05-16T21:14:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_211402_7fe36f61"}
2026-05-16T21:14:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_211402_7fe36f61"}
2026-05-16T21:14:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4287,"mtime":"2026-05-16T21:13:24+02:00","run_id":"20260516_211402_7fe36f61"}
2026-05-16T21:14:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_211402_7fe36f61"}
2026-05-16T21:14:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":10698,"mtime":"2026-05-16T21:13:24+02:00","run_id":"20260516_211402_7fe36f61"}
2026-05-16T21:14:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":30,"rb":27,"run_id":"20260516_211402_7fe36f61"}
2026-05-16T21:14:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_211402_7fe36f61"}
2026-05-16T21:14:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":1.021,"duration_milliseconds":1021,"important":true,"run_id":"20260516_211402_7fe36f61"}
2026-05-16T21:14:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_211402_7fe36f61"}
2026-05-16T21:14:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_211402_7fe36f61"}
2026-05-16T21:14:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_211402_7fe36f61"}
2026-05-16T21:14:04+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.086,"duration_milliseconds":86,"important":true,"run_id":"20260516_211402_7fe36f61"}
2026-05-16T21:14:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":110819,"run_id":"20260516_211402_7fe36f61"}
2026-05-16T21:14:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.928,"exec_milliseconds":1928,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":110819,"important":true,"run_id":"20260516_211402_7fe36f61"}
2026-05-16T21:15:07+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_211507_55235e0d"}
2026-05-16T21:15:07+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_211507_55235e0d"}
2026-05-16T21:15:07+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_211507_55235e0d"}
2026-05-16T21:15:07+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_211507_55235e0d"}
2026-05-16T21:15:07+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_211507_55235e0d"}
2026-05-16T21:15:07+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_211507_55235e0d"}
2026-05-16T21:15:08+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_211507_55235e0d"}
2026-05-16T21:15:08+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_211507_55235e0d"}
2026-05-16T21:15:08+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4287,"mtime":"2026-05-16T21:14:47+02:00","run_id":"20260516_211507_55235e0d"}
2026-05-16T21:15:08+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_211507_55235e0d"}
2026-05-16T21:15:08+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":10772,"mtime":"2026-05-16T21:14:47+02:00","run_id":"20260516_211507_55235e0d"}
2026-05-16T21:15:08+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":30,"rb":27,"run_id":"20260516_211507_55235e0d"}
2026-05-16T21:15:08+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_211507_55235e0d"}
2026-05-16T21:15:08+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.965,"duration_milliseconds":965,"important":true,"run_id":"20260516_211507_55235e0d"}
2026-05-16T21:15:09+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_211507_55235e0d"}
2026-05-16T21:15:09+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_211507_55235e0d"}
2026-05-16T21:15:09+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_211507_55235e0d"}
2026-05-16T21:15:09+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.091,"duration_milliseconds":91,"important":true,"run_id":"20260516_211507_55235e0d"}
2026-05-16T21:15:09+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":111100,"run_id":"20260516_211507_55235e0d"}
2026-05-16T21:15:09+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.81,"exec_milliseconds":1810,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":111100,"important":true,"run_id":"20260516_211507_55235e0d"}
2026-05-16T21:16:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_211602_1c8443b8"}
2026-05-16T21:16:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_211602_1c8443b8"}
2026-05-16T21:16:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_211602_1c8443b8"}
2026-05-16T21:16:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_211602_1c8443b8"}
2026-05-16T21:16:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_211602_1c8443b8"}
2026-05-16T21:16:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_211602_1c8443b8"}
2026-05-16T21:16:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_211602_1c8443b8"}
2026-05-16T21:16:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_211602_1c8443b8"}
2026-05-16T21:16:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4287,"mtime":"2026-05-16T21:16:01+02:00","run_id":"20260516_211602_1c8443b8"}
2026-05-16T21:16:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_211602_1c8443b8"}
2026-05-16T21:16:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":11148,"mtime":"2026-05-16T21:16:01+02:00","run_id":"20260516_211602_1c8443b8"}
2026-05-16T21:16:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":30,"rb":27,"run_id":"20260516_211602_1c8443b8"}
2026-05-16T21:16:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_211602_1c8443b8"}
2026-05-16T21:16:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.988,"duration_milliseconds":988,"important":true,"run_id":"20260516_211602_1c8443b8"}
2026-05-16T21:16:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_211602_1c8443b8"}
2026-05-16T21:16:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_211602_1c8443b8"}
2026-05-16T21:17:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_211701_b06fdfba"}
2026-05-16T21:17:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_211701_b06fdfba"}
2026-05-16T21:17:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_211701_b06fdfba"}
2026-05-16T21:17:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_211701_b06fdfba"}
2026-05-16T21:17:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_211701_b06fdfba"}
2026-05-16T21:17:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_211701_b06fdfba"}
2026-05-16T21:17:02+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_211701_b06fdfba"}
2026-05-16T21:17:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_211701_b06fdfba"}
2026-05-16T21:17:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4287,"mtime":"2026-05-16T21:16:48+02:00","run_id":"20260516_211701_b06fdfba"}
2026-05-16T21:17:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_211701_b06fdfba"}
2026-05-16T21:17:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":11372,"mtime":"2026-05-16T21:16:48+02:00","run_id":"20260516_211701_b06fdfba"}
2026-05-16T21:17:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":30,"rb":27,"run_id":"20260516_211701_b06fdfba"}
2026-05-16T21:17:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_211701_b06fdfba"}
2026-05-16T21:17:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.945,"duration_milliseconds":945,"important":true,"run_id":"20260516_211701_b06fdfba"}
2026-05-16T21:17:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_211701_b06fdfba"}
2026-05-16T21:17:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_211701_b06fdfba"}
2026-05-16T21:17:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_211701_b06fdfba"}
2026-05-16T21:17:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.1,"duration_milliseconds":100,"important":true,"run_id":"20260516_211701_b06fdfba"}
2026-05-16T21:17:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":113742,"run_id":"20260516_211701_b06fdfba"}
2026-05-16T21:17:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.878,"exec_milliseconds":1878,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":113742,"important":true,"run_id":"20260516_211701_b06fdfba"}
2026-05-16T21:18:03+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_211802_69c3cc0d"}
2026-05-16T21:18:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_211802_69c3cc0d"}
2026-05-16T21:18:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_211802_69c3cc0d"}
2026-05-16T21:18:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_211802_69c3cc0d"}
2026-05-16T21:18:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_211802_69c3cc0d"}
2026-05-16T21:18:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_211802_69c3cc0d"}
2026-05-16T21:18:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_211802_69c3cc0d"}
2026-05-16T21:18:04+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_211802_69c3cc0d"}
2026-05-16T21:18:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4287,"mtime":"2026-05-16T21:17:59+02:00","run_id":"20260516_211802_69c3cc0d"}
2026-05-16T21:18:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_211802_69c3cc0d"}
2026-05-16T21:18:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":11722,"mtime":"2026-05-16T21:17:59+02:00","run_id":"20260516_211802_69c3cc0d"}
2026-05-16T21:18:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":30,"rb":30,"run_id":"20260516_211802_69c3cc0d"}
2026-05-16T21:18:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_211802_69c3cc0d"}
2026-05-16T21:18:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.95,"duration_milliseconds":950,"important":true,"run_id":"20260516_211802_69c3cc0d"}
2026-05-16T21:18:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_211802_69c3cc0d"}
2026-05-16T21:18:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_211802_69c3cc0d"}
2026-05-16T21:19:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_211902_ecbfc0fa"}
2026-05-16T21:19:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_211902_ecbfc0fa"}
2026-05-16T21:19:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_211902_ecbfc0fa"}
2026-05-16T21:19:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_211902_ecbfc0fa"}
2026-05-16T21:19:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_211902_ecbfc0fa"}
2026-05-16T21:19:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_211902_ecbfc0fa"}
2026-05-16T21:19:02+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_211902_ecbfc0fa"}
2026-05-16T21:19:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_211902_ecbfc0fa"}
2026-05-16T21:19:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4287,"mtime":"2026-05-16T21:17:59+02:00","run_id":"20260516_211902_ecbfc0fa"}
2026-05-16T21:19:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_211902_ecbfc0fa"}
2026-05-16T21:19:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":11722,"mtime":"2026-05-16T21:17:59+02:00","run_id":"20260516_211902_ecbfc0fa"}
2026-05-16T21:19:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":30,"rb":30,"run_id":"20260516_211902_ecbfc0fa"}
2026-05-16T21:19:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_211902_ecbfc0fa"}
2026-05-16T21:19:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.947,"duration_milliseconds":947,"important":true,"run_id":"20260516_211902_ecbfc0fa"}
2026-05-16T21:19:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_211902_ecbfc0fa"}
2026-05-16T21:19:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_211902_ecbfc0fa"}
2026-05-16T21:19:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_211902_ecbfc0fa"}
2026-05-16T21:19:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.092,"duration_milliseconds":92,"important":true,"run_id":"20260516_211902_ecbfc0fa"}
2026-05-16T21:19:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":115210,"run_id":"20260516_211902_ecbfc0fa"}
2026-05-16T21:19:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.815,"exec_milliseconds":1815,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":115210,"important":true,"run_id":"20260516_211902_ecbfc0fa"}
2026-05-16T21:20:07+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_212007_522052a3"}
2026-05-16T21:20:07+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_212007_522052a3"}
2026-05-16T21:20:07+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_212007_522052a3"}
2026-05-16T21:20:07+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_212007_522052a3"}
2026-05-16T21:20:07+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_212007_522052a3"}
2026-05-16T21:20:07+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_212007_522052a3"}
2026-05-16T21:20:07+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_212007_522052a3"}
2026-05-16T21:20:08+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_212007_522052a3"}
2026-05-16T21:20:08+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4287,"mtime":"2026-05-16T21:20:00+02:00","run_id":"20260516_212007_522052a3"}
2026-05-16T21:20:08+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_212007_522052a3"}
2026-05-16T21:20:08+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":11877,"mtime":"2026-05-16T21:20:00+02:00","run_id":"20260516_212007_522052a3"}
2026-05-16T21:20:08+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":30,"rb":30,"run_id":"20260516_212007_522052a3"}
2026-05-16T21:20:08+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_212007_522052a3"}
2026-05-16T21:20:08+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.944,"duration_milliseconds":944,"important":true,"run_id":"20260516_212007_522052a3"}
2026-05-16T21:20:08+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_212007_522052a3"}
2026-05-16T21:20:08+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_212007_522052a3"}
2026-05-16T21:20:09+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_212007_522052a3"}
2026-05-16T21:20:09+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.089,"duration_milliseconds":89,"important":true,"run_id":"20260516_212007_522052a3"}
2026-05-16T21:20:09+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":115827,"run_id":"20260516_212007_522052a3"}
2026-05-16T21:20:09+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.838,"exec_milliseconds":1838,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":115827,"important":true,"run_id":"20260516_212007_522052a3"}
2026-05-16T21:21:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_212101_321ea0a9"}
2026-05-16T21:21:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_212101_321ea0a9"}
2026-05-16T21:21:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_212101_321ea0a9"}
2026-05-16T21:21:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_212101_321ea0a9"}
2026-05-16T21:21:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_212101_321ea0a9"}
2026-05-16T21:21:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_212101_321ea0a9"}
2026-05-16T21:21:02+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_212101_321ea0a9"}
2026-05-16T21:21:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_212101_321ea0a9"}
2026-05-16T21:21:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4287,"mtime":"2026-05-16T21:21:00+02:00","run_id":"20260516_212101_321ea0a9"}
2026-05-16T21:21:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_212101_321ea0a9"}
2026-05-16T21:21:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":12256,"mtime":"2026-05-16T21:21:00+02:00","run_id":"20260516_212101_321ea0a9"}
2026-05-16T21:21:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":30,"rb":30,"run_id":"20260516_212101_321ea0a9"}
2026-05-16T21:21:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_212101_321ea0a9"}
2026-05-16T21:21:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.925,"duration_milliseconds":925,"important":true,"run_id":"20260516_212101_321ea0a9"}
2026-05-16T21:21:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_212101_321ea0a9"}
2026-05-16T21:21:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_212101_321ea0a9"}
2026-05-16T21:21:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_212101_321ea0a9"}
2026-05-16T21:21:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.092,"duration_milliseconds":92,"important":true,"run_id":"20260516_212101_321ea0a9"}
2026-05-16T21:21:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":117506,"run_id":"20260516_212101_321ea0a9"}
2026-05-16T21:21:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.78,"exec_milliseconds":1780,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":117506,"important":true,"run_id":"20260516_212101_321ea0a9"}
2026-05-16T21:22:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_212202_52b697d9"}
2026-05-16T21:22:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_212202_52b697d9"}
2026-05-16T21:22:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_212202_52b697d9"}
2026-05-16T21:22:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_212202_52b697d9"}
2026-05-16T21:22:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_212202_52b697d9"}
2026-05-16T21:22:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_212202_52b697d9"}
2026-05-16T21:22:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_212202_52b697d9"}
2026-05-16T21:22:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_212202_52b697d9"}
2026-05-16T21:22:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4287,"mtime":"2026-05-16T21:21:35+02:00","run_id":"20260516_212202_52b697d9"}
2026-05-16T21:22:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_212202_52b697d9"}
2026-05-16T21:22:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":12548,"mtime":"2026-05-16T21:21:35+02:00","run_id":"20260516_212202_52b697d9"}
2026-05-16T21:22:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":30,"rb":30,"run_id":"20260516_212202_52b697d9"}
2026-05-16T21:22:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_212202_52b697d9"}
2026-05-16T21:22:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.976,"duration_milliseconds":976,"important":true,"run_id":"20260516_212202_52b697d9"}
2026-05-16T21:22:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_212202_52b697d9"}
2026-05-16T21:22:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_212202_52b697d9"}
2026-05-16T21:22:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_212202_52b697d9"}
2026-05-16T21:22:04+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.128,"duration_milliseconds":128,"important":true,"run_id":"20260516_212202_52b697d9"}
2026-05-16T21:22:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":118789,"run_id":"20260516_212202_52b697d9"}
2026-05-16T21:22:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.91,"exec_milliseconds":1910,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":118789,"important":true,"run_id":"20260516_212202_52b697d9"}
2026-05-16T21:23:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_212301_81593dc3"}
2026-05-16T21:23:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_212301_81593dc3"}
2026-05-16T21:23:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_212301_81593dc3"}
2026-05-16T21:23:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_212301_81593dc3"}
2026-05-16T21:23:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_212301_81593dc3"}
2026-05-16T21:23:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_212301_81593dc3"}
2026-05-16T21:23:02+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_212301_81593dc3"}
2026-05-16T21:23:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_212301_81593dc3"}
2026-05-16T21:23:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4287,"mtime":"2026-05-16T21:21:35+02:00","run_id":"20260516_212301_81593dc3"}
2026-05-16T21:23:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_212301_81593dc3"}
2026-05-16T21:23:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":12548,"mtime":"2026-05-16T21:21:35+02:00","run_id":"20260516_212301_81593dc3"}
2026-05-16T21:23:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":30,"rb":30,"run_id":"20260516_212301_81593dc3"}
2026-05-16T21:23:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_212301_81593dc3"}
2026-05-16T21:23:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.947,"duration_milliseconds":947,"important":true,"run_id":"20260516_212301_81593dc3"}
2026-05-16T21:23:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_212301_81593dc3"}
2026-05-16T21:23:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_212301_81593dc3"}
2026-05-16T21:23:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_212301_81593dc3"}
2026-05-16T21:23:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.101,"duration_milliseconds":101,"important":true,"run_id":"20260516_212301_81593dc3"}
2026-05-16T21:23:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":118789,"run_id":"20260516_212301_81593dc3"}
2026-05-16T21:23:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.859,"exec_milliseconds":1859,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":118789,"important":true,"run_id":"20260516_212301_81593dc3"}
2026-05-16T21:24:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_212402_f8e023be"}
2026-05-16T21:24:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_212402_f8e023be"}
2026-05-16T21:24:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_212402_f8e023be"}
2026-05-16T21:24:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_212402_f8e023be"}
2026-05-16T21:24:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_212402_f8e023be"}
2026-05-16T21:24:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_212402_f8e023be"}
2026-05-16T21:24:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_212402_f8e023be"}
2026-05-16T21:24:04+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_212402_f8e023be"}
2026-05-16T21:24:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4287,"mtime":"2026-05-16T21:21:35+02:00","run_id":"20260516_212402_f8e023be"}
2026-05-16T21:24:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_212402_f8e023be"}
2026-05-16T21:24:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":12548,"mtime":"2026-05-16T21:21:35+02:00","run_id":"20260516_212402_f8e023be"}
2026-05-16T21:24:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":30,"rb":30,"run_id":"20260516_212402_f8e023be"}
2026-05-16T21:24:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_212402_f8e023be"}
2026-05-16T21:24:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.967,"duration_milliseconds":967,"important":true,"run_id":"20260516_212402_f8e023be"}
2026-05-16T21:24:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_212402_f8e023be"}
2026-05-16T21:24:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_212402_f8e023be"}
2026-05-16T21:24:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_212402_f8e023be"}
2026-05-16T21:24:04+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.096,"duration_milliseconds":96,"important":true,"run_id":"20260516_212402_f8e023be"}
2026-05-16T21:24:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":118789,"run_id":"20260516_212402_f8e023be"}
2026-05-16T21:24:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.832,"exec_milliseconds":1832,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":118789,"important":true,"run_id":"20260516_212402_f8e023be"}
2026-05-16T21:25:04+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_212504_5931aa88"}
2026-05-16T21:25:04+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_212504_5931aa88"}
2026-05-16T21:25:04+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_212504_5931aa88"}
2026-05-16T21:25:04+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_212504_5931aa88"}
2026-05-16T21:25:04+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_212504_5931aa88"}
2026-05-16T21:25:04+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_212504_5931aa88"}
2026-05-16T21:25:04+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_212504_5931aa88"}
2026-05-16T21:25:05+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_212504_5931aa88"}
2026-05-16T21:25:05+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4287,"mtime":"2026-05-16T21:21:35+02:00","run_id":"20260516_212504_5931aa88"}
2026-05-16T21:25:05+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_212504_5931aa88"}
2026-05-16T21:25:05+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":12548,"mtime":"2026-05-16T21:21:35+02:00","run_id":"20260516_212504_5931aa88"}
2026-05-16T21:25:05+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":30,"rb":30,"run_id":"20260516_212504_5931aa88"}
2026-05-16T21:25:05+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_212504_5931aa88"}
2026-05-16T21:25:05+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.944,"duration_milliseconds":944,"important":true,"run_id":"20260516_212504_5931aa88"}
2026-05-16T21:25:05+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_212504_5931aa88"}
2026-05-16T21:25:05+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_212504_5931aa88"}
2026-05-16T21:25:05+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_212504_5931aa88"}
2026-05-16T21:25:05+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.09,"duration_milliseconds":90,"important":true,"run_id":"20260516_212504_5931aa88"}
2026-05-16T21:25:05+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":118747,"run_id":"20260516_212504_5931aa88"}
2026-05-16T21:25:05+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.81,"exec_milliseconds":1810,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":118747,"important":true,"run_id":"20260516_212504_5931aa88"}
2026-05-16T21:26:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_212602_482f442e"}
2026-05-16T21:26:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_212602_482f442e"}
2026-05-16T21:26:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_212602_482f442e"}
2026-05-16T21:26:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_212602_482f442e"}
2026-05-16T21:26:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_212602_482f442e"}
2026-05-16T21:26:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_212602_482f442e"}
2026-05-16T21:26:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_212602_482f442e"}
2026-05-16T21:26:04+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_212602_482f442e"}
2026-05-16T21:26:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4287,"mtime":"2026-05-16T21:21:35+02:00","run_id":"20260516_212602_482f442e"}
2026-05-16T21:26:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_212602_482f442e"}
2026-05-16T21:26:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":12548,"mtime":"2026-05-16T21:21:35+02:00","run_id":"20260516_212602_482f442e"}
2026-05-16T21:26:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":30,"rb":30,"run_id":"20260516_212602_482f442e"}
2026-05-16T21:26:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_212602_482f442e"}
2026-05-16T21:26:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.972,"duration_milliseconds":972,"important":true,"run_id":"20260516_212602_482f442e"}
2026-05-16T21:26:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_212602_482f442e"}
2026-05-16T21:26:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_212602_482f442e"}
2026-05-16T21:26:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_212602_482f442e"}
2026-05-16T21:26:04+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.091,"duration_milliseconds":91,"important":true,"run_id":"20260516_212602_482f442e"}
2026-05-16T21:26:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":118789,"run_id":"20260516_212602_482f442e"}
2026-05-16T21:26:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.945,"exec_milliseconds":1945,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":118789,"important":true,"run_id":"20260516_212602_482f442e"}
2026-05-16T21:27:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_212701_c73567f2"}
2026-05-16T21:27:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_212701_c73567f2"}
2026-05-16T21:27:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_212701_c73567f2"}
2026-05-16T21:27:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_212701_c73567f2"}
2026-05-16T21:27:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_212701_c73567f2"}
2026-05-16T21:27:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_212701_c73567f2"}
2026-05-16T21:27:02+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_212701_c73567f2"}
2026-05-16T21:27:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_212701_c73567f2"}
2026-05-16T21:27:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4287,"mtime":"2026-05-16T21:21:35+02:00","run_id":"20260516_212701_c73567f2"}
2026-05-16T21:27:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_212701_c73567f2"}
2026-05-16T21:27:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":12548,"mtime":"2026-05-16T21:21:35+02:00","run_id":"20260516_212701_c73567f2"}
2026-05-16T21:27:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":30,"rb":30,"run_id":"20260516_212701_c73567f2"}
2026-05-16T21:27:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_212701_c73567f2"}
2026-05-16T21:27:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.962,"duration_milliseconds":962,"important":true,"run_id":"20260516_212701_c73567f2"}
2026-05-16T21:27:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_212701_c73567f2"}
2026-05-16T21:27:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_212701_c73567f2"}
2026-05-16T21:27:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_212701_c73567f2"}
2026-05-16T21:27:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.109,"duration_milliseconds":109,"important":true,"run_id":"20260516_212701_c73567f2"}
2026-05-16T21:27:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":118789,"run_id":"20260516_212701_c73567f2"}
2026-05-16T21:27:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.943,"exec_milliseconds":1943,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":118789,"important":true,"run_id":"20260516_212701_c73567f2"}
2026-05-16T21:28:03+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_212803_e3f6f8d1"}
2026-05-16T21:28:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_212803_e3f6f8d1"}
2026-05-16T21:28:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_212803_e3f6f8d1"}
2026-05-16T21:28:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_212803_e3f6f8d1"}
2026-05-16T21:28:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_212803_e3f6f8d1"}
2026-05-16T21:28:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_212803_e3f6f8d1"}
2026-05-16T21:28:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_212803_e3f6f8d1"}
2026-05-16T21:28:04+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_212803_e3f6f8d1"}
2026-05-16T21:28:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4287,"mtime":"2026-05-16T21:21:35+02:00","run_id":"20260516_212803_e3f6f8d1"}
2026-05-16T21:28:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_212803_e3f6f8d1"}
2026-05-16T21:28:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":12548,"mtime":"2026-05-16T21:21:35+02:00","run_id":"20260516_212803_e3f6f8d1"}
2026-05-16T21:28:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":30,"rb":30,"run_id":"20260516_212803_e3f6f8d1"}
2026-05-16T21:28:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_212803_e3f6f8d1"}
2026-05-16T21:28:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.912,"duration_milliseconds":912,"important":true,"run_id":"20260516_212803_e3f6f8d1"}
2026-05-16T21:28:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_212803_e3f6f8d1"}
2026-05-16T21:28:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_212803_e3f6f8d1"}
2026-05-16T21:28:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_212803_e3f6f8d1"}
2026-05-16T21:28:04+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.085,"duration_milliseconds":85,"important":true,"run_id":"20260516_212803_e3f6f8d1"}
2026-05-16T21:28:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":118789,"run_id":"20260516_212803_e3f6f8d1"}
2026-05-16T21:28:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.822,"exec_milliseconds":1822,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":118789,"important":true,"run_id":"20260516_212803_e3f6f8d1"}
2026-05-16T21:29:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_212901_0466cf5c"}
2026-05-16T21:29:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_212901_0466cf5c"}
2026-05-16T21:29:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_212901_0466cf5c"}
2026-05-16T21:29:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_212901_0466cf5c"}
2026-05-16T21:29:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_212901_0466cf5c"}
2026-05-16T21:29:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_212901_0466cf5c"}
2026-05-16T21:29:02+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_212901_0466cf5c"}
2026-05-16T21:29:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_212901_0466cf5c"}
2026-05-16T21:29:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4287,"mtime":"2026-05-16T21:21:35+02:00","run_id":"20260516_212901_0466cf5c"}
2026-05-16T21:29:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_212901_0466cf5c"}
2026-05-16T21:29:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":12548,"mtime":"2026-05-16T21:21:35+02:00","run_id":"20260516_212901_0466cf5c"}
2026-05-16T21:29:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":30,"rb":30,"run_id":"20260516_212901_0466cf5c"}
2026-05-16T21:29:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_212901_0466cf5c"}
2026-05-16T21:29:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":1.018,"duration_milliseconds":1018,"important":true,"run_id":"20260516_212901_0466cf5c"}
2026-05-16T21:29:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_212901_0466cf5c"}
2026-05-16T21:29:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_212901_0466cf5c"}
2026-05-16T21:29:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_212901_0466cf5c"}
2026-05-16T21:29:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.087,"duration_milliseconds":87,"important":true,"run_id":"20260516_212901_0466cf5c"}
2026-05-16T21:29:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":118790,"run_id":"20260516_212901_0466cf5c"}
2026-05-16T21:29:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.892,"exec_milliseconds":1892,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":118790,"important":true,"run_id":"20260516_212901_0466cf5c"}
2026-05-16T21:30:11+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_213011_7e11e54d"}
2026-05-16T21:30:12+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_213011_7e11e54d"}
2026-05-16T21:30:12+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_213011_7e11e54d"}
2026-05-16T21:30:12+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_213011_7e11e54d"}
2026-05-16T21:30:12+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_213011_7e11e54d"}
2026-05-16T21:30:12+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_213011_7e11e54d"}
2026-05-16T21:30:12+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_213011_7e11e54d"}
2026-05-16T21:30:13+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_213011_7e11e54d"}
2026-05-16T21:30:13+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4287,"mtime":"2026-05-16T21:21:35+02:00","run_id":"20260516_213011_7e11e54d"}
2026-05-16T21:30:13+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_213011_7e11e54d"}
2026-05-16T21:30:13+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":12548,"mtime":"2026-05-16T21:21:35+02:00","run_id":"20260516_213011_7e11e54d"}
2026-05-16T21:30:13+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":30,"rb":30,"run_id":"20260516_213011_7e11e54d"}
2026-05-16T21:30:13+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_213011_7e11e54d"}
2026-05-16T21:30:13+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.938,"duration_milliseconds":938,"important":true,"run_id":"20260516_213011_7e11e54d"}
2026-05-16T21:30:13+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_213011_7e11e54d"}
2026-05-16T21:30:13+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_213011_7e11e54d"}
2026-05-16T21:30:13+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_213011_7e11e54d"}
2026-05-16T21:30:13+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.084,"duration_milliseconds":84,"important":true,"run_id":"20260516_213011_7e11e54d"}
2026-05-16T21:30:13+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":118747,"run_id":"20260516_213011_7e11e54d"}
2026-05-16T21:30:13+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.817,"exec_milliseconds":1817,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":118747,"important":true,"run_id":"20260516_213011_7e11e54d"}
2026-05-16T21:31:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_213101_8a12bd6a"}
2026-05-16T21:31:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_213101_8a12bd6a"}
2026-05-16T21:31:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_213101_8a12bd6a"}
2026-05-16T21:31:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_213101_8a12bd6a"}
2026-05-16T21:31:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_213101_8a12bd6a"}
2026-05-16T21:31:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_213101_8a12bd6a"}
2026-05-16T21:31:02+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_213101_8a12bd6a"}
2026-05-16T21:31:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_213101_8a12bd6a"}
2026-05-16T21:31:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4287,"mtime":"2026-05-16T21:21:35+02:00","run_id":"20260516_213101_8a12bd6a"}
2026-05-16T21:31:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_213101_8a12bd6a"}
2026-05-16T21:31:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":12548,"mtime":"2026-05-16T21:21:35+02:00","run_id":"20260516_213101_8a12bd6a"}
2026-05-16T21:31:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":30,"rb":30,"run_id":"20260516_213101_8a12bd6a"}
2026-05-16T21:31:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_213101_8a12bd6a"}
2026-05-16T21:31:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.948,"duration_milliseconds":948,"important":true,"run_id":"20260516_213101_8a12bd6a"}
2026-05-16T21:31:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_213101_8a12bd6a"}
2026-05-16T21:31:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_213101_8a12bd6a"}
2026-05-16T21:31:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_213101_8a12bd6a"}
2026-05-16T21:31:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.087,"duration_milliseconds":87,"important":true,"run_id":"20260516_213101_8a12bd6a"}
2026-05-16T21:31:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":118789,"run_id":"20260516_213101_8a12bd6a"}
2026-05-16T21:31:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.832,"exec_milliseconds":1832,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":118789,"important":true,"run_id":"20260516_213101_8a12bd6a"}
2026-05-16T21:32:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_213202_55c44bca"}
2026-05-16T21:32:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_213202_55c44bca"}
2026-05-16T21:32:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_213202_55c44bca"}
2026-05-16T21:32:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_213202_55c44bca"}
2026-05-16T21:32:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_213202_55c44bca"}
2026-05-16T21:32:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_213202_55c44bca"}
2026-05-16T21:32:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_213202_55c44bca"}
2026-05-16T21:32:04+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_213202_55c44bca"}
2026-05-16T21:32:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4287,"mtime":"2026-05-16T21:21:35+02:00","run_id":"20260516_213202_55c44bca"}
2026-05-16T21:32:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_213202_55c44bca"}
2026-05-16T21:32:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":12548,"mtime":"2026-05-16T21:21:35+02:00","run_id":"20260516_213202_55c44bca"}
2026-05-16T21:32:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":30,"rb":30,"run_id":"20260516_213202_55c44bca"}
2026-05-16T21:32:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_213202_55c44bca"}
2026-05-16T21:32:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.954,"duration_milliseconds":954,"important":true,"run_id":"20260516_213202_55c44bca"}
2026-05-16T21:32:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_213202_55c44bca"}
2026-05-16T21:32:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_213202_55c44bca"}
2026-05-16T21:32:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_213202_55c44bca"}
2026-05-16T21:32:04+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.097,"duration_milliseconds":97,"important":true,"run_id":"20260516_213202_55c44bca"}
2026-05-16T21:32:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":118789,"run_id":"20260516_213202_55c44bca"}
2026-05-16T21:32:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.873,"exec_milliseconds":1873,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":118789,"important":true,"run_id":"20260516_213202_55c44bca"}
2026-05-16T21:33:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_213301_09064928"}
2026-05-16T21:33:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_213301_09064928"}
2026-05-16T21:33:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_213301_09064928"}
2026-05-16T21:33:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_213301_09064928"}
2026-05-16T21:33:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_213301_09064928"}
2026-05-16T21:33:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_213301_09064928"}
2026-05-16T21:33:02+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_213301_09064928"}
2026-05-16T21:33:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_213301_09064928"}
2026-05-16T21:33:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4287,"mtime":"2026-05-16T21:21:35+02:00","run_id":"20260516_213301_09064928"}
2026-05-16T21:33:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_213301_09064928"}
2026-05-16T21:33:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":12548,"mtime":"2026-05-16T21:21:35+02:00","run_id":"20260516_213301_09064928"}
2026-05-16T21:33:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":30,"rb":30,"run_id":"20260516_213301_09064928"}
2026-05-16T21:33:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_213301_09064928"}
2026-05-16T21:33:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.957,"duration_milliseconds":957,"important":true,"run_id":"20260516_213301_09064928"}
2026-05-16T21:33:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_213301_09064928"}
2026-05-16T21:33:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_213301_09064928"}
2026-05-16T21:33:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_213301_09064928"}
2026-05-16T21:33:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.101,"duration_milliseconds":101,"important":true,"run_id":"20260516_213301_09064928"}
2026-05-16T21:33:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":118789,"run_id":"20260516_213301_09064928"}
2026-05-16T21:33:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.896,"exec_milliseconds":1896,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":118789,"important":true,"run_id":"20260516_213301_09064928"}
2026-05-16T21:34:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_213402_8c0c023d"}
2026-05-16T21:34:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_213402_8c0c023d"}
2026-05-16T21:34:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_213402_8c0c023d"}
2026-05-16T21:34:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_213402_8c0c023d"}
2026-05-16T21:34:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_213402_8c0c023d"}
2026-05-16T21:34:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_213402_8c0c023d"}
2026-05-16T21:34:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_213402_8c0c023d"}
2026-05-16T21:34:04+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_213402_8c0c023d"}
2026-05-16T21:34:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4287,"mtime":"2026-05-16T21:21:35+02:00","run_id":"20260516_213402_8c0c023d"}
2026-05-16T21:34:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_213402_8c0c023d"}
2026-05-16T21:34:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":12548,"mtime":"2026-05-16T21:21:35+02:00","run_id":"20260516_213402_8c0c023d"}
2026-05-16T21:34:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":30,"rb":30,"run_id":"20260516_213402_8c0c023d"}
2026-05-16T21:34:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_213402_8c0c023d"}
2026-05-16T21:34:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.942,"duration_milliseconds":942,"important":true,"run_id":"20260516_213402_8c0c023d"}
2026-05-16T21:34:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_213402_8c0c023d"}
2026-05-16T21:34:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_213402_8c0c023d"}
2026-05-16T21:35:04+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_213504_10fbb2ed"}
2026-05-16T21:35:04+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_213504_10fbb2ed"}
2026-05-16T21:35:04+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_213504_10fbb2ed"}
2026-05-16T21:35:04+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_213504_10fbb2ed"}
2026-05-16T21:35:04+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_213504_10fbb2ed"}
2026-05-16T21:35:04+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_213504_10fbb2ed"}
2026-05-16T21:35:05+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_213504_10fbb2ed"}
2026-05-16T21:35:05+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_213504_10fbb2ed"}
2026-05-16T21:35:05+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4287,"mtime":"2026-05-16T21:34:25+02:00","run_id":"20260516_213504_10fbb2ed"}
2026-05-16T21:35:05+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_213504_10fbb2ed"}
2026-05-16T21:35:05+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":12559,"mtime":"2026-05-16T21:34:25+02:00","run_id":"20260516_213504_10fbb2ed"}
2026-05-16T21:35:05+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":30,"rb":30,"run_id":"20260516_213504_10fbb2ed"}
2026-05-16T21:35:05+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_213504_10fbb2ed"}
2026-05-16T21:35:05+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.928,"duration_milliseconds":928,"important":true,"run_id":"20260516_213504_10fbb2ed"}
2026-05-16T21:35:05+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_213504_10fbb2ed"}
2026-05-16T21:35:06+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_213504_10fbb2ed"}
2026-05-16T21:35:06+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_213504_10fbb2ed"}
2026-05-16T21:35:06+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.081,"duration_milliseconds":81,"important":true,"run_id":"20260516_213504_10fbb2ed"}
2026-05-16T21:35:06+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":118781,"run_id":"20260516_213504_10fbb2ed"}
2026-05-16T21:35:06+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.77,"exec_milliseconds":1770,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":118781,"important":true,"run_id":"20260516_213504_10fbb2ed"}
2026-05-16T21:36:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_213602_4bdda21a"}
2026-05-16T21:36:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_213602_4bdda21a"}
2026-05-16T21:36:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_213602_4bdda21a"}
2026-05-16T21:36:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_213602_4bdda21a"}
2026-05-16T21:36:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_213602_4bdda21a"}
2026-05-16T21:36:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_213602_4bdda21a"}
2026-05-16T21:36:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_213602_4bdda21a"}
2026-05-16T21:36:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_213602_4bdda21a"}
2026-05-16T21:36:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4287,"mtime":"2026-05-16T21:34:25+02:00","run_id":"20260516_213602_4bdda21a"}
2026-05-16T21:36:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_213602_4bdda21a"}
2026-05-16T21:36:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":12559,"mtime":"2026-05-16T21:34:25+02:00","run_id":"20260516_213602_4bdda21a"}
2026-05-16T21:36:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":30,"rb":30,"run_id":"20260516_213602_4bdda21a"}
2026-05-16T21:36:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_213602_4bdda21a"}
2026-05-16T21:36:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":1.001,"duration_milliseconds":1001,"important":true,"run_id":"20260516_213602_4bdda21a"}
2026-05-16T21:36:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_213602_4bdda21a"}
2026-05-16T21:36:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_213602_4bdda21a"}
2026-05-16T21:36:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_213602_4bdda21a"}
2026-05-16T21:36:04+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.093,"duration_milliseconds":93,"important":true,"run_id":"20260516_213602_4bdda21a"}
2026-05-16T21:36:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":118922,"run_id":"20260516_213602_4bdda21a"}
2026-05-16T21:36:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.862,"exec_milliseconds":1862,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":118922,"important":true,"run_id":"20260516_213602_4bdda21a"}
2026-05-16T21:37:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_213701_9baa413e"}
2026-05-16T21:37:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_213701_9baa413e"}
2026-05-16T21:37:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_213701_9baa413e"}
2026-05-16T21:37:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_213701_9baa413e"}
2026-05-16T21:37:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_213701_9baa413e"}
2026-05-16T21:37:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_213701_9baa413e"}
2026-05-16T21:37:02+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_213701_9baa413e"}
2026-05-16T21:37:02+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_213701_9baa413e"}
2026-05-16T21:37:02+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4287,"mtime":"2026-05-16T21:36:57+02:00","run_id":"20260516_213701_9baa413e"}
2026-05-16T21:37:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_213701_9baa413e"}
2026-05-16T21:37:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":5349,"mtime":"2026-05-16T21:36:57+02:00","run_id":"20260516_213701_9baa413e"}
2026-05-16T21:37:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":30,"rb":30,"run_id":"20260516_213701_9baa413e"}
2026-05-16T21:37:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_213701_9baa413e"}
2026-05-16T21:37:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.937,"duration_milliseconds":937,"important":true,"run_id":"20260516_213701_9baa413e"}
2026-05-16T21:37:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_213701_9baa413e"}
2026-05-16T21:37:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_213701_9baa413e"}
2026-05-16T21:38:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_213802_56f62a7c"}
2026-05-16T21:38:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_213802_56f62a7c"}
2026-05-16T21:38:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_213802_56f62a7c"}
2026-05-16T21:38:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_213802_56f62a7c"}
2026-05-16T21:38:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_213802_56f62a7c"}
2026-05-16T21:38:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_213802_56f62a7c"}
2026-05-16T21:38:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_213802_56f62a7c"}
2026-05-16T21:38:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_213802_56f62a7c"}
2026-05-16T21:38:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4287,"mtime":"2026-05-16T21:37:50+02:00","run_id":"20260516_213802_56f62a7c"}
2026-05-16T21:38:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_213802_56f62a7c"}
2026-05-16T21:38:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":5618,"mtime":"2026-05-16T21:37:50+02:00","run_id":"20260516_213802_56f62a7c"}
2026-05-16T21:38:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":32,"rb":30,"run_id":"20260516_213802_56f62a7c"}
2026-05-16T21:38:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_213802_56f62a7c"}
2026-05-16T21:38:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.975,"duration_milliseconds":975,"important":true,"run_id":"20260516_213802_56f62a7c"}
2026-05-16T21:38:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_213802_56f62a7c"}
2026-05-16T21:38:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_213802_56f62a7c"}
2026-05-16T21:38:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_213802_56f62a7c"}
2026-05-16T21:38:04+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.098,"duration_milliseconds":98,"important":true,"run_id":"20260516_213802_56f62a7c"}
2026-05-16T21:38:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":88876,"run_id":"20260516_213802_56f62a7c"}
2026-05-16T21:38:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.857,"exec_milliseconds":1857,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":88876,"important":true,"run_id":"20260516_213802_56f62a7c"}
2026-05-16T21:39:13+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_213901_a0f56f96"}
2026-05-16T21:39:20+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_213901_a0f56f96"}
2026-05-16T21:39:21+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_213901_a0f56f96"}
2026-05-16T21:39:22+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_213901_a0f56f96"}
2026-05-16T21:39:24+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_213901_a0f56f96"}
2026-05-16T21:39:25+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_213901_a0f56f96"}
2026-05-16T21:39:29+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_213901_a0f56f96"}
2026-05-16T21:39:38+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_213901_a0f56f96"}
2026-05-16T21:39:40+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4287,"mtime":"2026-05-16T21:39:25+02:00","run_id":"20260516_213901_a0f56f96"}
2026-05-16T21:39:46+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_213901_a0f56f96"}
2026-05-16T21:39:47+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":6315,"mtime":"2026-05-16T21:39:42+02:00","run_id":"20260516_213901_a0f56f96"}
2026-05-16T21:39:52+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":32,"rb":35,"run_id":"20260516_213901_a0f56f96"}
2026-05-16T21:40:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_213901_a0f56f96"}
2026-05-16T21:40:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":34.048,"duration_milliseconds":34048,"important":true,"run_id":"20260516_213901_a0f56f96"}
2026-05-16T21:40:08+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_213901_a0f56f96"}
2026-05-16T21:40:08+02:00 [WARN] Skipping fallback query due to time budget {"important":true,"run_id":"20260516_213901_a0f56f96"}
2026-05-16T21:40:08+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":88645,"run_id":"20260516_213901_a0f56f96"}
2026-05-16T21:40:08+02:00 [INFO] Cron run finished {"status":"WARN","exec_seconds":66.606,"exec_milliseconds":66606,"live_games":1,"fallback_games":0,"warnings":1,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":1,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":88645,"important":true,"run_id":"20260516_213901_a0f56f96"}
2026-05-16T21:40:18+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_214006_babe9d5b"}
2026-05-16T21:40:19+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_214006_babe9d5b"}
2026-05-16T21:40:19+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_214006_babe9d5b"}
2026-05-16T21:40:19+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_214006_babe9d5b"}
2026-05-16T21:40:19+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_214006_babe9d5b"}
2026-05-16T21:40:19+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_214006_babe9d5b"}
2026-05-16T21:40:19+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_214006_babe9d5b"}
2026-05-16T21:40:20+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_214006_babe9d5b"}
2026-05-16T21:40:20+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4287,"mtime":"2026-05-16T21:40:16+02:00","run_id":"20260516_214006_babe9d5b"}
2026-05-16T21:40:20+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_214006_babe9d5b"}
2026-05-16T21:40:20+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":6530,"mtime":"2026-05-16T21:40:10+02:00","run_id":"20260516_214006_babe9d5b"}
2026-05-16T21:40:20+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":34,"rb":35,"run_id":"20260516_214006_babe9d5b"}
2026-05-16T21:40:20+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_214006_babe9d5b"}
2026-05-16T21:40:20+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.968,"duration_milliseconds":968,"important":true,"run_id":"20260516_214006_babe9d5b"}
2026-05-16T21:40:20+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_214006_babe9d5b"}
2026-05-16T21:40:20+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_214006_babe9d5b"}
2026-05-16T21:40:20+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_214006_babe9d5b"}
2026-05-16T21:40:20+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.085,"duration_milliseconds":85,"important":true,"run_id":"20260516_214006_babe9d5b"}
2026-05-16T21:40:20+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":92665,"run_id":"20260516_214006_babe9d5b"}
2026-05-16T21:40:20+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":13.847,"exec_milliseconds":13847,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":92665,"important":true,"run_id":"20260516_214006_babe9d5b"}
2026-05-16T21:41:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_214101_f1f55767"}
2026-05-16T21:41:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_214101_f1f55767"}
2026-05-16T21:41:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_214101_f1f55767"}
2026-05-16T21:41:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_214101_f1f55767"}
2026-05-16T21:41:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_214101_f1f55767"}
2026-05-16T21:41:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_214101_f1f55767"}
2026-05-16T21:41:02+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_214101_f1f55767"}
2026-05-16T21:41:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_214101_f1f55767"}
2026-05-16T21:41:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4287,"mtime":"2026-05-16T21:40:44+02:00","run_id":"20260516_214101_f1f55767"}
2026-05-16T21:41:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_214101_f1f55767"}
2026-05-16T21:41:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":6868,"mtime":"2026-05-16T21:40:44+02:00","run_id":"20260516_214101_f1f55767"}
2026-05-16T21:41:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":34,"rb":37,"run_id":"20260516_214101_f1f55767"}
2026-05-16T21:41:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_214101_f1f55767"}
2026-05-16T21:41:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.924,"duration_milliseconds":924,"important":true,"run_id":"20260516_214101_f1f55767"}
2026-05-16T21:41:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_214101_f1f55767"}
2026-05-16T21:41:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_214101_f1f55767"}
2026-05-16T21:42:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_214202_973dd7bf"}
2026-05-16T21:42:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_214202_973dd7bf"}
2026-05-16T21:42:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_214202_973dd7bf"}
2026-05-16T21:42:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_214202_973dd7bf"}
2026-05-16T21:42:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_214202_973dd7bf"}
2026-05-16T21:42:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_214202_973dd7bf"}
2026-05-16T21:42:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_214202_973dd7bf"}
2026-05-16T21:42:04+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_214202_973dd7bf"}
2026-05-16T21:42:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4287,"mtime":"2026-05-16T21:41:52+02:00","run_id":"20260516_214202_973dd7bf"}
2026-05-16T21:42:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_214202_973dd7bf"}
2026-05-16T21:42:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":7389,"mtime":"2026-05-16T21:41:52+02:00","run_id":"20260516_214202_973dd7bf"}
2026-05-16T21:42:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":37,"rb":39,"run_id":"20260516_214202_973dd7bf"}
2026-05-16T21:42:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_214202_973dd7bf"}
2026-05-16T21:42:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.959,"duration_milliseconds":959,"important":true,"run_id":"20260516_214202_973dd7bf"}
2026-05-16T21:42:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_214202_973dd7bf"}
2026-05-16T21:42:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_214202_973dd7bf"}
2026-05-16T21:42:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_214202_973dd7bf"}
2026-05-16T21:42:04+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.098,"duration_milliseconds":98,"important":true,"run_id":"20260516_214202_973dd7bf"}
2026-05-16T21:42:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":96357,"run_id":"20260516_214202_973dd7bf"}
2026-05-16T21:42:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.811,"exec_milliseconds":1811,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":96357,"important":true,"run_id":"20260516_214202_973dd7bf"}
2026-05-16T21:43:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_214301_46b385c4"}
2026-05-16T21:43:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_214301_46b385c4"}
2026-05-16T21:43:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_214301_46b385c4"}
2026-05-16T21:43:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_214301_46b385c4"}
2026-05-16T21:43:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_214301_46b385c4"}
2026-05-16T21:43:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_214301_46b385c4"}
2026-05-16T21:43:02+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_214301_46b385c4"}
2026-05-16T21:43:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_214301_46b385c4"}
2026-05-16T21:43:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4287,"mtime":"2026-05-16T21:42:59+02:00","run_id":"20260516_214301_46b385c4"}
2026-05-16T21:43:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_214301_46b385c4"}
2026-05-16T21:43:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":7956,"mtime":"2026-05-16T21:42:59+02:00","run_id":"20260516_214301_46b385c4"}
2026-05-16T21:43:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":37,"rb":41,"run_id":"20260516_214301_46b385c4"}
2026-05-16T21:43:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_214301_46b385c4"}
2026-05-16T21:43:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.932,"duration_milliseconds":932,"important":true,"run_id":"20260516_214301_46b385c4"}
2026-05-16T21:43:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_214301_46b385c4"}
2026-05-16T21:43:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_214301_46b385c4"}
2026-05-16T21:43:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_214301_46b385c4"}
2026-05-16T21:43:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.084,"duration_milliseconds":84,"important":true,"run_id":"20260516_214301_46b385c4"}
2026-05-16T21:43:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":98780,"run_id":"20260516_214301_46b385c4"}
2026-05-16T21:43:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.882,"exec_milliseconds":1882,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":98780,"important":true,"run_id":"20260516_214301_46b385c4"}
2026-05-16T21:44:03+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_214402_14a7e203"}
2026-05-16T21:44:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_214402_14a7e203"}
2026-05-16T21:44:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_214402_14a7e203"}
2026-05-16T21:44:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_214402_14a7e203"}
2026-05-16T21:44:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_214402_14a7e203"}
2026-05-16T21:44:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_214402_14a7e203"}
2026-05-16T21:44:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_214402_14a7e203"}
2026-05-16T21:44:04+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_214402_14a7e203"}
2026-05-16T21:44:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4287,"mtime":"2026-05-16T21:43:53+02:00","run_id":"20260516_214402_14a7e203"}
2026-05-16T21:44:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_214402_14a7e203"}
2026-05-16T21:44:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":8743,"mtime":"2026-05-16T21:43:53+02:00","run_id":"20260516_214402_14a7e203"}
2026-05-16T21:44:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":37,"rb":43,"run_id":"20260516_214402_14a7e203"}
2026-05-16T21:44:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_214402_14a7e203"}
2026-05-16T21:44:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.956,"duration_milliseconds":956,"important":true,"run_id":"20260516_214402_14a7e203"}
2026-05-16T21:44:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_214402_14a7e203"}
2026-05-16T21:44:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_214402_14a7e203"}
2026-05-16T21:44:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_214402_14a7e203"}
2026-05-16T21:44:04+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.085,"duration_milliseconds":85,"important":true,"run_id":"20260516_214402_14a7e203"}
2026-05-16T21:44:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":102169,"run_id":"20260516_214402_14a7e203"}
2026-05-16T21:44:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.882,"exec_milliseconds":1882,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":102169,"important":true,"run_id":"20260516_214402_14a7e203"}
2026-05-16T21:45:07+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_214507_5ae28361"}
2026-05-16T21:45:07+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_214507_5ae28361"}
2026-05-16T21:45:07+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_214507_5ae28361"}
2026-05-16T21:45:07+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_214507_5ae28361"}
2026-05-16T21:45:07+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_214507_5ae28361"}
2026-05-16T21:45:07+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_214507_5ae28361"}
2026-05-16T21:45:07+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_214507_5ae28361"}
2026-05-16T21:45:08+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_214507_5ae28361"}
2026-05-16T21:45:08+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4287,"mtime":"2026-05-16T21:44:22+02:00","run_id":"20260516_214507_5ae28361"}
2026-05-16T21:45:08+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_214507_5ae28361"}
2026-05-16T21:45:08+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":8743,"mtime":"2026-05-16T21:44:22+02:00","run_id":"20260516_214507_5ae28361"}
2026-05-16T21:45:08+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":37,"rb":43,"run_id":"20260516_214507_5ae28361"}
2026-05-16T21:45:08+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_214507_5ae28361"}
2026-05-16T21:45:08+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.936,"duration_milliseconds":936,"important":true,"run_id":"20260516_214507_5ae28361"}
2026-05-16T21:45:08+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_214507_5ae28361"}
2026-05-16T21:45:08+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_214507_5ae28361"}
2026-05-16T21:45:08+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_214507_5ae28361"}
2026-05-16T21:45:08+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.097,"duration_milliseconds":97,"important":true,"run_id":"20260516_214507_5ae28361"}
2026-05-16T21:45:08+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":102127,"run_id":"20260516_214507_5ae28361"}
2026-05-16T21:45:08+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.829,"exec_milliseconds":1829,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":102127,"important":true,"run_id":"20260516_214507_5ae28361"}
2026-05-16T21:46:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_214602_7606d2fa"}
2026-05-16T21:46:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_214602_7606d2fa"}
2026-05-16T21:46:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_214602_7606d2fa"}
2026-05-16T21:46:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_214602_7606d2fa"}
2026-05-16T21:46:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_214602_7606d2fa"}
2026-05-16T21:46:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_214602_7606d2fa"}
2026-05-16T21:46:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_214602_7606d2fa"}
2026-05-16T21:46:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_214602_7606d2fa"}
2026-05-16T21:46:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4287,"mtime":"2026-05-16T21:46:02+02:00","run_id":"20260516_214602_7606d2fa"}
2026-05-16T21:46:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_214602_7606d2fa"}
2026-05-16T21:46:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":9042,"mtime":"2026-05-16T21:46:01+02:00","run_id":"20260516_214602_7606d2fa"}
2026-05-16T21:46:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":39,"rb":44,"run_id":"20260516_214602_7606d2fa"}
2026-05-16T21:46:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_214602_7606d2fa"}
2026-05-16T21:46:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.955,"duration_milliseconds":955,"important":true,"run_id":"20260516_214602_7606d2fa"}
2026-05-16T21:46:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_214602_7606d2fa"}
2026-05-16T21:46:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_214602_7606d2fa"}
2026-05-16T21:46:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_214602_7606d2fa"}
2026-05-16T21:46:04+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.089,"duration_milliseconds":89,"important":true,"run_id":"20260516_214602_7606d2fa"}
2026-05-16T21:46:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":103414,"run_id":"20260516_214602_7606d2fa"}
2026-05-16T21:46:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.851,"exec_milliseconds":1851,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":103414,"important":true,"run_id":"20260516_214602_7606d2fa"}
2026-05-16T21:47:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_214701_943dac72"}
2026-05-16T21:47:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_214701_943dac72"}
2026-05-16T21:47:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_214701_943dac72"}
2026-05-16T21:47:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_214701_943dac72"}
2026-05-16T21:47:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_214701_943dac72"}
2026-05-16T21:47:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_214701_943dac72"}
2026-05-16T21:47:02+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_214701_943dac72"}
2026-05-16T21:47:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_214701_943dac72"}
2026-05-16T21:47:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4287,"mtime":"2026-05-16T21:46:45+02:00","run_id":"20260516_214701_943dac72"}
2026-05-16T21:47:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_214701_943dac72"}
2026-05-16T21:47:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":9494,"mtime":"2026-05-16T21:46:45+02:00","run_id":"20260516_214701_943dac72"}
2026-05-16T21:47:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":39,"rb":44,"run_id":"20260516_214701_943dac72"}
2026-05-16T21:47:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_214701_943dac72"}
2026-05-16T21:47:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.968,"duration_milliseconds":968,"important":true,"run_id":"20260516_214701_943dac72"}
2026-05-16T21:47:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_214701_943dac72"}
2026-05-16T21:47:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_214701_943dac72"}
2026-05-16T21:47:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_214701_943dac72"}
2026-05-16T21:47:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.095,"duration_milliseconds":95,"important":true,"run_id":"20260516_214701_943dac72"}
2026-05-16T21:47:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":105370,"run_id":"20260516_214701_943dac72"}
2026-05-16T21:47:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.836,"exec_milliseconds":1836,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":105370,"important":true,"run_id":"20260516_214701_943dac72"}
2026-05-16T21:48:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_214802_426bc202"}
2026-05-16T21:48:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_214802_426bc202"}
2026-05-16T21:48:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_214802_426bc202"}
2026-05-16T21:48:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_214802_426bc202"}
2026-05-16T21:48:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_214802_426bc202"}
2026-05-16T21:48:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_214802_426bc202"}
2026-05-16T21:48:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_214802_426bc202"}
2026-05-16T21:48:04+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_214802_426bc202"}
2026-05-16T21:48:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4287,"mtime":"2026-05-16T21:47:55+02:00","run_id":"20260516_214802_426bc202"}
2026-05-16T21:48:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_214802_426bc202"}
2026-05-16T21:48:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":9798,"mtime":"2026-05-16T21:47:55+02:00","run_id":"20260516_214802_426bc202"}
2026-05-16T21:48:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":39,"rb":44,"run_id":"20260516_214802_426bc202"}
2026-05-16T21:48:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_214802_426bc202"}
2026-05-16T21:48:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.932,"duration_milliseconds":932,"important":true,"run_id":"20260516_214802_426bc202"}
2026-05-16T21:48:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_214802_426bc202"}
2026-05-16T21:48:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_214802_426bc202"}
2026-05-16T21:48:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_214802_426bc202"}
2026-05-16T21:48:04+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.086,"duration_milliseconds":86,"important":true,"run_id":"20260516_214802_426bc202"}
2026-05-16T21:48:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":106678,"run_id":"20260516_214802_426bc202"}
2026-05-16T21:48:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.789,"exec_milliseconds":1789,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":106678,"important":true,"run_id":"20260516_214802_426bc202"}
2026-05-16T21:49:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_214901_6432e9c4"}
2026-05-16T21:49:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_214901_6432e9c4"}
2026-05-16T21:49:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_214901_6432e9c4"}
2026-05-16T21:49:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_214901_6432e9c4"}
2026-05-16T21:49:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_214901_6432e9c4"}
2026-05-16T21:49:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_214901_6432e9c4"}
2026-05-16T21:49:02+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_214901_6432e9c4"}
2026-05-16T21:49:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_214901_6432e9c4"}
2026-05-16T21:49:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4287,"mtime":"2026-05-16T21:48:57+02:00","run_id":"20260516_214901_6432e9c4"}
2026-05-16T21:49:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_214901_6432e9c4"}
2026-05-16T21:49:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":10168,"mtime":"2026-05-16T21:48:56+02:00","run_id":"20260516_214901_6432e9c4"}
2026-05-16T21:49:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":39,"rb":44,"run_id":"20260516_214901_6432e9c4"}
2026-05-16T21:49:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_214901_6432e9c4"}
2026-05-16T21:49:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.971,"duration_milliseconds":971,"important":true,"run_id":"20260516_214901_6432e9c4"}
2026-05-16T21:49:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_214901_6432e9c4"}
2026-05-16T21:49:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_214901_6432e9c4"}
2026-05-16T21:49:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_214901_6432e9c4"}
2026-05-16T21:49:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.096,"duration_milliseconds":96,"important":true,"run_id":"20260516_214901_6432e9c4"}
2026-05-16T21:49:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":108294,"run_id":"20260516_214901_6432e9c4"}
2026-05-16T21:49:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.875,"exec_milliseconds":1875,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":108294,"important":true,"run_id":"20260516_214901_6432e9c4"}
2026-05-16T21:50:06+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_215006_adb633e7"}
2026-05-16T21:50:06+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_215006_adb633e7"}
2026-05-16T21:50:06+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_215006_adb633e7"}
2026-05-16T21:50:06+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_215006_adb633e7"}
2026-05-16T21:50:06+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_215006_adb633e7"}
2026-05-16T21:50:06+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_215006_adb633e7"}
2026-05-16T21:50:06+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_215006_adb633e7"}
2026-05-16T21:50:07+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_215006_adb633e7"}
2026-05-16T21:50:07+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4287,"mtime":"2026-05-16T21:50:05+02:00","run_id":"20260516_215006_adb633e7"}
2026-05-16T21:50:07+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_215006_adb633e7"}
2026-05-16T21:50:07+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":10665,"mtime":"2026-05-16T21:50:04+02:00","run_id":"20260516_215006_adb633e7"}
2026-05-16T21:50:07+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":39,"rb":46,"run_id":"20260516_215006_adb633e7"}
2026-05-16T21:50:07+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_215006_adb633e7"}
2026-05-16T21:50:07+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.96,"duration_milliseconds":960,"important":true,"run_id":"20260516_215006_adb633e7"}
2026-05-16T21:50:07+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_215006_adb633e7"}
2026-05-16T21:50:07+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_215006_adb633e7"}
2026-05-16T21:50:07+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_215006_adb633e7"}
2026-05-16T21:50:07+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.099,"duration_milliseconds":99,"important":true,"run_id":"20260516_215006_adb633e7"}
2026-05-16T21:50:07+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":110359,"run_id":"20260516_215006_adb633e7"}
2026-05-16T21:50:07+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.863,"exec_milliseconds":1863,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":110359,"important":true,"run_id":"20260516_215006_adb633e7"}
2026-05-16T21:51:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_215101_170efbd2"}
2026-05-16T21:51:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_215101_170efbd2"}
2026-05-16T21:51:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_215101_170efbd2"}
2026-05-16T21:51:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_215101_170efbd2"}
2026-05-16T21:51:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_215101_170efbd2"}
2026-05-16T21:51:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_215101_170efbd2"}
2026-05-16T21:51:02+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_215101_170efbd2"}
2026-05-16T21:51:02+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_215101_170efbd2"}
2026-05-16T21:51:02+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4287,"mtime":"2026-05-16T21:50:51+02:00","run_id":"20260516_215101_170efbd2"}
2026-05-16T21:51:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_215101_170efbd2"}
2026-05-16T21:51:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":11080,"mtime":"2026-05-16T21:50:51+02:00","run_id":"20260516_215101_170efbd2"}
2026-05-16T21:51:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":39,"rb":48,"run_id":"20260516_215101_170efbd2"}
2026-05-16T21:51:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_215101_170efbd2"}
2026-05-16T21:51:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.956,"duration_milliseconds":956,"important":true,"run_id":"20260516_215101_170efbd2"}
2026-05-16T21:51:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_215101_170efbd2"}
2026-05-16T21:51:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_215101_170efbd2"}
2026-05-16T21:51:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_215101_170efbd2"}
2026-05-16T21:51:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.094,"duration_milliseconds":94,"important":true,"run_id":"20260516_215101_170efbd2"}
2026-05-16T21:51:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":112172,"run_id":"20260516_215101_170efbd2"}
2026-05-16T21:51:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.827,"exec_milliseconds":1827,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":112172,"important":true,"run_id":"20260516_215101_170efbd2"}
2026-05-16T21:52:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_215202_c5be22ce"}
2026-05-16T21:52:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_215202_c5be22ce"}
2026-05-16T21:52:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_215202_c5be22ce"}
2026-05-16T21:52:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_215202_c5be22ce"}
2026-05-16T21:52:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_215202_c5be22ce"}
2026-05-16T21:52:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_215202_c5be22ce"}
2026-05-16T21:52:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_215202_c5be22ce"}
2026-05-16T21:52:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_215202_c5be22ce"}
2026-05-16T21:52:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4287,"mtime":"2026-05-16T21:51:52+02:00","run_id":"20260516_215202_c5be22ce"}
2026-05-16T21:52:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_215202_c5be22ce"}
2026-05-16T21:52:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":11793,"mtime":"2026-05-16T21:51:51+02:00","run_id":"20260516_215202_c5be22ce"}
2026-05-16T21:52:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":41,"rb":52,"run_id":"20260516_215202_c5be22ce"}
2026-05-16T21:52:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_215202_c5be22ce"}
2026-05-16T21:52:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.936,"duration_milliseconds":936,"important":true,"run_id":"20260516_215202_c5be22ce"}
2026-05-16T21:52:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_215202_c5be22ce"}
2026-05-16T21:52:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_215202_c5be22ce"}
2026-05-16T21:52:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_215202_c5be22ce"}
2026-05-16T21:52:04+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.088,"duration_milliseconds":88,"important":true,"run_id":"20260516_215202_c5be22ce"}
2026-05-16T21:52:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":115183,"run_id":"20260516_215202_c5be22ce"}
2026-05-16T21:52:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.816,"exec_milliseconds":1816,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":115183,"important":true,"run_id":"20260516_215202_c5be22ce"}
2026-05-16T21:53:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_215301_f92cc964"}
2026-05-16T21:53:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_215301_f92cc964"}
2026-05-16T21:53:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_215301_f92cc964"}
2026-05-16T21:53:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_215301_f92cc964"}
2026-05-16T21:53:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_215301_f92cc964"}
2026-05-16T21:53:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_215301_f92cc964"}
2026-05-16T21:53:02+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_215301_f92cc964"}
2026-05-16T21:53:02+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_215301_f92cc964"}
2026-05-16T21:53:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4287,"mtime":"2026-05-16T21:53:01+02:00","run_id":"20260516_215301_f92cc964"}
2026-05-16T21:53:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_215301_f92cc964"}
2026-05-16T21:53:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":12168,"mtime":"2026-05-16T21:53:01+02:00","run_id":"20260516_215301_f92cc964"}
2026-05-16T21:53:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":41,"rb":52,"run_id":"20260516_215301_f92cc964"}
2026-05-16T21:53:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_215301_f92cc964"}
2026-05-16T21:53:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.951,"duration_milliseconds":951,"important":true,"run_id":"20260516_215301_f92cc964"}
2026-05-16T21:53:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_215301_f92cc964"}
2026-05-16T21:53:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_215301_f92cc964"}
2026-05-16T21:53:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_215301_f92cc964"}
2026-05-16T21:53:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.092,"duration_milliseconds":92,"important":true,"run_id":"20260516_215301_f92cc964"}
2026-05-16T21:53:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":116808,"run_id":"20260516_215301_f92cc964"}
2026-05-16T21:53:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.834,"exec_milliseconds":1834,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":116808,"important":true,"run_id":"20260516_215301_f92cc964"}
2026-05-16T21:54:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_215402_dbeef32a"}
2026-05-16T21:54:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_215402_dbeef32a"}
2026-05-16T21:54:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_215402_dbeef32a"}
2026-05-16T21:54:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_215402_dbeef32a"}
2026-05-16T21:54:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_215402_dbeef32a"}
2026-05-16T21:54:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_215402_dbeef32a"}
2026-05-16T21:54:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_215402_dbeef32a"}
2026-05-16T21:54:04+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_215402_dbeef32a"}
2026-05-16T21:54:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4287,"mtime":"2026-05-16T21:53:42+02:00","run_id":"20260516_215402_dbeef32a"}
2026-05-16T21:54:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_215402_dbeef32a"}
2026-05-16T21:54:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":12464,"mtime":"2026-05-16T21:53:42+02:00","run_id":"20260516_215402_dbeef32a"}
2026-05-16T21:54:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":41,"rb":52,"run_id":"20260516_215402_dbeef32a"}
2026-05-16T21:54:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_215402_dbeef32a"}
2026-05-16T21:54:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.949,"duration_milliseconds":949,"important":true,"run_id":"20260516_215402_dbeef32a"}
2026-05-16T21:54:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_215402_dbeef32a"}
2026-05-16T21:54:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_215402_dbeef32a"}
2026-05-16T21:54:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_215402_dbeef32a"}
2026-05-16T21:54:04+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.092,"duration_milliseconds":92,"important":true,"run_id":"20260516_215402_dbeef32a"}
2026-05-16T21:54:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":118100,"run_id":"20260516_215402_dbeef32a"}
2026-05-16T21:54:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.823,"exec_milliseconds":1823,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":118100,"important":true,"run_id":"20260516_215402_dbeef32a"}
2026-05-16T21:55:04+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_215504_63d496ab"}
2026-05-16T21:55:04+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_215504_63d496ab"}
2026-05-16T21:55:04+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_215504_63d496ab"}
2026-05-16T21:55:04+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_215504_63d496ab"}
2026-05-16T21:55:04+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_215504_63d496ab"}
2026-05-16T21:55:04+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_215504_63d496ab"}
2026-05-16T21:55:04+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_215504_63d496ab"}
2026-05-16T21:55:05+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_215504_63d496ab"}
2026-05-16T21:55:05+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4287,"mtime":"2026-05-16T21:54:57+02:00","run_id":"20260516_215504_63d496ab"}
2026-05-16T21:55:05+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_215504_63d496ab"}
2026-05-16T21:55:05+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":12777,"mtime":"2026-05-16T21:54:57+02:00","run_id":"20260516_215504_63d496ab"}
2026-05-16T21:55:05+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":43,"rb":54,"run_id":"20260516_215504_63d496ab"}
2026-05-16T21:55:05+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_215504_63d496ab"}
2026-05-16T21:55:05+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.962,"duration_milliseconds":962,"important":true,"run_id":"20260516_215504_63d496ab"}
2026-05-16T21:55:05+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_215504_63d496ab"}
2026-05-16T21:55:06+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_215504_63d496ab"}
2026-05-16T21:55:06+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_215504_63d496ab"}
2026-05-16T21:55:06+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.096,"duration_milliseconds":96,"important":true,"run_id":"20260516_215504_63d496ab"}
2026-05-16T21:55:06+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":119337,"run_id":"20260516_215504_63d496ab"}
2026-05-16T21:55:06+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.829,"exec_milliseconds":1829,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":119337,"important":true,"run_id":"20260516_215504_63d496ab"}
2026-05-16T21:56:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_215602_264bbd0f"}
2026-05-16T21:56:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_215602_264bbd0f"}
2026-05-16T21:56:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_215602_264bbd0f"}
2026-05-16T21:56:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_215602_264bbd0f"}
2026-05-16T21:56:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_215602_264bbd0f"}
2026-05-16T21:56:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_215602_264bbd0f"}
2026-05-16T21:56:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_215602_264bbd0f"}
2026-05-16T21:56:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_215602_264bbd0f"}
2026-05-16T21:56:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4287,"mtime":"2026-05-16T21:55:36+02:00","run_id":"20260516_215602_264bbd0f"}
2026-05-16T21:56:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_215602_264bbd0f"}
2026-05-16T21:56:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":13112,"mtime":"2026-05-16T21:55:36+02:00","run_id":"20260516_215602_264bbd0f"}
2026-05-16T21:56:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":45,"rb":54,"run_id":"20260516_215602_264bbd0f"}
2026-05-16T21:56:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_215602_264bbd0f"}
2026-05-16T21:56:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.93,"duration_milliseconds":930,"important":true,"run_id":"20260516_215602_264bbd0f"}
2026-05-16T21:56:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_215602_264bbd0f"}
2026-05-16T21:56:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_215602_264bbd0f"}
2026-05-16T21:56:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_215602_264bbd0f"}
2026-05-16T21:56:04+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.088,"duration_milliseconds":88,"important":true,"run_id":"20260516_215602_264bbd0f"}
2026-05-16T21:56:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":120812,"run_id":"20260516_215602_264bbd0f"}
2026-05-16T21:56:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.828,"exec_milliseconds":1828,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":120812,"important":true,"run_id":"20260516_215602_264bbd0f"}
2026-05-16T21:57:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_215701_de0a87ad"}
2026-05-16T21:57:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_215701_de0a87ad"}
2026-05-16T21:57:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_215701_de0a87ad"}
2026-05-16T21:57:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_215701_de0a87ad"}
2026-05-16T21:57:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_215701_de0a87ad"}
2026-05-16T21:57:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_215701_de0a87ad"}
2026-05-16T21:57:02+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_215701_de0a87ad"}
2026-05-16T21:57:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_215701_de0a87ad"}
2026-05-16T21:57:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4287,"mtime":"2026-05-16T21:56:53+02:00","run_id":"20260516_215701_de0a87ad"}
2026-05-16T21:57:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_215701_de0a87ad"}
2026-05-16T21:57:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":13262,"mtime":"2026-05-16T21:56:53+02:00","run_id":"20260516_215701_de0a87ad"}
2026-05-16T21:57:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":45,"rb":54,"run_id":"20260516_215701_de0a87ad"}
2026-05-16T21:57:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_215701_de0a87ad"}
2026-05-16T21:57:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":1,"duration_milliseconds":1000,"important":true,"run_id":"20260516_215701_de0a87ad"}
2026-05-16T21:57:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_215701_de0a87ad"}
2026-05-16T21:57:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_215701_de0a87ad"}
2026-05-16T21:57:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_215701_de0a87ad"}
2026-05-16T21:57:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.102,"duration_milliseconds":102,"important":true,"run_id":"20260516_215701_de0a87ad"}
2026-05-16T21:57:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":121463,"run_id":"20260516_215701_de0a87ad"}
2026-05-16T21:57:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.97,"exec_milliseconds":1970,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":121463,"important":true,"run_id":"20260516_215701_de0a87ad"}
2026-05-16T21:58:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_215802_2ce68b89"}
2026-05-16T21:58:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_215802_2ce68b89"}
2026-05-16T21:58:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_215802_2ce68b89"}
2026-05-16T21:58:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_215802_2ce68b89"}
2026-05-16T21:58:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_215802_2ce68b89"}
2026-05-16T21:58:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_215802_2ce68b89"}
2026-05-16T21:58:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_215802_2ce68b89"}
2026-05-16T21:58:04+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_215802_2ce68b89"}
2026-05-16T21:58:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4287,"mtime":"2026-05-16T21:57:55+02:00","run_id":"20260516_215802_2ce68b89"}
2026-05-16T21:58:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_215802_2ce68b89"}
2026-05-16T21:58:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":13566,"mtime":"2026-05-16T21:57:54+02:00","run_id":"20260516_215802_2ce68b89"}
2026-05-16T21:58:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":45,"rb":54,"run_id":"20260516_215802_2ce68b89"}
2026-05-16T21:58:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_215802_2ce68b89"}
2026-05-16T21:58:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.937,"duration_milliseconds":937,"important":true,"run_id":"20260516_215802_2ce68b89"}
2026-05-16T21:58:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_215802_2ce68b89"}
2026-05-16T21:58:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_215802_2ce68b89"}
2026-05-16T21:59:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_215901_adac4061"}
2026-05-16T21:59:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_215901_adac4061"}
2026-05-16T21:59:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_215901_adac4061"}
2026-05-16T21:59:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_215901_adac4061"}
2026-05-16T21:59:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_215901_adac4061"}
2026-05-16T21:59:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_215901_adac4061"}
2026-05-16T21:59:02+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_215901_adac4061"}
2026-05-16T21:59:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_215901_adac4061"}
2026-05-16T21:59:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4287,"mtime":"2026-05-16T21:58:48+02:00","run_id":"20260516_215901_adac4061"}
2026-05-16T21:59:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_215901_adac4061"}
2026-05-16T21:59:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":13936,"mtime":"2026-05-16T21:58:48+02:00","run_id":"20260516_215901_adac4061"}
2026-05-16T21:59:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":45,"rb":54,"run_id":"20260516_215901_adac4061"}
2026-05-16T21:59:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_215901_adac4061"}
2026-05-16T21:59:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.952,"duration_milliseconds":952,"important":true,"run_id":"20260516_215901_adac4061"}
2026-05-16T21:59:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_215901_adac4061"}
2026-05-16T21:59:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_215901_adac4061"}
2026-05-16T21:59:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_215901_adac4061"}
2026-05-16T21:59:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.089,"duration_milliseconds":89,"important":true,"run_id":"20260516_215901_adac4061"}
2026-05-16T21:59:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":124386,"run_id":"20260516_215901_adac4061"}
2026-05-16T21:59:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.825,"exec_milliseconds":1825,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":124386,"important":true,"run_id":"20260516_215901_adac4061"}
2026-05-16T22:00:18+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_220018_936b419a"}
2026-05-16T22:00:18+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_220018_936b419a"}
2026-05-16T22:00:18+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_220018_936b419a"}
2026-05-16T22:00:18+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_220018_936b419a"}
2026-05-16T22:00:19+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_220018_936b419a"}
2026-05-16T22:00:19+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_220018_936b419a"}
2026-05-16T22:00:19+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_220018_936b419a"}
2026-05-16T22:00:19+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_220018_936b419a"}
2026-05-16T22:00:19+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4287,"mtime":"2026-05-16T22:00:19+02:00","run_id":"20260516_220018_936b419a"}
2026-05-16T22:00:19+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_220018_936b419a"}
2026-05-16T22:00:19+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":14082,"mtime":"2026-05-16T22:00:18+02:00","run_id":"20260516_220018_936b419a"}
2026-05-16T22:00:19+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":45,"rb":54,"run_id":"20260516_220018_936b419a"}
2026-05-16T22:00:20+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_220018_936b419a"}
2026-05-16T22:00:20+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.945,"duration_milliseconds":945,"important":true,"run_id":"20260516_220018_936b419a"}
2026-05-16T22:00:20+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_220018_936b419a"}
2026-05-16T22:00:20+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_220018_936b419a"}
2026-05-16T22:00:20+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_220018_936b419a"}
2026-05-16T22:00:20+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.095,"duration_milliseconds":95,"important":true,"run_id":"20260516_220018_936b419a"}
2026-05-16T22:00:20+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":125034,"run_id":"20260516_220018_936b419a"}
2026-05-16T22:00:20+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.848,"exec_milliseconds":1848,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":125034,"important":true,"run_id":"20260516_220018_936b419a"}
2026-05-16T22:01:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_220101_35b558e8"}
2026-05-16T22:01:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_220101_35b558e8"}
2026-05-16T22:01:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_220101_35b558e8"}
2026-05-16T22:01:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_220101_35b558e8"}
2026-05-16T22:01:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_220101_35b558e8"}
2026-05-16T22:01:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_220101_35b558e8"}
2026-05-16T22:01:02+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_220101_35b558e8"}
2026-05-16T22:01:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_220101_35b558e8"}
2026-05-16T22:01:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4287,"mtime":"2026-05-16T22:01:02+02:00","run_id":"20260516_220101_35b558e8"}
2026-05-16T22:01:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_220101_35b558e8"}
2026-05-16T22:01:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":14083,"mtime":"2026-05-16T22:01:02+02:00","run_id":"20260516_220101_35b558e8"}
2026-05-16T22:01:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":45,"rb":54,"run_id":"20260516_220101_35b558e8"}
2026-05-16T22:01:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_220101_35b558e8"}
2026-05-16T22:01:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.972,"duration_milliseconds":972,"important":true,"run_id":"20260516_220101_35b558e8"}
2026-05-16T22:01:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_220101_35b558e8"}
2026-05-16T22:01:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_220101_35b558e8"}
2026-05-16T22:01:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_220101_35b558e8"}
2026-05-16T22:01:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.089,"duration_milliseconds":89,"important":true,"run_id":"20260516_220101_35b558e8"}
2026-05-16T22:01:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":125039,"run_id":"20260516_220101_35b558e8"}
2026-05-16T22:01:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.838,"exec_milliseconds":1838,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":125039,"important":true,"run_id":"20260516_220101_35b558e8"}
2026-05-16T22:02:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_220202_71de4e30"}
2026-05-16T22:02:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_220202_71de4e30"}
2026-05-16T22:02:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_220202_71de4e30"}
2026-05-16T22:02:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_220202_71de4e30"}
2026-05-16T22:02:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_220202_71de4e30"}
2026-05-16T22:02:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_220202_71de4e30"}
2026-05-16T22:02:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_220202_71de4e30"}
2026-05-16T22:02:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_220202_71de4e30"}
2026-05-16T22:02:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4287,"mtime":"2026-05-16T22:02:01+02:00","run_id":"20260516_220202_71de4e30"}
2026-05-16T22:02:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_220202_71de4e30"}
2026-05-16T22:02:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":6288,"mtime":"2026-05-16T22:02:00+02:00","run_id":"20260516_220202_71de4e30"}
2026-05-16T22:02:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":45,"rb":54,"run_id":"20260516_220202_71de4e30"}
2026-05-16T22:02:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_220202_71de4e30"}
2026-05-16T22:02:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.956,"duration_milliseconds":956,"important":true,"run_id":"20260516_220202_71de4e30"}
2026-05-16T22:02:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_220202_71de4e30"}
2026-05-16T22:02:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_220202_71de4e30"}
2026-05-16T22:03:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_220301_ae695958"}
2026-05-16T22:03:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_220301_ae695958"}
2026-05-16T22:03:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_220301_ae695958"}
2026-05-16T22:03:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_220301_ae695958"}
2026-05-16T22:03:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_220301_ae695958"}
2026-05-16T22:03:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_220301_ae695958"}
2026-05-16T22:03:02+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_220301_ae695958"}
2026-05-16T22:03:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_220301_ae695958"}
2026-05-16T22:03:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4287,"mtime":"2026-05-16T22:02:44+02:00","run_id":"20260516_220301_ae695958"}
2026-05-16T22:03:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_220301_ae695958"}
2026-05-16T22:03:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":6508,"mtime":"2026-05-16T22:02:44+02:00","run_id":"20260516_220301_ae695958"}
2026-05-16T22:03:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":45,"rb":56,"run_id":"20260516_220301_ae695958"}
2026-05-16T22:03:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_220301_ae695958"}
2026-05-16T22:03:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.981,"duration_milliseconds":981,"important":true,"run_id":"20260516_220301_ae695958"}
2026-05-16T22:03:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_220301_ae695958"}
2026-05-16T22:03:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_220301_ae695958"}
2026-05-16T22:03:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_220301_ae695958"}
2026-05-16T22:03:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.095,"duration_milliseconds":95,"important":true,"run_id":"20260516_220301_ae695958"}
2026-05-16T22:03:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":92464,"run_id":"20260516_220301_ae695958"}
2026-05-16T22:03:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.898,"exec_milliseconds":1898,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":92464,"important":true,"run_id":"20260516_220301_ae695958"}
2026-05-16T22:04:03+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_220402_c0dcac37"}
2026-05-16T22:04:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_220402_c0dcac37"}
2026-05-16T22:04:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_220402_c0dcac37"}
2026-05-16T22:04:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_220402_c0dcac37"}
2026-05-16T22:04:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_220402_c0dcac37"}
2026-05-16T22:04:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_220402_c0dcac37"}
2026-05-16T22:04:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_220402_c0dcac37"}
2026-05-16T22:04:04+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_220402_c0dcac37"}
2026-05-16T22:04:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4287,"mtime":"2026-05-16T22:03:54+02:00","run_id":"20260516_220402_c0dcac37"}
2026-05-16T22:04:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_220402_c0dcac37"}
2026-05-16T22:04:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":7000,"mtime":"2026-05-16T22:04:03+02:00","run_id":"20260516_220402_c0dcac37"}
2026-05-16T22:04:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":45,"rb":58,"run_id":"20260516_220402_c0dcac37"}
2026-05-16T22:04:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_220402_c0dcac37"}
2026-05-16T22:04:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.948,"duration_milliseconds":948,"important":true,"run_id":"20260516_220402_c0dcac37"}
2026-05-16T22:04:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_220402_c0dcac37"}
2026-05-16T22:04:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_220402_c0dcac37"}
2026-05-16T22:05:04+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_220504_bdd90636"}
2026-05-16T22:05:04+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_220504_bdd90636"}
2026-05-16T22:05:04+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_220504_bdd90636"}
2026-05-16T22:05:04+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_220504_bdd90636"}
2026-05-16T22:05:04+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_220504_bdd90636"}
2026-05-16T22:05:04+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_220504_bdd90636"}
2026-05-16T22:05:04+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_220504_bdd90636"}
2026-05-16T22:05:05+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_220504_bdd90636"}
2026-05-16T22:05:05+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4287,"mtime":"2026-05-16T22:04:48+02:00","run_id":"20260516_220504_bdd90636"}
2026-05-16T22:05:05+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_220504_bdd90636"}
2026-05-16T22:05:05+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":7536,"mtime":"2026-05-16T22:04:48+02:00","run_id":"20260516_220504_bdd90636"}
2026-05-16T22:05:05+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":45,"rb":58,"run_id":"20260516_220504_bdd90636"}
2026-05-16T22:05:05+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_220504_bdd90636"}
2026-05-16T22:05:05+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.935,"duration_milliseconds":935,"important":true,"run_id":"20260516_220504_bdd90636"}
2026-05-16T22:05:05+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_220504_bdd90636"}
2026-05-16T22:05:05+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_220504_bdd90636"}
2026-05-16T22:05:05+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_220504_bdd90636"}
2026-05-16T22:05:05+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.082,"duration_milliseconds":82,"important":true,"run_id":"20260516_220504_bdd90636"}
2026-05-16T22:05:05+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":96818,"run_id":"20260516_220504_bdd90636"}
2026-05-16T22:05:05+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.806,"exec_milliseconds":1806,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":96818,"important":true,"run_id":"20260516_220504_bdd90636"}
2026-05-16T22:06:03+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_220603_e5c99916"}
2026-05-16T22:06:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_220603_e5c99916"}
2026-05-16T22:06:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_220603_e5c99916"}
2026-05-16T22:06:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_220603_e5c99916"}
2026-05-16T22:06:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_220603_e5c99916"}
2026-05-16T22:06:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_220603_e5c99916"}
2026-05-16T22:06:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_220603_e5c99916"}
2026-05-16T22:06:04+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_220603_e5c99916"}
2026-05-16T22:06:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4287,"mtime":"2026-05-16T22:05:44+02:00","run_id":"20260516_220603_e5c99916"}
2026-05-16T22:06:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_220603_e5c99916"}
2026-05-16T22:06:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":8067,"mtime":"2026-05-16T22:05:44+02:00","run_id":"20260516_220603_e5c99916"}
2026-05-16T22:06:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":45,"rb":58,"run_id":"20260516_220603_e5c99916"}
2026-05-16T22:06:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_220603_e5c99916"}
2026-05-16T22:06:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.953,"duration_milliseconds":953,"important":true,"run_id":"20260516_220603_e5c99916"}
2026-05-16T22:06:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_220603_e5c99916"}
2026-05-16T22:06:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_220603_e5c99916"}
2026-05-16T22:06:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_220603_e5c99916"}
2026-05-16T22:06:04+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.091,"duration_milliseconds":91,"important":true,"run_id":"20260516_220603_e5c99916"}
2026-05-16T22:06:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":99149,"run_id":"20260516_220603_e5c99916"}
2026-05-16T22:06:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.815,"exec_milliseconds":1815,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":99149,"important":true,"run_id":"20260516_220603_e5c99916"}
2026-05-16T22:07:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_220701_193ff47e"}
2026-05-16T22:07:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_220701_193ff47e"}
2026-05-16T22:07:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_220701_193ff47e"}
2026-05-16T22:07:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_220701_193ff47e"}
2026-05-16T22:07:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_220701_193ff47e"}
2026-05-16T22:07:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_220701_193ff47e"}
2026-05-16T22:07:02+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_220701_193ff47e"}
2026-05-16T22:07:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_220701_193ff47e"}
2026-05-16T22:07:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4287,"mtime":"2026-05-16T22:06:53+02:00","run_id":"20260516_220701_193ff47e"}
2026-05-16T22:07:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_220701_193ff47e"}
2026-05-16T22:07:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":8324,"mtime":"2026-05-16T22:06:53+02:00","run_id":"20260516_220701_193ff47e"}
2026-05-16T22:08:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_220802_c5496515"}
2026-05-16T22:08:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_220802_c5496515"}
2026-05-16T22:08:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_220802_c5496515"}
2026-05-16T22:08:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_220802_c5496515"}
2026-05-16T22:08:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_220802_c5496515"}
2026-05-16T22:08:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_220802_c5496515"}
2026-05-16T22:08:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_220802_c5496515"}
2026-05-16T22:08:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_220802_c5496515"}
2026-05-16T22:08:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4287,"mtime":"2026-05-16T22:08:00+02:00","run_id":"20260516_220802_c5496515"}
2026-05-16T22:08:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_220802_c5496515"}
2026-05-16T22:08:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":8961,"mtime":"2026-05-16T22:07:58+02:00","run_id":"20260516_220802_c5496515"}
2026-05-16T22:08:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":48,"rb":58,"run_id":"20260516_220802_c5496515"}
2026-05-16T22:08:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_220802_c5496515"}
2026-05-16T22:08:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.941,"duration_milliseconds":941,"important":true,"run_id":"20260516_220802_c5496515"}
2026-05-16T22:08:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_220802_c5496515"}
2026-05-16T22:08:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_220802_c5496515"}
2026-05-16T22:09:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_220901_30397d99"}
2026-05-16T22:09:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_220901_30397d99"}
2026-05-16T22:09:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_220901_30397d99"}
2026-05-16T22:09:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_220901_30397d99"}
2026-05-16T22:09:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_220901_30397d99"}
2026-05-16T22:09:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_220901_30397d99"}
2026-05-16T22:09:02+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_220901_30397d99"}
2026-05-16T22:09:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_220901_30397d99"}
2026-05-16T22:09:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4287,"mtime":"2026-05-16T22:08:57+02:00","run_id":"20260516_220901_30397d99"}
2026-05-16T22:09:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_220901_30397d99"}
2026-05-16T22:09:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":9561,"mtime":"2026-05-16T22:08:57+02:00","run_id":"20260516_220901_30397d99"}
2026-05-16T22:09:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":48,"rb":58,"run_id":"20260516_220901_30397d99"}
2026-05-16T22:09:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_220901_30397d99"}
2026-05-16T22:09:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.958,"duration_milliseconds":958,"important":true,"run_id":"20260516_220901_30397d99"}
2026-05-16T22:09:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_220901_30397d99"}
2026-05-16T22:09:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_220901_30397d99"}
2026-05-16T22:09:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_220901_30397d99"}
2026-05-16T22:09:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.092,"duration_milliseconds":92,"important":true,"run_id":"20260516_220901_30397d99"}
2026-05-16T22:09:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":105585,"run_id":"20260516_220901_30397d99"}
2026-05-16T22:09:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.821,"exec_milliseconds":1821,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":105585,"important":true,"run_id":"20260516_220901_30397d99"}
2026-05-16T22:10:07+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_221007_e04aa453"}
2026-05-16T22:10:07+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_221007_e04aa453"}
2026-05-16T22:10:07+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_221007_e04aa453"}
2026-05-16T22:10:07+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_221007_e04aa453"}
2026-05-16T22:10:07+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_221007_e04aa453"}
2026-05-16T22:10:07+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_221007_e04aa453"}
2026-05-16T22:10:07+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_221007_e04aa453"}
2026-05-16T22:10:08+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_221007_e04aa453"}
2026-05-16T22:10:08+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4287,"mtime":"2026-05-16T22:10:02+02:00","run_id":"20260516_221007_e04aa453"}
2026-05-16T22:10:08+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_221007_e04aa453"}
2026-05-16T22:10:08+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":9892,"mtime":"2026-05-16T22:10:01+02:00","run_id":"20260516_221007_e04aa453"}
2026-05-16T22:10:08+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":49,"rb":58,"run_id":"20260516_221007_e04aa453"}
2026-05-16T22:10:08+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_221007_e04aa453"}
2026-05-16T22:10:08+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.937,"duration_milliseconds":937,"important":true,"run_id":"20260516_221007_e04aa453"}
2026-05-16T22:10:08+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_221007_e04aa453"}
2026-05-16T22:10:08+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_221007_e04aa453"}
2026-05-16T22:10:09+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_221007_e04aa453"}
2026-05-16T22:10:09+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.105,"duration_milliseconds":105,"important":true,"run_id":"20260516_221007_e04aa453"}
2026-05-16T22:10:09+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":106968,"run_id":"20260516_221007_e04aa453"}
2026-05-16T22:10:09+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.848,"exec_milliseconds":1848,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":106968,"important":true,"run_id":"20260516_221007_e04aa453"}
2026-05-16T22:11:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_221101_d274fb3a"}
2026-05-16T22:11:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_221101_d274fb3a"}
2026-05-16T22:11:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_221101_d274fb3a"}
2026-05-16T22:11:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_221101_d274fb3a"}
2026-05-16T22:11:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_221101_d274fb3a"}
2026-05-16T22:11:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_221101_d274fb3a"}
2026-05-16T22:11:02+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_221101_d274fb3a"}
2026-05-16T22:11:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_221101_d274fb3a"}
2026-05-16T22:11:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4287,"mtime":"2026-05-16T22:11:03+02:00","run_id":"20260516_221101_d274fb3a"}
2026-05-16T22:11:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_221101_d274fb3a"}
2026-05-16T22:11:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":10594,"mtime":"2026-05-16T22:11:03+02:00","run_id":"20260516_221101_d274fb3a"}
2026-05-16T22:11:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":51,"rb":58,"run_id":"20260516_221101_d274fb3a"}
2026-05-16T22:11:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_221101_d274fb3a"}
2026-05-16T22:11:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.967,"duration_milliseconds":967,"important":true,"run_id":"20260516_221101_d274fb3a"}
2026-05-16T22:11:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_221101_d274fb3a"}
2026-05-16T22:11:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_221101_d274fb3a"}
2026-05-16T22:11:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_221101_d274fb3a"}
2026-05-16T22:11:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.095,"duration_milliseconds":95,"important":true,"run_id":"20260516_221101_d274fb3a"}
2026-05-16T22:11:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":110048,"run_id":"20260516_221101_d274fb3a"}
2026-05-16T22:11:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.86,"exec_milliseconds":1860,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":110048,"important":true,"run_id":"20260516_221101_d274fb3a"}
2026-05-16T22:12:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_221202_2df15413"}
2026-05-16T22:12:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_221202_2df15413"}
2026-05-16T22:12:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_221202_2df15413"}
2026-05-16T22:12:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_221202_2df15413"}
2026-05-16T22:12:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_221202_2df15413"}
2026-05-16T22:12:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_221202_2df15413"}
2026-05-16T22:12:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_221202_2df15413"}
2026-05-16T22:12:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_221202_2df15413"}
2026-05-16T22:12:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4287,"mtime":"2026-05-16T22:12:00+02:00","run_id":"20260516_221202_2df15413"}
2026-05-16T22:12:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_221202_2df15413"}
2026-05-16T22:12:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":11126,"mtime":"2026-05-16T22:11:59+02:00","run_id":"20260516_221202_2df15413"}
2026-05-16T22:13:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_221301_4b1bd753"}
2026-05-16T22:13:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_221301_4b1bd753"}
2026-05-16T22:13:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_221301_4b1bd753"}
2026-05-16T22:13:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_221301_4b1bd753"}
2026-05-16T22:13:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_221301_4b1bd753"}
2026-05-16T22:13:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_221301_4b1bd753"}
2026-05-16T22:13:02+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_221301_4b1bd753"}
2026-05-16T22:13:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_221301_4b1bd753"}
2026-05-16T22:13:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4287,"mtime":"2026-05-16T22:12:52+02:00","run_id":"20260516_221301_4b1bd753"}
2026-05-16T22:13:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_221301_4b1bd753"}
2026-05-16T22:13:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":11465,"mtime":"2026-05-16T22:12:52+02:00","run_id":"20260516_221301_4b1bd753"}
2026-05-16T22:13:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":51,"rb":61,"run_id":"20260516_221301_4b1bd753"}
2026-05-16T22:13:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_221301_4b1bd753"}
2026-05-16T22:13:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.95,"duration_milliseconds":950,"important":true,"run_id":"20260516_221301_4b1bd753"}
2026-05-16T22:13:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_221301_4b1bd753"}
2026-05-16T22:13:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_221301_4b1bd753"}
2026-05-16T22:13:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_221301_4b1bd753"}
2026-05-16T22:13:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.098,"duration_milliseconds":98,"important":true,"run_id":"20260516_221301_4b1bd753"}
2026-05-16T22:13:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":113779,"run_id":"20260516_221301_4b1bd753"}
2026-05-16T22:13:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.838,"exec_milliseconds":1838,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":113779,"important":true,"run_id":"20260516_221301_4b1bd753"}
2026-05-16T22:14:03+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_221403_8a10489f"}
2026-05-16T22:14:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_221403_8a10489f"}
2026-05-16T22:14:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_221403_8a10489f"}
2026-05-16T22:14:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_221403_8a10489f"}
2026-05-16T22:14:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_221403_8a10489f"}
2026-05-16T22:14:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_221403_8a10489f"}
2026-05-16T22:14:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_221403_8a10489f"}
2026-05-16T22:14:04+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_221403_8a10489f"}
2026-05-16T22:14:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4287,"mtime":"2026-05-16T22:13:38+02:00","run_id":"20260516_221403_8a10489f"}
2026-05-16T22:14:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_221403_8a10489f"}
2026-05-16T22:14:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":11756,"mtime":"2026-05-16T22:13:38+02:00","run_id":"20260516_221403_8a10489f"}
2026-05-16T22:14:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":51,"rb":61,"run_id":"20260516_221403_8a10489f"}
2026-05-16T22:14:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_221403_8a10489f"}
2026-05-16T22:14:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.957,"duration_milliseconds":957,"important":true,"run_id":"20260516_221403_8a10489f"}
2026-05-16T22:14:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_221403_8a10489f"}
2026-05-16T22:14:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_221403_8a10489f"}
2026-05-16T22:14:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_221403_8a10489f"}
2026-05-16T22:14:04+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.092,"duration_milliseconds":92,"important":true,"run_id":"20260516_221403_8a10489f"}
2026-05-16T22:14:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":115058,"run_id":"20260516_221403_8a10489f"}
2026-05-16T22:14:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.96,"exec_milliseconds":1960,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":115058,"important":true,"run_id":"20260516_221403_8a10489f"}
2026-05-16T22:15:06+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_221506_1fe0cb48"}
2026-05-16T22:15:07+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_221506_1fe0cb48"}
2026-05-16T22:15:07+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_221506_1fe0cb48"}
2026-05-16T22:15:07+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_221506_1fe0cb48"}
2026-05-16T22:15:07+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_221506_1fe0cb48"}
2026-05-16T22:15:07+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_221506_1fe0cb48"}
2026-05-16T22:15:07+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_221506_1fe0cb48"}
2026-05-16T22:15:08+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_221506_1fe0cb48"}
2026-05-16T22:15:08+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4287,"mtime":"2026-05-16T22:14:45+02:00","run_id":"20260516_221506_1fe0cb48"}
2026-05-16T22:15:08+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_221506_1fe0cb48"}
2026-05-16T22:15:08+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":12439,"mtime":"2026-05-16T22:14:45+02:00","run_id":"20260516_221506_1fe0cb48"}
2026-05-16T22:15:08+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":51,"rb":61,"run_id":"20260516_221506_1fe0cb48"}
2026-05-16T22:15:08+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_221506_1fe0cb48"}
2026-05-16T22:15:08+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.948,"duration_milliseconds":948,"important":true,"run_id":"20260516_221506_1fe0cb48"}
2026-05-16T22:15:08+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_221506_1fe0cb48"}
2026-05-16T22:15:08+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_221506_1fe0cb48"}
2026-05-16T22:15:08+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_221506_1fe0cb48"}
2026-05-16T22:15:08+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.088,"duration_milliseconds":88,"important":true,"run_id":"20260516_221506_1fe0cb48"}
2026-05-16T22:15:08+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":117961,"run_id":"20260516_221506_1fe0cb48"}
2026-05-16T22:15:08+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.852,"exec_milliseconds":1852,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":117961,"important":true,"run_id":"20260516_221506_1fe0cb48"}
2026-05-16T22:16:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_221602_8fab1ce8"}
2026-05-16T22:16:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_221602_8fab1ce8"}
2026-05-16T22:16:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_221602_8fab1ce8"}
2026-05-16T22:16:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_221602_8fab1ce8"}
2026-05-16T22:16:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_221602_8fab1ce8"}
2026-05-16T22:16:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_221602_8fab1ce8"}
2026-05-16T22:16:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_221602_8fab1ce8"}
2026-05-16T22:16:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_221602_8fab1ce8"}
2026-05-16T22:16:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4287,"mtime":"2026-05-16T22:15:34+02:00","run_id":"20260516_221602_8fab1ce8"}
2026-05-16T22:16:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_221602_8fab1ce8"}
2026-05-16T22:16:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":12930,"mtime":"2026-05-16T22:15:33+02:00","run_id":"20260516_221602_8fab1ce8"}
2026-05-16T22:16:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":51,"rb":64,"run_id":"20260516_221602_8fab1ce8"}
2026-05-16T22:16:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_221602_8fab1ce8"}
2026-05-16T22:16:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.967,"duration_milliseconds":967,"important":true,"run_id":"20260516_221602_8fab1ce8"}
2026-05-16T22:16:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_221602_8fab1ce8"}
2026-05-16T22:16:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_221602_8fab1ce8"}
2026-05-16T22:16:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_221602_8fab1ce8"}
2026-05-16T22:16:04+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.097,"duration_milliseconds":97,"important":true,"run_id":"20260516_221602_8fab1ce8"}
2026-05-16T22:16:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":120096,"run_id":"20260516_221602_8fab1ce8"}
2026-05-16T22:16:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.887,"exec_milliseconds":1887,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":120096,"important":true,"run_id":"20260516_221602_8fab1ce8"}
2026-05-16T22:17:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_221701_7c6fbc91"}
2026-05-16T22:17:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_221701_7c6fbc91"}
2026-05-16T22:17:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_221701_7c6fbc91"}
2026-05-16T22:17:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_221701_7c6fbc91"}
2026-05-16T22:17:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_221701_7c6fbc91"}
2026-05-16T22:17:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_221701_7c6fbc91"}
2026-05-16T22:17:02+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_221701_7c6fbc91"}
2026-05-16T22:17:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_221701_7c6fbc91"}
2026-05-16T22:17:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4287,"mtime":"2026-05-16T22:15:34+02:00","run_id":"20260516_221701_7c6fbc91"}
2026-05-16T22:17:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_221701_7c6fbc91"}
2026-05-16T22:17:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":12930,"mtime":"2026-05-16T22:15:33+02:00","run_id":"20260516_221701_7c6fbc91"}
2026-05-16T22:17:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":51,"rb":64,"run_id":"20260516_221701_7c6fbc91"}
2026-05-16T22:17:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_221701_7c6fbc91"}
2026-05-16T22:17:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.942,"duration_milliseconds":942,"important":true,"run_id":"20260516_221701_7c6fbc91"}
2026-05-16T22:17:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_221701_7c6fbc91"}
2026-05-16T22:17:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_221701_7c6fbc91"}
2026-05-16T22:17:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_221701_7c6fbc91"}
2026-05-16T22:17:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.091,"duration_milliseconds":91,"important":true,"run_id":"20260516_221701_7c6fbc91"}
2026-05-16T22:17:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":120096,"run_id":"20260516_221701_7c6fbc91"}
2026-05-16T22:17:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.811,"exec_milliseconds":1811,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":120096,"important":true,"run_id":"20260516_221701_7c6fbc91"}
2026-05-16T22:18:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_221802_a2ae684b"}
2026-05-16T22:18:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_221802_a2ae684b"}
2026-05-16T22:18:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_221802_a2ae684b"}
2026-05-16T22:18:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_221802_a2ae684b"}
2026-05-16T22:18:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_221802_a2ae684b"}
2026-05-16T22:18:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_221802_a2ae684b"}
2026-05-16T22:18:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_221802_a2ae684b"}
2026-05-16T22:18:04+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_221802_a2ae684b"}
2026-05-16T22:18:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4287,"mtime":"2026-05-16T22:18:02+02:00","run_id":"20260516_221802_a2ae684b"}
2026-05-16T22:18:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_221802_a2ae684b"}
2026-05-16T22:18:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":13236,"mtime":"2026-05-16T22:18:01+02:00","run_id":"20260516_221802_a2ae684b"}
2026-05-16T22:18:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":51,"rb":64,"run_id":"20260516_221802_a2ae684b"}
2026-05-16T22:18:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_221802_a2ae684b"}
2026-05-16T22:18:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.956,"duration_milliseconds":956,"important":true,"run_id":"20260516_221802_a2ae684b"}
2026-05-16T22:18:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_221802_a2ae684b"}
2026-05-16T22:18:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_221802_a2ae684b"}
2026-05-16T22:18:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_221802_a2ae684b"}
2026-05-16T22:18:04+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.092,"duration_milliseconds":92,"important":true,"run_id":"20260516_221802_a2ae684b"}
2026-05-16T22:18:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":121410,"run_id":"20260516_221802_a2ae684b"}
2026-05-16T22:18:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.834,"exec_milliseconds":1834,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":121410,"important":true,"run_id":"20260516_221802_a2ae684b"}
2026-05-16T22:19:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_221901_104ba28b"}
2026-05-16T22:19:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_221901_104ba28b"}
2026-05-16T22:19:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_221901_104ba28b"}
2026-05-16T22:19:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_221901_104ba28b"}
2026-05-16T22:19:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_221901_104ba28b"}
2026-05-16T22:19:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_221901_104ba28b"}
2026-05-16T22:19:02+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_221901_104ba28b"}
2026-05-16T22:19:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_221901_104ba28b"}
2026-05-16T22:19:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4287,"mtime":"2026-05-16T22:19:01+02:00","run_id":"20260516_221901_104ba28b"}
2026-05-16T22:19:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_221901_104ba28b"}
2026-05-16T22:19:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":13922,"mtime":"2026-05-16T22:19:01+02:00","run_id":"20260516_221901_104ba28b"}
2026-05-16T22:20:06+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_222006_35d960ec"}
2026-05-16T22:20:07+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_222006_35d960ec"}
2026-05-16T22:20:07+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_222006_35d960ec"}
2026-05-16T22:20:07+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_222006_35d960ec"}
2026-05-16T22:20:07+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_222006_35d960ec"}
2026-05-16T22:20:07+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_222006_35d960ec"}
2026-05-16T22:20:07+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_222006_35d960ec"}
2026-05-16T22:20:08+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_222006_35d960ec"}
2026-05-16T22:20:08+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4287,"mtime":"2026-05-16T22:19:56+02:00","run_id":"20260516_222006_35d960ec"}
2026-05-16T22:20:08+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_222006_35d960ec"}
2026-05-16T22:20:08+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":14176,"mtime":"2026-05-16T22:19:56+02:00","run_id":"20260516_222006_35d960ec"}
2026-05-16T22:20:08+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":54,"rb":67,"run_id":"20260516_222006_35d960ec"}
2026-05-16T22:20:08+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_222006_35d960ec"}
2026-05-16T22:20:08+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.92,"duration_milliseconds":920,"important":true,"run_id":"20260516_222006_35d960ec"}
2026-05-16T22:20:08+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_222006_35d960ec"}
2026-05-16T22:20:08+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_222006_35d960ec"}
2026-05-16T22:20:08+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_222006_35d960ec"}
2026-05-16T22:20:08+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.078,"duration_milliseconds":78,"important":true,"run_id":"20260516_222006_35d960ec"}
2026-05-16T22:20:08+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":125364,"run_id":"20260516_222006_35d960ec"}
2026-05-16T22:20:08+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.767,"exec_milliseconds":1767,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":125364,"important":true,"run_id":"20260516_222006_35d960ec"}
2026-05-16T22:21:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_222102_150e458f"}
2026-05-16T22:21:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_222102_150e458f"}
2026-05-16T22:21:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_222102_150e458f"}
2026-05-16T22:21:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_222102_150e458f"}
2026-05-16T22:21:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_222102_150e458f"}
2026-05-16T22:21:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_222102_150e458f"}
2026-05-16T22:21:02+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_222102_150e458f"}
2026-05-16T22:21:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_222102_150e458f"}
2026-05-16T22:21:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4287,"mtime":"2026-05-16T22:20:56+02:00","run_id":"20260516_222102_150e458f"}
2026-05-16T22:21:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_222102_150e458f"}
2026-05-16T22:21:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":14821,"mtime":"2026-05-16T22:20:56+02:00","run_id":"20260516_222102_150e458f"}
2026-05-16T22:21:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":54,"rb":69,"run_id":"20260516_222102_150e458f"}
2026-05-16T22:21:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_222102_150e458f"}
2026-05-16T22:21:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.957,"duration_milliseconds":957,"important":true,"run_id":"20260516_222102_150e458f"}
2026-05-16T22:21:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_222102_150e458f"}
2026-05-16T22:21:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_222102_150e458f"}
2026-05-16T22:21:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_222102_150e458f"}
2026-05-16T22:21:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.095,"duration_milliseconds":95,"important":true,"run_id":"20260516_222102_150e458f"}
2026-05-16T22:21:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":128161,"run_id":"20260516_222102_150e458f"}
2026-05-16T22:21:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.859,"exec_milliseconds":1859,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":128161,"important":true,"run_id":"20260516_222102_150e458f"}
2026-05-16T22:22:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_222202_5c1ae2de"}
2026-05-16T22:22:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_222202_5c1ae2de"}
2026-05-16T22:22:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_222202_5c1ae2de"}
2026-05-16T22:22:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_222202_5c1ae2de"}
2026-05-16T22:22:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_222202_5c1ae2de"}
2026-05-16T22:22:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_222202_5c1ae2de"}
2026-05-16T22:22:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_222202_5c1ae2de"}
2026-05-16T22:22:04+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_222202_5c1ae2de"}
2026-05-16T22:22:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4287,"mtime":"2026-05-16T22:21:55+02:00","run_id":"20260516_222202_5c1ae2de"}
2026-05-16T22:22:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_222202_5c1ae2de"}
2026-05-16T22:22:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":15436,"mtime":"2026-05-16T22:22:04+02:00","run_id":"20260516_222202_5c1ae2de"}
2026-05-16T22:22:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":54,"rb":69,"run_id":"20260516_222202_5c1ae2de"}
2026-05-16T22:22:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_222202_5c1ae2de"}
2026-05-16T22:22:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.926,"duration_milliseconds":926,"important":true,"run_id":"20260516_222202_5c1ae2de"}
2026-05-16T22:22:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_222202_5c1ae2de"}
2026-05-16T22:22:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_222202_5c1ae2de"}
2026-05-16T22:22:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_222202_5c1ae2de"}
2026-05-16T22:22:04+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.083,"duration_milliseconds":83,"important":true,"run_id":"20260516_222202_5c1ae2de"}
2026-05-16T22:22:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":130796,"run_id":"20260516_222202_5c1ae2de"}
2026-05-16T22:22:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.758,"exec_milliseconds":1758,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":130796,"important":true,"run_id":"20260516_222202_5c1ae2de"}
2026-05-16T22:23:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_222301_06c276ac"}
2026-05-16T22:23:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_222301_06c276ac"}
2026-05-16T22:23:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_222301_06c276ac"}
2026-05-16T22:23:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_222301_06c276ac"}
2026-05-16T22:23:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_222301_06c276ac"}
2026-05-16T22:23:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_222301_06c276ac"}
2026-05-16T22:23:02+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_222301_06c276ac"}
2026-05-16T22:23:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_222301_06c276ac"}
2026-05-16T22:23:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4287,"mtime":"2026-05-16T22:22:21+02:00","run_id":"20260516_222301_06c276ac"}
2026-05-16T22:23:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":null,"run_id":"20260516_222301_06c276ac"}
2026-05-16T22:23:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":15572,"mtime":"2026-05-16T22:22:21+02:00","run_id":"20260516_222301_06c276ac"}
2026-05-16T22:23:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":54,"rb":69,"run_id":"20260516_222301_06c276ac"}
2026-05-16T22:23:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_222301_06c276ac"}
2026-05-16T22:23:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.968,"duration_milliseconds":968,"important":true,"run_id":"20260516_222301_06c276ac"}
2026-05-16T22:23:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_222301_06c276ac"}
2026-05-16T22:23:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_222301_06c276ac"}
2026-05-16T22:23:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_222301_06c276ac"}
2026-05-16T22:23:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.097,"duration_milliseconds":97,"important":true,"run_id":"20260516_222301_06c276ac"}
2026-05-16T22:23:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":131410,"run_id":"20260516_222301_06c276ac"}
2026-05-16T22:23:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.854,"exec_milliseconds":1854,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":131410,"important":true,"run_id":"20260516_222301_06c276ac"}
2026-05-16T22:24:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_222402_7be47e37"}
2026-05-16T22:24:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_222402_7be47e37"}
2026-05-16T22:24:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_222402_7be47e37"}
2026-05-16T22:24:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_222402_7be47e37"}
2026-05-16T22:24:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_222402_7be47e37"}
2026-05-16T22:24:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_222402_7be47e37"}
2026-05-16T22:24:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_222402_7be47e37"}
2026-05-16T22:24:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_222402_7be47e37"}
2026-05-16T22:24:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4291,"mtime":"2026-05-16T22:23:08+02:00","run_id":"20260516_222402_7be47e37"}
2026-05-16T22:24:04+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":6000,"run_id":"20260516_222402_7be47e37"}
2026-05-16T22:24:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":15572,"mtime":"2026-05-16T22:23:08+02:00","run_id":"20260516_222402_7be47e37"}
2026-05-16T22:24:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":54,"rb":69,"run_id":"20260516_222402_7be47e37"}
2026-05-16T22:24:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_222402_7be47e37"}
2026-05-16T22:24:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.952,"duration_milliseconds":952,"important":true,"run_id":"20260516_222402_7be47e37"}
2026-05-16T22:24:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_222402_7be47e37"}
2026-05-16T22:24:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_222402_7be47e37"}
2026-05-16T22:24:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_222402_7be47e37"}
2026-05-16T22:24:04+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.106,"duration_milliseconds":106,"important":true,"run_id":"20260516_222402_7be47e37"}
2026-05-16T22:24:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":131255,"run_id":"20260516_222402_7be47e37"}
2026-05-16T22:24:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.832,"exec_milliseconds":1832,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":131255,"important":true,"run_id":"20260516_222402_7be47e37"}
2026-05-16T22:25:03+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_222503_ab4ca5b5"}
2026-05-16T22:25:04+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_222503_ab4ca5b5"}
2026-05-16T22:25:04+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_222503_ab4ca5b5"}
2026-05-16T22:25:04+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_222503_ab4ca5b5"}
2026-05-16T22:25:04+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_222503_ab4ca5b5"}
2026-05-16T22:25:04+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_222503_ab4ca5b5"}
2026-05-16T22:25:04+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_222503_ab4ca5b5"}
2026-05-16T22:25:05+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_222503_ab4ca5b5"}
2026-05-16T22:25:05+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4291,"mtime":"2026-05-16T22:23:08+02:00","run_id":"20260516_222503_ab4ca5b5"}
2026-05-16T22:25:05+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":6000,"run_id":"20260516_222503_ab4ca5b5"}
2026-05-16T22:25:05+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":15572,"mtime":"2026-05-16T22:23:08+02:00","run_id":"20260516_222503_ab4ca5b5"}
2026-05-16T22:25:05+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":54,"rb":69,"run_id":"20260516_222503_ab4ca5b5"}
2026-05-16T22:25:05+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_222503_ab4ca5b5"}
2026-05-16T22:25:05+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.937,"duration_milliseconds":937,"important":true,"run_id":"20260516_222503_ab4ca5b5"}
2026-05-16T22:25:05+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_222503_ab4ca5b5"}
2026-05-16T22:25:05+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_222503_ab4ca5b5"}
2026-05-16T22:25:05+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_222503_ab4ca5b5"}
2026-05-16T22:25:05+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.081,"duration_milliseconds":81,"important":true,"run_id":"20260516_222503_ab4ca5b5"}
2026-05-16T22:25:05+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":131213,"run_id":"20260516_222503_ab4ca5b5"}
2026-05-16T22:25:05+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.799,"exec_milliseconds":1799,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":131213,"important":true,"run_id":"20260516_222503_ab4ca5b5"}
2026-05-16T22:26:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_222602_59e8cfab"}
2026-05-16T22:26:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_222602_59e8cfab"}
2026-05-16T22:26:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_222602_59e8cfab"}
2026-05-16T22:26:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_222602_59e8cfab"}
2026-05-16T22:26:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_222602_59e8cfab"}
2026-05-16T22:26:03+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_222602_59e8cfab"}
2026-05-16T22:26:03+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_222602_59e8cfab"}
2026-05-16T22:26:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_222602_59e8cfab"}
2026-05-16T22:26:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4291,"mtime":"2026-05-16T22:23:08+02:00","run_id":"20260516_222602_59e8cfab"}
2026-05-16T22:26:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":6000,"run_id":"20260516_222602_59e8cfab"}
2026-05-16T22:26:04+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":15572,"mtime":"2026-05-16T22:23:08+02:00","run_id":"20260516_222602_59e8cfab"}
2026-05-16T22:26:04+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":54,"rb":69,"run_id":"20260516_222602_59e8cfab"}
2026-05-16T22:26:04+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_222602_59e8cfab"}
2026-05-16T22:26:04+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.931,"duration_milliseconds":931,"important":true,"run_id":"20260516_222602_59e8cfab"}
2026-05-16T22:26:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_222602_59e8cfab"}
2026-05-16T22:26:04+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_222602_59e8cfab"}
2026-05-16T22:26:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_222602_59e8cfab"}
2026-05-16T22:26:04+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.091,"duration_milliseconds":91,"important":true,"run_id":"20260516_222602_59e8cfab"}
2026-05-16T22:26:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":131255,"run_id":"20260516_222602_59e8cfab"}
2026-05-16T22:26:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.81,"exec_milliseconds":1810,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":131255,"important":true,"run_id":"20260516_222602_59e8cfab"}
2026-05-16T22:27:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_222701_65c9c06e"}
2026-05-16T22:27:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_222701_65c9c06e"}
2026-05-16T22:27:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_222701_65c9c06e"}
2026-05-16T22:27:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_222701_65c9c06e"}
2026-05-16T22:27:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_222701_65c9c06e"}
2026-05-16T22:27:02+02:00 [INFO] Live games query successful {"count":1,"run_id":"20260516_222701_65c9c06e"}
2026-05-16T22:27:02+02:00 [INFO] Processing live game {"spiel_id":2005747,"team_id":415,"league":"BBL","run_id":"20260516_222701_65c9c06e"}
2026-05-16T22:27:03+02:00 [INFO] SFTP upload directory reachable {"team_id":415,"spiel_id":2005747,"run_id":"20260516_222701_65c9c06e"}
2026-05-16T22:27:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747_INIT.JSN","size":4291,"mtime":"2026-05-16T22:26:30+02:00","run_id":"20260516_222701_65c9c06e"}
2026-05-16T22:27:03+02:00 [INFO] Init JSON parsed {"spiel_id":2005747,"file":"2005747_INIT.JSN","referee_count":4,"spect":6000,"run_id":"20260516_222701_65c9c06e"}
2026-05-16T22:27:03+02:00 [INFO] SFTP file found {"spiel_id":2005747,"file":"2005747.JSN","size":15572,"mtime":"2026-05-16T22:26:30+02:00","run_id":"20260516_222701_65c9c06e"}
2026-05-16T22:27:03+02:00 [INFO] Scout JSON parsed {"spiel_id":2005747,"file":"2005747.JSN","ra":54,"rb":69,"run_id":"20260516_222701_65c9c06e"}
2026-05-16T22:27:03+02:00 [INFO] Live row rendered {"spiel_id":2005747,"run_id":"20260516_222701_65c9c06e"}
2026-05-16T22:27:03+02:00 [INFO] Live game timing {"spiel_id":2005747,"duration_seconds":0.94,"duration_milliseconds":940,"important":true,"run_id":"20260516_222701_65c9c06e"}
2026-05-16T22:27:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_222701_65c9c06e"}
2026-05-16T22:27:03+02:00 [INFO] Fallback query executed {"remaining_slots":8,"run_id":"20260516_222701_65c9c06e"}
2026-05-16T22:27:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_222701_65c9c06e"}
2026-05-16T22:27:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.085,"duration_milliseconds":85,"important":true,"run_id":"20260516_222701_65c9c06e"}
2026-05-16T22:27:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":131271,"run_id":"20260516_222701_65c9c06e"}
2026-05-16T22:27:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.81,"exec_milliseconds":1810,"live_games":1,"fallback_games":1,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":131271,"important":true,"run_id":"20260516_222701_65c9c06e"}
2026-05-16T22:28:03+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_222802_36e816fc"}
2026-05-16T22:28:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_222802_36e816fc"}
2026-05-16T22:28:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_222802_36e816fc"}
2026-05-16T22:28:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_222802_36e816fc"}
2026-05-16T22:28:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_222802_36e816fc"}
2026-05-16T22:28:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_222802_36e816fc"}
2026-05-16T22:28:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_222802_36e816fc"}
2026-05-16T22:28:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_222802_36e816fc"}
2026-05-16T22:28:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_222802_36e816fc"}
2026-05-16T22:28:04+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.741,"duration_milliseconds":741,"important":true,"run_id":"20260516_222802_36e816fc"}
2026-05-16T22:28:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"54:69","run_id":"20260516_222802_36e816fc"}
2026-05-16T22:28:04+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.094,"duration_milliseconds":94,"important":true,"run_id":"20260516_222802_36e816fc"}
2026-05-16T22:28:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":39439,"run_id":"20260516_222802_36e816fc"}
2026-05-16T22:28:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.674,"exec_milliseconds":1674,"live_games":0,"fallback_games":2,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":39439,"important":true,"run_id":"20260516_222802_36e816fc"}
2026-05-16T22:29:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_222902_6d4770d2"}
2026-05-16T22:29:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_222902_6d4770d2"}
2026-05-16T22:29:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_222902_6d4770d2"}
2026-05-16T22:29:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_222902_6d4770d2"}
2026-05-16T22:29:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_222902_6d4770d2"}
2026-05-16T22:29:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_222902_6d4770d2"}
2026-05-16T22:29:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_222902_6d4770d2"}
2026-05-16T22:29:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_222902_6d4770d2"}
2026-05-16T22:29:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_222902_6d4770d2"}
2026-05-16T22:29:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.74,"duration_milliseconds":740,"important":true,"run_id":"20260516_222902_6d4770d2"}
2026-05-16T22:29:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"54:69","run_id":"20260516_222902_6d4770d2"}
2026-05-16T22:29:03+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.108,"duration_milliseconds":108,"important":true,"run_id":"20260516_222902_6d4770d2"}
2026-05-16T22:29:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":39481,"run_id":"20260516_222902_6d4770d2"}
2026-05-16T22:29:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.675,"exec_milliseconds":1675,"live_games":0,"fallback_games":2,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":39481,"important":true,"run_id":"20260516_222902_6d4770d2"}
2026-05-16T22:30:11+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_223011_00da773d"}
2026-05-16T22:30:11+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_223011_00da773d"}
2026-05-16T22:30:11+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_223011_00da773d"}
2026-05-16T22:30:11+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_223011_00da773d"}
2026-05-16T22:30:12+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_223011_00da773d"}
2026-05-16T22:30:12+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_223011_00da773d"}
2026-05-16T22:30:12+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_223011_00da773d"}
2026-05-16T22:30:12+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_223011_00da773d"}
2026-05-16T22:30:12+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_223011_00da773d"}
2026-05-16T22:30:12+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.745,"duration_milliseconds":745,"important":true,"run_id":"20260516_223011_00da773d"}
2026-05-16T22:30:13+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"54:69","run_id":"20260516_223011_00da773d"}
2026-05-16T22:30:13+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.095,"duration_milliseconds":95,"important":true,"run_id":"20260516_223011_00da773d"}
2026-05-16T22:30:13+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":39397,"run_id":"20260516_223011_00da773d"}
2026-05-16T22:30:13+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.657,"exec_milliseconds":1657,"live_games":0,"fallback_games":2,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":39397,"important":true,"run_id":"20260516_223011_00da773d"}
2026-05-16T22:31:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_223102_e2a1d6f5"}
2026-05-16T22:31:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_223102_e2a1d6f5"}
2026-05-16T22:31:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_223102_e2a1d6f5"}
2026-05-16T22:31:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_223102_e2a1d6f5"}
2026-05-16T22:31:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_223102_e2a1d6f5"}
2026-05-16T22:31:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_223102_e2a1d6f5"}
2026-05-16T22:31:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_223102_e2a1d6f5"}
2026-05-16T22:31:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_223102_e2a1d6f5"}
2026-05-16T22:31:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_223102_e2a1d6f5"}
2026-05-16T22:31:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.747,"duration_milliseconds":747,"important":true,"run_id":"20260516_223102_e2a1d6f5"}
2026-05-16T22:31:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"54:69","run_id":"20260516_223102_e2a1d6f5"}
2026-05-16T22:31:03+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.09,"duration_milliseconds":90,"important":true,"run_id":"20260516_223102_e2a1d6f5"}
2026-05-16T22:31:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":39481,"run_id":"20260516_223102_e2a1d6f5"}
2026-05-16T22:31:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.635,"exec_milliseconds":1635,"live_games":0,"fallback_games":2,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":39481,"important":true,"run_id":"20260516_223102_e2a1d6f5"}
2026-05-16T22:32:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_223202_1788cc50"}
2026-05-16T22:32:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_223202_1788cc50"}
2026-05-16T22:32:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_223202_1788cc50"}
2026-05-16T22:32:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_223202_1788cc50"}
2026-05-16T22:32:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_223202_1788cc50"}
2026-05-16T22:32:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_223202_1788cc50"}
2026-05-16T22:32:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_223202_1788cc50"}
2026-05-16T22:32:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_223202_1788cc50"}
2026-05-16T22:32:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_223202_1788cc50"}
2026-05-16T22:32:04+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.731,"duration_milliseconds":731,"important":true,"run_id":"20260516_223202_1788cc50"}
2026-05-16T22:32:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"54:69","run_id":"20260516_223202_1788cc50"}
2026-05-16T22:32:04+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.084,"duration_milliseconds":84,"important":true,"run_id":"20260516_223202_1788cc50"}
2026-05-16T22:32:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":39481,"run_id":"20260516_223202_1788cc50"}
2026-05-16T22:32:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.59,"exec_milliseconds":1590,"live_games":0,"fallback_games":2,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":39481,"important":true,"run_id":"20260516_223202_1788cc50"}
2026-05-16T22:33:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_223301_0ca4b7fe"}
2026-05-16T22:33:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_223301_0ca4b7fe"}
2026-05-16T22:33:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_223301_0ca4b7fe"}
2026-05-16T22:33:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_223301_0ca4b7fe"}
2026-05-16T22:33:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_223301_0ca4b7fe"}
2026-05-16T22:33:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_223301_0ca4b7fe"}
2026-05-16T22:33:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_223301_0ca4b7fe"}
2026-05-16T22:33:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_223301_0ca4b7fe"}
2026-05-16T22:33:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_223301_0ca4b7fe"}
2026-05-16T22:33:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.738,"duration_milliseconds":738,"important":true,"run_id":"20260516_223301_0ca4b7fe"}
2026-05-16T22:33:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"54:69","run_id":"20260516_223301_0ca4b7fe"}
2026-05-16T22:33:03+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.095,"duration_milliseconds":95,"important":true,"run_id":"20260516_223301_0ca4b7fe"}
2026-05-16T22:33:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":39481,"run_id":"20260516_223301_0ca4b7fe"}
2026-05-16T22:33:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.627,"exec_milliseconds":1627,"live_games":0,"fallback_games":2,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":39481,"important":true,"run_id":"20260516_223301_0ca4b7fe"}
2026-05-16T22:34:03+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_223402_df7af88d"}
2026-05-16T22:34:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_223402_df7af88d"}
2026-05-16T22:34:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_223402_df7af88d"}
2026-05-16T22:34:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_223402_df7af88d"}
2026-05-16T22:34:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_223402_df7af88d"}
2026-05-16T22:34:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_223402_df7af88d"}
2026-05-16T22:34:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_223402_df7af88d"}
2026-05-16T22:34:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_223402_df7af88d"}
2026-05-16T22:34:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_223402_df7af88d"}
2026-05-16T22:34:04+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.733,"duration_milliseconds":733,"important":true,"run_id":"20260516_223402_df7af88d"}
2026-05-16T22:34:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"54:69","run_id":"20260516_223402_df7af88d"}
2026-05-16T22:34:04+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.083,"duration_milliseconds":83,"important":true,"run_id":"20260516_223402_df7af88d"}
2026-05-16T22:34:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":39481,"run_id":"20260516_223402_df7af88d"}
2026-05-16T22:34:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.61,"exec_milliseconds":1610,"live_games":0,"fallback_games":2,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":39481,"important":true,"run_id":"20260516_223402_df7af88d"}
2026-05-16T22:35:04+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_223504_e8230ced"}
2026-05-16T22:35:04+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_223504_e8230ced"}
2026-05-16T22:35:04+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_223504_e8230ced"}
2026-05-16T22:35:04+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_223504_e8230ced"}
2026-05-16T22:35:04+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_223504_e8230ced"}
2026-05-16T22:35:04+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_223504_e8230ced"}
2026-05-16T22:35:04+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_223504_e8230ced"}
2026-05-16T22:35:04+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_223504_e8230ced"}
2026-05-16T22:35:05+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_223504_e8230ced"}
2026-05-16T22:35:05+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.73,"duration_milliseconds":730,"important":true,"run_id":"20260516_223504_e8230ced"}
2026-05-16T22:35:05+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"54:69","run_id":"20260516_223504_e8230ced"}
2026-05-16T22:35:05+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.093,"duration_milliseconds":93,"important":true,"run_id":"20260516_223504_e8230ced"}
2026-05-16T22:35:05+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":39397,"run_id":"20260516_223504_e8230ced"}
2026-05-16T22:35:05+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.622,"exec_milliseconds":1622,"live_games":0,"fallback_games":2,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":39397,"important":true,"run_id":"20260516_223504_e8230ced"}
2026-05-16T22:36:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_223602_4bc8adb0"}
2026-05-16T22:36:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_223602_4bc8adb0"}
2026-05-16T22:36:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_223602_4bc8adb0"}
2026-05-16T22:36:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_223602_4bc8adb0"}
2026-05-16T22:36:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_223602_4bc8adb0"}
2026-05-16T22:36:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_223602_4bc8adb0"}
2026-05-16T22:36:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_223602_4bc8adb0"}
2026-05-16T22:36:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_223602_4bc8adb0"}
2026-05-16T22:36:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_223602_4bc8adb0"}
2026-05-16T22:36:04+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.735,"duration_milliseconds":735,"important":true,"run_id":"20260516_223602_4bc8adb0"}
2026-05-16T22:36:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"54:69","run_id":"20260516_223602_4bc8adb0"}
2026-05-16T22:36:04+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.097,"duration_milliseconds":97,"important":true,"run_id":"20260516_223602_4bc8adb0"}
2026-05-16T22:36:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":39481,"run_id":"20260516_223602_4bc8adb0"}
2026-05-16T22:36:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.603,"exec_milliseconds":1603,"live_games":0,"fallback_games":2,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":39481,"important":true,"run_id":"20260516_223602_4bc8adb0"}
2026-05-16T22:37:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_223701_26a40572"}
2026-05-16T22:37:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_223701_26a40572"}
2026-05-16T22:37:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_223701_26a40572"}
2026-05-16T22:37:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_223701_26a40572"}
2026-05-16T22:37:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_223701_26a40572"}
2026-05-16T22:37:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_223701_26a40572"}
2026-05-16T22:37:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_223701_26a40572"}
2026-05-16T22:37:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_223701_26a40572"}
2026-05-16T22:37:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_223701_26a40572"}
2026-05-16T22:37:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.738,"duration_milliseconds":738,"important":true,"run_id":"20260516_223701_26a40572"}
2026-05-16T22:37:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"54:69","run_id":"20260516_223701_26a40572"}
2026-05-16T22:37:03+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.095,"duration_milliseconds":95,"important":true,"run_id":"20260516_223701_26a40572"}
2026-05-16T22:37:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":39481,"run_id":"20260516_223701_26a40572"}
2026-05-16T22:37:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.6,"exec_milliseconds":1600,"live_games":0,"fallback_games":2,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":39481,"important":true,"run_id":"20260516_223701_26a40572"}
2026-05-16T22:38:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_223802_ca9dee79"}
2026-05-16T22:38:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_223802_ca9dee79"}
2026-05-16T22:38:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_223802_ca9dee79"}
2026-05-16T22:38:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_223802_ca9dee79"}
2026-05-16T22:38:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_223802_ca9dee79"}
2026-05-16T22:38:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_223802_ca9dee79"}
2026-05-16T22:38:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_223802_ca9dee79"}
2026-05-16T22:38:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_223802_ca9dee79"}
2026-05-16T22:38:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_223802_ca9dee79"}
2026-05-16T22:38:04+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.733,"duration_milliseconds":733,"important":true,"run_id":"20260516_223802_ca9dee79"}
2026-05-16T22:38:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"54:69","run_id":"20260516_223802_ca9dee79"}
2026-05-16T22:38:04+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.093,"duration_milliseconds":93,"important":true,"run_id":"20260516_223802_ca9dee79"}
2026-05-16T22:38:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":39481,"run_id":"20260516_223802_ca9dee79"}
2026-05-16T22:38:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.599,"exec_milliseconds":1599,"live_games":0,"fallback_games":2,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":39481,"important":true,"run_id":"20260516_223802_ca9dee79"}
2026-05-16T22:39:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_223901_97e41443"}
2026-05-16T22:39:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_223901_97e41443"}
2026-05-16T22:39:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_223901_97e41443"}
2026-05-16T22:39:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_223901_97e41443"}
2026-05-16T22:39:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_223901_97e41443"}
2026-05-16T22:39:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_223901_97e41443"}
2026-05-16T22:39:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_223901_97e41443"}
2026-05-16T22:39:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_223901_97e41443"}
2026-05-16T22:39:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_223901_97e41443"}
2026-05-16T22:39:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.744,"duration_milliseconds":744,"important":true,"run_id":"20260516_223901_97e41443"}
2026-05-16T22:39:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"54:69","run_id":"20260516_223901_97e41443"}
2026-05-16T22:39:03+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.095,"duration_milliseconds":95,"important":true,"run_id":"20260516_223901_97e41443"}
2026-05-16T22:39:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":39481,"run_id":"20260516_223901_97e41443"}
2026-05-16T22:39:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.621,"exec_milliseconds":1621,"live_games":0,"fallback_games":2,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":39481,"important":true,"run_id":"20260516_223901_97e41443"}
2026-05-16T22:40:06+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_224006_d101e5db"}
2026-05-16T22:40:07+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_224006_d101e5db"}
2026-05-16T22:40:07+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_224006_d101e5db"}
2026-05-16T22:40:07+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_224006_d101e5db"}
2026-05-16T22:40:07+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_224006_d101e5db"}
2026-05-16T22:40:07+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_224006_d101e5db"}
2026-05-16T22:40:07+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_224006_d101e5db"}
2026-05-16T22:40:07+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_224006_d101e5db"}
2026-05-16T22:40:08+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_224006_d101e5db"}
2026-05-16T22:40:08+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.745,"duration_milliseconds":745,"important":true,"run_id":"20260516_224006_d101e5db"}
2026-05-16T22:40:08+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"54:69","run_id":"20260516_224006_d101e5db"}
2026-05-16T22:40:08+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.098,"duration_milliseconds":98,"important":true,"run_id":"20260516_224006_d101e5db"}
2026-05-16T22:40:08+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":39397,"run_id":"20260516_224006_d101e5db"}
2026-05-16T22:40:08+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.629,"exec_milliseconds":1629,"live_games":0,"fallback_games":2,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":39397,"important":true,"run_id":"20260516_224006_d101e5db"}
2026-05-16T22:41:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_224101_31e00e02"}
2026-05-16T22:41:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_224101_31e00e02"}
2026-05-16T22:41:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_224101_31e00e02"}
2026-05-16T22:41:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_224101_31e00e02"}
2026-05-16T22:41:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_224101_31e00e02"}
2026-05-16T22:41:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_224101_31e00e02"}
2026-05-16T22:41:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_224101_31e00e02"}
2026-05-16T22:41:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_224101_31e00e02"}
2026-05-16T22:41:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_224101_31e00e02"}
2026-05-16T22:41:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.718,"duration_milliseconds":718,"important":true,"run_id":"20260516_224101_31e00e02"}
2026-05-16T22:41:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"54:69","run_id":"20260516_224101_31e00e02"}
2026-05-16T22:41:03+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.086,"duration_milliseconds":86,"important":true,"run_id":"20260516_224101_31e00e02"}
2026-05-16T22:41:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":39481,"run_id":"20260516_224101_31e00e02"}
2026-05-16T22:41:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.586,"exec_milliseconds":1586,"live_games":0,"fallback_games":2,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":39481,"important":true,"run_id":"20260516_224101_31e00e02"}
2026-05-16T22:42:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_224202_09b83b30"}
2026-05-16T22:42:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_224202_09b83b30"}
2026-05-16T22:42:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_224202_09b83b30"}
2026-05-16T22:42:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_224202_09b83b30"}
2026-05-16T22:42:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_224202_09b83b30"}
2026-05-16T22:42:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_224202_09b83b30"}
2026-05-16T22:42:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_224202_09b83b30"}
2026-05-16T22:42:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_224202_09b83b30"}
2026-05-16T22:42:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_224202_09b83b30"}
2026-05-16T22:42:04+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.759,"duration_milliseconds":759,"important":true,"run_id":"20260516_224202_09b83b30"}
2026-05-16T22:42:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"54:69","run_id":"20260516_224202_09b83b30"}
2026-05-16T22:42:04+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.091,"duration_milliseconds":91,"important":true,"run_id":"20260516_224202_09b83b30"}
2026-05-16T22:42:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":39481,"run_id":"20260516_224202_09b83b30"}
2026-05-16T22:42:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.671,"exec_milliseconds":1671,"live_games":0,"fallback_games":2,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":39481,"important":true,"run_id":"20260516_224202_09b83b30"}
2026-05-16T22:43:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_224301_d30321a5"}
2026-05-16T22:43:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_224301_d30321a5"}
2026-05-16T22:43:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_224301_d30321a5"}
2026-05-16T22:43:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_224301_d30321a5"}
2026-05-16T22:43:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_224301_d30321a5"}
2026-05-16T22:43:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_224301_d30321a5"}
2026-05-16T22:43:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_224301_d30321a5"}
2026-05-16T22:43:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_224301_d30321a5"}
2026-05-16T22:43:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_224301_d30321a5"}
2026-05-16T22:43:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.745,"duration_milliseconds":745,"important":true,"run_id":"20260516_224301_d30321a5"}
2026-05-16T22:43:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"54:69","run_id":"20260516_224301_d30321a5"}
2026-05-16T22:43:03+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.088,"duration_milliseconds":88,"important":true,"run_id":"20260516_224301_d30321a5"}
2026-05-16T22:43:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":39481,"run_id":"20260516_224301_d30321a5"}
2026-05-16T22:43:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.587,"exec_milliseconds":1587,"live_games":0,"fallback_games":2,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":39481,"important":true,"run_id":"20260516_224301_d30321a5"}
2026-05-16T22:44:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_224402_abfde33e"}
2026-05-16T22:44:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_224402_abfde33e"}
2026-05-16T22:44:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_224402_abfde33e"}
2026-05-16T22:44:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_224402_abfde33e"}
2026-05-16T22:44:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_224402_abfde33e"}
2026-05-16T22:44:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_224402_abfde33e"}
2026-05-16T22:44:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_224402_abfde33e"}
2026-05-16T22:44:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_224402_abfde33e"}
2026-05-16T22:44:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_224402_abfde33e"}
2026-05-16T22:44:04+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.722,"duration_milliseconds":722,"important":true,"run_id":"20260516_224402_abfde33e"}
2026-05-16T22:44:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"54:69","run_id":"20260516_224402_abfde33e"}
2026-05-16T22:44:04+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.076,"duration_milliseconds":76,"important":true,"run_id":"20260516_224402_abfde33e"}
2026-05-16T22:44:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":39481,"run_id":"20260516_224402_abfde33e"}
2026-05-16T22:44:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.602,"exec_milliseconds":1602,"live_games":0,"fallback_games":2,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":39481,"important":true,"run_id":"20260516_224402_abfde33e"}
2026-05-16T22:45:06+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_224506_9b5debdf"}
2026-05-16T22:45:06+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_224506_9b5debdf"}
2026-05-16T22:45:06+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_224506_9b5debdf"}
2026-05-16T22:45:06+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_224506_9b5debdf"}
2026-05-16T22:45:06+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_224506_9b5debdf"}
2026-05-16T22:45:07+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_224506_9b5debdf"}
2026-05-16T22:45:07+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_224506_9b5debdf"}
2026-05-16T22:45:07+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_224506_9b5debdf"}
2026-05-16T22:45:07+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_224506_9b5debdf"}
2026-05-16T22:45:07+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.738,"duration_milliseconds":738,"important":true,"run_id":"20260516_224506_9b5debdf"}
2026-05-16T22:45:08+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"54:69","run_id":"20260516_224506_9b5debdf"}
2026-05-16T22:45:08+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.09,"duration_milliseconds":90,"important":true,"run_id":"20260516_224506_9b5debdf"}
2026-05-16T22:45:08+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":39397,"run_id":"20260516_224506_9b5debdf"}
2026-05-16T22:45:08+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.642,"exec_milliseconds":1642,"live_games":0,"fallback_games":2,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":39397,"important":true,"run_id":"20260516_224506_9b5debdf"}
2026-05-16T22:46:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_224602_e14febd8"}
2026-05-16T22:46:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_224602_e14febd8"}
2026-05-16T22:46:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_224602_e14febd8"}
2026-05-16T22:46:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_224602_e14febd8"}
2026-05-16T22:46:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_224602_e14febd8"}
2026-05-16T22:46:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_224602_e14febd8"}
2026-05-16T22:46:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_224602_e14febd8"}
2026-05-16T22:46:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_224602_e14febd8"}
2026-05-16T22:46:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_224602_e14febd8"}
2026-05-16T22:46:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.726,"duration_milliseconds":726,"important":true,"run_id":"20260516_224602_e14febd8"}
2026-05-16T22:46:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"54:69","run_id":"20260516_224602_e14febd8"}
2026-05-16T22:46:04+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.089,"duration_milliseconds":89,"important":true,"run_id":"20260516_224602_e14febd8"}
2026-05-16T22:46:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":39481,"run_id":"20260516_224602_e14febd8"}
2026-05-16T22:46:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.613,"exec_milliseconds":1613,"live_games":0,"fallback_games":2,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":39481,"important":true,"run_id":"20260516_224602_e14febd8"}
2026-05-16T22:47:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_224701_3276f5e9"}
2026-05-16T22:47:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_224701_3276f5e9"}
2026-05-16T22:47:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_224701_3276f5e9"}
2026-05-16T22:47:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_224701_3276f5e9"}
2026-05-16T22:47:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_224701_3276f5e9"}
2026-05-16T22:47:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_224701_3276f5e9"}
2026-05-16T22:47:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_224701_3276f5e9"}
2026-05-16T22:47:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_224701_3276f5e9"}
2026-05-16T22:47:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_224701_3276f5e9"}
2026-05-16T22:47:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.724,"duration_milliseconds":724,"important":true,"run_id":"20260516_224701_3276f5e9"}
2026-05-16T22:47:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"54:69","run_id":"20260516_224701_3276f5e9"}
2026-05-16T22:47:03+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.093,"duration_milliseconds":93,"important":true,"run_id":"20260516_224701_3276f5e9"}
2026-05-16T22:47:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":39481,"run_id":"20260516_224701_3276f5e9"}
2026-05-16T22:47:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.598,"exec_milliseconds":1598,"live_games":0,"fallback_games":2,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":39481,"important":true,"run_id":"20260516_224701_3276f5e9"}
2026-05-16T22:48:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_224802_7a76cd66"}
2026-05-16T22:48:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_224802_7a76cd66"}
2026-05-16T22:48:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_224802_7a76cd66"}
2026-05-16T22:48:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_224802_7a76cd66"}
2026-05-16T22:48:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_224802_7a76cd66"}
2026-05-16T22:48:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_224802_7a76cd66"}
2026-05-16T22:48:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_224802_7a76cd66"}
2026-05-16T22:48:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_224802_7a76cd66"}
2026-05-16T22:48:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_224802_7a76cd66"}
2026-05-16T22:48:04+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.724,"duration_milliseconds":724,"important":true,"run_id":"20260516_224802_7a76cd66"}
2026-05-16T22:48:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"54:69","run_id":"20260516_224802_7a76cd66"}
2026-05-16T22:48:04+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.084,"duration_milliseconds":84,"important":true,"run_id":"20260516_224802_7a76cd66"}
2026-05-16T22:48:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":39481,"run_id":"20260516_224802_7a76cd66"}
2026-05-16T22:48:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.57,"exec_milliseconds":1570,"live_games":0,"fallback_games":2,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":39481,"important":true,"run_id":"20260516_224802_7a76cd66"}
2026-05-16T22:49:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_224901_a6c45847"}
2026-05-16T22:49:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_224901_a6c45847"}
2026-05-16T22:49:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_224901_a6c45847"}
2026-05-16T22:49:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_224901_a6c45847"}
2026-05-16T22:49:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_224901_a6c45847"}
2026-05-16T22:49:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_224901_a6c45847"}
2026-05-16T22:49:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_224901_a6c45847"}
2026-05-16T22:49:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_224901_a6c45847"}
2026-05-16T22:49:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_224901_a6c45847"}
2026-05-16T22:49:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.728,"duration_milliseconds":728,"important":true,"run_id":"20260516_224901_a6c45847"}
2026-05-16T22:49:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"54:69","run_id":"20260516_224901_a6c45847"}
2026-05-16T22:49:03+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.094,"duration_milliseconds":94,"important":true,"run_id":"20260516_224901_a6c45847"}
2026-05-16T22:49:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":39481,"run_id":"20260516_224901_a6c45847"}
2026-05-16T22:49:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.599,"exec_milliseconds":1599,"live_games":0,"fallback_games":2,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":39481,"important":true,"run_id":"20260516_224901_a6c45847"}
2026-05-16T22:50:07+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_225006_935973d0"}
2026-05-16T22:50:07+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_225006_935973d0"}
2026-05-16T22:50:07+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_225006_935973d0"}
2026-05-16T22:50:07+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_225006_935973d0"}
2026-05-16T22:50:07+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_225006_935973d0"}
2026-05-16T22:50:07+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_225006_935973d0"}
2026-05-16T22:50:07+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_225006_935973d0"}
2026-05-16T22:50:07+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_225006_935973d0"}
2026-05-16T22:50:08+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_225006_935973d0"}
2026-05-16T22:50:08+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.721,"duration_milliseconds":721,"important":true,"run_id":"20260516_225006_935973d0"}
2026-05-16T22:50:08+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"54:69","run_id":"20260516_225006_935973d0"}
2026-05-16T22:50:08+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.083,"duration_milliseconds":83,"important":true,"run_id":"20260516_225006_935973d0"}
2026-05-16T22:50:08+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":39397,"run_id":"20260516_225006_935973d0"}
2026-05-16T22:50:08+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.569,"exec_milliseconds":1569,"live_games":0,"fallback_games":2,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":39397,"important":true,"run_id":"20260516_225006_935973d0"}
2026-05-16T22:51:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_225101_4014b287"}
2026-05-16T22:51:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_225101_4014b287"}
2026-05-16T22:51:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_225101_4014b287"}
2026-05-16T22:51:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_225101_4014b287"}
2026-05-16T22:51:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_225101_4014b287"}
2026-05-16T22:51:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_225101_4014b287"}
2026-05-16T22:51:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_225101_4014b287"}
2026-05-16T22:51:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_225101_4014b287"}
2026-05-16T22:51:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_225101_4014b287"}
2026-05-16T22:51:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.731,"duration_milliseconds":731,"important":true,"run_id":"20260516_225101_4014b287"}
2026-05-16T22:51:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"54:69","run_id":"20260516_225101_4014b287"}
2026-05-16T22:51:03+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.091,"duration_milliseconds":91,"important":true,"run_id":"20260516_225101_4014b287"}
2026-05-16T22:51:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":39481,"run_id":"20260516_225101_4014b287"}
2026-05-16T22:51:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.576,"exec_milliseconds":1576,"live_games":0,"fallback_games":2,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":39481,"important":true,"run_id":"20260516_225101_4014b287"}
2026-05-16T22:52:03+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_225203_69b74912"}
2026-05-16T22:52:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_225203_69b74912"}
2026-05-16T22:52:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_225203_69b74912"}
2026-05-16T22:52:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_225203_69b74912"}
2026-05-16T22:52:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_225203_69b74912"}
2026-05-16T22:52:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_225203_69b74912"}
2026-05-16T22:52:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_225203_69b74912"}
2026-05-16T22:52:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_225203_69b74912"}
2026-05-16T22:52:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_225203_69b74912"}
2026-05-16T22:52:04+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.735,"duration_milliseconds":735,"important":true,"run_id":"20260516_225203_69b74912"}
2026-05-16T22:52:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"54:69","run_id":"20260516_225203_69b74912"}
2026-05-16T22:52:04+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.088,"duration_milliseconds":88,"important":true,"run_id":"20260516_225203_69b74912"}
2026-05-16T22:52:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":39481,"run_id":"20260516_225203_69b74912"}
2026-05-16T22:52:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.611,"exec_milliseconds":1611,"live_games":0,"fallback_games":2,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":39481,"important":true,"run_id":"20260516_225203_69b74912"}
2026-05-16T22:53:01+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_225301_efe5e0fd"}
2026-05-16T22:53:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_225301_efe5e0fd"}
2026-05-16T22:53:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_225301_efe5e0fd"}
2026-05-16T22:53:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_225301_efe5e0fd"}
2026-05-16T22:53:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_225301_efe5e0fd"}
2026-05-16T22:53:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_225301_efe5e0fd"}
2026-05-16T22:53:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_225301_efe5e0fd"}
2026-05-16T22:53:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_225301_efe5e0fd"}
2026-05-16T22:53:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_225301_efe5e0fd"}
2026-05-16T22:53:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.74,"duration_milliseconds":740,"important":true,"run_id":"20260516_225301_efe5e0fd"}
2026-05-16T22:53:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"54:69","run_id":"20260516_225301_efe5e0fd"}
2026-05-16T22:53:03+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.095,"duration_milliseconds":95,"important":true,"run_id":"20260516_225301_efe5e0fd"}
2026-05-16T22:53:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":39481,"run_id":"20260516_225301_efe5e0fd"}
2026-05-16T22:53:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.607,"exec_milliseconds":1607,"live_games":0,"fallback_games":2,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":39481,"important":true,"run_id":"20260516_225301_efe5e0fd"}
2026-05-16T22:54:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_225402_8c7b9550"}
2026-05-16T22:54:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_225402_8c7b9550"}
2026-05-16T22:54:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_225402_8c7b9550"}
2026-05-16T22:54:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_225402_8c7b9550"}
2026-05-16T22:54:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_225402_8c7b9550"}
2026-05-16T22:54:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_225402_8c7b9550"}
2026-05-16T22:54:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_225402_8c7b9550"}
2026-05-16T22:54:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_225402_8c7b9550"}
2026-05-16T22:54:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_225402_8c7b9550"}
2026-05-16T22:54:04+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.729,"duration_milliseconds":729,"important":true,"run_id":"20260516_225402_8c7b9550"}
2026-05-16T22:54:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"54:69","run_id":"20260516_225402_8c7b9550"}
2026-05-16T22:54:04+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.09,"duration_milliseconds":90,"important":true,"run_id":"20260516_225402_8c7b9550"}
2026-05-16T22:54:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":39481,"run_id":"20260516_225402_8c7b9550"}
2026-05-16T22:54:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.624,"exec_milliseconds":1624,"live_games":0,"fallback_games":2,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":39481,"important":true,"run_id":"20260516_225402_8c7b9550"}
2026-05-16T22:55:04+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_225504_4688cbfa"}
2026-05-16T22:55:04+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_225504_4688cbfa"}
2026-05-16T22:55:04+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_225504_4688cbfa"}
2026-05-16T22:55:04+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_225504_4688cbfa"}
2026-05-16T22:55:05+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_225504_4688cbfa"}
2026-05-16T22:55:05+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_225504_4688cbfa"}
2026-05-16T22:55:05+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_225504_4688cbfa"}
2026-05-16T22:55:05+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_225504_4688cbfa"}
2026-05-16T22:55:05+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_225504_4688cbfa"}
2026-05-16T22:55:05+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.734,"duration_milliseconds":734,"important":true,"run_id":"20260516_225504_4688cbfa"}
2026-05-16T22:55:06+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"54:69","run_id":"20260516_225504_4688cbfa"}
2026-05-16T22:55:06+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.093,"duration_milliseconds":93,"important":true,"run_id":"20260516_225504_4688cbfa"}
2026-05-16T22:55:06+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":39397,"run_id":"20260516_225504_4688cbfa"}
2026-05-16T22:55:06+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.593,"exec_milliseconds":1593,"live_games":0,"fallback_games":2,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":39397,"important":true,"run_id":"20260516_225504_4688cbfa"}
2026-05-16T22:56:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_225602_f8bb9a58"}
2026-05-16T22:56:03+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_225602_f8bb9a58"}
2026-05-16T22:56:03+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_225602_f8bb9a58"}
2026-05-16T22:56:03+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_225602_f8bb9a58"}
2026-05-16T22:56:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_225602_f8bb9a58"}
2026-05-16T22:56:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_225602_f8bb9a58"}
2026-05-16T22:56:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_225602_f8bb9a58"}
2026-05-16T22:56:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_225602_f8bb9a58"}
2026-05-16T22:56:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_225602_f8bb9a58"}
2026-05-16T22:56:04+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.731,"duration_milliseconds":731,"important":true,"run_id":"20260516_225602_f8bb9a58"}
2026-05-16T22:56:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"54:69","run_id":"20260516_225602_f8bb9a58"}
2026-05-16T22:56:04+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.097,"duration_milliseconds":97,"important":true,"run_id":"20260516_225602_f8bb9a58"}
2026-05-16T22:56:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":39481,"run_id":"20260516_225602_f8bb9a58"}
2026-05-16T22:56:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.562,"exec_milliseconds":1562,"live_games":0,"fallback_games":2,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":39481,"important":true,"run_id":"20260516_225602_f8bb9a58"}
2026-05-16T22:57:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_225701_4a341b80"}
2026-05-16T22:57:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_225701_4a341b80"}
2026-05-16T22:57:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_225701_4a341b80"}
2026-05-16T22:57:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_225701_4a341b80"}
2026-05-16T22:57:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_225701_4a341b80"}
2026-05-16T22:57:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_225701_4a341b80"}
2026-05-16T22:57:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_225701_4a341b80"}
2026-05-16T22:57:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_225701_4a341b80"}
2026-05-16T22:57:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_225701_4a341b80"}
2026-05-16T22:57:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.725,"duration_milliseconds":725,"important":true,"run_id":"20260516_225701_4a341b80"}
2026-05-16T22:57:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"54:69","run_id":"20260516_225701_4a341b80"}
2026-05-16T22:57:03+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.088,"duration_milliseconds":88,"important":true,"run_id":"20260516_225701_4a341b80"}
2026-05-16T22:57:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":39481,"run_id":"20260516_225701_4a341b80"}
2026-05-16T22:57:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.593,"exec_milliseconds":1593,"live_games":0,"fallback_games":2,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":39481,"important":true,"run_id":"20260516_225701_4a341b80"}
2026-05-16T22:58:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_225802_3cceb641"}
2026-05-16T22:58:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_225802_3cceb641"}
2026-05-16T22:58:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_225802_3cceb641"}
2026-05-16T22:58:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_225802_3cceb641"}
2026-05-16T22:58:03+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_225802_3cceb641"}
2026-05-16T22:58:03+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_225802_3cceb641"}
2026-05-16T22:58:03+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_225802_3cceb641"}
2026-05-16T22:58:03+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_225802_3cceb641"}
2026-05-16T22:58:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_225802_3cceb641"}
2026-05-16T22:58:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.725,"duration_milliseconds":725,"important":true,"run_id":"20260516_225802_3cceb641"}
2026-05-16T22:58:04+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"54:69","run_id":"20260516_225802_3cceb641"}
2026-05-16T22:58:04+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.082,"duration_milliseconds":82,"important":true,"run_id":"20260516_225802_3cceb641"}
2026-05-16T22:58:04+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":39481,"run_id":"20260516_225802_3cceb641"}
2026-05-16T22:58:04+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.59,"exec_milliseconds":1590,"live_games":0,"fallback_games":2,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":39481,"important":true,"run_id":"20260516_225802_3cceb641"}
2026-05-16T22:59:02+02:00 [INFO] Cron run started {"php_sapi":"apache2handler","env_file":"/var/www/html/stats/cron/.env","max_live_games":9,"enable_period_scan":0,"verbose_log":1,"time_budget_seconds":28,"sftp_timeout_seconds":4,"log_retention_days":7,"season":"2025/2026","minimal_roundtrip":0,"alert_email_to":"michael@grewelding.com","alert_cooldown_seconds":21600,"important":true,"run_id":"20260516_225901_7dc1da06"}
2026-05-16T22:59:02+02:00 [INFO] SFTP login successful {"host":"sftp.easycredit-bbl.de","user":"liga","run_id":"20260516_225901_7dc1da06"}
2026-05-16T22:59:02+02:00 [INFO] Loaded referee list {"count":36,"run_id":"20260516_225901_7dc1da06"}
2026-05-16T22:59:02+02:00 [INFO] Loaded TK list {"count":15,"run_id":"20260516_225901_7dc1da06"}
2026-05-16T22:59:02+02:00 [INFO] Team meta loaded {"count":24,"season":"2025/2026","run_id":"20260516_225901_7dc1da06"}
2026-05-16T22:59:02+02:00 [INFO] Live games query successful {"count":0,"run_id":"20260516_225901_7dc1da06"}
2026-05-16T22:59:02+02:00 [WARN] No statstatus column found in liga1.viw_game_status_all; Official filter skipped {"run_id":"20260516_225901_7dc1da06"}
2026-05-16T22:59:02+02:00 [INFO] Fallback query executed {"remaining_slots":9,"run_id":"20260516_225901_7dc1da06"}
2026-05-16T22:59:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005752,"result":"80:74","run_id":"20260516_225901_7dc1da06"}
2026-05-16T22:59:03+02:00 [INFO] Fallback game timing {"spiel_id":2005752,"duration_seconds":0.729,"duration_milliseconds":729,"important":true,"run_id":"20260516_225901_7dc1da06"}
2026-05-16T22:59:03+02:00 [INFO] Fallback row rendered {"spiel_id":2005747,"result":"54:69","run_id":"20260516_225901_7dc1da06"}
2026-05-16T22:59:03+02:00 [INFO] Fallback game timing {"spiel_id":2005747,"duration_seconds":0.095,"duration_milliseconds":95,"important":true,"run_id":"20260516_225901_7dc1da06"}
2026-05-16T22:59:03+02:00 [INFO] Output file written {"file":"/var/www/html/stats/newLiveCheck.html","bytes":39481,"run_id":"20260516_225901_7dc1da06"}
2026-05-16T22:59:03+02:00 [INFO] Cron run finished {"status":"OK","exec_seconds":1.657,"exec_milliseconds":1657,"live_games":0,"fallback_games":2,"warnings":0,"errors":0,"json_errors":0,"sftp_dir_errors":0,"sftp_file_missing":0,"timed_out":0,"truncated_live_games":0,"output_file":"/var/www/html/stats/newLiveCheck.html","output_bytes":39481,"important":true,"run_id":"20260516_225901_7dc1da06"}
