You're offline — showing cached data

Sweep overdue ledger rows into orchestrator_inbox

luci-followup-sweep
2026-06-13 06:15:47 SAST
← Back to Tasks

OVERRIDES runtime profile: uses direct Python (no claude CLI) because the sweep is a pure SQL scan over mc.db — no LLM call, no provider routing.

Every 30 minutes:

  1. Parses any Expected check-in: line on open tickets and writes the typed tickets.expected_check_in_at column (idempotent backfill).
  2. Lists open tickets and active runtime_sessions whose expected_check_in_at is in the past.
  3. For each overdue ticket inserts one pending row into orchestrator_inbox with source_type='followup_sweep', deduped so a single overdue episode produces a single inbox row (matches the _has_open_row discipline used by orchestrator_triage).
  4. Posts a single [follow-up] N min past expected check-in system comment on the ticket when the inbox row is created.

The orchestrator pickup loop drains orchestrator_inbox into the next Luci digest, so overdue check-ins surface in the standard control-plane channel instead of triggering ad-hoc Telegrams.

Closes gap §5 item 2 in runbooks/luci-delegation-control-plane.md.

Verification: python3 /home/lucienne/workspace/scripts/luci_followup_sweep.py --dry-run --timeout 90 --db-timeout 5 prints a JSON summary without writing.

The command uses an internal 90s wall deadline and a 5s SQLite busy timeout, both below the scheduler's 120s kill timeout. Dry-run opens the DB read-only so manual reproduction cannot run schema migrations/backfills.

Logs to the standard scheduler task_runs.output field — one JSON line per run with counts of backfilled, overdue, inserted and deduped rows. Progress is emitted as JSON lines on stderr and error JSON includes the active phase so a future scheduler failure shows where it stalled.

Every 30 minutes*/30 * * * *
Yes
shell
120s
No
in 14m (2026-06-13 06:30)

Task Definition

tasks/luci-followup-sweep.md
shell
set
No
No
/usr/bin/python3 /home/lucienne/workspace/scripts/luci_followup_sweep.py --timeout 90 --db-timeout 5

Edit Schedule

Result:
349
Runs (7d)
348
Completed
0
Failed
1
Timeout
100%
Success (7d)
1s
Avg Duration
orchestrator followup ledger

Run History (50)

StartedFinishedStatusDurationOutputLog
15m ago 15m ago completed 0s
{"ts": "2026-06-13T04:00:44Z", "db": "/home/lucienne/workspace/mission-control/mc.db", "dry_run": false, "elapsed_s": 0. ...
View log
45m ago 45m ago completed 0s
{"ts": "2026-06-13T03:30:22Z", "db": "/home/lucienne/workspace/mission-control/mc.db", "dry_run": false, "elapsed_s": 0. ...
View log
1h ago 1h ago completed 0s
{"ts": "2026-06-13T03:00:54Z", "db": "/home/lucienne/workspace/mission-control/mc.db", "dry_run": false, "elapsed_s": 0. ...
View log
2h ago 2h ago completed 0s
{"ts": "2026-06-13T02:30:21Z", "db": "/home/lucienne/workspace/mission-control/mc.db", "dry_run": false, "elapsed_s": 0. ...
View log
2h ago 2h ago completed 0s
{"ts": "2026-06-13T02:04:32Z", "db": "/home/lucienne/workspace/mission-control/mc.db", "dry_run": false, "elapsed_s": 0. ...
View log
3h ago 3h ago completed 0s
{"ts": "2026-06-13T01:31:20Z", "db": "/home/lucienne/workspace/mission-control/mc.db", "dry_run": false, "elapsed_s": 0. ...
View log
3h ago 3h ago completed 0s
{"ts": "2026-06-13T01:00:33Z", "db": "/home/lucienne/workspace/mission-control/mc.db", "dry_run": false, "elapsed_s": 0. ...
View log
4h ago 4h ago completed 0s
{"ts": "2026-06-13T00:30:22Z", "db": "/home/lucienne/workspace/mission-control/mc.db", "dry_run": false, "elapsed_s": 0. ...
View log
4h ago 4h ago completed 0s
{"ts": "2026-06-13T00:02:20Z", "db": "/home/lucienne/workspace/mission-control/mc.db", "dry_run": false, "elapsed_s": 0. ...
View log
5h ago 5h ago completed 0s
{"ts": "2026-06-12T23:30:22Z", "db": "/home/lucienne/workspace/mission-control/mc.db", "dry_run": false, "elapsed_s": 0. ...
View log
5h ago 5h ago completed 0s
{"ts": "2026-06-12T23:00:36Z", "db": "/home/lucienne/workspace/mission-control/mc.db", "dry_run": false, "elapsed_s": 0. ...
View log
6h ago 6h ago completed 0s
{"ts": "2026-06-12T22:30:21Z", "db": "/home/lucienne/workspace/mission-control/mc.db", "dry_run": false, "elapsed_s": 0. ...
View log
6h ago 6h ago completed 0s
{"ts": "2026-06-12T22:00:46Z", "db": "/home/lucienne/workspace/mission-control/mc.db", "dry_run": false, "elapsed_s": 0. ...
View log
7h ago 7h ago completed 0s
{"ts": "2026-06-12T21:30:22Z", "db": "/home/lucienne/workspace/mission-control/mc.db", "dry_run": false, "elapsed_s": 0. ...
View log
7h ago 7h ago completed 0s
{"ts": "2026-06-12T21:00:35Z", "db": "/home/lucienne/workspace/mission-control/mc.db", "dry_run": false, "elapsed_s": 0. ...
View log
8h ago 8h ago completed 0s
{"ts": "2026-06-12T20:30:23Z", "db": "/home/lucienne/workspace/mission-control/mc.db", "dry_run": false, "elapsed_s": 0. ...
View log
8h ago 8h ago completed 0s
{"ts": "2026-06-12T20:00:31Z", "db": "/home/lucienne/workspace/mission-control/mc.db", "dry_run": false, "elapsed_s": 0. ...
View log
9h ago 9h ago completed 0s
{"ts": "2026-06-12T19:30:23Z", "db": "/home/lucienne/workspace/mission-control/mc.db", "dry_run": false, "elapsed_s": 0. ...
View log
9h ago 9h ago completed 0s
{"ts": "2026-06-12T19:00:30Z", "db": "/home/lucienne/workspace/mission-control/mc.db", "dry_run": false, "elapsed_s": 0. ...
View log
10h ago 10h ago completed 0s
{"ts": "2026-06-12T18:30:23Z", "db": "/home/lucienne/workspace/mission-control/mc.db", "dry_run": false, "elapsed_s": 0. ...
View log
10h ago 10h ago completed 0s
{"ts": "2026-06-12T18:00:28Z", "db": "/home/lucienne/workspace/mission-control/mc.db", "dry_run": false, "elapsed_s": 0. ...
View log
11h ago 11h ago completed 0s
{"ts": "2026-06-12T17:30:23Z", "db": "/home/lucienne/workspace/mission-control/mc.db", "dry_run": false, "elapsed_s": 0. ...
View log
11h ago 11h ago completed 0s
{"ts": "2026-06-12T17:04:02Z", "db": "/home/lucienne/workspace/mission-control/mc.db", "dry_run": false, "elapsed_s": 0. ...
View log
12h ago 12h ago completed 0s
{"ts": "2026-06-12T16:30:39Z", "db": "/home/lucienne/workspace/mission-control/mc.db", "dry_run": false, "elapsed_s": 0. ...
View log
12h ago 12h ago completed 0s
{"ts": "2026-06-12T16:01:16Z", "db": "/home/lucienne/workspace/mission-control/mc.db", "dry_run": false, "elapsed_s": 0. ...
View log
13h ago 13h ago completed 0s
{"ts": "2026-06-12T15:30:41Z", "db": "/home/lucienne/workspace/mission-control/mc.db", "dry_run": false, "elapsed_s": 0. ...
View log
13h ago 13h ago completed 0s
{"ts": "2026-06-12T15:03:07Z", "db": "/home/lucienne/workspace/mission-control/mc.db", "dry_run": false, "elapsed_s": 0. ...
View log
14h ago 14h ago completed 0s
{"ts": "2026-06-12T14:30:40Z", "db": "/home/lucienne/workspace/mission-control/mc.db", "dry_run": false, "elapsed_s": 0. ...
View log
14h ago 14h ago completed 0s
{"ts": "2026-06-12T14:00:27Z", "db": "/home/lucienne/workspace/mission-control/mc.db", "dry_run": false, "elapsed_s": 0. ...
View log
15h ago 15h ago completed 0s
{"ts": "2026-06-12T13:30:25Z", "db": "/home/lucienne/workspace/mission-control/mc.db", "dry_run": false, "elapsed_s": 0. ...
View log
15h ago 15h ago completed 0s
{"ts": "2026-06-12T13:00:28Z", "db": "/home/lucienne/workspace/mission-control/mc.db", "dry_run": false, "elapsed_s": 0. ...
View log
16h ago 16h ago completed 0s
{"ts": "2026-06-12T12:30:39Z", "db": "/home/lucienne/workspace/mission-control/mc.db", "dry_run": false, "elapsed_s": 0. ...
View log
16h ago 16h ago completed 0s
{"ts": "2026-06-12T12:00:41Z", "db": "/home/lucienne/workspace/mission-control/mc.db", "dry_run": false, "elapsed_s": 0. ...
View log
17h ago 17h ago completed 0s
{"ts": "2026-06-12T11:30:40Z", "db": "/home/lucienne/workspace/mission-control/mc.db", "dry_run": false, "elapsed_s": 0. ...
View log
17h ago 17h ago completed 0s
{"ts": "2026-06-12T11:00:45Z", "db": "/home/lucienne/workspace/mission-control/mc.db", "dry_run": false, "elapsed_s": 0. ...
View log
18h ago 18h ago completed 0s
{"ts": "2026-06-12T10:30:21Z", "db": "/home/lucienne/workspace/mission-control/mc.db", "dry_run": false, "elapsed_s": 0. ...
View log
18h ago 18h ago completed 0s
{"ts": "2026-06-12T10:09:12Z", "db": "/home/lucienne/workspace/mission-control/mc.db", "dry_run": false, "elapsed_s": 0. ...
View log
19h ago 19h ago completed 0s
{"ts": "2026-06-12T09:30:18Z", "db": "/home/lucienne/workspace/mission-control/mc.db", "dry_run": false, "elapsed_s": 0. ...
View log
19h ago 19h ago completed 0s
{"ts": "2026-06-12T09:00:23Z", "db": "/home/lucienne/workspace/mission-control/mc.db", "dry_run": false, "elapsed_s": 0. ...
View log
20h ago 20h ago completed 0s
{"ts": "2026-06-12T08:30:18Z", "db": "/home/lucienne/workspace/mission-control/mc.db", "dry_run": false, "elapsed_s": 0. ...
View log
20h ago 20h ago completed 0s
{"ts": "2026-06-12T08:00:22Z", "db": "/home/lucienne/workspace/mission-control/mc.db", "dry_run": false, "elapsed_s": 0. ...
View log
21h ago 21h ago completed 0s
{"ts": "2026-06-12T07:30:18Z", "db": "/home/lucienne/workspace/mission-control/mc.db", "dry_run": false, "elapsed_s": 0. ...
View log
21h ago 21h ago completed 0s
{"ts": "2026-06-12T07:00:24Z", "db": "/home/lucienne/workspace/mission-control/mc.db", "dry_run": false, "elapsed_s": 0. ...
View log
22h ago 22h ago completed 0s
{"ts": "2026-06-12T06:30:18Z", "db": "/home/lucienne/workspace/mission-control/mc.db", "dry_run": false, "elapsed_s": 0. ...
View log
22h ago 22h ago completed 0s
{"ts": "2026-06-12T06:03:13Z", "db": "/home/lucienne/workspace/mission-control/mc.db", "dry_run": false, "elapsed_s": 0. ...
View log
23h ago 23h ago completed 0s
{"ts": "2026-06-12T05:30:16Z", "db": "/home/lucienne/workspace/mission-control/mc.db", "dry_run": false, "elapsed_s": 0. ...
View log
23h ago 23h ago completed 0s
{"ts": "2026-06-12T05:00:21Z", "db": "/home/lucienne/workspace/mission-control/mc.db", "dry_run": false, "elapsed_s": 0. ...
View log
24h ago 24h ago completed 0s
{"ts": "2026-06-12T04:30:18Z", "db": "/home/lucienne/workspace/mission-control/mc.db", "dry_run": false, "elapsed_s": 0. ...
View log
1d ago 1d ago completed 0s
{"ts": "2026-06-12T04:01:04Z", "db": "/home/lucienne/workspace/mission-control/mc.db", "dry_run": false, "elapsed_s": 0. ...
View log
1d ago 1d ago completed 0s
{"ts": "2026-06-12T03:30:18Z", "db": "/home/lucienne/workspace/mission-control/mc.db", "dry_run": false, "elapsed_s": 0. ...
View log

Comments (0)

No comments yet — add instructions for Luci
Help