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,210 +0,0 @@
1
- export const PROFILE_AUDIT_LEVELS = new Set(["low", "medium", "high"]);
2
- export const PROFILE_EVOLUTION_MODES = new Set(["realtime", "async"]);
3
- export const PROFILE_TEST_LEVELS = new Set(["smoke", "unit", "full"]);
4
- export const PROFILE_DEFAULTS = {
5
- audit_level: "medium",
6
- risk_paths: [],
7
- evolution_mode: "realtime",
8
- gate: {
9
- require_plan_for_risk_paths: true,
10
- require_audit_before_write: true,
11
- require_reviewer_after_write: true,
12
- },
13
- tests: {
14
- on_change: "smoke",
15
- on_risk_change: "unit",
16
- commands: {},
17
- },
18
- pain: {
19
- soft_capture_threshold: 30,
20
- adaptive: {
21
- enabled: true,
22
- spiral_boost: 20,
23
- min_threshold: 15,
24
- max_threshold: 70,
25
- backlog_trigger: 6,
26
- hard_failure_trigger: 1,
27
- low_recent_success_boost: 15,
28
- high_recent_pain_boost: 10,
29
- },
30
- },
31
- lifecycle: {
32
- enabled: true,
33
- heartbeat_stale_hours: 72,
34
- },
35
- progressive_gate: {
36
- enabled: true,
37
- plan_approvals: {
38
- enabled: false,
39
- max_lines_override: -1,
40
- allowed_patterns: [],
41
- allowed_operations: [],
42
- },
43
- },
44
- edit_verification: {
45
- enabled: true,
46
- max_file_size_bytes: 10 * 1024 * 1024, // 10MB
47
- fuzzy_match_enabled: true,
48
- fuzzy_match_threshold: 0.8,
49
- skip_large_file_action: "warn", // "warn" or "block"
50
- },
51
- thinking_checkpoint: {
52
- enabled: false, // Default OFF to avoid blocking new users
53
- window_ms: 5 * 60 * 1000, // 5 minute window
54
- high_risk_tools: ['run_shell_command', 'delete_file', 'move_file'],
55
- },
56
- custom_guards: [],
57
- };
58
- export function normalizeProfile(rawProfile) {
59
- const defaults = JSON.parse(JSON.stringify(PROFILE_DEFAULTS));
60
- const warnings = [];
61
- const normalized = { ...defaults };
62
- let invalid = false;
63
- if (!rawProfile || typeof rawProfile !== "object" || Array.isArray(rawProfile)) {
64
- warnings.push("PROFILE root must be an object; defaults applied.");
65
- invalid = true;
66
- }
67
- else {
68
- // Merge known fields (Support both snake_case and camelCase)
69
- const auditLevel = rawProfile.audit_level ?? rawProfile.auditLevel;
70
- if (PROFILE_AUDIT_LEVELS.has(auditLevel)) {
71
- normalized.audit_level = auditLevel;
72
- }
73
- else if (auditLevel !== undefined) {
74
- warnings.push(`Invalid audit_level '${auditLevel}'`);
75
- }
76
- const evolutionMode = rawProfile.evolution_mode ?? rawProfile.evolutionMode;
77
- if (PROFILE_EVOLUTION_MODES.has(evolutionMode)) {
78
- normalized.evolution_mode = evolutionMode;
79
- }
80
- else if (evolutionMode !== undefined) {
81
- warnings.push(`Invalid evolution_mode '${evolutionMode}'`);
82
- }
83
- const riskPaths = rawProfile.risk_paths ?? rawProfile.riskPaths;
84
- if (Array.isArray(riskPaths)) {
85
- normalized.risk_paths = riskPaths.filter((p) => typeof p === 'string');
86
- }
87
- else if (typeof riskPaths === 'string') {
88
- normalized.risk_paths = [riskPaths];
89
- }
90
- else if (riskPaths !== undefined) {
91
- warnings.push("risk_paths must be an array of strings");
92
- }
93
- // Gate settings
94
- if (rawProfile.gate && typeof rawProfile.gate === 'object') {
95
- const g = rawProfile.gate;
96
- normalized.gate.require_plan_for_risk_paths = g.require_plan_for_risk_paths ?? g.requirePlanForRiskPaths ?? defaults.gate.require_plan_for_risk_paths;
97
- normalized.gate.require_audit_before_write = g.require_audit_before_write ?? g.requireAuditBeforeWrite ?? defaults.gate.require_audit_before_write;
98
- normalized.gate.require_reviewer_after_write = g.require_reviewer_after_write ?? g.requireReviewerAfterWrite ?? defaults.gate.require_reviewer_after_write;
99
- }
100
- // Progressive Gate
101
- if (rawProfile.progressive_gate && typeof rawProfile.progressive_gate === 'object') {
102
- const pg = rawProfile.progressive_gate;
103
- normalized.progressive_gate.enabled = pg.enabled ?? pg.enabled ?? defaults.progressive_gate.enabled;
104
- // Plan approvals configuration
105
- if (pg.plan_approvals && typeof pg.plan_approvals === 'object') {
106
- const pa = pg.plan_approvals;
107
- normalized.progressive_gate.plan_approvals.enabled = pa.enabled ?? pa.planApprovals ?? defaults.progressive_gate.plan_approvals.enabled;
108
- const maxLines = pa.max_lines_override ?? pa.maxLinesOverride;
109
- if (typeof maxLines === 'number' && maxLines >= -1) {
110
- normalized.progressive_gate.plan_approvals.max_lines_override = maxLines;
111
- }
112
- if (Array.isArray(pa.allowed_patterns)) {
113
- normalized.progressive_gate.plan_approvals.allowed_patterns = pa.allowed_patterns.filter((p) => typeof p === 'string');
114
- }
115
- if (Array.isArray(pa.allowed_operations)) {
116
- normalized.progressive_gate.plan_approvals.allowed_operations = pa.allowed_operations.filter((o) => typeof o === 'string');
117
- }
118
- }
119
- }
120
- else if (rawProfile.progressiveGate && typeof rawProfile.progressiveGate === 'object') {
121
- const pg = rawProfile.progressiveGate;
122
- normalized.progressive_gate.enabled = pg.enabled ?? defaults.progressive_gate.enabled;
123
- // Plan approvals configuration (camelCase)
124
- if (pg.planApprovals && typeof pg.planApprovals === 'object') {
125
- const pa = pg.planApprovals;
126
- normalized.progressive_gate.plan_approvals.enabled = pa.enabled ?? defaults.progressive_gate.plan_approvals.enabled;
127
- const maxLines = pa.maxLinesOverride;
128
- if (typeof maxLines === 'number' && maxLines >= -1) {
129
- normalized.progressive_gate.plan_approvals.max_lines_override = maxLines;
130
- }
131
- if (Array.isArray(pa.allowedPatterns)) {
132
- normalized.progressive_gate.plan_approvals.allowed_patterns = pa.allowedPatterns.filter((p) => typeof p === 'string');
133
- }
134
- if (Array.isArray(pa.allowedOperations)) {
135
- normalized.progressive_gate.plan_approvals.allowed_operations = pa.allowedOperations.filter((o) => typeof o === 'string');
136
- }
137
- }
138
- }
139
- // Edit verification settings (P-03)
140
- const evRaw = rawProfile.edit_verification ?? rawProfile.editVerification;
141
- if (evRaw && typeof evRaw === 'object') {
142
- normalized.edit_verification.enabled = evRaw.enabled ?? defaults.edit_verification.enabled;
143
- const maxSize = evRaw.max_file_size_bytes ?? evRaw.maxFileSizeBytes;
144
- if (typeof maxSize === 'number' && maxSize >= 0) {
145
- normalized.edit_verification.max_file_size_bytes = maxSize;
146
- }
147
- normalized.edit_verification.fuzzy_match_enabled = evRaw.fuzzy_match_enabled ?? evRaw.fuzzyMatchEnabled ?? defaults.edit_verification.fuzzy_match_enabled;
148
- const threshold = evRaw.fuzzy_match_threshold ?? evRaw.fuzzyMatchThreshold;
149
- if (typeof threshold === 'number' && threshold > 0 && threshold <= 1) {
150
- normalized.edit_verification.fuzzy_match_threshold = threshold;
151
- }
152
- const action = evRaw.skip_large_file_action ?? evRaw.skipLargeFileAction;
153
- if (typeof action === 'string' && ['warn', 'block'].includes(action)) {
154
- normalized.edit_verification.skip_large_file_action = action;
155
- }
156
- }
157
- // Test settings
158
- if (rawProfile.tests && typeof rawProfile.tests === 'object') {
159
- const t = rawProfile.tests;
160
- const onChange = t.on_change ?? t.onChange;
161
- if (PROFILE_TEST_LEVELS.has(onChange)) {
162
- normalized.tests.on_change = onChange;
163
- }
164
- const onRiskChange = t.on_risk_change ?? t.onRiskChange;
165
- if (PROFILE_TEST_LEVELS.has(onRiskChange)) {
166
- normalized.tests.on_risk_change = onRiskChange;
167
- }
168
- if (t.commands && typeof t.commands === 'object') {
169
- normalized.tests.commands = { ...defaults.tests.commands, ...t.commands };
170
- }
171
- }
172
- // Pain settings
173
- if (rawProfile.pain && typeof rawProfile.pain === 'object') {
174
- const p = rawProfile.pain;
175
- normalized.pain.soft_capture_threshold = p.soft_capture_threshold ?? p.softCaptureThreshold ?? defaults.pain.soft_capture_threshold;
176
- if (p.adaptive && typeof p.adaptive === 'object') {
177
- normalized.pain.adaptive = { ...defaults.pain.adaptive, ...p.adaptive };
178
- }
179
- }
180
- // Thinking OS Checkpoint settings (P-10)
181
- const tcRaw = rawProfile.thinking_checkpoint ?? rawProfile.thinkingCheckpoint;
182
- if (tcRaw && typeof tcRaw === 'object') {
183
- normalized.thinking_checkpoint.enabled = tcRaw.enabled ?? defaults.thinking_checkpoint.enabled;
184
- const windowMs = tcRaw.window_ms ?? tcRaw.windowMs;
185
- if (typeof windowMs === 'number' && windowMs > 0) {
186
- normalized.thinking_checkpoint.window_ms = windowMs;
187
- }
188
- if (Array.isArray(tcRaw.high_risk_tools ?? tcRaw.highRiskTools)) {
189
- normalized.thinking_checkpoint.high_risk_tools = (tcRaw.high_risk_tools ?? tcRaw.highRiskTools).filter((t) => typeof t === 'string');
190
- }
191
- }
192
- if (Array.isArray(rawProfile.custom_guards)) {
193
- normalized.custom_guards = rawProfile.custom_guards.map((item) => {
194
- let severity = "error";
195
- const itemSeverity = item.severity;
196
- if (itemSeverity && ["info", "warning", "error", "fatal"].includes(String(itemSeverity).toLowerCase())) {
197
- severity = String(itemSeverity).toLowerCase();
198
- }
199
- return {
200
- pattern: String(item.pattern || ""),
201
- message: String(item.message || "Custom guard triggered"),
202
- severity,
203
- };
204
- }).filter((item) => item.pattern);
205
- }
206
- }
207
- normalized._profile_invalid = invalid;
208
- normalized._profile_warnings = warnings;
209
- return normalized;
210
- }
@@ -1,238 +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 { type TrainableWorkerProfile } from './external-training-contract.js';
43
- /**
44
- * Candidate delta must exceed this to enter shadow_ready.
45
- */
46
- export declare const DEFAULT_MIN_DELTA = 0.05;
47
- /**
48
- * Default allowed margin for constraint metrics.
49
- * Constraint metrics can regress by at most this amount.
50
- */
51
- export declare const DEFAULT_ALLOWED_MARGIN = 0.05;
52
- /**
53
- * Minimum shadow window duration in milliseconds.
54
- * A checkpoint must remain in shadow_ready for at least this duration
55
- * before it can be promoted to promotable.
56
- *
57
- * Phase 7 default: 1 hour (3600000 ms)
58
- * This gives time for real-world feedback before full promotion.
59
- */
60
- export declare const MIN_SHADOW_WINDOW_MS: number;
61
- /**
62
- * Promotion states for a checkpoint.
63
- */
64
- export type PromotionState = 'rejected' | 'candidate_only' | 'shadow_ready' | 'promotable';
65
- /**
66
- * Constraint metrics for promotion gate.
67
- */
68
- export interface PromotionConstraints {
69
- arbiterRejectRate: number;
70
- executabilityRejectRate: number;
71
- reviewedSubsetQuality: number;
72
- routingScopeNotExpanded: boolean;
73
- }
74
- /**
75
- * Baseline metrics for comparison.
76
- */
77
- export interface BaselineMetrics {
78
- arbiterRejectRate: number;
79
- executabilityRejectRate: number;
80
- reviewedSubsetQuality: number;
81
- }
82
- /**
83
- * A promotion record — tracks the state and lineage of a promoted checkpoint.
84
- */
85
- export interface PromotionRecord {
86
- /** Unique identifier for this promotion record */
87
- promotionId: string;
88
- /** Checkpoint being promoted */
89
- checkpointId: string;
90
- /** Current promotion state */
91
- state: PromotionState;
92
- /** Worker profile this promotion targets */
93
- targetProfile: TrainableWorkerProfile;
94
- /** Target model family */
95
- targetModelFamily: string;
96
- /** Reduced-prompt holdout delta (primary objective) */
97
- reducedPromptDelta: number;
98
- /** Constraint metrics at time of promotion */
99
- constraintMetrics: PromotionConstraints;
100
- /** Baseline metrics used for comparison */
101
- baselineMetrics: BaselineMetrics;
102
- /** Whether orchestrator review was passed */
103
- orchestratorReviewPassed: boolean;
104
- /** Human review note (if any) */
105
- reviewNote?: string;
106
- /** ISO-8601 timestamp when state last changed */
107
- stateChangedAt: string;
108
- /** ISO-8601 timestamp when promotion record was created */
109
- createdAt: string;
110
- /** ISO-8601 timestamp when shadow window opened (if applicable) */
111
- shadowStartedAt?: string;
112
- /** ISO-8601 timestamp when promotable was achieved */
113
- promotableAt?: string;
114
- /** Previous promotion record ID (for rollback chain) */
115
- previousPromotionId?: string;
116
- }
117
- /**
118
- * The complete promotion registry.
119
- */
120
- export interface PromotionRegistry {
121
- promotions: PromotionRecord[];
122
- }
123
- /**
124
- * Result of evaluating the promotion gate.
125
- */
126
- export interface PromotionGateResult {
127
- /** Whether the checkpoint passes the gate */
128
- passes: boolean;
129
- /** The promotion state if passed */
130
- suggestedState?: PromotionState;
131
- /** Reasons for rejection (if not passed) */
132
- blockers: string[];
133
- /** Details about each constraint check */
134
- constraintChecks: {
135
- constraint: string;
136
- actual: number;
137
- baseline: number;
138
- threshold: number;
139
- passed: boolean;
140
- /** Source of the evidence: 'shadow' (real runtime) or 'eval-proxy' (fallback) */
141
- source?: 'shadow' | 'eval-proxy';
142
- }[];
143
- /** Primary objective (delta) check */
144
- deltaCheck: {
145
- actual: number;
146
- threshold: number;
147
- passed: boolean;
148
- };
149
- }
150
- /**
151
- * Parameters for evaluating the promotion gate.
152
- */
153
- export interface EvaluateGateParams {
154
- /** Checkpoint ID to evaluate */
155
- checkpointId: string;
156
- /** Target worker profile */
157
- targetProfile: TrainableWorkerProfile;
158
- /** Baseline metrics for comparison */
159
- baselineMetrics: BaselineMetrics;
160
- /** Minimum delta threshold for positive signal */
161
- minDelta?: number;
162
- /** Allowed margin for constraint metrics */
163
- allowedMargin?: number;
164
- }
165
- /**
166
- * Evaluate whether a checkpoint passes the promotion gate.
167
- *
168
- * @param stateDir - Workspace state directory
169
- * @param params - Evaluation parameters
170
- * @returns PromotionGateResult with pass/fail and details
171
- *
172
- * FAIL-CLOSED: Returns { passes: false } if:
173
- * - No eval attached to checkpoint
174
- * - Delta is negative or below threshold
175
- * - Any constraint metric regresses beyond allowed margin
176
- * - Profile is not in allowed rollout list
177
- */
178
- export declare function evaluatePromotionGate(stateDir: string, params: EvaluateGateParams): PromotionGateResult;
179
- /**
180
- * Parameters for advancing promotion state.
181
- */
182
- export interface AdvancePromotionParams {
183
- /** Checkpoint ID to promote */
184
- checkpointId: string;
185
- /** Target worker profile */
186
- targetProfile: TrainableWorkerProfile;
187
- /** Baseline metrics for comparison */
188
- baselineMetrics: BaselineMetrics;
189
- /** Orchestrator review passed (required for promotable) */
190
- orchestratorReviewPassed?: boolean;
191
- /** Human review note */
192
- reviewNote?: string;
193
- /** Minimum delta threshold */
194
- minDelta?: number;
195
- /** Allowed margin for constraints */
196
- allowedMargin?: number;
197
- }
198
- /**
199
- * Advance a checkpoint's promotion state.
200
- *
201
- * @param stateDir - Workspace state directory
202
- * @param params - Advancement parameters
203
- * @returns The updated PromotionRecord
204
- *
205
- * @throws Error if gate evaluation fails
206
- * @throws Error if state transition is not allowed
207
- */
208
- export declare function advancePromotion(stateDir: string, params: AdvancePromotionParams): PromotionRecord;
209
- /**
210
- * Get the current promotion state for a checkpoint.
211
- */
212
- export declare function getPromotionState(stateDir: string, checkpointId: string): PromotionState | null;
213
- /**
214
- * Get the promotion record for a checkpoint.
215
- */
216
- export declare function getPromotionRecord(stateDir: string, checkpointId: string): PromotionRecord | null;
217
- /**
218
- * List promotions by state.
219
- */
220
- export declare function listPromotionsByState(stateDir: string, state: PromotionState): PromotionRecord[];
221
- /**
222
- * List all promotions for a profile.
223
- */
224
- export declare function listPromotionsForProfile(stateDir: string, targetProfile: TrainableWorkerProfile): PromotionRecord[];
225
- /**
226
- * Reject a checkpoint, preventing it from being promoted.
227
- *
228
- * @param stateDir - Workspace state directory
229
- * @param checkpointId - Checkpoint to reject
230
- * @param reason - Reason for rejection
231
- * @returns The updated PromotionRecord
232
- */
233
- export declare function rejectCheckpoint(stateDir: string, checkpointId: string, reason: string): PromotionRecord;
234
- /**
235
- * Default baseline metrics for Phase 7.
236
- * These represent the "acceptable" thresholds that new checkpoints must meet.
237
- */
238
- export declare const DEFAULT_BASELINE_METRICS: BaselineMetrics;