instar 1.3.5 → 1.3.6
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.
- package/dist/monitoring/FrameworkIssueLedger.d.ts +46 -0
- package/dist/monitoring/FrameworkIssueLedger.d.ts.map +1 -1
- package/dist/monitoring/FrameworkIssueLedger.js +79 -0
- package/dist/monitoring/FrameworkIssueLedger.js.map +1 -1
- package/dist/server/CapabilityIndex.d.ts.map +1 -1
- package/dist/server/CapabilityIndex.js +1 -0
- package/dist/server/CapabilityIndex.js.map +1 -1
- package/dist/server/routes.d.ts.map +1 -1
- package/dist/server/routes.js +9 -0
- package/dist/server/routes.js.map +1 -1
- package/package.json +1 -1
- package/src/data/builtin-manifest.json +46 -46
- package/upgrades/1.3.6.md +43 -0
- package/upgrades/side-effects/framework-issue-capture.md +68 -0
package/package.json
CHANGED
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
{
|
|
2
2
|
"$schema": "./builtin-manifest.schema.json",
|
|
3
3
|
"schemaVersion": 1,
|
|
4
|
-
"generatedAt": "2026-05-27T03:
|
|
5
|
-
"instarVersion": "1.3.
|
|
4
|
+
"generatedAt": "2026-05-27T03:42:33.009Z",
|
|
5
|
+
"instarVersion": "1.3.6",
|
|
6
6
|
"entryCount": 192,
|
|
7
7
|
"entries": {
|
|
8
8
|
"hook:session-start": {
|
|
@@ -401,7 +401,7 @@
|
|
|
401
401
|
"type": "route-group",
|
|
402
402
|
"domain": "monitoring",
|
|
403
403
|
"sourcePath": "src/server/routes.ts",
|
|
404
|
-
"contentHash": "
|
|
404
|
+
"contentHash": "2347b1bdaa18ac50c52ac5acceb0438a813754db0f1fb486f91864930be9830a",
|
|
405
405
|
"since": "2025-01-01"
|
|
406
406
|
},
|
|
407
407
|
"route-group:agents": {
|
|
@@ -409,7 +409,7 @@
|
|
|
409
409
|
"type": "route-group",
|
|
410
410
|
"domain": "sessions",
|
|
411
411
|
"sourcePath": "src/server/routes.ts",
|
|
412
|
-
"contentHash": "
|
|
412
|
+
"contentHash": "2347b1bdaa18ac50c52ac5acceb0438a813754db0f1fb486f91864930be9830a",
|
|
413
413
|
"since": "2025-01-01"
|
|
414
414
|
},
|
|
415
415
|
"route-group:backups": {
|
|
@@ -417,7 +417,7 @@
|
|
|
417
417
|
"type": "route-group",
|
|
418
418
|
"domain": "operations",
|
|
419
419
|
"sourcePath": "src/server/routes.ts",
|
|
420
|
-
"contentHash": "
|
|
420
|
+
"contentHash": "2347b1bdaa18ac50c52ac5acceb0438a813754db0f1fb486f91864930be9830a",
|
|
421
421
|
"since": "2025-01-01"
|
|
422
422
|
},
|
|
423
423
|
"route-group:git": {
|
|
@@ -425,7 +425,7 @@
|
|
|
425
425
|
"type": "route-group",
|
|
426
426
|
"domain": "coordination",
|
|
427
427
|
"sourcePath": "src/server/routes.ts",
|
|
428
|
-
"contentHash": "
|
|
428
|
+
"contentHash": "2347b1bdaa18ac50c52ac5acceb0438a813754db0f1fb486f91864930be9830a",
|
|
429
429
|
"since": "2025-01-01"
|
|
430
430
|
},
|
|
431
431
|
"route-group:memory": {
|
|
@@ -433,7 +433,7 @@
|
|
|
433
433
|
"type": "route-group",
|
|
434
434
|
"domain": "memory",
|
|
435
435
|
"sourcePath": "src/server/routes.ts",
|
|
436
|
-
"contentHash": "
|
|
436
|
+
"contentHash": "2347b1bdaa18ac50c52ac5acceb0438a813754db0f1fb486f91864930be9830a",
|
|
437
437
|
"since": "2025-01-01"
|
|
438
438
|
},
|
|
439
439
|
"route-group:semantic": {
|
|
@@ -441,7 +441,7 @@
|
|
|
441
441
|
"type": "route-group",
|
|
442
442
|
"domain": "memory",
|
|
443
443
|
"sourcePath": "src/server/routes.ts",
|
|
444
|
-
"contentHash": "
|
|
444
|
+
"contentHash": "2347b1bdaa18ac50c52ac5acceb0438a813754db0f1fb486f91864930be9830a",
|
|
445
445
|
"since": "2025-01-01"
|
|
446
446
|
},
|
|
447
447
|
"route-group:status": {
|
|
@@ -449,7 +449,7 @@
|
|
|
449
449
|
"type": "route-group",
|
|
450
450
|
"domain": "monitoring",
|
|
451
451
|
"sourcePath": "src/server/routes.ts",
|
|
452
|
-
"contentHash": "
|
|
452
|
+
"contentHash": "2347b1bdaa18ac50c52ac5acceb0438a813754db0f1fb486f91864930be9830a",
|
|
453
453
|
"since": "2025-01-01"
|
|
454
454
|
},
|
|
455
455
|
"route-group:capabilities": {
|
|
@@ -457,7 +457,7 @@
|
|
|
457
457
|
"type": "route-group",
|
|
458
458
|
"domain": "mapping",
|
|
459
459
|
"sourcePath": "src/server/routes.ts",
|
|
460
|
-
"contentHash": "
|
|
460
|
+
"contentHash": "2347b1bdaa18ac50c52ac5acceb0438a813754db0f1fb486f91864930be9830a",
|
|
461
461
|
"since": "2025-01-01"
|
|
462
462
|
},
|
|
463
463
|
"route-group:project-map": {
|
|
@@ -465,7 +465,7 @@
|
|
|
465
465
|
"type": "route-group",
|
|
466
466
|
"domain": "mapping",
|
|
467
467
|
"sourcePath": "src/server/routes.ts",
|
|
468
|
-
"contentHash": "
|
|
468
|
+
"contentHash": "2347b1bdaa18ac50c52ac5acceb0438a813754db0f1fb486f91864930be9830a",
|
|
469
469
|
"since": "2025-01-01"
|
|
470
470
|
},
|
|
471
471
|
"route-group:coherence": {
|
|
@@ -473,7 +473,7 @@
|
|
|
473
473
|
"type": "route-group",
|
|
474
474
|
"domain": "coherence",
|
|
475
475
|
"sourcePath": "src/server/routes.ts",
|
|
476
|
-
"contentHash": "
|
|
476
|
+
"contentHash": "2347b1bdaa18ac50c52ac5acceb0438a813754db0f1fb486f91864930be9830a",
|
|
477
477
|
"since": "2025-01-01"
|
|
478
478
|
},
|
|
479
479
|
"route-group:topic-bindings": {
|
|
@@ -481,7 +481,7 @@
|
|
|
481
481
|
"type": "route-group",
|
|
482
482
|
"domain": "sessions",
|
|
483
483
|
"sourcePath": "src/server/routes.ts",
|
|
484
|
-
"contentHash": "
|
|
484
|
+
"contentHash": "2347b1bdaa18ac50c52ac5acceb0438a813754db0f1fb486f91864930be9830a",
|
|
485
485
|
"since": "2025-01-01"
|
|
486
486
|
},
|
|
487
487
|
"route-group:context": {
|
|
@@ -489,7 +489,7 @@
|
|
|
489
489
|
"type": "route-group",
|
|
490
490
|
"domain": "context",
|
|
491
491
|
"sourcePath": "src/server/routes.ts",
|
|
492
|
-
"contentHash": "
|
|
492
|
+
"contentHash": "2347b1bdaa18ac50c52ac5acceb0438a813754db0f1fb486f91864930be9830a",
|
|
493
493
|
"since": "2025-01-01"
|
|
494
494
|
},
|
|
495
495
|
"route-group:scope-coherence": {
|
|
@@ -497,7 +497,7 @@
|
|
|
497
497
|
"type": "route-group",
|
|
498
498
|
"domain": "coherence",
|
|
499
499
|
"sourcePath": "src/server/routes.ts",
|
|
500
|
-
"contentHash": "
|
|
500
|
+
"contentHash": "2347b1bdaa18ac50c52ac5acceb0438a813754db0f1fb486f91864930be9830a",
|
|
501
501
|
"since": "2025-01-01"
|
|
502
502
|
},
|
|
503
503
|
"route-group:canonical-state": {
|
|
@@ -505,7 +505,7 @@
|
|
|
505
505
|
"type": "route-group",
|
|
506
506
|
"domain": "state",
|
|
507
507
|
"sourcePath": "src/server/routes.ts",
|
|
508
|
-
"contentHash": "
|
|
508
|
+
"contentHash": "2347b1bdaa18ac50c52ac5acceb0438a813754db0f1fb486f91864930be9830a",
|
|
509
509
|
"since": "2025-01-01"
|
|
510
510
|
},
|
|
511
511
|
"route-group:ci": {
|
|
@@ -513,7 +513,7 @@
|
|
|
513
513
|
"type": "route-group",
|
|
514
514
|
"domain": "monitoring",
|
|
515
515
|
"sourcePath": "src/server/routes.ts",
|
|
516
|
-
"contentHash": "
|
|
516
|
+
"contentHash": "2347b1bdaa18ac50c52ac5acceb0438a813754db0f1fb486f91864930be9830a",
|
|
517
517
|
"since": "2025-01-01"
|
|
518
518
|
},
|
|
519
519
|
"route-group:sessions": {
|
|
@@ -521,7 +521,7 @@
|
|
|
521
521
|
"type": "route-group",
|
|
522
522
|
"domain": "sessions",
|
|
523
523
|
"sourcePath": "src/server/routes.ts",
|
|
524
|
-
"contentHash": "
|
|
524
|
+
"contentHash": "2347b1bdaa18ac50c52ac5acceb0438a813754db0f1fb486f91864930be9830a",
|
|
525
525
|
"since": "2025-01-01"
|
|
526
526
|
},
|
|
527
527
|
"route-group:jobs": {
|
|
@@ -529,7 +529,7 @@
|
|
|
529
529
|
"type": "route-group",
|
|
530
530
|
"domain": "scheduling",
|
|
531
531
|
"sourcePath": "src/server/routes.ts",
|
|
532
|
-
"contentHash": "
|
|
532
|
+
"contentHash": "2347b1bdaa18ac50c52ac5acceb0438a813754db0f1fb486f91864930be9830a",
|
|
533
533
|
"since": "2025-01-01"
|
|
534
534
|
},
|
|
535
535
|
"route-group:skip-ledger": {
|
|
@@ -537,7 +537,7 @@
|
|
|
537
537
|
"type": "route-group",
|
|
538
538
|
"domain": "scheduling",
|
|
539
539
|
"sourcePath": "src/server/routes.ts",
|
|
540
|
-
"contentHash": "
|
|
540
|
+
"contentHash": "2347b1bdaa18ac50c52ac5acceb0438a813754db0f1fb486f91864930be9830a",
|
|
541
541
|
"since": "2025-01-01"
|
|
542
542
|
},
|
|
543
543
|
"route-group:telegram": {
|
|
@@ -545,7 +545,7 @@
|
|
|
545
545
|
"type": "route-group",
|
|
546
546
|
"domain": "communication",
|
|
547
547
|
"sourcePath": "src/server/routes.ts",
|
|
548
|
-
"contentHash": "
|
|
548
|
+
"contentHash": "2347b1bdaa18ac50c52ac5acceb0438a813754db0f1fb486f91864930be9830a",
|
|
549
549
|
"since": "2025-01-01"
|
|
550
550
|
},
|
|
551
551
|
"route-group:attention": {
|
|
@@ -553,7 +553,7 @@
|
|
|
553
553
|
"type": "route-group",
|
|
554
554
|
"domain": "communication",
|
|
555
555
|
"sourcePath": "src/server/routes.ts",
|
|
556
|
-
"contentHash": "
|
|
556
|
+
"contentHash": "2347b1bdaa18ac50c52ac5acceb0438a813754db0f1fb486f91864930be9830a",
|
|
557
557
|
"since": "2025-01-01"
|
|
558
558
|
},
|
|
559
559
|
"route-group:relationships": {
|
|
@@ -561,7 +561,7 @@
|
|
|
561
561
|
"type": "route-group",
|
|
562
562
|
"domain": "relationships",
|
|
563
563
|
"sourcePath": "src/server/routes.ts",
|
|
564
|
-
"contentHash": "
|
|
564
|
+
"contentHash": "2347b1bdaa18ac50c52ac5acceb0438a813754db0f1fb486f91864930be9830a",
|
|
565
565
|
"since": "2025-01-01"
|
|
566
566
|
},
|
|
567
567
|
"route-group:feedback": {
|
|
@@ -569,7 +569,7 @@
|
|
|
569
569
|
"type": "route-group",
|
|
570
570
|
"domain": "feedback",
|
|
571
571
|
"sourcePath": "src/server/routes.ts",
|
|
572
|
-
"contentHash": "
|
|
572
|
+
"contentHash": "2347b1bdaa18ac50c52ac5acceb0438a813754db0f1fb486f91864930be9830a",
|
|
573
573
|
"since": "2025-01-01"
|
|
574
574
|
},
|
|
575
575
|
"route-group:updates": {
|
|
@@ -577,7 +577,7 @@
|
|
|
577
577
|
"type": "route-group",
|
|
578
578
|
"domain": "updates",
|
|
579
579
|
"sourcePath": "src/server/routes.ts",
|
|
580
|
-
"contentHash": "
|
|
580
|
+
"contentHash": "2347b1bdaa18ac50c52ac5acceb0438a813754db0f1fb486f91864930be9830a",
|
|
581
581
|
"since": "2025-01-01"
|
|
582
582
|
},
|
|
583
583
|
"route-group:dispatches": {
|
|
@@ -585,7 +585,7 @@
|
|
|
585
585
|
"type": "route-group",
|
|
586
586
|
"domain": "dispatches",
|
|
587
587
|
"sourcePath": "src/server/routes.ts",
|
|
588
|
-
"contentHash": "
|
|
588
|
+
"contentHash": "2347b1bdaa18ac50c52ac5acceb0438a813754db0f1fb486f91864930be9830a",
|
|
589
589
|
"since": "2025-01-01"
|
|
590
590
|
},
|
|
591
591
|
"route-group:quota": {
|
|
@@ -593,7 +593,7 @@
|
|
|
593
593
|
"type": "route-group",
|
|
594
594
|
"domain": "monitoring",
|
|
595
595
|
"sourcePath": "src/server/routes.ts",
|
|
596
|
-
"contentHash": "
|
|
596
|
+
"contentHash": "2347b1bdaa18ac50c52ac5acceb0438a813754db0f1fb486f91864930be9830a",
|
|
597
597
|
"since": "2025-01-01"
|
|
598
598
|
},
|
|
599
599
|
"route-group:publishing": {
|
|
@@ -601,7 +601,7 @@
|
|
|
601
601
|
"type": "route-group",
|
|
602
602
|
"domain": "publishing",
|
|
603
603
|
"sourcePath": "src/server/routes.ts",
|
|
604
|
-
"contentHash": "
|
|
604
|
+
"contentHash": "2347b1bdaa18ac50c52ac5acceb0438a813754db0f1fb486f91864930be9830a",
|
|
605
605
|
"since": "2025-01-01"
|
|
606
606
|
},
|
|
607
607
|
"route-group:private-views": {
|
|
@@ -609,7 +609,7 @@
|
|
|
609
609
|
"type": "route-group",
|
|
610
610
|
"domain": "publishing",
|
|
611
611
|
"sourcePath": "src/server/routes.ts",
|
|
612
|
-
"contentHash": "
|
|
612
|
+
"contentHash": "2347b1bdaa18ac50c52ac5acceb0438a813754db0f1fb486f91864930be9830a",
|
|
613
613
|
"since": "2025-01-01"
|
|
614
614
|
},
|
|
615
615
|
"route-group:tunnel": {
|
|
@@ -617,7 +617,7 @@
|
|
|
617
617
|
"type": "route-group",
|
|
618
618
|
"domain": "networking",
|
|
619
619
|
"sourcePath": "src/server/routes.ts",
|
|
620
|
-
"contentHash": "
|
|
620
|
+
"contentHash": "2347b1bdaa18ac50c52ac5acceb0438a813754db0f1fb486f91864930be9830a",
|
|
621
621
|
"since": "2025-01-01"
|
|
622
622
|
},
|
|
623
623
|
"route-group:events": {
|
|
@@ -625,7 +625,7 @@
|
|
|
625
625
|
"type": "route-group",
|
|
626
626
|
"domain": "networking",
|
|
627
627
|
"sourcePath": "src/server/routes.ts",
|
|
628
|
-
"contentHash": "
|
|
628
|
+
"contentHash": "2347b1bdaa18ac50c52ac5acceb0438a813754db0f1fb486f91864930be9830a",
|
|
629
629
|
"since": "2025-01-01"
|
|
630
630
|
},
|
|
631
631
|
"route-group:evolution": {
|
|
@@ -633,7 +633,7 @@
|
|
|
633
633
|
"type": "route-group",
|
|
634
634
|
"domain": "evolution",
|
|
635
635
|
"sourcePath": "src/server/routes.ts",
|
|
636
|
-
"contentHash": "
|
|
636
|
+
"contentHash": "2347b1bdaa18ac50c52ac5acceb0438a813754db0f1fb486f91864930be9830a",
|
|
637
637
|
"since": "2025-01-01"
|
|
638
638
|
},
|
|
639
639
|
"route-group:watchdog": {
|
|
@@ -641,7 +641,7 @@
|
|
|
641
641
|
"type": "route-group",
|
|
642
642
|
"domain": "monitoring",
|
|
643
643
|
"sourcePath": "src/server/routes.ts",
|
|
644
|
-
"contentHash": "
|
|
644
|
+
"contentHash": "2347b1bdaa18ac50c52ac5acceb0438a813754db0f1fb486f91864930be9830a",
|
|
645
645
|
"since": "2025-01-01"
|
|
646
646
|
},
|
|
647
647
|
"route-group:topic-memory": {
|
|
@@ -649,7 +649,7 @@
|
|
|
649
649
|
"type": "route-group",
|
|
650
650
|
"domain": "memory",
|
|
651
651
|
"sourcePath": "src/server/routes.ts",
|
|
652
|
-
"contentHash": "
|
|
652
|
+
"contentHash": "2347b1bdaa18ac50c52ac5acceb0438a813754db0f1fb486f91864930be9830a",
|
|
653
653
|
"since": "2025-01-01"
|
|
654
654
|
},
|
|
655
655
|
"route-group:state-sync": {
|
|
@@ -657,7 +657,7 @@
|
|
|
657
657
|
"type": "route-group",
|
|
658
658
|
"domain": "coordination",
|
|
659
659
|
"sourcePath": "src/server/routes.ts",
|
|
660
|
-
"contentHash": "
|
|
660
|
+
"contentHash": "2347b1bdaa18ac50c52ac5acceb0438a813754db0f1fb486f91864930be9830a",
|
|
661
661
|
"since": "2025-01-01"
|
|
662
662
|
},
|
|
663
663
|
"route-group:intent": {
|
|
@@ -665,7 +665,7 @@
|
|
|
665
665
|
"type": "route-group",
|
|
666
666
|
"domain": "intent",
|
|
667
667
|
"sourcePath": "src/server/routes.ts",
|
|
668
|
-
"contentHash": "
|
|
668
|
+
"contentHash": "2347b1bdaa18ac50c52ac5acceb0438a813754db0f1fb486f91864930be9830a",
|
|
669
669
|
"since": "2025-01-01"
|
|
670
670
|
},
|
|
671
671
|
"route-group:triage": {
|
|
@@ -673,7 +673,7 @@
|
|
|
673
673
|
"type": "route-group",
|
|
674
674
|
"domain": "safety",
|
|
675
675
|
"sourcePath": "src/server/routes.ts",
|
|
676
|
-
"contentHash": "
|
|
676
|
+
"contentHash": "2347b1bdaa18ac50c52ac5acceb0438a813754db0f1fb486f91864930be9830a",
|
|
677
677
|
"since": "2025-01-01"
|
|
678
678
|
},
|
|
679
679
|
"route-group:operations": {
|
|
@@ -681,7 +681,7 @@
|
|
|
681
681
|
"type": "route-group",
|
|
682
682
|
"domain": "safety",
|
|
683
683
|
"sourcePath": "src/server/routes.ts",
|
|
684
|
-
"contentHash": "
|
|
684
|
+
"contentHash": "2347b1bdaa18ac50c52ac5acceb0438a813754db0f1fb486f91864930be9830a",
|
|
685
685
|
"since": "2025-01-01"
|
|
686
686
|
},
|
|
687
687
|
"route-group:sentinel": {
|
|
@@ -689,7 +689,7 @@
|
|
|
689
689
|
"type": "route-group",
|
|
690
690
|
"domain": "safety",
|
|
691
691
|
"sourcePath": "src/server/routes.ts",
|
|
692
|
-
"contentHash": "
|
|
692
|
+
"contentHash": "2347b1bdaa18ac50c52ac5acceb0438a813754db0f1fb486f91864930be9830a",
|
|
693
693
|
"since": "2025-01-01"
|
|
694
694
|
},
|
|
695
695
|
"route-group:trust": {
|
|
@@ -697,7 +697,7 @@
|
|
|
697
697
|
"type": "route-group",
|
|
698
698
|
"domain": "safety",
|
|
699
699
|
"sourcePath": "src/server/routes.ts",
|
|
700
|
-
"contentHash": "
|
|
700
|
+
"contentHash": "2347b1bdaa18ac50c52ac5acceb0438a813754db0f1fb486f91864930be9830a",
|
|
701
701
|
"since": "2025-01-01"
|
|
702
702
|
},
|
|
703
703
|
"route-group:monitoring": {
|
|
@@ -705,7 +705,7 @@
|
|
|
705
705
|
"type": "route-group",
|
|
706
706
|
"domain": "monitoring",
|
|
707
707
|
"sourcePath": "src/server/routes.ts",
|
|
708
|
-
"contentHash": "
|
|
708
|
+
"contentHash": "2347b1bdaa18ac50c52ac5acceb0438a813754db0f1fb486f91864930be9830a",
|
|
709
709
|
"since": "2025-01-01"
|
|
710
710
|
},
|
|
711
711
|
"route-group:commitments": {
|
|
@@ -713,7 +713,7 @@
|
|
|
713
713
|
"type": "route-group",
|
|
714
714
|
"domain": "commitments",
|
|
715
715
|
"sourcePath": "src/server/routes.ts",
|
|
716
|
-
"contentHash": "
|
|
716
|
+
"contentHash": "2347b1bdaa18ac50c52ac5acceb0438a813754db0f1fb486f91864930be9830a",
|
|
717
717
|
"since": "2025-01-01"
|
|
718
718
|
},
|
|
719
719
|
"route-group:episodes": {
|
|
@@ -721,7 +721,7 @@
|
|
|
721
721
|
"type": "route-group",
|
|
722
722
|
"domain": "memory",
|
|
723
723
|
"sourcePath": "src/server/routes.ts",
|
|
724
|
-
"contentHash": "
|
|
724
|
+
"contentHash": "2347b1bdaa18ac50c52ac5acceb0438a813754db0f1fb486f91864930be9830a",
|
|
725
725
|
"since": "2025-01-01"
|
|
726
726
|
},
|
|
727
727
|
"route-group:messages": {
|
|
@@ -729,7 +729,7 @@
|
|
|
729
729
|
"type": "route-group",
|
|
730
730
|
"domain": "coordination",
|
|
731
731
|
"sourcePath": "src/server/routes.ts",
|
|
732
|
-
"contentHash": "
|
|
732
|
+
"contentHash": "2347b1bdaa18ac50c52ac5acceb0438a813754db0f1fb486f91864930be9830a",
|
|
733
733
|
"since": "2025-01-01"
|
|
734
734
|
},
|
|
735
735
|
"route-group:system-reviews": {
|
|
@@ -737,7 +737,7 @@
|
|
|
737
737
|
"type": "route-group",
|
|
738
738
|
"domain": "monitoring",
|
|
739
739
|
"sourcePath": "src/server/routes.ts",
|
|
740
|
-
"contentHash": "
|
|
740
|
+
"contentHash": "2347b1bdaa18ac50c52ac5acceb0438a813754db0f1fb486f91864930be9830a",
|
|
741
741
|
"since": "2025-01-01"
|
|
742
742
|
},
|
|
743
743
|
"route-group:machine-mesh": {
|
|
@@ -753,7 +753,7 @@
|
|
|
753
753
|
"type": "route-group",
|
|
754
754
|
"domain": "security",
|
|
755
755
|
"sourcePath": "src/server/routes.ts",
|
|
756
|
-
"contentHash": "
|
|
756
|
+
"contentHash": "2347b1bdaa18ac50c52ac5acceb0438a813754db0f1fb486f91864930be9830a",
|
|
757
757
|
"since": "2025-01-01"
|
|
758
758
|
},
|
|
759
759
|
"cli:init": {
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
# Instar Upgrade Guide — NEXT
|
|
2
|
+
|
|
3
|
+
<!-- bump: patch -->
|
|
4
|
+
|
|
5
|
+
## What Changed
|
|
6
|
+
|
|
7
|
+
**Framework-Onboarding Mentor System — Stage-B auto-capture (§19.2).** Building on the issue
|
|
8
|
+
ledger shipped last release, this adds the *write path*: a single atomic `captureRun()` entry
|
|
9
|
+
point that the mentor tick will call after observing a framework, plus a **capture funnel** that
|
|
10
|
+
logs **every** run — including runs that found nothing. That funnel is the structural guard
|
|
11
|
+
against a silent, broken writer: because a zero-finding run is still recorded as a run, "ran and
|
|
12
|
+
found nothing" is always distinguishable from "never ran / writer is dead." Regression candidates
|
|
13
|
+
(a new issue matching a previously-fixed one) are *surfaced for review, never auto-linked* — the
|
|
14
|
+
writer doesn't get to decide a regression.
|
|
15
|
+
|
|
16
|
+
A new read-only route `GET /framework-issues/capture-stats` exposes the funnel (runs vs
|
|
17
|
+
observations written, broken down per framework). Still observability-only — nothing gates, and
|
|
18
|
+
there is no production caller yet (the mentor job that calls `captureRun` ships in a later staged
|
|
19
|
+
PR), so this is dormant infrastructure with full test coverage.
|
|
20
|
+
|
|
21
|
+
## What to Tell Your User
|
|
22
|
+
|
|
23
|
+
- The "notebook" now has a guaranteed *hand that writes* — whatever I notice while inspecting a
|
|
24
|
+
framework gets recorded automatically, and there's a visible counter so a broken writer can't
|
|
25
|
+
hide by looking quiet.
|
|
26
|
+
- Nothing changes in your day-to-day yet; it's the next layer of a system that's still rolling
|
|
27
|
+
out gradually and stays off by default.
|
|
28
|
+
|
|
29
|
+
## Summary of New Capabilities
|
|
30
|
+
|
|
31
|
+
| Capability | How to Use |
|
|
32
|
+
|-----------|-----------|
|
|
33
|
+
| Stage-B auto-capture | `FrameworkIssueLedger.captureRun({ framework, tickId, findings })` — one atomic call the mentor tick makes; writes findings + logs the run |
|
|
34
|
+
| Capture funnel | `curl -H "Authorization: Bearer $AUTH" http://localhost:<port>/framework-issues/capture-stats` — runs vs observations written, per framework (inert-writer guard) |
|
|
35
|
+
|
|
36
|
+
## Evidence
|
|
37
|
+
|
|
38
|
+
Net-new feature, not a bug fix — no prior failure to reproduce. Behavior is verified by tests:
|
|
39
|
+
the inert-writer guard is proven by a unit test asserting a **zero-finding `captureRun` still
|
|
40
|
+
increments the funnel's run count while observations stay at 0** (so "ran, found nothing" ≠ "never
|
|
41
|
+
ran"), and a Tier-3 e2e boots the real server, runs a capture against the live ledger, and confirms
|
|
42
|
+
`GET /framework-issues/capture-stats` reflects both the run and the written observation. 46 feature
|
|
43
|
+
tests + 299 capability tests green; affected push-config suite (842) green vs canonical main.
|
|
@@ -0,0 +1,68 @@
|
|
|
1
|
+
# Side-Effects Review — Stage-B auto-capture + funnel (Mentor System §19.2)
|
|
2
|
+
|
|
3
|
+
**Spec:** `docs/specs/FRAMEWORK-ONBOARDING-MENTOR-SPEC.md` (converged 5 iters, approved by Justin)
|
|
4
|
+
**Change:** Adds the Stage-B auto-capture entry point `FrameworkIssueLedger.captureRun()` + a
|
|
5
|
+
`framework_capture_runs` funnel table + `captureStats()` + a read-only route
|
|
6
|
+
`GET /framework-issues/capture-stats`. Builds on §19.1 (the ledger foundation, PR #405).
|
|
7
|
+
**Files:** `src/monitoring/FrameworkIssueLedger.ts`, `src/server/routes.ts`,
|
|
8
|
+
`src/server/CapabilityIndex.ts`, `tests/unit/FrameworkIssueLedger.test.ts`,
|
|
9
|
+
`tests/integration/framework-issues-routes.test.ts`,
|
|
10
|
+
`tests/e2e/framework-issue-ledger-lifecycle.test.ts`, `upgrades/NEXT.md`.
|
|
11
|
+
|
|
12
|
+
## Principle check (Phase 1)
|
|
13
|
+
|
|
14
|
+
Does this involve a decision point that gates info flow / blocks actions / constrains behavior?
|
|
15
|
+
**No.** `captureRun()` is the write-path the mentor tick will call after forensics — it records
|
|
16
|
+
findings and logs the run. It holds no blocking authority. The capture-stats route is read-only
|
|
17
|
+
observability. Signal-only. The decision-bearing components (Stage A, the job, graduation) are
|
|
18
|
+
§19.3–5.
|
|
19
|
+
|
|
20
|
+
## The seven questions
|
|
21
|
+
|
|
22
|
+
1. **Over-block.** None. `captureRun` writes whatever findings it's given (validated against the
|
|
23
|
+
same enum allowlists as `recordObservation`); it rejects only structurally-invalid findings
|
|
24
|
+
(bad bucket/severity), which is correct.
|
|
25
|
+
|
|
26
|
+
2. **Under-block.** The funnel is the explicit guard against the under-detection failure mode it
|
|
27
|
+
exists for: a run that writes nothing is still logged, so an inert/broken writer (runs climbing,
|
|
28
|
+
observations flat) is visible. It does not *interpret* that signal (no alerting yet) — surfacing
|
|
29
|
+
is via the read-only route; an alert/threshold is a later concern (§19.5 observability surface),
|
|
30
|
+
not under-blocking here. There is still no public write route, so no untrusted-write surface.
|
|
31
|
+
|
|
32
|
+
3. **Level-of-abstraction fit.** `captureRun` lives ON the ledger (not a separate DI component)
|
|
33
|
+
because better-sqlite3 has no nested transactions and the capture is a thin orchestration over
|
|
34
|
+
`recordObservation` + `suggestRegressions` + a run-log insert. One atomic entry point for the
|
|
35
|
+
tick to call is the right seam; a separate service would add wiring with no benefit.
|
|
36
|
+
|
|
37
|
+
4. **Signal vs authority.** Compliant. `captureRun` writes signal; regression candidates are
|
|
38
|
+
*surfaced, never auto-linked* (the writer doesn't get to decide a regression — §13.5). Promotion
|
|
39
|
+
and graduation authority stay with the human (§6/§8).
|
|
40
|
+
|
|
41
|
+
5. **Interactions.** `captureRun` calls `recordObservation` per finding (each its own txn — no
|
|
42
|
+
nested-transaction violation), then writes one `framework_capture_runs` row. Episode-collapsing
|
|
43
|
+
in `recordObservation` already prevents double-counting across runs, so re-observing the same
|
|
44
|
+
open issue next tick does not inflate `observationsWritten`. The funnel table is independent of
|
|
45
|
+
the issues/observations tables — no shadowing.
|
|
46
|
+
|
|
47
|
+
6. **External surfaces.** One new read-only route (`/framework-issues/capture-stats`) behind the
|
|
48
|
+
standard Bearer middleware, added to the existing `frameworkIssues` CapabilityIndex entry (no
|
|
49
|
+
new prefix → no discoverability-classification gap). No agent-facing template change needed
|
|
50
|
+
beyond §19.1's. No timing/conversation-state dependence.
|
|
51
|
+
|
|
52
|
+
7. **Rollback cost.** Low. Still dormant — no production caller until the mentor job (§19.4). The
|
|
53
|
+
`framework_capture_runs` table auto-creates at startup (idempotent `CREATE TABLE IF NOT EXISTS`)
|
|
54
|
+
and is harmless read-only data. Back-out = revert; the table can stay or be dropped.
|
|
55
|
+
|
|
56
|
+
## Phase 5 — second-pass
|
|
57
|
+
|
|
58
|
+
**Not required.** Read-only observability + a signal-only write-path; no block/allow, no
|
|
59
|
+
session-lifecycle, nothing named sentinel/guard/gate/watchdog. The spec passed full convergence.
|
|
60
|
+
|
|
61
|
+
## Testing
|
|
62
|
+
|
|
63
|
+
- Tier 1 (unit, +6 = 28 total): captureRun writes findings + reports summary; **every run logged
|
|
64
|
+
to the funnel including a zero-finding run** (inert-writer guard); no double-count across runs;
|
|
65
|
+
regression candidates surfaced not auto-linked; per-framework funnel breakdown; enum guard.
|
|
66
|
+
- Tier 2 (integration, +2 = 11 total): `/framework-issues/capture-stats` 503 + 200-with-funnel.
|
|
67
|
+
- Tier 3 (e2e, +1 = 7 total): a real capture run surfaces in the funnel route on the live server.
|
|
68
|
+
- Affected push-config suite (vs JKHeadley/main): 842 + 299 capability tests green, no regressions.
|