Commit Graph

73 Commits

Author SHA1 Message Date
nate c24847ec18 fix 2026-04-10 00:18:59 +04:00
nate 60b88dd4d4 store more metadata 2026-04-09 23:53:02 +04:00
nate ed59e9c8dc remove $consider, replace with $not 2026-04-09 23:43:10 +04:00
nate 9b2f1de4e7 refactor query language 2026-04-09 23:30:57 +04:00
nate 1434330545 fix 2026-04-08 14:42:08 +04:00
nate 2336f86aa3 fix: docs placement 2026-04-08 13:28:46 +04:00
nate 1f01a00ad6 feat: refactor stage 1 2026-04-08 08:58:44 +04:00
nate 8e554498f0 fet: reduce LOC by reducing comments 2026-03-28 18:05:29 +04:00
nate 005f635fab fix: improve monitor 2026-03-28 17:15:12 +04:00
nate d844b495b2 fix 2026-03-26 14:04:15 +04:00
nate 7b5411ab64 feat: filter pings 2026-03-26 12:20:09 +04:00
nate bb05dae926 feat: increase response body limit 2026-03-24 17:08:40 +04:00
nate 30468e378d fix: default content type 2026-03-19 16:13:05 +04:00
nate dae1d5f77a fix: poll coordinator every 500ms to reduce jitter on 1s intervals 2026-03-18 20:33:36 +04:00
nate 5be1f85365 fix: run cert expiry check concurrently to avoid delaying results 2026-03-18 19:04:30 +04:00
nate 42024a9fc3 fix: use monitor-side checked_at timestamp instead of coordinator arrival time 2026-03-18 18:50:16 +04:00
nate 425bfbfc39 perf: optimize monitor runner, fix SSE leak, deduplicate shared utils 2026-03-18 18:44:08 +04:00
M1 980261632e fix: deserialize scheduled_at_ms as string or number (postgres bigint serializes as string) 2026-03-18 17:17:29 +04:00
M1 c5eb514990 feat: lookahead scheduling — API returns scheduled_at_ms, nodes sleep-until for tight coordination 2026-03-18 17:14:28 +04:00
M1 7b98ae78e5 fix: run_id = hash(monitor_id, interval_bucket) — unique per window, consistent across regions 2026-03-18 17:03:17 +04:00
M1 b6a66ddb21 fix: run_id derived from scheduled_at bucket so all regions share same ID per window 2026-03-18 16:46:30 +04:00
M1 f7ab3b96b2 feat: per-region due scheduling + run_id to group pings across regions 2026-03-18 16:36:35 +04:00
M1 93db31db3b feat: multi-region monitor support — region selector in UI, region flag on pings 2026-03-18 16:08:39 +04:00
M1 52f7f8102b feat: update user-agent to Mozilla-compatible string 2026-03-18 14:43:33 +04:00
M1 957674fca4 fix: clear in-flight after post_result to prevent double-pings, revert poll to 50ms 2026-03-18 14:29:37 +04:00
M1 d3ee0ef9d5 fix: revert grace period, increase poll interval to 500ms to prevent doubles without adding jitter 2026-03-18 14:27:38 +04:00
M1 6882162d7f fix: use system CA store for ureq TLS to verify Cloudflare-issued certs 2026-03-18 14:10:28 +04:00
M1 1b8cbc6e23 fix: force ureq to use ring crypto provider to match main.rs init 2026-03-18 14:05:04 +04:00
M1 f17bfbfd4b fix: switch ureq from native-tls to rustls (bundled roots) 2026-03-18 13:54:39 +04:00
M1 3fa624eff8 fix: replace curl subprocess with ureq blocking client in std::thread 2026-03-18 13:40:28 +04:00
M1 6b8e1fc9d9 cleanup: remove debug warn logs from monitor runner 2026-03-18 13:30:19 +04:00
M1 6e1d642c77 fix: allow null status_code in ingest schema; check HTTP status in post_result 2026-03-18 13:28:42 +04:00
M1 5037222846 fix: add 10s timeout to post_result to prevent hung API calls 2026-03-18 13:24:52 +04:00
M1 3ce89a88bf debug: log post_result calls 2026-03-18 13:22:35 +04:00
M1 749a06b9d7 debug: log check errors and trace post_result calls 2026-03-18 13:19:35 +04:00
M1 cb8d0f81b1 debug: add warn logs to curl thread, fix temp file uniqueness 2026-03-18 13:17:11 +04:00
M1 556729b881 fix: use std::thread + tokio oneshot for curl — fully decoupled from tokio thread pool 2026-03-18 13:10:04 +04:00
M1 5e76b2212f fix: use std::process::Command+spawn_blocking+temp file to avoid all pipe/async hang issues 2026-03-18 13:08:08 +04:00
M1 289ec8e038 fix: hard task-level timeout as failsafe so in-flight lock always clears 2026-03-18 13:05:43 +04:00
M1 0edce8c555 fix: use spawn+manual read+wait instead of output() to avoid stdout pipe hang 2026-03-18 13:03:06 +04:00
M1 94200b430f fix: set kill_on_drop and explicit stdio pipes so curl doesn't inherit parent fds 2026-03-18 12:59:34 +04:00
M1 79bf7d9295 fix: wrap curl output() in tokio timeout in case process hangs on stdout 2026-03-18 12:58:12 +04:00
M1 554d95cfb4 fix: correctly handle curl non-zero exit codes as errors 2026-03-18 12:55:00 +04:00
M1 5730a3cb83 fix: replace reqwest with curl subprocess for reliable hard timeouts 2026-03-18 12:52:17 +04:00
M1 c68700da46 fix: use blocking reqwest in spawn_blocking for reliable OS-level timeout 2026-03-18 12:48:30 +04:00
M1 4035a3b215 fix: switch reqwest to native-tls so connect_timeout covers TLS handshake 2026-03-18 12:45:52 +04:00
M1 5b0bce65c6 fix: pre-flight TCP connect check with hard tokio timeout before reqwest attempt 2026-03-18 12:43:27 +04:00
M1 b8b0a9d5e2 fix: per-check client with connect_timeout to guarantee OS-level TCP timeout 2026-03-18 12:42:09 +04:00
M1 7905a8003b fix: clean up cert check - only runs after successful response, no more borrow errors 2026-03-18 12:40:03 +04:00
M1 de6e24e973 fix: move cert check to after successful HTTP response, never runs on down/timeout hosts 2026-03-18 12:39:18 +04:00