fix: use payment initiation timestamp for stale PENDING detection #583
+102
−13
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Summary
Fixes stale PENDING detection to use the actual payment initiation timestamp instead of the unrelated
taken_atorder field.Closes #570
Problem
The stale PENDING cleanup query used
taken_at(when the order was taken by a counterparty) to determine if a PENDING dev fee entry is stale. This is wrong because:Solution (Option A from the issue — no schema change)
PENDING marker now includes timestamp
Stale detection parses timestamp from marker
Instead of a SQL
WHERE taken_at < cutoff, we now:PENDING-%rowsparse_pending_timestamp()Timestamp parsing
Since order IDs are UUIDs (containing dashes), the parser uses
rsplitto get the last segment and validates it's exactly 10 decimal digits (valid for unix timestamps 2001–2286), distinguishing it from UUID hex segments.Tests
5 new unit tests for
parse_pending_timestamp():Verification
cargo fmt— cleancargo clippy --all-targets --all-features— cleancargo test— 117 passed, 0 failed