instar 1.2.82 → 1.2.83

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (41) hide show
  1. package/dist/commands/server.d.ts.map +1 -1
  2. package/dist/commands/server.js +99 -1
  3. package/dist/commands/server.js.map +1 -1
  4. package/dist/config/ConfigDefaults.d.ts.map +1 -1
  5. package/dist/config/ConfigDefaults.js +23 -0
  6. package/dist/config/ConfigDefaults.js.map +1 -1
  7. package/dist/core/SessionManager.d.ts +43 -0
  8. package/dist/core/SessionManager.d.ts.map +1 -1
  9. package/dist/core/SessionManager.js +123 -24
  10. package/dist/core/SessionManager.js.map +1 -1
  11. package/dist/core/types.d.ts +26 -0
  12. package/dist/core/types.d.ts.map +1 -1
  13. package/dist/core/types.js.map +1 -1
  14. package/dist/monitoring/SessionReaper.d.ts +153 -0
  15. package/dist/monitoring/SessionReaper.d.ts.map +1 -0
  16. package/dist/monitoring/SessionReaper.js +376 -0
  17. package/dist/monitoring/SessionReaper.js.map +1 -0
  18. package/dist/monitoring/TokenLedger.d.ts +12 -0
  19. package/dist/monitoring/TokenLedger.d.ts.map +1 -1
  20. package/dist/monitoring/TokenLedger.js +22 -0
  21. package/dist/monitoring/TokenLedger.js.map +1 -1
  22. package/dist/monitoring/transcriptProber.d.ts +44 -0
  23. package/dist/monitoring/transcriptProber.d.ts.map +1 -0
  24. package/dist/monitoring/transcriptProber.js +57 -0
  25. package/dist/monitoring/transcriptProber.js.map +1 -0
  26. package/dist/scaffold/templates.d.ts.map +1 -1
  27. package/dist/scaffold/templates.js +6 -0
  28. package/dist/scaffold/templates.js.map +1 -1
  29. package/dist/server/AgentServer.d.ts +3 -0
  30. package/dist/server/AgentServer.d.ts.map +1 -1
  31. package/dist/server/AgentServer.js +1 -0
  32. package/dist/server/AgentServer.js.map +1 -1
  33. package/dist/server/routes.d.ts +3 -0
  34. package/dist/server/routes.d.ts.map +1 -1
  35. package/dist/server/routes.js +10 -0
  36. package/dist/server/routes.js.map +1 -1
  37. package/package.json +1 -1
  38. package/src/data/builtin-manifest.json +48 -48
  39. package/src/scaffold/templates.ts +6 -0
  40. package/upgrades/1.2.83.md +26 -0
  41. package/upgrades/side-effects/session-reaper.md +42 -0
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "instar",
3
- "version": "1.2.82",
3
+ "version": "1.2.83",
4
4
  "description": "Coherence infrastructure for self-evolving AI agents — on the Claude Code or Codex subscription you already have.",
5
5
  "type": "module",
6
6
  "main": "dist/index.js",
@@ -1,8 +1,8 @@
1
1
  {
2
2
  "$schema": "./builtin-manifest.schema.json",
3
3
  "schemaVersion": 1,
4
- "generatedAt": "2026-05-26T06:02:13.395Z",
5
- "instarVersion": "1.2.82",
4
+ "generatedAt": "2026-05-26T16:19:48.394Z",
5
+ "instarVersion": "1.2.83",
6
6
  "entryCount": 191,
7
7
  "entries": {
8
8
  "hook:session-start": {
@@ -392,7 +392,7 @@
392
392
  "type": "route-group",
393
393
  "domain": "monitoring",
394
394
  "sourcePath": "src/server/routes.ts",
395
- "contentHash": "8576d7a2b03dc1c83a9acad4415757299153c44f5bbe2a12f0313b6bc2df2b8e",
395
+ "contentHash": "e7ecb683c067a3e36768c52252eac303ea9178c3a060828f5673251e8b8908c1",
396
396
  "since": "2025-01-01"
397
397
  },
398
398
  "route-group:agents": {
@@ -400,7 +400,7 @@
400
400
  "type": "route-group",
401
401
  "domain": "sessions",
402
402
  "sourcePath": "src/server/routes.ts",
403
- "contentHash": "8576d7a2b03dc1c83a9acad4415757299153c44f5bbe2a12f0313b6bc2df2b8e",
403
+ "contentHash": "e7ecb683c067a3e36768c52252eac303ea9178c3a060828f5673251e8b8908c1",
404
404
  "since": "2025-01-01"
405
405
  },
406
406
  "route-group:backups": {
@@ -408,7 +408,7 @@
408
408
  "type": "route-group",
409
409
  "domain": "operations",
410
410
  "sourcePath": "src/server/routes.ts",
411
- "contentHash": "8576d7a2b03dc1c83a9acad4415757299153c44f5bbe2a12f0313b6bc2df2b8e",
411
+ "contentHash": "e7ecb683c067a3e36768c52252eac303ea9178c3a060828f5673251e8b8908c1",
412
412
  "since": "2025-01-01"
413
413
  },
414
414
  "route-group:git": {
@@ -416,7 +416,7 @@
416
416
  "type": "route-group",
417
417
  "domain": "coordination",
418
418
  "sourcePath": "src/server/routes.ts",
419
- "contentHash": "8576d7a2b03dc1c83a9acad4415757299153c44f5bbe2a12f0313b6bc2df2b8e",
419
+ "contentHash": "e7ecb683c067a3e36768c52252eac303ea9178c3a060828f5673251e8b8908c1",
420
420
  "since": "2025-01-01"
421
421
  },
422
422
  "route-group:memory": {
@@ -424,7 +424,7 @@
424
424
  "type": "route-group",
425
425
  "domain": "memory",
426
426
  "sourcePath": "src/server/routes.ts",
427
- "contentHash": "8576d7a2b03dc1c83a9acad4415757299153c44f5bbe2a12f0313b6bc2df2b8e",
427
+ "contentHash": "e7ecb683c067a3e36768c52252eac303ea9178c3a060828f5673251e8b8908c1",
428
428
  "since": "2025-01-01"
429
429
  },
430
430
  "route-group:semantic": {
@@ -432,7 +432,7 @@
432
432
  "type": "route-group",
433
433
  "domain": "memory",
434
434
  "sourcePath": "src/server/routes.ts",
435
- "contentHash": "8576d7a2b03dc1c83a9acad4415757299153c44f5bbe2a12f0313b6bc2df2b8e",
435
+ "contentHash": "e7ecb683c067a3e36768c52252eac303ea9178c3a060828f5673251e8b8908c1",
436
436
  "since": "2025-01-01"
437
437
  },
438
438
  "route-group:status": {
@@ -440,7 +440,7 @@
440
440
  "type": "route-group",
441
441
  "domain": "monitoring",
442
442
  "sourcePath": "src/server/routes.ts",
443
- "contentHash": "8576d7a2b03dc1c83a9acad4415757299153c44f5bbe2a12f0313b6bc2df2b8e",
443
+ "contentHash": "e7ecb683c067a3e36768c52252eac303ea9178c3a060828f5673251e8b8908c1",
444
444
  "since": "2025-01-01"
445
445
  },
446
446
  "route-group:capabilities": {
@@ -448,7 +448,7 @@
448
448
  "type": "route-group",
449
449
  "domain": "mapping",
450
450
  "sourcePath": "src/server/routes.ts",
451
- "contentHash": "8576d7a2b03dc1c83a9acad4415757299153c44f5bbe2a12f0313b6bc2df2b8e",
451
+ "contentHash": "e7ecb683c067a3e36768c52252eac303ea9178c3a060828f5673251e8b8908c1",
452
452
  "since": "2025-01-01"
453
453
  },
454
454
  "route-group:project-map": {
@@ -456,7 +456,7 @@
456
456
  "type": "route-group",
457
457
  "domain": "mapping",
458
458
  "sourcePath": "src/server/routes.ts",
459
- "contentHash": "8576d7a2b03dc1c83a9acad4415757299153c44f5bbe2a12f0313b6bc2df2b8e",
459
+ "contentHash": "e7ecb683c067a3e36768c52252eac303ea9178c3a060828f5673251e8b8908c1",
460
460
  "since": "2025-01-01"
461
461
  },
462
462
  "route-group:coherence": {
@@ -464,7 +464,7 @@
464
464
  "type": "route-group",
465
465
  "domain": "coherence",
466
466
  "sourcePath": "src/server/routes.ts",
467
- "contentHash": "8576d7a2b03dc1c83a9acad4415757299153c44f5bbe2a12f0313b6bc2df2b8e",
467
+ "contentHash": "e7ecb683c067a3e36768c52252eac303ea9178c3a060828f5673251e8b8908c1",
468
468
  "since": "2025-01-01"
469
469
  },
470
470
  "route-group:topic-bindings": {
@@ -472,7 +472,7 @@
472
472
  "type": "route-group",
473
473
  "domain": "sessions",
474
474
  "sourcePath": "src/server/routes.ts",
475
- "contentHash": "8576d7a2b03dc1c83a9acad4415757299153c44f5bbe2a12f0313b6bc2df2b8e",
475
+ "contentHash": "e7ecb683c067a3e36768c52252eac303ea9178c3a060828f5673251e8b8908c1",
476
476
  "since": "2025-01-01"
477
477
  },
478
478
  "route-group:context": {
@@ -480,7 +480,7 @@
480
480
  "type": "route-group",
481
481
  "domain": "context",
482
482
  "sourcePath": "src/server/routes.ts",
483
- "contentHash": "8576d7a2b03dc1c83a9acad4415757299153c44f5bbe2a12f0313b6bc2df2b8e",
483
+ "contentHash": "e7ecb683c067a3e36768c52252eac303ea9178c3a060828f5673251e8b8908c1",
484
484
  "since": "2025-01-01"
485
485
  },
486
486
  "route-group:scope-coherence": {
@@ -488,7 +488,7 @@
488
488
  "type": "route-group",
489
489
  "domain": "coherence",
490
490
  "sourcePath": "src/server/routes.ts",
491
- "contentHash": "8576d7a2b03dc1c83a9acad4415757299153c44f5bbe2a12f0313b6bc2df2b8e",
491
+ "contentHash": "e7ecb683c067a3e36768c52252eac303ea9178c3a060828f5673251e8b8908c1",
492
492
  "since": "2025-01-01"
493
493
  },
494
494
  "route-group:canonical-state": {
@@ -496,7 +496,7 @@
496
496
  "type": "route-group",
497
497
  "domain": "state",
498
498
  "sourcePath": "src/server/routes.ts",
499
- "contentHash": "8576d7a2b03dc1c83a9acad4415757299153c44f5bbe2a12f0313b6bc2df2b8e",
499
+ "contentHash": "e7ecb683c067a3e36768c52252eac303ea9178c3a060828f5673251e8b8908c1",
500
500
  "since": "2025-01-01"
501
501
  },
502
502
  "route-group:ci": {
@@ -504,7 +504,7 @@
504
504
  "type": "route-group",
505
505
  "domain": "monitoring",
506
506
  "sourcePath": "src/server/routes.ts",
507
- "contentHash": "8576d7a2b03dc1c83a9acad4415757299153c44f5bbe2a12f0313b6bc2df2b8e",
507
+ "contentHash": "e7ecb683c067a3e36768c52252eac303ea9178c3a060828f5673251e8b8908c1",
508
508
  "since": "2025-01-01"
509
509
  },
510
510
  "route-group:sessions": {
@@ -512,7 +512,7 @@
512
512
  "type": "route-group",
513
513
  "domain": "sessions",
514
514
  "sourcePath": "src/server/routes.ts",
515
- "contentHash": "8576d7a2b03dc1c83a9acad4415757299153c44f5bbe2a12f0313b6bc2df2b8e",
515
+ "contentHash": "e7ecb683c067a3e36768c52252eac303ea9178c3a060828f5673251e8b8908c1",
516
516
  "since": "2025-01-01"
517
517
  },
518
518
  "route-group:jobs": {
@@ -520,7 +520,7 @@
520
520
  "type": "route-group",
521
521
  "domain": "scheduling",
522
522
  "sourcePath": "src/server/routes.ts",
523
- "contentHash": "8576d7a2b03dc1c83a9acad4415757299153c44f5bbe2a12f0313b6bc2df2b8e",
523
+ "contentHash": "e7ecb683c067a3e36768c52252eac303ea9178c3a060828f5673251e8b8908c1",
524
524
  "since": "2025-01-01"
525
525
  },
526
526
  "route-group:skip-ledger": {
@@ -528,7 +528,7 @@
528
528
  "type": "route-group",
529
529
  "domain": "scheduling",
530
530
  "sourcePath": "src/server/routes.ts",
531
- "contentHash": "8576d7a2b03dc1c83a9acad4415757299153c44f5bbe2a12f0313b6bc2df2b8e",
531
+ "contentHash": "e7ecb683c067a3e36768c52252eac303ea9178c3a060828f5673251e8b8908c1",
532
532
  "since": "2025-01-01"
533
533
  },
534
534
  "route-group:telegram": {
@@ -536,7 +536,7 @@
536
536
  "type": "route-group",
537
537
  "domain": "communication",
538
538
  "sourcePath": "src/server/routes.ts",
539
- "contentHash": "8576d7a2b03dc1c83a9acad4415757299153c44f5bbe2a12f0313b6bc2df2b8e",
539
+ "contentHash": "e7ecb683c067a3e36768c52252eac303ea9178c3a060828f5673251e8b8908c1",
540
540
  "since": "2025-01-01"
541
541
  },
542
542
  "route-group:attention": {
@@ -544,7 +544,7 @@
544
544
  "type": "route-group",
545
545
  "domain": "communication",
546
546
  "sourcePath": "src/server/routes.ts",
547
- "contentHash": "8576d7a2b03dc1c83a9acad4415757299153c44f5bbe2a12f0313b6bc2df2b8e",
547
+ "contentHash": "e7ecb683c067a3e36768c52252eac303ea9178c3a060828f5673251e8b8908c1",
548
548
  "since": "2025-01-01"
549
549
  },
550
550
  "route-group:relationships": {
@@ -552,7 +552,7 @@
552
552
  "type": "route-group",
553
553
  "domain": "relationships",
554
554
  "sourcePath": "src/server/routes.ts",
555
- "contentHash": "8576d7a2b03dc1c83a9acad4415757299153c44f5bbe2a12f0313b6bc2df2b8e",
555
+ "contentHash": "e7ecb683c067a3e36768c52252eac303ea9178c3a060828f5673251e8b8908c1",
556
556
  "since": "2025-01-01"
557
557
  },
558
558
  "route-group:feedback": {
@@ -560,7 +560,7 @@
560
560
  "type": "route-group",
561
561
  "domain": "feedback",
562
562
  "sourcePath": "src/server/routes.ts",
563
- "contentHash": "8576d7a2b03dc1c83a9acad4415757299153c44f5bbe2a12f0313b6bc2df2b8e",
563
+ "contentHash": "e7ecb683c067a3e36768c52252eac303ea9178c3a060828f5673251e8b8908c1",
564
564
  "since": "2025-01-01"
565
565
  },
566
566
  "route-group:updates": {
@@ -568,7 +568,7 @@
568
568
  "type": "route-group",
569
569
  "domain": "updates",
570
570
  "sourcePath": "src/server/routes.ts",
571
- "contentHash": "8576d7a2b03dc1c83a9acad4415757299153c44f5bbe2a12f0313b6bc2df2b8e",
571
+ "contentHash": "e7ecb683c067a3e36768c52252eac303ea9178c3a060828f5673251e8b8908c1",
572
572
  "since": "2025-01-01"
573
573
  },
574
574
  "route-group:dispatches": {
@@ -576,7 +576,7 @@
576
576
  "type": "route-group",
577
577
  "domain": "dispatches",
578
578
  "sourcePath": "src/server/routes.ts",
579
- "contentHash": "8576d7a2b03dc1c83a9acad4415757299153c44f5bbe2a12f0313b6bc2df2b8e",
579
+ "contentHash": "e7ecb683c067a3e36768c52252eac303ea9178c3a060828f5673251e8b8908c1",
580
580
  "since": "2025-01-01"
581
581
  },
582
582
  "route-group:quota": {
@@ -584,7 +584,7 @@
584
584
  "type": "route-group",
585
585
  "domain": "monitoring",
586
586
  "sourcePath": "src/server/routes.ts",
587
- "contentHash": "8576d7a2b03dc1c83a9acad4415757299153c44f5bbe2a12f0313b6bc2df2b8e",
587
+ "contentHash": "e7ecb683c067a3e36768c52252eac303ea9178c3a060828f5673251e8b8908c1",
588
588
  "since": "2025-01-01"
589
589
  },
590
590
  "route-group:publishing": {
@@ -592,7 +592,7 @@
592
592
  "type": "route-group",
593
593
  "domain": "publishing",
594
594
  "sourcePath": "src/server/routes.ts",
595
- "contentHash": "8576d7a2b03dc1c83a9acad4415757299153c44f5bbe2a12f0313b6bc2df2b8e",
595
+ "contentHash": "e7ecb683c067a3e36768c52252eac303ea9178c3a060828f5673251e8b8908c1",
596
596
  "since": "2025-01-01"
597
597
  },
598
598
  "route-group:private-views": {
@@ -600,7 +600,7 @@
600
600
  "type": "route-group",
601
601
  "domain": "publishing",
602
602
  "sourcePath": "src/server/routes.ts",
603
- "contentHash": "8576d7a2b03dc1c83a9acad4415757299153c44f5bbe2a12f0313b6bc2df2b8e",
603
+ "contentHash": "e7ecb683c067a3e36768c52252eac303ea9178c3a060828f5673251e8b8908c1",
604
604
  "since": "2025-01-01"
605
605
  },
606
606
  "route-group:tunnel": {
@@ -608,7 +608,7 @@
608
608
  "type": "route-group",
609
609
  "domain": "networking",
610
610
  "sourcePath": "src/server/routes.ts",
611
- "contentHash": "8576d7a2b03dc1c83a9acad4415757299153c44f5bbe2a12f0313b6bc2df2b8e",
611
+ "contentHash": "e7ecb683c067a3e36768c52252eac303ea9178c3a060828f5673251e8b8908c1",
612
612
  "since": "2025-01-01"
613
613
  },
614
614
  "route-group:events": {
@@ -616,7 +616,7 @@
616
616
  "type": "route-group",
617
617
  "domain": "networking",
618
618
  "sourcePath": "src/server/routes.ts",
619
- "contentHash": "8576d7a2b03dc1c83a9acad4415757299153c44f5bbe2a12f0313b6bc2df2b8e",
619
+ "contentHash": "e7ecb683c067a3e36768c52252eac303ea9178c3a060828f5673251e8b8908c1",
620
620
  "since": "2025-01-01"
621
621
  },
622
622
  "route-group:evolution": {
@@ -624,7 +624,7 @@
624
624
  "type": "route-group",
625
625
  "domain": "evolution",
626
626
  "sourcePath": "src/server/routes.ts",
627
- "contentHash": "8576d7a2b03dc1c83a9acad4415757299153c44f5bbe2a12f0313b6bc2df2b8e",
627
+ "contentHash": "e7ecb683c067a3e36768c52252eac303ea9178c3a060828f5673251e8b8908c1",
628
628
  "since": "2025-01-01"
629
629
  },
630
630
  "route-group:watchdog": {
@@ -632,7 +632,7 @@
632
632
  "type": "route-group",
633
633
  "domain": "monitoring",
634
634
  "sourcePath": "src/server/routes.ts",
635
- "contentHash": "8576d7a2b03dc1c83a9acad4415757299153c44f5bbe2a12f0313b6bc2df2b8e",
635
+ "contentHash": "e7ecb683c067a3e36768c52252eac303ea9178c3a060828f5673251e8b8908c1",
636
636
  "since": "2025-01-01"
637
637
  },
638
638
  "route-group:topic-memory": {
@@ -640,7 +640,7 @@
640
640
  "type": "route-group",
641
641
  "domain": "memory",
642
642
  "sourcePath": "src/server/routes.ts",
643
- "contentHash": "8576d7a2b03dc1c83a9acad4415757299153c44f5bbe2a12f0313b6bc2df2b8e",
643
+ "contentHash": "e7ecb683c067a3e36768c52252eac303ea9178c3a060828f5673251e8b8908c1",
644
644
  "since": "2025-01-01"
645
645
  },
646
646
  "route-group:state-sync": {
@@ -648,7 +648,7 @@
648
648
  "type": "route-group",
649
649
  "domain": "coordination",
650
650
  "sourcePath": "src/server/routes.ts",
651
- "contentHash": "8576d7a2b03dc1c83a9acad4415757299153c44f5bbe2a12f0313b6bc2df2b8e",
651
+ "contentHash": "e7ecb683c067a3e36768c52252eac303ea9178c3a060828f5673251e8b8908c1",
652
652
  "since": "2025-01-01"
653
653
  },
654
654
  "route-group:intent": {
@@ -656,7 +656,7 @@
656
656
  "type": "route-group",
657
657
  "domain": "intent",
658
658
  "sourcePath": "src/server/routes.ts",
659
- "contentHash": "8576d7a2b03dc1c83a9acad4415757299153c44f5bbe2a12f0313b6bc2df2b8e",
659
+ "contentHash": "e7ecb683c067a3e36768c52252eac303ea9178c3a060828f5673251e8b8908c1",
660
660
  "since": "2025-01-01"
661
661
  },
662
662
  "route-group:triage": {
@@ -664,7 +664,7 @@
664
664
  "type": "route-group",
665
665
  "domain": "safety",
666
666
  "sourcePath": "src/server/routes.ts",
667
- "contentHash": "8576d7a2b03dc1c83a9acad4415757299153c44f5bbe2a12f0313b6bc2df2b8e",
667
+ "contentHash": "e7ecb683c067a3e36768c52252eac303ea9178c3a060828f5673251e8b8908c1",
668
668
  "since": "2025-01-01"
669
669
  },
670
670
  "route-group:operations": {
@@ -672,7 +672,7 @@
672
672
  "type": "route-group",
673
673
  "domain": "safety",
674
674
  "sourcePath": "src/server/routes.ts",
675
- "contentHash": "8576d7a2b03dc1c83a9acad4415757299153c44f5bbe2a12f0313b6bc2df2b8e",
675
+ "contentHash": "e7ecb683c067a3e36768c52252eac303ea9178c3a060828f5673251e8b8908c1",
676
676
  "since": "2025-01-01"
677
677
  },
678
678
  "route-group:sentinel": {
@@ -680,7 +680,7 @@
680
680
  "type": "route-group",
681
681
  "domain": "safety",
682
682
  "sourcePath": "src/server/routes.ts",
683
- "contentHash": "8576d7a2b03dc1c83a9acad4415757299153c44f5bbe2a12f0313b6bc2df2b8e",
683
+ "contentHash": "e7ecb683c067a3e36768c52252eac303ea9178c3a060828f5673251e8b8908c1",
684
684
  "since": "2025-01-01"
685
685
  },
686
686
  "route-group:trust": {
@@ -688,7 +688,7 @@
688
688
  "type": "route-group",
689
689
  "domain": "safety",
690
690
  "sourcePath": "src/server/routes.ts",
691
- "contentHash": "8576d7a2b03dc1c83a9acad4415757299153c44f5bbe2a12f0313b6bc2df2b8e",
691
+ "contentHash": "e7ecb683c067a3e36768c52252eac303ea9178c3a060828f5673251e8b8908c1",
692
692
  "since": "2025-01-01"
693
693
  },
694
694
  "route-group:monitoring": {
@@ -696,7 +696,7 @@
696
696
  "type": "route-group",
697
697
  "domain": "monitoring",
698
698
  "sourcePath": "src/server/routes.ts",
699
- "contentHash": "8576d7a2b03dc1c83a9acad4415757299153c44f5bbe2a12f0313b6bc2df2b8e",
699
+ "contentHash": "e7ecb683c067a3e36768c52252eac303ea9178c3a060828f5673251e8b8908c1",
700
700
  "since": "2025-01-01"
701
701
  },
702
702
  "route-group:commitments": {
@@ -704,7 +704,7 @@
704
704
  "type": "route-group",
705
705
  "domain": "commitments",
706
706
  "sourcePath": "src/server/routes.ts",
707
- "contentHash": "8576d7a2b03dc1c83a9acad4415757299153c44f5bbe2a12f0313b6bc2df2b8e",
707
+ "contentHash": "e7ecb683c067a3e36768c52252eac303ea9178c3a060828f5673251e8b8908c1",
708
708
  "since": "2025-01-01"
709
709
  },
710
710
  "route-group:episodes": {
@@ -712,7 +712,7 @@
712
712
  "type": "route-group",
713
713
  "domain": "memory",
714
714
  "sourcePath": "src/server/routes.ts",
715
- "contentHash": "8576d7a2b03dc1c83a9acad4415757299153c44f5bbe2a12f0313b6bc2df2b8e",
715
+ "contentHash": "e7ecb683c067a3e36768c52252eac303ea9178c3a060828f5673251e8b8908c1",
716
716
  "since": "2025-01-01"
717
717
  },
718
718
  "route-group:messages": {
@@ -720,7 +720,7 @@
720
720
  "type": "route-group",
721
721
  "domain": "coordination",
722
722
  "sourcePath": "src/server/routes.ts",
723
- "contentHash": "8576d7a2b03dc1c83a9acad4415757299153c44f5bbe2a12f0313b6bc2df2b8e",
723
+ "contentHash": "e7ecb683c067a3e36768c52252eac303ea9178c3a060828f5673251e8b8908c1",
724
724
  "since": "2025-01-01"
725
725
  },
726
726
  "route-group:system-reviews": {
@@ -728,7 +728,7 @@
728
728
  "type": "route-group",
729
729
  "domain": "monitoring",
730
730
  "sourcePath": "src/server/routes.ts",
731
- "contentHash": "8576d7a2b03dc1c83a9acad4415757299153c44f5bbe2a12f0313b6bc2df2b8e",
731
+ "contentHash": "e7ecb683c067a3e36768c52252eac303ea9178c3a060828f5673251e8b8908c1",
732
732
  "since": "2025-01-01"
733
733
  },
734
734
  "route-group:machine-mesh": {
@@ -744,7 +744,7 @@
744
744
  "type": "route-group",
745
745
  "domain": "security",
746
746
  "sourcePath": "src/server/routes.ts",
747
- "contentHash": "8576d7a2b03dc1c83a9acad4415757299153c44f5bbe2a12f0313b6bc2df2b8e",
747
+ "contentHash": "e7ecb683c067a3e36768c52252eac303ea9178c3a060828f5673251e8b8908c1",
748
748
  "since": "2025-01-01"
749
749
  },
750
750
  "cli:init": {
@@ -1440,7 +1440,7 @@
1440
1440
  "type": "subsystem",
1441
1441
  "domain": "server",
1442
1442
  "sourcePath": "src/server/AgentServer.ts",
1443
- "contentHash": "823d36d25490f6afb6968e96d27a538ce031dae7d97a7f2c979ddab707d2918a",
1443
+ "contentHash": "8cd98b665356990ea26c422b9bab3f6aee15ce48798d5fe17fff3757fc617213",
1444
1444
  "since": "2025-01-01"
1445
1445
  },
1446
1446
  "subsystem:session-manager": {
@@ -1448,7 +1448,7 @@
1448
1448
  "type": "subsystem",
1449
1449
  "domain": "sessions",
1450
1450
  "sourcePath": "src/core/SessionManager.ts",
1451
- "contentHash": "b0de35800c7eacf06e520b7224d3169b81e8f0293ce65b69047fae3be1befad4",
1451
+ "contentHash": "a689041288c39070fd0d13362193bd4335367cb5a1db5458e3f73a6295b6e4c7",
1452
1452
  "since": "2025-01-01"
1453
1453
  },
1454
1454
  "subsystem:auto-updater": {
@@ -404,6 +404,12 @@ This routes feedback to the Instar maintainers automatically. Valid types: \`bug
404
404
  - List: \`curl -H "Authorization: Bearer $AUTH" http://localhost:${port}/sessions\`
405
405
  - Spawn: \`curl -X POST -H "Authorization: Bearer $AUTH" http://localhost:${port}/sessions/spawn -d '{"name":"task","prompt":"do something"}'\`
406
406
 
407
+ **SessionReaper** — Pressure-aware cleanup of idle-but-alive sessions (sessions parked at a ready prompt, doing nothing, holding memory). Distinct from the crash/zombie reapers: it only acts when the machine is under memory pressure, and it NEVER reaps a session that might be working — it requires positive proof a session is idle (turn complete + at a ready prompt + screen byte-static across several checks + no running process + no transcript growth), and KEEPs on any ambiguity. Ships OFF + dry-run by default (the only monitor that kills on a heuristic).
408
+ - Why it matters: idle sessions pile up across agents until the machine starves and new sessions get "spawn denied" — silently breaking cross-agent messaging. This sweeps them, but only under real pressure.
409
+ - See current state / why each session is kept or flagged: \`curl -H "Authorization: Bearer $AUTH" http://localhost:${port}/sessions/reaper\`
410
+ - Enable (after reviewing the dry-run log): in \`.instar/config.json\` set \`{"monitoring": {"sessionReaper": {"enabled": true, "dryRun": false}}}\`. Leave \`dryRun: true\` first to watch what it WOULD reap (logged to \`logs/sentinel-events.jsonl\`) without killing anything.
411
+ - Proactive: user asks "why are sessions piling up?" / "clean up idle sessions" / "are we low on memory?" → GET /sessions/reaper for the pressure tier + per-session verdict.
412
+
407
413
  **Multi-Session Autonomy** — I can run multiple autonomous jobs at once, one per topic (default cap 5, set \`autonomousSessions.maxConcurrent\` in config). Each topic's job is isolated, survives restarts, and is keyed on its topic.
408
414
  - What's running: \`curl -H "Authorization: Bearer $AUTH" http://localhost:${port}/autonomous/sessions\`
409
415
  - The cap + budget gate is checked automatically when a job starts (\`GET /autonomous/can-start\`); a start is refused when at the cap or under budget pressure.
@@ -0,0 +1,26 @@
1
+ # Upgrade Guide — NEXT
2
+
3
+ <!-- bump: minor -->
4
+ <!-- Valid values: patch, minor, major -->
5
+ <!-- patch = bug fixes, refactors, test additions, doc updates -->
6
+ <!-- minor = new features, new APIs, new capabilities (backwards-compatible) -->
7
+ <!-- major = breaking changes to existing APIs or behavior -->
8
+
9
+ ## What Changed
10
+
11
+ **SessionReaper — pressure-aware cleanup of idle-but-alive sessions.** A new monitor that reaps sessions sitting idle at a ready prompt (holding memory) — but ONLY when the machine is under memory pressure, and it NEVER reaps a session that might be working. It requires *positive* proof of idleness (turn complete + at a ready prompt + screen byte-static across several checks + no running process + no transcript growth) and KEEPs on any ambiguity. Ships **OFF + dry-run by default** — the only monitor that kills on a heuristic, so it stays dark until an operator validates the dry-run log and opts in. Closes the gap behind the 2026-05-25 fleet pileup (idle sessions accumulated until the machine starved and cross-agent messaging silently failed because agents could no longer spawn).
12
+
13
+ New read-only endpoint `GET /sessions/reaper` shows the live pressure tier and, per session, the verdict + the exact gate that kept it. `SessionManager` gains a single-writer `terminateSession()` so the existing idle-kill and the reaper can never double-kill. The zombie-kill recovery veto now also defers to the socket + silence sentinels.
14
+
15
+ ## What to Tell Your User
16
+
17
+ - **Idle sessions get cleaned up under memory pressure — safely.** When your machine fills up with idle agent sessions, this sweeps them so new sessions (and incoming cross-agent messages) don't get refused. It will never reap a session that's actually working. It's off by default; ask me to turn it on after we watch its dry-run log.
18
+ - **You won't notice anything unless you enable it.** No behavior change on update.
19
+
20
+ ## Summary of New Capabilities
21
+
22
+ | Capability | How to Use |
23
+ |-----------|-----------|
24
+ | SessionReaper (idle-session cleanup under pressure) | `monitoring.sessionReaper.enabled:true` (leave `dryRun:true` first). Off by default. |
25
+ | Reaper observability | `GET /sessions/reaper` — pressure tier + per-session verdict + keptBy |
26
+ | Single-writer session termination | `SessionManager.terminateSession()` — idle-kill + reaper share one CAS kill path |
@@ -0,0 +1,42 @@
1
+ # Side-Effects Review — SessionReaper
2
+
3
+ Spec: `docs/specs/SESSION-REAPER-SPEC.md` (v2 CONVERGED + ratified). Build branch `build/session-reaper`.
4
+
5
+ ## What changes for a deployed agent
6
+
7
+ - A new monitor (`SessionReaper`) is constructed and started at server boot. **Default OFF + dry-run** (`monitoring.sessionReaper.enabled:false, dryRun:true`), so deployed agents get **no behavior change** until an operator opts in. New config block arrives via the standard `ConfigDefaults`/`applyDefaults` migration; operator-set values are never overwritten.
8
+ - New read-only endpoint `GET /sessions/reaper` (503 when unwired, 200 snapshot otherwise).
9
+ - `SessionManager` gains `terminateSession()` (single-writer CAS), `isRelayLeaseActive()`, and `markReaping/clearReaping/isReaping`. The existing idle-kill now funnels through `terminateSession` and skips reaping-leased sessions; `killSession` shares the CAS guard and now sets `endedReason` (its event emissions are unchanged — still no `sessionComplete`).
10
+ - The zombie-kill recovery veto (`activeRecoveryChecker`) is recomposed to include the socket + silence sentinels (previously compaction + rate-limit only) — a strict superset; nothing is dropped.
11
+
12
+ ## Over/under-block analysis (the hard requirement)
13
+
14
+ The reaper must never reap a working session. Safety rests on positive evidence, not absence of activity:
15
+ - **Under-block (fails to reap a genuinely idle session):** acceptable — the existing 15m/4h idle-kill still runs; the reaper is additive pressure relief.
16
+ - **Over-block (reaps a working session):** the failure that matters. Mitigations: (1) requires a *positive* turn-complete idle-prompt signal; (2) render-stasis — pane byte-identical across all confirm ticks; (3) process + transcript must be quiet, and any *unresolvable* signal (no `claudeSessionId`, Codex/missing/rotated transcript, uninspectable process) forces KEEP, never "quiet"; (4) hysteresis; (5) two-phase reap with a final-grace re-check that aborts on any frame change; (6) Normal pressure tier reaps nothing; (7) bounded per-tick/per-hour budget; (8) auto-disable to dry-run on any ambiguous/failed reap; (9) ships OFF + dry-run.
17
+
18
+ ## Level-of-abstraction / signal-vs-authority
19
+
20
+ Signals carry confidence and only *recommend*; kill authority sits behind the budget + dry-run + single-writer `terminateSession` CAS + auto-disable. The reaper computes a verdict; it does not own an unbounded kill.
21
+
22
+ ## Interactions
23
+
24
+ - Composes with (does not fight) existing watchdogs: gate G defers to any recovery-in-flight (now incl. socket/silence); disjoint from OrphanProcessReaper (untracked procs) and SessionWatchdog (active-but-stuck); shares the single-writer kill path with the idle-kill so no double-kill / double-event.
25
+ - Pressure source is freemem-tiered for v1 (advisory; macOS under-reports). Crucially, an over-eager pressure tier can only reap a *genuinely-idle* session sooner — it cannot cause a working session to be reaped, because the classifier protects working sessions independent of tier.
26
+
27
+ ## Rollback
28
+
29
+ Set `monitoring.sessionReaper.enabled:false` (the default) — fully inert. No data migration; `endedReason` is additive/optional. Revert the branch to remove code; no persisted state needs cleanup beyond an optional `state/session-reaper.json` (absent unless restart-durability is later wired).
30
+
31
+ ## Tests
32
+
33
+ 3-tier: unit (transcript prober, terminateSession CAS, classifier incl. every false-reap vector, config/migration), integration (`/sessions/reaper` + dry-run), e2e (feature-alive + dangerous cases). Wiring-integrity guards the construct→start→pass chain. Live test-as-self on a real in-flight build + a real Codex session precedes merge.
34
+
35
+ ## Phase-3 review fixes (post multi-agent code review)
36
+
37
+ Independent review confirmed NO blocker to the hard requirement (cannot reap a working session) and surfaced safety-net hardening, all applied:
38
+ - **Reaping-lease leak:** when a matured reap is budget/tier-gated, the reaping lease is now released — previously it could permanently disable the fast idle-kill for that session.
39
+ - **Protected-list wiring:** gate A now reads `SessionManager.getProtectedSessions()` (the resolved list including the `<project>-server` default) rather than the raw config field, preventing spurious auto-disable when the server session goes idle.
40
+ - **Robustness:** `tick()` and `snapshot()` treat a throwing protect-signal as KEEP — never reap on a failed evaluation, and the `/sessions/reaper` route never 500s.
41
+ - **`killSession` contract preserved:** unconditional pane kill retained (only the in-flight guard added; no terminal-status early-return).
42
+ - **Known v1 gap (documented, not a false-reap vector):** the optional `mainProcessActive` CPU/IO-delta signal is not wired in v1; render-stasis is the real-time liveness channel that covers in-process work. Promoting `mainProcessActive` is a tracked enhancement, validated during the dry-run rollout.