principles-disciple 1.8.1 → 1.8.3

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 (508) hide show
  1. package/ADVANCED_CONFIG_ZH.md +97 -0
  2. package/AGENT_INSTALL.md +173 -0
  3. package/AGENT_INSTALL_EN.md +173 -0
  4. package/INSTALL.md +256 -0
  5. package/SKILL.md +63 -0
  6. package/docs/COMMAND_REFERENCE.md +76 -0
  7. package/docs/COMMAND_REFERENCE_EN.md +79 -0
  8. package/esbuild.config.js +75 -0
  9. package/openclaw.plugin.json +4 -4
  10. package/package.json +11 -13
  11. package/scripts/build-web.mjs +46 -0
  12. package/scripts/install-dependencies.cjs +47 -0
  13. package/scripts/sync-plugin.mjs +802 -0
  14. package/scripts/verify-build.mjs +109 -0
  15. package/src/agents/nocturnal-dreamer.md +152 -0
  16. package/src/agents/nocturnal-philosopher.md +138 -0
  17. package/src/agents/nocturnal-reflector.md +126 -0
  18. package/src/agents/nocturnal-scribe.md +164 -0
  19. package/src/commands/capabilities.ts +85 -0
  20. package/{dist/commands/context.js → src/commands/context.ts} +78 -38
  21. package/src/commands/evolution-status.ts +146 -0
  22. package/src/commands/export.ts +111 -0
  23. package/src/commands/focus.ts +533 -0
  24. package/src/commands/nocturnal-review.ts +311 -0
  25. package/src/commands/nocturnal-rollout.ts +763 -0
  26. package/src/commands/nocturnal-train.ts +1002 -0
  27. package/{dist/commands/pain.js → src/commands/pain.ts} +68 -49
  28. package/src/commands/principle-rollback.ts +27 -0
  29. package/{dist/commands/rollback.js → src/commands/rollback.ts} +44 -12
  30. package/src/commands/samples.ts +60 -0
  31. package/src/commands/strategy.ts +38 -0
  32. package/{dist/commands/thinking-os.js → src/commands/thinking-os.ts} +59 -36
  33. package/src/commands/workflow-debug.ts +128 -0
  34. package/{dist/config/defaults/runtime.js → src/config/defaults/runtime.ts} +12 -5
  35. package/src/config/errors.ts +163 -0
  36. package/{dist/config/index.d.ts → src/config/index.ts} +2 -1
  37. package/src/constants/diagnostician.ts +66 -0
  38. package/src/constants/tools.ts +62 -0
  39. package/src/core/adaptive-thresholds.ts +476 -0
  40. package/{dist/core/config-service.js → src/core/config-service.ts} +7 -4
  41. package/{dist/core/config.js → src/core/config.ts} +158 -46
  42. package/src/core/control-ui-db.ts +435 -0
  43. package/{dist/core/detection-funnel.js → src/core/detection-funnel.ts} +36 -21
  44. package/{dist/core/detection-service.js → src/core/detection-service.ts} +7 -4
  45. package/{dist/core/dictionary-service.js → src/core/dictionary-service.ts} +7 -4
  46. package/{dist/core/dictionary.js → src/core/dictionary.ts} +57 -34
  47. package/src/core/empathy-keyword-matcher.ts +327 -0
  48. package/src/core/empathy-types.ts +218 -0
  49. package/src/core/event-log.ts +544 -0
  50. package/src/core/evolution-engine.ts +612 -0
  51. package/src/core/evolution-logger.ts +353 -0
  52. package/src/core/evolution-migration.ts +77 -0
  53. package/src/core/evolution-reducer.ts +731 -0
  54. package/src/core/evolution-types.ts +456 -0
  55. package/src/core/external-training-contract.ts +527 -0
  56. package/src/core/focus-history.ts +1458 -0
  57. package/src/core/hygiene/tracker.ts +117 -0
  58. package/{dist/core/init.js → src/core/init.ts} +39 -26
  59. package/src/core/local-worker-routing.ts +617 -0
  60. package/{dist/core/migration.js → src/core/migration.ts} +18 -11
  61. package/src/core/model-deployment-registry.ts +722 -0
  62. package/src/core/model-training-registry.ts +813 -0
  63. package/src/core/nocturnal-arbiter.ts +706 -0
  64. package/src/core/nocturnal-candidate-scoring.ts +392 -0
  65. package/src/core/nocturnal-compliance.ts +1075 -0
  66. package/src/core/nocturnal-dataset.ts +668 -0
  67. package/src/core/nocturnal-executability.ts +428 -0
  68. package/src/core/nocturnal-export.ts +390 -0
  69. package/{dist/core/nocturnal-paths.js → src/core/nocturnal-paths.ts} +49 -23
  70. package/src/core/nocturnal-trajectory-extractor.ts +484 -0
  71. package/src/core/nocturnal-trinity.ts +1384 -0
  72. package/src/core/pain.ts +122 -0
  73. package/{dist/core/path-resolver.js → src/core/path-resolver.ts} +157 -36
  74. package/{dist/core/paths.js → src/core/paths.ts} +13 -4
  75. package/src/core/principle-training-state.ts +450 -0
  76. package/src/core/profile.ts +226 -0
  77. package/src/core/promotion-gate.ts +822 -0
  78. package/{dist/core/risk-calculator.js → src/core/risk-calculator.ts} +42 -16
  79. package/{dist/core/session-tracker.js → src/core/session-tracker.ts} +175 -62
  80. package/src/core/shadow-observation-registry.ts +534 -0
  81. package/{dist/core/system-logger.js → src/core/system-logger.ts} +9 -5
  82. package/src/core/thinking-models.ts +217 -0
  83. package/src/core/training-program.ts +630 -0
  84. package/src/core/trajectory-types.ts +243 -0
  85. package/src/core/trajectory.ts +1673 -0
  86. package/{dist/core/workspace-context.js → src/core/workspace-context.ts} +57 -32
  87. package/src/hooks/bash-risk.ts +171 -0
  88. package/src/hooks/edit-verification.ts +295 -0
  89. package/src/hooks/gate-block-helper.ts +160 -0
  90. package/src/hooks/gate.ts +210 -0
  91. package/src/hooks/gfi-gate.ts +177 -0
  92. package/src/hooks/lifecycle.ts +326 -0
  93. package/{dist/hooks/llm.js → src/hooks/llm.ts} +160 -80
  94. package/src/hooks/message-sanitize.ts +45 -0
  95. package/src/hooks/pain.ts +384 -0
  96. package/src/hooks/progressive-trust-gate.ts +174 -0
  97. package/src/hooks/prompt.ts +920 -0
  98. package/src/hooks/subagent.ts +207 -0
  99. package/src/hooks/thinking-checkpoint.ts +73 -0
  100. package/src/hooks/trajectory-collector.ts +290 -0
  101. package/src/http/principles-console-route.ts +716 -0
  102. package/src/i18n/commands.ts +117 -0
  103. package/src/index.ts +694 -0
  104. package/src/service/central-database.ts +831 -0
  105. package/src/service/control-ui-query-service.ts +888 -0
  106. package/src/service/evolution-query-service.ts +405 -0
  107. package/src/service/evolution-worker.ts +1646 -0
  108. package/src/service/health-query-service.ts +836 -0
  109. package/{dist/service/nocturnal-runtime.js → src/service/nocturnal-runtime.ts} +235 -79
  110. package/src/service/nocturnal-service.ts +1015 -0
  111. package/src/service/nocturnal-target-selector.ts +532 -0
  112. package/src/service/phase3-input-filter.ts +237 -0
  113. package/src/service/runtime-summary-service.ts +757 -0
  114. package/src/service/subagent-workflow/deep-reflect-workflow-manager.ts +513 -0
  115. package/{dist/service/subagent-workflow/empathy-observer-workflow-manager.js → src/service/subagent-workflow/empathy-observer-workflow-manager.ts} +240 -117
  116. package/src/service/subagent-workflow/index.ts +51 -0
  117. package/src/service/subagent-workflow/nocturnal-workflow-manager.ts +856 -0
  118. package/src/service/subagent-workflow/runtime-direct-driver.ts +166 -0
  119. package/{dist/service/subagent-workflow/types.d.ts → src/service/subagent-workflow/types.ts} +137 -18
  120. package/src/service/subagent-workflow/workflow-store.ts +328 -0
  121. package/src/service/trajectory-service.ts +15 -0
  122. package/{dist/tools/critique-prompt.js → src/tools/critique-prompt.ts} +25 -8
  123. package/src/tools/deep-reflect.ts +349 -0
  124. package/{dist/tools/model-index.js → src/tools/model-index.ts} +33 -17
  125. package/src/types/event-types.ts +453 -0
  126. package/src/types/hygiene-types.ts +31 -0
  127. package/src/types/principle-tree-schema.ts +244 -0
  128. package/src/types/runtime-summary.ts +49 -0
  129. package/src/types.ts +74 -0
  130. package/src/utils/file-lock.ts +391 -0
  131. package/{dist/utils/glob-match.js → src/utils/glob-match.ts} +21 -20
  132. package/{dist/utils/hashing.js → src/utils/hashing.ts} +6 -4
  133. package/src/utils/io.ts +110 -0
  134. package/{dist/utils/nlp.js → src/utils/nlp.ts} +19 -12
  135. package/{dist/utils/plugin-logger.js → src/utils/plugin-logger.ts} +33 -8
  136. package/src/utils/subagent-probe.ts +94 -0
  137. package/templates/langs/en/skills/ai-sprint-orchestration/EXAMPLES.md +63 -0
  138. package/templates/langs/en/skills/ai-sprint-orchestration/REFERENCE.md +136 -0
  139. package/templates/langs/en/skills/ai-sprint-orchestration/SKILL.md +67 -0
  140. package/templates/langs/en/skills/ai-sprint-orchestration/references/agent-registry.json +214 -0
  141. package/templates/langs/en/skills/ai-sprint-orchestration/references/specs/bugfix-complex-template.json +107 -0
  142. package/templates/langs/en/skills/ai-sprint-orchestration/references/specs/feature-complex-template.json +107 -0
  143. package/templates/langs/en/skills/ai-sprint-orchestration/references/specs/workflow-validation-minimal-verify.json +105 -0
  144. package/templates/langs/en/skills/ai-sprint-orchestration/references/specs/workflow-validation-minimal.json +108 -0
  145. package/templates/langs/en/skills/ai-sprint-orchestration/references/workflow-v1-acceptance-checklist.md +58 -0
  146. package/templates/langs/en/skills/ai-sprint-orchestration/references/workflow-v1.4-work-unit-handoff.md +190 -0
  147. package/templates/langs/en/skills/ai-sprint-orchestration/runtime/.gitignore +2 -0
  148. package/templates/langs/en/skills/ai-sprint-orchestration/scripts/lib/archive.mjs +310 -0
  149. package/templates/langs/en/skills/ai-sprint-orchestration/scripts/lib/contract-enforcement.mjs +683 -0
  150. package/templates/langs/en/skills/ai-sprint-orchestration/scripts/lib/decision.mjs +604 -0
  151. package/templates/langs/en/skills/ai-sprint-orchestration/scripts/lib/state-store.mjs +32 -0
  152. package/templates/langs/en/skills/ai-sprint-orchestration/scripts/lib/task-specs.mjs +707 -0
  153. package/templates/langs/en/skills/ai-sprint-orchestration/scripts/run.mjs +3419 -0
  154. package/templates/langs/zh/skills/ai-sprint-orchestration/EXAMPLES.md +63 -0
  155. package/templates/langs/zh/skills/ai-sprint-orchestration/REFERENCE.md +136 -0
  156. package/templates/langs/zh/skills/ai-sprint-orchestration/SKILL.md +67 -0
  157. package/templates/langs/zh/skills/ai-sprint-orchestration/references/agent-registry.json +214 -0
  158. package/templates/langs/zh/skills/ai-sprint-orchestration/references/specs/bugfix-complex-template.json +107 -0
  159. package/templates/langs/zh/skills/ai-sprint-orchestration/references/specs/feature-complex-template.json +107 -0
  160. package/templates/langs/zh/skills/ai-sprint-orchestration/references/specs/workflow-validation-minimal-verify.json +105 -0
  161. package/templates/langs/zh/skills/ai-sprint-orchestration/references/specs/workflow-validation-minimal.json +108 -0
  162. package/templates/langs/zh/skills/ai-sprint-orchestration/references/workflow-v1-acceptance-checklist.md +58 -0
  163. package/templates/langs/zh/skills/ai-sprint-orchestration/references/workflow-v1.4-work-unit-handoff.md +190 -0
  164. package/templates/langs/zh/skills/ai-sprint-orchestration/runtime/.gitignore +2 -0
  165. package/templates/langs/zh/skills/ai-sprint-orchestration/scripts/lib/archive.mjs +310 -0
  166. package/templates/langs/zh/skills/ai-sprint-orchestration/scripts/lib/contract-enforcement.mjs +683 -0
  167. package/templates/langs/zh/skills/ai-sprint-orchestration/scripts/lib/decision.mjs +604 -0
  168. package/templates/langs/zh/skills/ai-sprint-orchestration/scripts/lib/state-store.mjs +32 -0
  169. package/templates/langs/zh/skills/ai-sprint-orchestration/scripts/lib/task-specs.mjs +707 -0
  170. package/templates/langs/zh/skills/ai-sprint-orchestration/scripts/run.mjs +3419 -0
  171. package/templates/langs/zh/skills/ai-sprint-orchestration/test/archive.test.mjs +230 -0
  172. package/templates/langs/zh/skills/ai-sprint-orchestration/test/contract-enforcement.test.mjs +672 -0
  173. package/templates/langs/zh/skills/ai-sprint-orchestration/test/decision.test.mjs +1321 -0
  174. package/templates/langs/zh/skills/ai-sprint-orchestration/test/run.test.mjs +1419 -0
  175. package/templates/langs/zh/skills/pd-diagnostician/SKILL.md +70 -1
  176. package/templates/pain_settings.json +2 -1
  177. package/tests/README.md +120 -0
  178. package/tests/build-artifacts.test.ts +111 -0
  179. package/tests/commands/evolution-status.test.ts +222 -0
  180. package/tests/commands/evolver.test.ts +22 -0
  181. package/tests/commands/export.test.ts +78 -0
  182. package/tests/commands/nocturnal-review.test.ts +448 -0
  183. package/tests/commands/nocturnal-train.test.ts +97 -0
  184. package/tests/commands/pain.test.ts +108 -0
  185. package/tests/commands/samples.test.ts +65 -0
  186. package/tests/commands/strategy.test.ts +34 -0
  187. package/tests/commands/thinking-os.test.ts +88 -0
  188. package/tests/core/adaptive-thresholds.test.ts +261 -0
  189. package/tests/core/config-service.test.ts +89 -0
  190. package/tests/core/config.test.ts +90 -0
  191. package/tests/core/control-ui-db.test.ts +75 -0
  192. package/tests/core/core-template-guidance.test.ts +21 -0
  193. package/tests/core/detection-funnel.test.ts +63 -0
  194. package/tests/core/detection-service.test.ts +50 -0
  195. package/tests/core/dictionary-service.test.ts +116 -0
  196. package/tests/core/dictionary.test.ts +168 -0
  197. package/tests/core/empathy-keyword-matcher.test.ts +209 -0
  198. package/tests/core/event-log.test.ts +181 -0
  199. package/tests/core/evolution-e2e.test.ts +58 -0
  200. package/tests/core/evolution-engine-gate-integration.test.ts +543 -0
  201. package/tests/core/evolution-engine.test.ts +562 -0
  202. package/tests/core/evolution-logger.test.ts +148 -0
  203. package/tests/core/evolution-migration.test.ts +50 -0
  204. package/tests/core/evolution-paths.test.ts +21 -0
  205. package/tests/core/evolution-reducer.detector-metadata.test.ts +602 -0
  206. package/tests/core/evolution-reducer.test.ts +180 -0
  207. package/tests/core/evolution-types-loop.test.ts +48 -0
  208. package/tests/core/evolution-user-stories.e2e.test.ts +249 -0
  209. package/tests/core/external-training-contract.test.ts +463 -0
  210. package/tests/core/focus-history.test.ts +682 -0
  211. package/tests/core/init-flatten.test.ts +69 -0
  212. package/tests/core/init-refactor.test.ts +87 -0
  213. package/tests/core/init-v1.3.test.ts +46 -0
  214. package/tests/core/init.test.ts +190 -0
  215. package/tests/core/local-worker-routing.test.ts +757 -0
  216. package/tests/core/migration.test.ts +84 -0
  217. package/tests/core/model-deployment-registry.test.ts +845 -0
  218. package/tests/core/model-training-registry.test.ts +889 -0
  219. package/tests/core/nocturnal-arbiter.test.ts +494 -0
  220. package/tests/core/nocturnal-candidate-scoring.test.ts +400 -0
  221. package/tests/core/nocturnal-compliance.test.ts +646 -0
  222. package/tests/core/nocturnal-dataset.test.ts +892 -0
  223. package/tests/core/nocturnal-executability.test.ts +357 -0
  224. package/tests/core/nocturnal-export.test.ts +462 -0
  225. package/tests/core/nocturnal-reviewed-subset-comparison.test.ts +428 -0
  226. package/tests/core/nocturnal-trajectory-extractor.test.ts +634 -0
  227. package/tests/core/nocturnal-trinity.test.ts +953 -0
  228. package/tests/core/pain.test.ts +33 -0
  229. package/tests/core/path-resolver.test.ts +57 -0
  230. package/tests/core/paths-refactor.test.ts +42 -0
  231. package/tests/core/phase7-rollout-integration.test.ts +477 -0
  232. package/tests/core/principle-training-state.test.ts +712 -0
  233. package/tests/core/profile.test.ts +56 -0
  234. package/tests/core/promotion-gate.test.ts +556 -0
  235. package/tests/core/risk-calculator.test.ts +168 -0
  236. package/tests/core/session-tracker.test.ts +191 -0
  237. package/tests/core/training-program.test.ts +472 -0
  238. package/tests/core/trajectory.test.ts +265 -0
  239. package/tests/core/workspace-context-factory.test.ts +18 -0
  240. package/tests/core/workspace-context.test.ts +134 -0
  241. package/tests/fixtures/nocturnal-reviewed-subset.json +183 -0
  242. package/tests/fixtures/production-compatibility.test.ts +147 -0
  243. package/tests/fixtures/production-mock-generator.ts +282 -0
  244. package/tests/hooks/bash-risk-integration.test.ts +137 -0
  245. package/tests/hooks/bash-risk.test.ts +81 -0
  246. package/tests/hooks/edit-verification.test.ts +678 -0
  247. package/tests/hooks/gate-edit-verification-p1.test.ts +632 -0
  248. package/tests/hooks/gate-edit-verification.test.ts +435 -0
  249. package/tests/hooks/gate-pipeline-integration.test.ts +404 -0
  250. package/tests/hooks/gate.test.ts +271 -0
  251. package/tests/hooks/gfi-gate-unit.test.ts +422 -0
  252. package/tests/hooks/gfi-gate.test.ts +669 -0
  253. package/tests/hooks/lifecycle.test.ts +248 -0
  254. package/tests/hooks/llm.test.ts +308 -0
  255. package/tests/hooks/message-sanitize.test.ts +36 -0
  256. package/tests/hooks/pain.test.ts +141 -0
  257. package/tests/hooks/progressive-trust-gate.test.ts +277 -0
  258. package/tests/hooks/prompt.test.ts +1411 -0
  259. package/tests/hooks/subagent.test.ts +467 -0
  260. package/tests/hooks/thinking-gate.test.ts +313 -0
  261. package/tests/http/principles-console-route.test.ts +140 -0
  262. package/tests/hygiene-tracker.test.ts +77 -0
  263. package/tests/index.integration.test.ts +179 -0
  264. package/tests/index.shadow-routing.integration.test.ts +140 -0
  265. package/tests/index.test.ts +9 -0
  266. package/tests/integration/empathy-workflow-integration.test.ts +627 -0
  267. package/tests/service/control-ui-query-service.test.ts +121 -0
  268. package/tests/service/empathy-observer-workflow-manager.test.ts +176 -0
  269. package/tests/service/evolution-worker.test.ts +585 -0
  270. package/tests/service/nocturnal-runtime.test.ts +470 -0
  271. package/tests/service/nocturnal-service.test.ts +577 -0
  272. package/tests/service/nocturnal-target-selector.test.ts +615 -0
  273. package/tests/service/nocturnal-workflow-manager.test.ts +439 -0
  274. package/tests/service/phase3-input-filter.test.ts +289 -0
  275. package/tests/service/runtime-summary-service.test.ts +919 -0
  276. package/tests/task-compliance.test.ts +166 -0
  277. package/tests/test-utils.ts +48 -0
  278. package/tests/tools/critique-prompt.test.ts +260 -0
  279. package/tests/tools/deep-reflect.test.ts +232 -0
  280. package/tests/tools/model-index.test.ts +246 -0
  281. package/tests/ui/app.test.tsx +114 -0
  282. package/tests/utils/file-lock.test.ts +407 -0
  283. package/tests/utils/hashing.test.ts +32 -0
  284. package/tests/utils/io.test.ts +39 -0
  285. package/tests/utils/nlp.test.ts +53 -0
  286. package/tests/utils/plugin-logger.test.ts +156 -0
  287. package/tsconfig.json +16 -0
  288. package/tsconfig.tsbuildinfo +1 -0
  289. package/ui/src/App.tsx +45 -0
  290. package/ui/src/api.ts +216 -0
  291. package/ui/src/charts.tsx +586 -0
  292. package/ui/src/components/ErrorState.tsx +6 -0
  293. package/ui/src/components/Loading.tsx +13 -0
  294. package/ui/src/components/ProtectedRoute.tsx +12 -0
  295. package/ui/src/components/Shell.tsx +91 -0
  296. package/ui/src/components/WorkspaceConfig.tsx +146 -0
  297. package/ui/src/components/index.ts +5 -0
  298. package/ui/src/context/auth.tsx +80 -0
  299. package/ui/src/context/theme.tsx +66 -0
  300. package/ui/src/hooks/useAutoRefresh.ts +39 -0
  301. package/ui/src/i18n/ui.ts +363 -0
  302. package/ui/src/main.tsx +16 -0
  303. package/ui/src/pages/EvolutionPage.tsx +352 -0
  304. package/ui/src/pages/FeedbackPage.tsx +140 -0
  305. package/ui/src/pages/GateMonitorPage.tsx +136 -0
  306. package/ui/src/pages/LoginPage.tsx +88 -0
  307. package/ui/src/pages/OverviewPage.tsx +238 -0
  308. package/ui/src/pages/SamplesPage.tsx +174 -0
  309. package/ui/src/pages/ThinkingModelsPage.tsx +127 -0
  310. package/ui/src/styles.css +1661 -0
  311. package/ui/src/types.ts +368 -0
  312. package/ui/src/utils/format.ts +15 -0
  313. package/vitest.config.ts +23 -0
  314. package/dist/commands/capabilities.d.ts +0 -3
  315. package/dist/commands/capabilities.js +0 -73
  316. package/dist/commands/context.d.ts +0 -5
  317. package/dist/commands/evolution-status.d.ts +0 -4
  318. package/dist/commands/evolution-status.js +0 -117
  319. package/dist/commands/evolver.d.ts +0 -9
  320. package/dist/commands/evolver.js +0 -26
  321. package/dist/commands/export.d.ts +0 -2
  322. package/dist/commands/export.js +0 -98
  323. package/dist/commands/focus.d.ts +0 -14
  324. package/dist/commands/focus.js +0 -457
  325. package/dist/commands/nocturnal-review.d.ts +0 -24
  326. package/dist/commands/nocturnal-review.js +0 -265
  327. package/dist/commands/nocturnal-rollout.d.ts +0 -27
  328. package/dist/commands/nocturnal-rollout.js +0 -671
  329. package/dist/commands/nocturnal-train.d.ts +0 -25
  330. package/dist/commands/nocturnal-train.js +0 -919
  331. package/dist/commands/pain.d.ts +0 -5
  332. package/dist/commands/principle-rollback.d.ts +0 -4
  333. package/dist/commands/principle-rollback.js +0 -22
  334. package/dist/commands/rollback.d.ts +0 -19
  335. package/dist/commands/samples.d.ts +0 -2
  336. package/dist/commands/samples.js +0 -55
  337. package/dist/commands/strategy.d.ts +0 -3
  338. package/dist/commands/strategy.js +0 -29
  339. package/dist/commands/thinking-os.d.ts +0 -2
  340. package/dist/config/defaults/runtime.d.ts +0 -40
  341. package/dist/config/errors.d.ts +0 -84
  342. package/dist/config/errors.js +0 -94
  343. package/dist/config/index.js +0 -7
  344. package/dist/constants/diagnostician.d.ts +0 -12
  345. package/dist/constants/diagnostician.js +0 -56
  346. package/dist/constants/tools.d.ts +0 -17
  347. package/dist/constants/tools.js +0 -54
  348. package/dist/core/adaptive-thresholds.d.ts +0 -186
  349. package/dist/core/adaptive-thresholds.js +0 -300
  350. package/dist/core/config-service.d.ts +0 -15
  351. package/dist/core/config.d.ts +0 -129
  352. package/dist/core/control-ui-db.d.ts +0 -95
  353. package/dist/core/control-ui-db.js +0 -292
  354. package/dist/core/detection-funnel.d.ts +0 -33
  355. package/dist/core/detection-service.d.ts +0 -15
  356. package/dist/core/dictionary-service.d.ts +0 -15
  357. package/dist/core/dictionary.d.ts +0 -38
  358. package/dist/core/event-log.d.ts +0 -82
  359. package/dist/core/event-log.js +0 -463
  360. package/dist/core/evolution-engine.d.ts +0 -118
  361. package/dist/core/evolution-engine.js +0 -464
  362. package/dist/core/evolution-logger.d.ts +0 -137
  363. package/dist/core/evolution-logger.js +0 -256
  364. package/dist/core/evolution-migration.d.ts +0 -5
  365. package/dist/core/evolution-migration.js +0 -65
  366. package/dist/core/evolution-reducer.d.ts +0 -98
  367. package/dist/core/evolution-reducer.js +0 -465
  368. package/dist/core/evolution-types.d.ts +0 -287
  369. package/dist/core/evolution-types.js +0 -78
  370. package/dist/core/external-training-contract.d.ts +0 -276
  371. package/dist/core/external-training-contract.js +0 -269
  372. package/dist/core/focus-history.d.ts +0 -210
  373. package/dist/core/focus-history.js +0 -1185
  374. package/dist/core/hygiene/tracker.d.ts +0 -22
  375. package/dist/core/hygiene/tracker.js +0 -106
  376. package/dist/core/init.d.ts +0 -12
  377. package/dist/core/local-worker-routing.d.ts +0 -175
  378. package/dist/core/local-worker-routing.js +0 -525
  379. package/dist/core/migration.d.ts +0 -6
  380. package/dist/core/model-deployment-registry.d.ts +0 -218
  381. package/dist/core/model-deployment-registry.js +0 -503
  382. package/dist/core/model-training-registry.d.ts +0 -295
  383. package/dist/core/model-training-registry.js +0 -475
  384. package/dist/core/nocturnal-arbiter.d.ts +0 -159
  385. package/dist/core/nocturnal-arbiter.js +0 -534
  386. package/dist/core/nocturnal-candidate-scoring.d.ts +0 -137
  387. package/dist/core/nocturnal-candidate-scoring.js +0 -266
  388. package/dist/core/nocturnal-compliance.d.ts +0 -175
  389. package/dist/core/nocturnal-compliance.js +0 -824
  390. package/dist/core/nocturnal-dataset.d.ts +0 -224
  391. package/dist/core/nocturnal-dataset.js +0 -443
  392. package/dist/core/nocturnal-executability.d.ts +0 -85
  393. package/dist/core/nocturnal-executability.js +0 -331
  394. package/dist/core/nocturnal-export.d.ts +0 -124
  395. package/dist/core/nocturnal-export.js +0 -275
  396. package/dist/core/nocturnal-paths.d.ts +0 -124
  397. package/dist/core/nocturnal-trajectory-extractor.d.ts +0 -242
  398. package/dist/core/nocturnal-trajectory-extractor.js +0 -307
  399. package/dist/core/nocturnal-trinity.d.ts +0 -311
  400. package/dist/core/nocturnal-trinity.js +0 -880
  401. package/dist/core/pain.d.ts +0 -4
  402. package/dist/core/pain.js +0 -70
  403. package/dist/core/path-resolver.d.ts +0 -46
  404. package/dist/core/paths.d.ts +0 -65
  405. package/dist/core/principle-training-state.d.ts +0 -121
  406. package/dist/core/principle-training-state.js +0 -321
  407. package/dist/core/profile.d.ts +0 -62
  408. package/dist/core/profile.js +0 -210
  409. package/dist/core/promotion-gate.d.ts +0 -238
  410. package/dist/core/promotion-gate.js +0 -529
  411. package/dist/core/risk-calculator.d.ts +0 -22
  412. package/dist/core/session-tracker.d.ts +0 -101
  413. package/dist/core/shadow-observation-registry.d.ts +0 -217
  414. package/dist/core/shadow-observation-registry.js +0 -308
  415. package/dist/core/system-logger.d.ts +0 -8
  416. package/dist/core/thinking-models.d.ts +0 -38
  417. package/dist/core/thinking-models.js +0 -170
  418. package/dist/core/training-program.d.ts +0 -233
  419. package/dist/core/training-program.js +0 -433
  420. package/dist/core/trajectory.d.ts +0 -411
  421. package/dist/core/trajectory.js +0 -1307
  422. package/dist/core/workspace-context.d.ts +0 -71
  423. package/dist/hooks/bash-risk.d.ts +0 -57
  424. package/dist/hooks/bash-risk.js +0 -137
  425. package/dist/hooks/edit-verification.d.ts +0 -62
  426. package/dist/hooks/edit-verification.js +0 -256
  427. package/dist/hooks/gate-block-helper.d.ts +0 -44
  428. package/dist/hooks/gate-block-helper.js +0 -119
  429. package/dist/hooks/gate.d.ts +0 -24
  430. package/dist/hooks/gate.js +0 -173
  431. package/dist/hooks/gfi-gate.d.ts +0 -40
  432. package/dist/hooks/gfi-gate.js +0 -113
  433. package/dist/hooks/lifecycle.d.ts +0 -5
  434. package/dist/hooks/lifecycle.js +0 -284
  435. package/dist/hooks/llm.d.ts +0 -13
  436. package/dist/hooks/message-sanitize.d.ts +0 -3
  437. package/dist/hooks/message-sanitize.js +0 -37
  438. package/dist/hooks/pain.d.ts +0 -5
  439. package/dist/hooks/pain.js +0 -301
  440. package/dist/hooks/progressive-trust-gate.d.ts +0 -52
  441. package/dist/hooks/progressive-trust-gate.js +0 -134
  442. package/dist/hooks/prompt.d.ts +0 -49
  443. package/dist/hooks/prompt.js +0 -905
  444. package/dist/hooks/subagent.d.ts +0 -10
  445. package/dist/hooks/subagent.js +0 -387
  446. package/dist/hooks/thinking-checkpoint.d.ts +0 -37
  447. package/dist/hooks/thinking-checkpoint.js +0 -51
  448. package/dist/hooks/trajectory-collector.d.ts +0 -32
  449. package/dist/hooks/trajectory-collector.js +0 -256
  450. package/dist/http/principles-console-route.d.ts +0 -9
  451. package/dist/http/principles-console-route.js +0 -681
  452. package/dist/i18n/commands.d.ts +0 -26
  453. package/dist/i18n/commands.js +0 -116
  454. package/dist/index.d.ts +0 -7
  455. package/dist/index.js +0 -581
  456. package/dist/service/central-database.d.ts +0 -104
  457. package/dist/service/central-database.js +0 -649
  458. package/dist/service/control-ui-query-service.d.ts +0 -221
  459. package/dist/service/control-ui-query-service.js +0 -543
  460. package/dist/service/empathy-observer-manager.d.ts +0 -88
  461. package/dist/service/empathy-observer-manager.js +0 -414
  462. package/dist/service/evolution-query-service.d.ts +0 -155
  463. package/dist/service/evolution-query-service.js +0 -258
  464. package/dist/service/evolution-worker.d.ts +0 -101
  465. package/dist/service/evolution-worker.js +0 -975
  466. package/dist/service/health-query-service.d.ts +0 -170
  467. package/dist/service/health-query-service.js +0 -662
  468. package/dist/service/nocturnal-runtime.d.ts +0 -183
  469. package/dist/service/nocturnal-service.d.ts +0 -163
  470. package/dist/service/nocturnal-service.js +0 -787
  471. package/dist/service/nocturnal-target-selector.d.ts +0 -145
  472. package/dist/service/nocturnal-target-selector.js +0 -315
  473. package/dist/service/phase3-input-filter.d.ts +0 -73
  474. package/dist/service/phase3-input-filter.js +0 -172
  475. package/dist/service/runtime-summary-service.d.ts +0 -122
  476. package/dist/service/runtime-summary-service.js +0 -485
  477. package/dist/service/subagent-workflow/empathy-observer-workflow-manager.d.ts +0 -48
  478. package/dist/service/subagent-workflow/index.d.ts +0 -4
  479. package/dist/service/subagent-workflow/index.js +0 -3
  480. package/dist/service/subagent-workflow/runtime-direct-driver.d.ts +0 -77
  481. package/dist/service/subagent-workflow/runtime-direct-driver.js +0 -75
  482. package/dist/service/subagent-workflow/types.js +0 -11
  483. package/dist/service/subagent-workflow/workflow-store.d.ts +0 -26
  484. package/dist/service/subagent-workflow/workflow-store.js +0 -165
  485. package/dist/service/trajectory-service.d.ts +0 -2
  486. package/dist/service/trajectory-service.js +0 -15
  487. package/dist/tools/critique-prompt.d.ts +0 -14
  488. package/dist/tools/deep-reflect.d.ts +0 -39
  489. package/dist/tools/deep-reflect.js +0 -350
  490. package/dist/tools/model-index.d.ts +0 -9
  491. package/dist/types/event-types.d.ts +0 -306
  492. package/dist/types/event-types.js +0 -106
  493. package/dist/types/hygiene-types.d.ts +0 -20
  494. package/dist/types/hygiene-types.js +0 -12
  495. package/dist/types/runtime-summary.d.ts +0 -47
  496. package/dist/types/runtime-summary.js +0 -1
  497. package/dist/types.d.ts +0 -50
  498. package/dist/types.js +0 -22
  499. package/dist/utils/file-lock.d.ts +0 -71
  500. package/dist/utils/file-lock.js +0 -309
  501. package/dist/utils/glob-match.d.ts +0 -28
  502. package/dist/utils/hashing.d.ts +0 -9
  503. package/dist/utils/io.d.ts +0 -6
  504. package/dist/utils/io.js +0 -106
  505. package/dist/utils/nlp.d.ts +0 -9
  506. package/dist/utils/plugin-logger.d.ts +0 -39
  507. package/dist/utils/subagent-probe.d.ts +0 -34
  508. package/dist/utils/subagent-probe.js +0 -81
@@ -1,529 +0,0 @@
1
- /**
2
- * Promotion Gate — Checkpoint Promotion State Machine and Gate Logic
3
- * ==================================================================
4
- *
5
- * PURPOSE: Control when a checkpoint can advance from training → shadow → promotion.
6
- * Training success alone is not enough — a checkpoint must prove it improves
7
- * bounded worker behavior under the existing offline benchmark and does not
8
- * regress runtime safety signals.
9
- *
10
- * PROMOTION STATES:
11
- * - rejected: The checkpoint must not be routed
12
- * - candidate_only: The checkpoint is valid but not yet ready for shadow
13
- * - shadow_ready: The checkpoint may enter controlled shadow rollout
14
- * - promotable: The checkpoint may replace the active checkpoint
15
- *
16
- * STATE TRANSITIONS:
17
- * training_completed
18
- * ↓
19
- * candidate_only ←── (eval attached, lineage complete)
20
- * ↓
21
- * shadow_ready ←── (positive delta, safe constraints)
22
- * ↓
23
- * promotable ←── (shadow window passed, orchestrator review passed)
24
- * ↓
25
- * deployed
26
- *
27
- * PRIMARY OBJECTIVE:
28
- * maximize reduced_prompt_holdout_delta
29
- *
30
- * CONSTRAINT METRICS (must all pass for promotion):
31
- * - arbiterRejectRate <= baseline + allowedMargin
32
- * - executabilityRejectRate <= baseline + allowedMargin
33
- * - reviewedSubsetQuality >= baseline
34
- * - routingScopeNotExpanded == true
35
- *
36
- * DESIGN CONSTRAINTS:
37
- * - No automatic promotion without explicit gate approval
38
- * - Orchestrator review remains mandatory for all promotions
39
- * - Rollback path must be always available
40
- * - First rollout limited to `local-reader` only
41
- */
42
- import * as fs from 'fs';
43
- import * as path from 'path';
44
- import * as crypto from 'crypto';
45
- import { withLock } from '../utils/file-lock.js';
46
- import { getCheckpoint, getEvalSummary, } from './model-training-registry.js';
47
- import { computeShadowStats, } from './shadow-observation-registry.js';
48
- // ---------------------------------------------------------------------------
49
- // Constants
50
- // ---------------------------------------------------------------------------
51
- /**
52
- * Candidate delta must exceed this to enter shadow_ready.
53
- */
54
- export const DEFAULT_MIN_DELTA = 0.05;
55
- /**
56
- * Default allowed margin for constraint metrics.
57
- * Constraint metrics can regress by at most this amount.
58
- */
59
- export const DEFAULT_ALLOWED_MARGIN = 0.05;
60
- /**
61
- * Allowed worker profiles for Phase 7 shadow rollout.
62
- * Only bounded local workers eligible. local-reader first, local-editor deferred.
63
- */
64
- const ALLOWED_ROLLOUT_PROFILES = ['local-reader'];
65
- /**
66
- * Registry file for promotion records.
67
- */
68
- const PROMOTION_REGISTRY_FILE = 'promotion-registry.json';
69
- /**
70
- * Minimum shadow window duration in milliseconds.
71
- * A checkpoint must remain in shadow_ready for at least this duration
72
- * before it can be promoted to promotable.
73
- *
74
- * Phase 7 default: 1 hour (3600000 ms)
75
- * This gives time for real-world feedback before full promotion.
76
- */
77
- export const MIN_SHADOW_WINDOW_MS = 60 * 60 * 1000; // 1 hour
78
- // ---------------------------------------------------------------------------
79
- // Registry Path
80
- // ---------------------------------------------------------------------------
81
- function getRegistryPath(stateDir) {
82
- return path.join(stateDir, PROMOTION_REGISTRY_FILE);
83
- }
84
- /**
85
- * Ensure the registry directory exists.
86
- */
87
- function ensureRegistryDir(stateDir) {
88
- const registryPath = getRegistryPath(stateDir);
89
- const dir = path.dirname(registryPath);
90
- if (!fs.existsSync(dir)) {
91
- fs.mkdirSync(dir, { recursive: true });
92
- }
93
- }
94
- // ---------------------------------------------------------------------------
95
- // File Operations
96
- // ---------------------------------------------------------------------------
97
- /**
98
- * Read the registry from disk. Returns empty registry if missing.
99
- */
100
- function readRegistry(stateDir) {
101
- const registryPath = getRegistryPath(stateDir);
102
- if (!fs.existsSync(registryPath)) {
103
- return { promotions: [] };
104
- }
105
- try {
106
- const content = fs.readFileSync(registryPath, 'utf-8');
107
- return JSON.parse(content);
108
- }
109
- catch (err) {
110
- console.warn(`[promotion-gate] Registry corrupted at ${registryPath}, recovering with empty state: ${String(err)}`);
111
- return { promotions: [] };
112
- }
113
- }
114
- /**
115
- * Write the registry to disk atomically.
116
- */
117
- function writeRegistry(stateDir, registry) {
118
- ensureRegistryDir(stateDir);
119
- const registryPath = getRegistryPath(stateDir);
120
- const tmpPath = `${registryPath}.tmp`;
121
- fs.writeFileSync(tmpPath, JSON.stringify(registry, null, 2), 'utf-8');
122
- fs.renameSync(tmpPath, registryPath);
123
- }
124
- /**
125
- * Execute a read-modify-write under an exclusive file lock.
126
- */
127
- function withPromotionRegistryLock(stateDir, fn) {
128
- const registryPath = getRegistryPath(stateDir);
129
- return withLock(registryPath, () => {
130
- const registry = readRegistry(stateDir);
131
- return fn(registry);
132
- });
133
- }
134
- /**
135
- * Evaluate whether a checkpoint passes the promotion gate.
136
- *
137
- * @param stateDir - Workspace state directory
138
- * @param params - Evaluation parameters
139
- * @returns PromotionGateResult with pass/fail and details
140
- *
141
- * FAIL-CLOSED: Returns { passes: false } if:
142
- * - No eval attached to checkpoint
143
- * - Delta is negative or below threshold
144
- * - Any constraint metric regresses beyond allowed margin
145
- * - Profile is not in allowed rollout list
146
- */
147
- export function evaluatePromotionGate(stateDir, params) {
148
- const { checkpointId, targetProfile, baselineMetrics, minDelta = DEFAULT_MIN_DELTA, allowedMargin = DEFAULT_ALLOWED_MARGIN, } = params;
149
- const blockers = [];
150
- const constraintChecks = [];
151
- // --- Check 1: Checkpoint exists ---
152
- const checkpoint = getCheckpoint(stateDir, checkpointId);
153
- if (!checkpoint) {
154
- blockers.push(`Checkpoint not found: ${checkpointId}`);
155
- return {
156
- passes: false,
157
- blockers,
158
- constraintChecks: [],
159
- deltaCheck: { actual: 0, threshold: minDelta, passed: false },
160
- };
161
- }
162
- // --- Check 2: Has eval attached ---
163
- if (!checkpoint.lastEvalSummaryRef) {
164
- blockers.push(`Checkpoint ${checkpointId} has no eval summary attached. ` +
165
- `Run benchmark evaluation before promotion gate.`);
166
- return {
167
- passes: false,
168
- blockers,
169
- constraintChecks: [],
170
- deltaCheck: { actual: 0, threshold: minDelta, passed: false },
171
- };
172
- }
173
- // --- Check 3: Get eval summary ---
174
- const evalSummary = getEvalSummary(stateDir, checkpoint.lastEvalSummaryRef);
175
- if (!evalSummary) {
176
- blockers.push(`Eval summary '${checkpoint.lastEvalSummaryRef}' not found. ` +
177
- `Cannot evaluate promotion gate without valid eval.`);
178
- return {
179
- passes: false,
180
- blockers,
181
- constraintChecks: [],
182
- deltaCheck: { actual: 0, threshold: minDelta, passed: false },
183
- };
184
- }
185
- // --- Check 4: Delta must be positive and above threshold ---
186
- const delta = evalSummary.delta;
187
- const deltaCheck = {
188
- actual: delta,
189
- threshold: minDelta,
190
- passed: delta >= minDelta,
191
- };
192
- if (!deltaCheck.passed) {
193
- blockers.push(`Reduced-prompt holdout delta (${delta.toFixed(4)}) is below threshold (${minDelta}). ` +
194
- `Checkpoint must show positive improvement to be promoted.`);
195
- }
196
- // --- Check 5: Arbiter reject rate constraint ---
197
- // PREFER real shadow evidence over eval verdict proxy
198
- // Shadow evidence comes from actual runtime routing decisions
199
- const shadowStats = computeShadowStats(stateDir, { checkpointId });
200
- let arbiterRejectRate;
201
- let arbiterRejectSource;
202
- if (shadowStats && shadowStats.isStatisticallySignificant) {
203
- // Use real shadow evidence: reject rate from shadow routing
204
- arbiterRejectRate = shadowStats.rejectRate;
205
- arbiterRejectSource = 'shadow';
206
- }
207
- else {
208
- // Fall back to eval verdict proxy (Phase 7 initial state)
209
- // This is a coarse approximation: 'fail' verdict maps to 100% reject
210
- arbiterRejectRate = evalSummary.verdict === 'fail' ? 1 : 0;
211
- arbiterRejectSource = 'eval-proxy';
212
- }
213
- const arbiterRejectCheck = {
214
- constraint: 'arbiterRejectRate',
215
- actual: arbiterRejectRate,
216
- baseline: baselineMetrics.arbiterRejectRate,
217
- threshold: baselineMetrics.arbiterRejectRate + allowedMargin,
218
- passed: arbiterRejectRate <= baselineMetrics.arbiterRejectRate + allowedMargin,
219
- source: arbiterRejectSource,
220
- };
221
- constraintChecks.push(arbiterRejectCheck);
222
- if (!arbiterRejectCheck.passed) {
223
- blockers.push(`arbiterRejectRate regressed: ${arbiterRejectRate.toFixed(4)} > ${arbiterRejectCheck.threshold.toFixed(4)} ` +
224
- `(baseline: ${baselineMetrics.arbiterRejectRate.toFixed(4)}, margin: ${allowedMargin}) ` +
225
- `[source: ${arbiterRejectSource}${shadowStats ? `, n=${shadowStats.totalCount}` : ''}]`);
226
- }
227
- // --- Check 6: Executability reject rate constraint ---
228
- // PREFER real shadow evidence: escalation rate + profile rejection rate
229
- let executabilityRejectRate;
230
- let executabilityRejectSource;
231
- if (shadowStats && shadowStats.isStatisticallySignificant) {
232
- // Use real shadow evidence: escalation + profile rejection from routing
233
- executabilityRejectRate = shadowStats.escalationRate + shadowStats.profileRejectedRate;
234
- executabilityRejectSource = 'shadow';
235
- }
236
- else {
237
- // Fall back to eval verdict proxy
238
- // This is a coarse approximation
239
- executabilityRejectRate = evalSummary.verdict === 'fail' ? 0.1 : 0;
240
- executabilityRejectSource = 'eval-proxy';
241
- }
242
- const executabilityRejectCheck = {
243
- constraint: 'executabilityRejectRate',
244
- actual: executabilityRejectRate,
245
- baseline: baselineMetrics.executabilityRejectRate,
246
- threshold: baselineMetrics.executabilityRejectRate + allowedMargin,
247
- passed: executabilityRejectRate <= baselineMetrics.executabilityRejectRate + allowedMargin,
248
- source: executabilityRejectSource,
249
- };
250
- constraintChecks.push(executabilityRejectCheck);
251
- if (!executabilityRejectCheck.passed) {
252
- blockers.push(`executabilityRejectRate regressed: ${executabilityRejectRate.toFixed(4)} > ${executabilityRejectCheck.threshold.toFixed(4)} ` +
253
- `(baseline: ${baselineMetrics.executabilityRejectRate.toFixed(4)}, margin: ${allowedMargin}) ` +
254
- `[source: ${executabilityRejectSource}${shadowStats ? `, n=${shadowStats.totalCount}` : ''}]`);
255
- }
256
- // --- Check 7: Reviewed subset quality constraint ---
257
- // Use eval score as proxy for quality
258
- const reviewedSubsetQuality = evalSummary.candidateScore;
259
- const qualityCheck = {
260
- constraint: 'reviewedSubsetQuality',
261
- actual: reviewedSubsetQuality,
262
- baseline: baselineMetrics.reviewedSubsetQuality,
263
- threshold: baselineMetrics.reviewedSubsetQuality - allowedMargin,
264
- passed: reviewedSubsetQuality >= baselineMetrics.reviewedSubsetQuality - allowedMargin,
265
- };
266
- constraintChecks.push(qualityCheck);
267
- if (!qualityCheck.passed) {
268
- blockers.push(`reviewedSubsetQuality regressed: ${reviewedSubsetQuality.toFixed(4)} < ${qualityCheck.threshold.toFixed(4)} ` +
269
- `(baseline: ${baselineMetrics.reviewedSubsetQuality.toFixed(4)})`);
270
- }
271
- // --- Determine if passes ---
272
- const allPassed = deltaCheck.passed &&
273
- arbiterRejectCheck.passed &&
274
- executabilityRejectCheck.passed &&
275
- qualityCheck.passed;
276
- // --- Suggest state based on checks ---
277
- let suggestedState;
278
- if (allPassed) {
279
- suggestedState = 'candidate_only';
280
- // If delta is strong enough, could be shadow_ready directly
281
- if (delta >= minDelta * 2) {
282
- suggestedState = 'shadow_ready';
283
- }
284
- }
285
- else {
286
- suggestedState = 'rejected';
287
- }
288
- return {
289
- passes: allPassed,
290
- suggestedState,
291
- blockers,
292
- constraintChecks,
293
- deltaCheck,
294
- };
295
- }
296
- /**
297
- * Advance a checkpoint's promotion state.
298
- *
299
- * @param stateDir - Workspace state directory
300
- * @param params - Advancement parameters
301
- * @returns The updated PromotionRecord
302
- *
303
- * @throws Error if gate evaluation fails
304
- * @throws Error if state transition is not allowed
305
- */
306
- export function advancePromotion(stateDir, params) {
307
- const { checkpointId, targetProfile, baselineMetrics, orchestratorReviewPassed = false, reviewNote, minDelta = DEFAULT_MIN_DELTA, allowedMargin = DEFAULT_ALLOWED_MARGIN, } = params;
308
- // First, evaluate the gate
309
- const gateResult = evaluatePromotionGate(stateDir, {
310
- checkpointId,
311
- targetProfile,
312
- baselineMetrics,
313
- minDelta,
314
- allowedMargin,
315
- });
316
- // Find existing promotion record (if any) - need this to know current state
317
- return withPromotionRegistryLock(stateDir, (registry) => {
318
- const now = new Date().toISOString();
319
- const existingIdx = registry.promotions.findIndex((p) => p.checkpointId === checkpointId);
320
- const currentState = existingIdx >= 0 ? registry.promotions[existingIdx].state : 'candidate_only';
321
- // Determine the target state based on current state, gate result, and review
322
- //
323
- // STATE TRANSITION RULES:
324
- // - Any state → rejected: if gate fails
325
- // - rejected/candidate_only → candidate_only: if gate passes but no review yet
326
- // - shadow_ready → promotable: if gate passes + review + shadow window elapsed
327
- // - rejected → candidate_only/shadow_ready: allowed via re-evaluation
328
- // (new eval data may reverse a previous rejection)
329
- //
330
- let targetState;
331
- if (!gateResult.passes) {
332
- targetState = 'rejected';
333
- }
334
- else if (!orchestratorReviewPassed) {
335
- // Gate passed but need orchestrator review before shadow_ready
336
- // Review is ALWAYS required to reach shadow_ready, regardless of delta strength
337
- targetState = 'candidate_only';
338
- }
339
- else {
340
- // Gate passed and orchestrator review passed: advance one level
341
- // Only go to promotable if already at shadow_ready; otherwise advance to shadow_ready
342
- if (currentState === 'shadow_ready') {
343
- // Check shadow window duration before allowing promotion
344
- const existing = existingIdx >= 0 ? registry.promotions[existingIdx] : null;
345
- const shadowStartedAt = existing?.shadowStartedAt;
346
- if (shadowStartedAt) {
347
- const shadowElapsed = Date.now() - new Date(shadowStartedAt).getTime();
348
- if (shadowElapsed < MIN_SHADOW_WINDOW_MS) {
349
- // Shadow window not elapsed yet — stay at shadow_ready
350
- targetState = 'shadow_ready';
351
- }
352
- else {
353
- // Shadow window elapsed — allow promotion to promotable
354
- targetState = 'promotable';
355
- }
356
- }
357
- else {
358
- // No shadowStartedAt, allow promotion (backward compat)
359
- targetState = 'promotable';
360
- }
361
- }
362
- else {
363
- // At candidate_only (or new), advance to shadow_ready
364
- targetState = 'shadow_ready';
365
- }
366
- }
367
- // Get previous promotion ID for chain
368
- const previousPromotionId = existingIdx >= 0
369
- ? registry.promotions[existingIdx].promotionId
370
- : undefined;
371
- // Get checkpoint info for lineage
372
- const checkpoint = getCheckpoint(stateDir, checkpointId);
373
- const evalSummary = checkpoint?.lastEvalSummaryRef
374
- ? getEvalSummary(stateDir, checkpoint.lastEvalSummaryRef)
375
- : null;
376
- // Get current delta
377
- const reducedPromptDelta = evalSummary?.delta ?? 0;
378
- // Create/update promotion record
379
- const promotion = {
380
- promotionId: existingIdx >= 0
381
- ? registry.promotions[existingIdx].promotionId
382
- : crypto.randomUUID(),
383
- checkpointId,
384
- state: targetState,
385
- targetProfile,
386
- targetModelFamily: checkpoint?.targetModelFamily ?? 'unknown',
387
- reducedPromptDelta,
388
- constraintMetrics: {
389
- arbiterRejectRate: evalSummary?.verdict === 'fail' ? 1 : 0,
390
- executabilityRejectRate: evalSummary?.verdict === 'fail' ? 0.1 : 0,
391
- reviewedSubsetQuality: evalSummary?.candidateScore ?? 0,
392
- routingScopeNotExpanded: true, // Always true in Phase 7
393
- },
394
- baselineMetrics,
395
- orchestratorReviewPassed,
396
- reviewNote,
397
- stateChangedAt: now,
398
- createdAt: existingIdx >= 0
399
- ? registry.promotions[existingIdx].createdAt
400
- : now,
401
- shadowStartedAt: (targetState === 'shadow_ready' || targetState === 'promotable')
402
- ? (() => {
403
- const existing = existingIdx >= 0 ? registry.promotions[existingIdx] : null;
404
- // Only preserve shadowStartedAt if the checkpoint was already on the
405
- // shadow path (shadow_ready or promotable). A demotion to candidate_only
406
- // or rejected means the next shadow entry is a fresh start — use now.
407
- if (existing?.shadowStartedAt &&
408
- (existing.state === 'shadow_ready' || existing.state === 'promotable')) {
409
- return existing.shadowStartedAt;
410
- }
411
- return now;
412
- })()
413
- : existingIdx >= 0
414
- ? registry.promotions[existingIdx].shadowStartedAt
415
- : undefined,
416
- promotableAt: targetState === 'promotable'
417
- ? now
418
- : existingIdx >= 0
419
- ? registry.promotions[existingIdx].promotableAt
420
- : undefined,
421
- previousPromotionId,
422
- };
423
- if (existingIdx >= 0) {
424
- registry.promotions[existingIdx] = promotion;
425
- }
426
- else {
427
- registry.promotions.push(promotion);
428
- }
429
- writeRegistry(stateDir, registry);
430
- return promotion;
431
- });
432
- }
433
- // ---------------------------------------------------------------------------
434
- // Promotion Queries
435
- // ---------------------------------------------------------------------------
436
- /**
437
- * Get the current promotion state for a checkpoint.
438
- */
439
- export function getPromotionState(stateDir, checkpointId) {
440
- const registry = readRegistry(stateDir);
441
- const promotion = registry.promotions.find((p) => p.checkpointId === checkpointId);
442
- return promotion?.state ?? null;
443
- }
444
- /**
445
- * Get the promotion record for a checkpoint.
446
- */
447
- export function getPromotionRecord(stateDir, checkpointId) {
448
- const registry = readRegistry(stateDir);
449
- return registry.promotions.find((p) => p.checkpointId === checkpointId) ?? null;
450
- }
451
- /**
452
- * List promotions by state.
453
- */
454
- export function listPromotionsByState(stateDir, state) {
455
- const registry = readRegistry(stateDir);
456
- return registry.promotions.filter((p) => p.state === state);
457
- }
458
- /**
459
- * List all promotions for a profile.
460
- */
461
- export function listPromotionsForProfile(stateDir, targetProfile) {
462
- const registry = readRegistry(stateDir);
463
- return registry.promotions.filter((p) => p.targetProfile === targetProfile);
464
- }
465
- // ---------------------------------------------------------------------------
466
- // Rollback Support
467
- // ---------------------------------------------------------------------------
468
- /**
469
- * Reject a checkpoint, preventing it from being promoted.
470
- *
471
- * @param stateDir - Workspace state directory
472
- * @param checkpointId - Checkpoint to reject
473
- * @param reason - Reason for rejection
474
- * @returns The updated PromotionRecord
475
- */
476
- export function rejectCheckpoint(stateDir, checkpointId, reason) {
477
- return withPromotionRegistryLock(stateDir, (registry) => {
478
- const now = new Date().toISOString();
479
- const existingIdx = registry.promotions.findIndex((p) => p.checkpointId === checkpointId);
480
- const checkpoint = getCheckpoint(stateDir, checkpointId);
481
- const promotion = {
482
- promotionId: existingIdx >= 0
483
- ? registry.promotions[existingIdx].promotionId
484
- : crypto.randomUUID(),
485
- checkpointId,
486
- state: 'rejected',
487
- targetProfile: 'local-reader', // Default, should be overridden
488
- targetModelFamily: checkpoint?.targetModelFamily ?? 'unknown',
489
- reducedPromptDelta: 0,
490
- constraintMetrics: {
491
- arbiterRejectRate: 1,
492
- executabilityRejectRate: 1,
493
- reviewedSubsetQuality: 0,
494
- routingScopeNotExpanded: true,
495
- },
496
- baselineMetrics: {
497
- arbiterRejectRate: 0,
498
- executabilityRejectRate: 0,
499
- reviewedSubsetQuality: 0,
500
- },
501
- orchestratorReviewPassed: false,
502
- reviewNote: reason,
503
- stateChangedAt: now,
504
- createdAt: existingIdx >= 0
505
- ? registry.promotions[existingIdx].createdAt
506
- : now,
507
- };
508
- if (existingIdx >= 0) {
509
- registry.promotions[existingIdx] = promotion;
510
- }
511
- else {
512
- registry.promotions.push(promotion);
513
- }
514
- writeRegistry(stateDir, registry);
515
- return promotion;
516
- });
517
- }
518
- // ---------------------------------------------------------------------------
519
- // Default Baseline Metrics
520
- // ---------------------------------------------------------------------------
521
- /**
522
- * Default baseline metrics for Phase 7.
523
- * These represent the "acceptable" thresholds that new checkpoints must meet.
524
- */
525
- export const DEFAULT_BASELINE_METRICS = {
526
- arbiterRejectRate: 0.15, // 15% max arbiter rejection
527
- executabilityRejectRate: 0.10, // 10% max executability rejection
528
- reviewedSubsetQuality: 0.70, // 70% minimum quality score
529
- };
@@ -1,22 +0,0 @@
1
- export type RiskLevel = 'LOW' | 'MEDIUM' | 'HIGH' | 'CRITICAL';
2
- export interface FileModification {
3
- toolName: string;
4
- params: any;
5
- }
6
- export declare function estimateLineChanges(modification: FileModification): number;
7
- export declare function assessRiskLevel(filePath: string, modification: FileModification, riskPaths: string[]): RiskLevel;
8
- /**
9
- * Get the total line count of a target file.
10
- * @param absoluteFilePath - Absolute path to the file
11
- * @returns File line count, or null if file doesn't exist or can't be read
12
- */
13
- export declare function getTargetFileLineCount(absoluteFilePath: string): number | null;
14
- /**
15
- * Calculate the effective line limit based on percentage of target file.
16
- * @param targetLineCount - Total lines in target file
17
- * @param percentage - Allowed percentage (0-100)
18
- * @param minLines - Absolute minimum threshold
19
- * @param maxLines - Optional upper bound to prevent misconfiguration
20
- * @returns Maximum allowed lines (at least minLines, at most maxLines if provided)
21
- */
22
- export declare function calculatePercentageThreshold(targetLineCount: number, percentage: number, minLines: number, maxLines?: number): number;
@@ -1,101 +0,0 @@
1
- import { PainConfig } from './config.js';
2
- export interface TokenUsage {
3
- input?: number;
4
- output?: number;
5
- cacheRead?: number;
6
- cacheWrite?: number;
7
- total?: number;
8
- }
9
- export interface SessionState {
10
- sessionId: string;
11
- sessionKey?: string;
12
- trigger?: string;
13
- workspaceDir?: string;
14
- toolReadsByFile: Record<string, number>;
15
- llmTurns: number;
16
- blockedAttempts: number;
17
- lastActivityAt: number;
18
- lastControlActivityAt: number;
19
- totalInputTokens: number;
20
- totalOutputTokens: number;
21
- cacheHits: number;
22
- stuckLoops: number;
23
- currentGfi: number;
24
- gfiBySource?: Record<string, number>;
25
- lastErrorSource?: string;
26
- lastErrorHash: string;
27
- consecutiveErrors: number;
28
- dailyToolCalls: number;
29
- dailyToolFailures: number;
30
- dailyPainSignals: number;
31
- dailyGfiPeak: number;
32
- lastThinkingTimestamp: number;
33
- injectedProbationIds?: string[];
34
- }
35
- /**
36
- * Initialize persistence for session state.
37
- * Call this once during plugin startup.
38
- */
39
- export declare function initPersistence(stateDir: string): void;
40
- /**
41
- * Force persist all sessions immediately.
42
- */
43
- export declare function flushAllSessions(): void;
44
- export declare function trackToolRead(sessionId: string, filePath: string, workspaceDir?: string): SessionState;
45
- export declare function trackLlmOutput(sessionId: string, usage: TokenUsage | undefined, config?: PainConfig, workspaceDir?: string, sessionKey?: string, trigger?: string): SessionState;
46
- /**
47
- * Tracks physical friction based on tool execution failures.
48
- */
49
- export declare function trackFriction(sessionId: string, deltaF: number, hash: string, workspaceDir?: string, options?: {
50
- source?: string;
51
- }): SessionState;
52
- /**
53
- * Resets the friction index upon successful action.
54
- */
55
- export declare function resetFriction(sessionId: string, workspaceDir?: string, options?: {
56
- source?: string;
57
- amount?: number;
58
- }): SessionState;
59
- /**
60
- * Records that deep thinking (Thinking OS) was performed in this session.
61
- * Used by the Thinking OS checkpoint to allow high-risk operations.
62
- */
63
- export declare function recordThinkingCheckpoint(sessionId: string, workspaceDir?: string): SessionState;
64
- /**
65
- * Checks if deep thinking was performed recently (within the given window).
66
- * @param sessionId - The session to check
67
- * @param windowMs - How recent the thinking must be (default: 5 minutes)
68
- * @returns true if thinking was recorded within the window
69
- */
70
- export declare function hasRecentThinking(sessionId: string, windowMs?: number): boolean;
71
- export declare function trackBlock(sessionId: string): SessionState;
72
- export declare function setInjectedProbationIds(sessionId: string, ids: string[], workspaceDir?: string): SessionState;
73
- export declare function getInjectedProbationIds(sessionId: string, workspaceDir?: string): string[];
74
- export declare function clearInjectedProbationIds(sessionId: string, workspaceDir?: string): SessionState;
75
- export declare function getSession(sessionId: string): SessionState | undefined;
76
- export declare function listSessions(workspaceDir?: string): SessionState[];
77
- export declare function clearSession(sessionId: string): void;
78
- /**
79
- * Seed a session directly into SessionTracker.sessions for testing.
80
- * This bypasses the normal tool-call flow to set up test data for
81
- * checkWorkspaceIdle without requiring full integration test setup.
82
- *
83
- * @param sessionId - Session ID
84
- * @param workspaceDir - Workspace directory (optional, for filtering)
85
- * @param lastActivityAt - Unix timestamp in ms (default: now)
86
- */
87
- export declare function seedSessionForTest(sessionId: string, workspaceDir?: string, lastActivityAt?: number): void;
88
- export declare function garbageCollectSessions(): void;
89
- /**
90
- * Get daily statistics summary for a session.
91
- */
92
- export declare function getDailySummary(sessionId: string): {
93
- toolCalls: number;
94
- toolFailures: number;
95
- painSignals: number;
96
- gfiPeak: number;
97
- } | null;
98
- /**
99
- * Reset daily statistics (call at midnight or on new day).
100
- */
101
- export declare function resetDailyStats(sessionId: string): void;