principles-disciple 1.8.0 → 1.8.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/ADVANCED_CONFIG_ZH.md +97 -0
- package/AGENT_INSTALL.md +173 -0
- package/AGENT_INSTALL_EN.md +173 -0
- package/INSTALL.md +256 -0
- package/SKILL.md +63 -0
- package/docs/COMMAND_REFERENCE.md +76 -0
- package/docs/COMMAND_REFERENCE_EN.md +79 -0
- package/esbuild.config.js +75 -0
- package/openclaw.plugin.json +6 -1
- package/package.json +13 -15
- package/scripts/build-web.mjs +46 -0
- package/scripts/install-dependencies.cjs +47 -0
- package/scripts/sync-plugin.mjs +802 -0
- package/scripts/verify-build.mjs +109 -0
- package/src/agents/nocturnal-dreamer.md +152 -0
- package/src/agents/nocturnal-philosopher.md +138 -0
- package/src/agents/nocturnal-reflector.md +126 -0
- package/src/agents/nocturnal-scribe.md +164 -0
- package/src/commands/capabilities.ts +85 -0
- package/{dist/commands/context.js → src/commands/context.ts} +78 -38
- package/src/commands/evolution-status.ts +146 -0
- package/src/commands/export.ts +111 -0
- package/src/commands/focus.ts +533 -0
- package/src/commands/nocturnal-review.ts +311 -0
- package/src/commands/nocturnal-rollout.ts +763 -0
- package/src/commands/nocturnal-train.ts +1002 -0
- package/{dist/commands/pain.js → src/commands/pain.ts} +68 -49
- package/src/commands/principle-rollback.ts +27 -0
- package/{dist/commands/rollback.js → src/commands/rollback.ts} +44 -12
- package/src/commands/samples.ts +60 -0
- package/src/commands/strategy.ts +38 -0
- package/{dist/commands/thinking-os.js → src/commands/thinking-os.ts} +59 -36
- package/src/commands/workflow-debug.ts +128 -0
- package/{dist/config/defaults/runtime.js → src/config/defaults/runtime.ts} +12 -5
- package/src/config/errors.ts +163 -0
- package/{dist/config/index.d.ts → src/config/index.ts} +2 -1
- package/src/constants/diagnostician.ts +66 -0
- package/src/constants/tools.ts +62 -0
- package/src/core/adaptive-thresholds.ts +476 -0
- package/{dist/core/config-service.js → src/core/config-service.ts} +7 -4
- package/{dist/core/config.js → src/core/config.ts} +158 -46
- package/src/core/control-ui-db.ts +435 -0
- package/{dist/core/detection-funnel.js → src/core/detection-funnel.ts} +36 -21
- package/{dist/core/detection-service.js → src/core/detection-service.ts} +7 -4
- package/{dist/core/dictionary-service.js → src/core/dictionary-service.ts} +7 -4
- package/{dist/core/dictionary.js → src/core/dictionary.ts} +57 -34
- package/src/core/empathy-keyword-matcher.ts +327 -0
- package/src/core/empathy-types.ts +218 -0
- package/src/core/event-log.ts +544 -0
- package/src/core/evolution-engine.ts +612 -0
- package/src/core/evolution-logger.ts +353 -0
- package/src/core/evolution-migration.ts +77 -0
- package/src/core/evolution-reducer.ts +731 -0
- package/src/core/evolution-types.ts +456 -0
- package/src/core/external-training-contract.ts +527 -0
- package/src/core/focus-history.ts +1458 -0
- package/src/core/hygiene/tracker.ts +117 -0
- package/{dist/core/init.js → src/core/init.ts} +39 -26
- package/src/core/local-worker-routing.ts +617 -0
- package/{dist/core/migration.js → src/core/migration.ts} +18 -11
- package/src/core/model-deployment-registry.ts +722 -0
- package/src/core/model-training-registry.ts +813 -0
- package/src/core/nocturnal-arbiter.ts +706 -0
- package/src/core/nocturnal-candidate-scoring.ts +392 -0
- package/src/core/nocturnal-compliance.ts +1075 -0
- package/src/core/nocturnal-dataset.ts +668 -0
- package/src/core/nocturnal-executability.ts +428 -0
- package/src/core/nocturnal-export.ts +390 -0
- package/{dist/core/nocturnal-paths.js → src/core/nocturnal-paths.ts} +49 -23
- package/src/core/nocturnal-trajectory-extractor.ts +484 -0
- package/src/core/nocturnal-trinity.ts +1384 -0
- package/src/core/pain.ts +122 -0
- package/{dist/core/path-resolver.js → src/core/path-resolver.ts} +157 -36
- package/{dist/core/paths.js → src/core/paths.ts} +13 -4
- package/src/core/principle-training-state.ts +450 -0
- package/src/core/profile.ts +226 -0
- package/src/core/promotion-gate.ts +822 -0
- package/{dist/core/risk-calculator.js → src/core/risk-calculator.ts} +42 -16
- package/{dist/core/session-tracker.js → src/core/session-tracker.ts} +185 -63
- package/src/core/shadow-observation-registry.ts +534 -0
- package/{dist/core/system-logger.js → src/core/system-logger.ts} +9 -5
- package/src/core/thinking-models.ts +217 -0
- package/src/core/training-program.ts +630 -0
- package/src/core/trajectory-types.ts +243 -0
- package/src/core/trajectory.ts +1673 -0
- package/{dist/core/workspace-context.js → src/core/workspace-context.ts} +57 -32
- package/src/hooks/bash-risk.ts +171 -0
- package/src/hooks/edit-verification.ts +295 -0
- package/src/hooks/gate-block-helper.ts +160 -0
- package/src/hooks/gate.ts +210 -0
- package/src/hooks/gfi-gate.ts +177 -0
- package/src/hooks/lifecycle.ts +326 -0
- package/{dist/hooks/llm.js → src/hooks/llm.ts} +166 -139
- package/src/hooks/message-sanitize.ts +45 -0
- package/src/hooks/pain.ts +384 -0
- package/src/hooks/progressive-trust-gate.ts +174 -0
- package/src/hooks/prompt.ts +920 -0
- package/src/hooks/subagent.ts +207 -0
- package/src/hooks/thinking-checkpoint.ts +73 -0
- package/src/hooks/trajectory-collector.ts +290 -0
- package/src/http/principles-console-route.ts +716 -0
- package/src/i18n/commands.ts +117 -0
- package/src/index.ts +694 -0
- package/src/service/central-database.ts +831 -0
- package/src/service/control-ui-query-service.ts +888 -0
- package/src/service/evolution-query-service.ts +405 -0
- package/src/service/evolution-worker.ts +1646 -0
- package/src/service/health-query-service.ts +836 -0
- package/{dist/service/nocturnal-runtime.js → src/service/nocturnal-runtime.ts} +263 -36
- package/src/service/nocturnal-service.ts +1015 -0
- package/src/service/nocturnal-target-selector.ts +532 -0
- package/src/service/phase3-input-filter.ts +237 -0
- package/src/service/runtime-summary-service.ts +757 -0
- package/src/service/subagent-workflow/deep-reflect-workflow-manager.ts +513 -0
- package/src/service/subagent-workflow/empathy-observer-workflow-manager.ts +603 -0
- package/src/service/subagent-workflow/index.ts +51 -0
- package/src/service/subagent-workflow/nocturnal-workflow-manager.ts +856 -0
- package/src/service/subagent-workflow/runtime-direct-driver.ts +166 -0
- package/src/service/subagent-workflow/types.ts +378 -0
- package/src/service/subagent-workflow/workflow-store.ts +328 -0
- package/src/service/trajectory-service.ts +15 -0
- package/{dist/tools/critique-prompt.js → src/tools/critique-prompt.ts} +25 -8
- package/src/tools/deep-reflect.ts +349 -0
- package/{dist/tools/model-index.js → src/tools/model-index.ts} +33 -17
- package/src/types/event-types.ts +453 -0
- package/src/types/hygiene-types.ts +31 -0
- package/src/types/principle-tree-schema.ts +244 -0
- package/src/types/runtime-summary.ts +49 -0
- package/src/types.ts +74 -0
- package/src/utils/file-lock.ts +391 -0
- package/{dist/utils/glob-match.js → src/utils/glob-match.ts} +21 -20
- package/{dist/utils/hashing.js → src/utils/hashing.ts} +6 -4
- package/src/utils/io.ts +110 -0
- package/{dist/utils/nlp.js → src/utils/nlp.ts} +19 -12
- package/{dist/utils/plugin-logger.js → src/utils/plugin-logger.ts} +33 -8
- package/src/utils/subagent-probe.ts +94 -0
- package/templates/langs/zh/skills/pd-diagnostician/SKILL.md +70 -1
- package/templates/pain_settings.json +2 -1
- package/tests/README.md +120 -0
- package/tests/build-artifacts.test.ts +111 -0
- package/tests/commands/evolution-status.test.ts +222 -0
- package/tests/commands/evolver.test.ts +22 -0
- package/tests/commands/export.test.ts +78 -0
- package/tests/commands/nocturnal-review.test.ts +448 -0
- package/tests/commands/nocturnal-train.test.ts +97 -0
- package/tests/commands/pain.test.ts +108 -0
- package/tests/commands/samples.test.ts +65 -0
- package/tests/commands/strategy.test.ts +34 -0
- package/tests/commands/thinking-os.test.ts +88 -0
- package/tests/core/adaptive-thresholds.test.ts +261 -0
- package/tests/core/config-service.test.ts +89 -0
- package/tests/core/config.test.ts +90 -0
- package/tests/core/control-ui-db.test.ts +75 -0
- package/tests/core/core-template-guidance.test.ts +21 -0
- package/tests/core/detection-funnel.test.ts +63 -0
- package/tests/core/detection-service.test.ts +50 -0
- package/tests/core/dictionary-service.test.ts +116 -0
- package/tests/core/dictionary.test.ts +168 -0
- package/tests/core/empathy-keyword-matcher.test.ts +209 -0
- package/tests/core/event-log.test.ts +181 -0
- package/tests/core/evolution-e2e.test.ts +58 -0
- package/tests/core/evolution-engine-gate-integration.test.ts +543 -0
- package/tests/core/evolution-engine.test.ts +562 -0
- package/tests/core/evolution-logger.test.ts +148 -0
- package/tests/core/evolution-migration.test.ts +50 -0
- package/tests/core/evolution-paths.test.ts +21 -0
- package/tests/core/evolution-reducer.detector-metadata.test.ts +602 -0
- package/tests/core/evolution-reducer.test.ts +180 -0
- package/tests/core/evolution-types-loop.test.ts +48 -0
- package/tests/core/evolution-user-stories.e2e.test.ts +249 -0
- package/tests/core/external-training-contract.test.ts +463 -0
- package/tests/core/focus-history.test.ts +682 -0
- package/tests/core/init-flatten.test.ts +69 -0
- package/tests/core/init-refactor.test.ts +87 -0
- package/tests/core/init-v1.3.test.ts +46 -0
- package/tests/core/init.test.ts +190 -0
- package/tests/core/local-worker-routing.test.ts +757 -0
- package/tests/core/migration.test.ts +84 -0
- package/tests/core/model-deployment-registry.test.ts +845 -0
- package/tests/core/model-training-registry.test.ts +889 -0
- package/tests/core/nocturnal-arbiter.test.ts +494 -0
- package/tests/core/nocturnal-candidate-scoring.test.ts +400 -0
- package/tests/core/nocturnal-compliance.test.ts +646 -0
- package/tests/core/nocturnal-dataset.test.ts +892 -0
- package/tests/core/nocturnal-executability.test.ts +357 -0
- package/tests/core/nocturnal-export.test.ts +462 -0
- package/tests/core/nocturnal-reviewed-subset-comparison.test.ts +428 -0
- package/tests/core/nocturnal-trajectory-extractor.test.ts +634 -0
- package/tests/core/nocturnal-trinity.test.ts +953 -0
- package/tests/core/pain.test.ts +33 -0
- package/tests/core/path-resolver.test.ts +57 -0
- package/tests/core/paths-refactor.test.ts +42 -0
- package/tests/core/phase7-rollout-integration.test.ts +477 -0
- package/tests/core/principle-training-state.test.ts +712 -0
- package/tests/core/profile.test.ts +56 -0
- package/tests/core/promotion-gate.test.ts +556 -0
- package/tests/core/risk-calculator.test.ts +168 -0
- package/tests/core/session-tracker.test.ts +191 -0
- package/tests/core/training-program.test.ts +472 -0
- package/tests/core/trajectory.test.ts +265 -0
- package/tests/core/workspace-context-factory.test.ts +18 -0
- package/tests/core/workspace-context.test.ts +134 -0
- package/tests/fixtures/nocturnal-reviewed-subset.json +183 -0
- package/tests/fixtures/production-compatibility.test.ts +147 -0
- package/tests/fixtures/production-mock-generator.ts +282 -0
- package/tests/hooks/bash-risk-integration.test.ts +137 -0
- package/tests/hooks/bash-risk.test.ts +81 -0
- package/tests/hooks/edit-verification.test.ts +678 -0
- package/tests/hooks/gate-edit-verification-p1.test.ts +632 -0
- package/tests/hooks/gate-edit-verification.test.ts +435 -0
- package/tests/hooks/gate-pipeline-integration.test.ts +404 -0
- package/tests/hooks/gate.test.ts +271 -0
- package/tests/hooks/gfi-gate-unit.test.ts +422 -0
- package/tests/hooks/gfi-gate.test.ts +669 -0
- package/tests/hooks/lifecycle.test.ts +248 -0
- package/tests/hooks/llm.test.ts +308 -0
- package/tests/hooks/message-sanitize.test.ts +36 -0
- package/tests/hooks/pain.test.ts +141 -0
- package/tests/hooks/progressive-trust-gate.test.ts +277 -0
- package/tests/hooks/prompt.test.ts +1411 -0
- package/tests/hooks/subagent.test.ts +467 -0
- package/tests/hooks/thinking-gate.test.ts +313 -0
- package/tests/http/principles-console-route.test.ts +140 -0
- package/tests/hygiene-tracker.test.ts +77 -0
- package/tests/index.integration.test.ts +179 -0
- package/tests/index.shadow-routing.integration.test.ts +140 -0
- package/tests/index.test.ts +9 -0
- package/tests/integration/empathy-workflow-integration.test.ts +627 -0
- package/tests/service/control-ui-query-service.test.ts +121 -0
- package/tests/service/empathy-observer-workflow-manager.test.ts +176 -0
- package/tests/service/evolution-worker.test.ts +585 -0
- package/tests/service/nocturnal-runtime.test.ts +470 -0
- package/tests/service/nocturnal-service.test.ts +577 -0
- package/tests/service/nocturnal-target-selector.test.ts +615 -0
- package/tests/service/nocturnal-workflow-manager.test.ts +439 -0
- package/tests/service/phase3-input-filter.test.ts +289 -0
- package/tests/service/runtime-summary-service.test.ts +919 -0
- package/tests/task-compliance.test.ts +166 -0
- package/tests/test-utils.ts +48 -0
- package/tests/tools/critique-prompt.test.ts +260 -0
- package/tests/tools/deep-reflect.test.ts +232 -0
- package/tests/tools/model-index.test.ts +246 -0
- package/tests/ui/app.test.tsx +114 -0
- package/tests/utils/file-lock.test.ts +407 -0
- package/tests/utils/hashing.test.ts +32 -0
- package/tests/utils/io.test.ts +39 -0
- package/tests/utils/nlp.test.ts +53 -0
- package/tests/utils/plugin-logger.test.ts +156 -0
- package/tsconfig.json +16 -0
- package/tsconfig.tsbuildinfo +1 -0
- package/ui/src/App.tsx +45 -0
- package/ui/src/api.ts +216 -0
- package/ui/src/charts.tsx +586 -0
- package/ui/src/components/ErrorState.tsx +6 -0
- package/ui/src/components/Loading.tsx +13 -0
- package/ui/src/components/ProtectedRoute.tsx +12 -0
- package/ui/src/components/Shell.tsx +91 -0
- package/ui/src/components/WorkspaceConfig.tsx +146 -0
- package/ui/src/components/index.ts +5 -0
- package/ui/src/context/auth.tsx +80 -0
- package/ui/src/context/theme.tsx +66 -0
- package/ui/src/hooks/useAutoRefresh.ts +39 -0
- package/ui/src/i18n/ui.ts +363 -0
- package/ui/src/main.tsx +16 -0
- package/ui/src/pages/EvolutionPage.tsx +352 -0
- package/ui/src/pages/FeedbackPage.tsx +140 -0
- package/ui/src/pages/GateMonitorPage.tsx +136 -0
- package/ui/src/pages/LoginPage.tsx +88 -0
- package/ui/src/pages/OverviewPage.tsx +238 -0
- package/ui/src/pages/SamplesPage.tsx +174 -0
- package/ui/src/pages/ThinkingModelsPage.tsx +127 -0
- package/ui/src/styles.css +1661 -0
- package/ui/src/types.ts +368 -0
- package/ui/src/utils/format.ts +15 -0
- package/vitest.config.ts +23 -0
- package/dist/commands/capabilities.d.ts +0 -3
- package/dist/commands/capabilities.js +0 -73
- package/dist/commands/context.d.ts +0 -5
- package/dist/commands/evolution-status.d.ts +0 -4
- package/dist/commands/evolution-status.js +0 -117
- package/dist/commands/evolver.d.ts +0 -9
- package/dist/commands/evolver.js +0 -26
- package/dist/commands/export.d.ts +0 -2
- package/dist/commands/export.js +0 -98
- package/dist/commands/focus.d.ts +0 -14
- package/dist/commands/focus.js +0 -457
- package/dist/commands/nocturnal-review.d.ts +0 -24
- package/dist/commands/nocturnal-review.js +0 -265
- package/dist/commands/nocturnal-rollout.d.ts +0 -27
- package/dist/commands/nocturnal-rollout.js +0 -671
- package/dist/commands/nocturnal-train.d.ts +0 -25
- package/dist/commands/nocturnal-train.js +0 -919
- package/dist/commands/pain.d.ts +0 -5
- package/dist/commands/principle-rollback.d.ts +0 -4
- package/dist/commands/principle-rollback.js +0 -22
- package/dist/commands/rollback.d.ts +0 -19
- package/dist/commands/samples.d.ts +0 -2
- package/dist/commands/samples.js +0 -55
- package/dist/commands/strategy.d.ts +0 -3
- package/dist/commands/strategy.js +0 -29
- package/dist/commands/thinking-os.d.ts +0 -2
- package/dist/config/defaults/runtime.d.ts +0 -40
- package/dist/config/errors.d.ts +0 -84
- package/dist/config/errors.js +0 -94
- package/dist/config/index.js +0 -7
- package/dist/constants/diagnostician.d.ts +0 -12
- package/dist/constants/diagnostician.js +0 -56
- package/dist/constants/tools.d.ts +0 -17
- package/dist/constants/tools.js +0 -54
- package/dist/core/adaptive-thresholds.d.ts +0 -186
- package/dist/core/adaptive-thresholds.js +0 -300
- package/dist/core/config-service.d.ts +0 -15
- package/dist/core/config.d.ts +0 -127
- package/dist/core/control-ui-db.d.ts +0 -95
- package/dist/core/control-ui-db.js +0 -292
- package/dist/core/detection-funnel.d.ts +0 -33
- package/dist/core/detection-service.d.ts +0 -15
- package/dist/core/dictionary-service.d.ts +0 -15
- package/dist/core/dictionary.d.ts +0 -38
- package/dist/core/event-log.d.ts +0 -82
- package/dist/core/event-log.js +0 -463
- package/dist/core/evolution-engine.d.ts +0 -118
- package/dist/core/evolution-engine.js +0 -464
- package/dist/core/evolution-logger.d.ts +0 -137
- package/dist/core/evolution-logger.js +0 -256
- package/dist/core/evolution-migration.d.ts +0 -5
- package/dist/core/evolution-migration.js +0 -65
- package/dist/core/evolution-reducer.d.ts +0 -98
- package/dist/core/evolution-reducer.js +0 -465
- package/dist/core/evolution-types.d.ts +0 -287
- package/dist/core/evolution-types.js +0 -78
- package/dist/core/external-training-contract.d.ts +0 -276
- package/dist/core/external-training-contract.js +0 -269
- package/dist/core/focus-history.d.ts +0 -210
- package/dist/core/focus-history.js +0 -1185
- package/dist/core/hygiene/tracker.d.ts +0 -22
- package/dist/core/hygiene/tracker.js +0 -106
- package/dist/core/init.d.ts +0 -12
- package/dist/core/local-worker-routing.d.ts +0 -175
- package/dist/core/local-worker-routing.js +0 -525
- package/dist/core/migration.d.ts +0 -6
- package/dist/core/model-deployment-registry.d.ts +0 -218
- package/dist/core/model-deployment-registry.js +0 -503
- package/dist/core/model-training-registry.d.ts +0 -295
- package/dist/core/model-training-registry.js +0 -475
- package/dist/core/nocturnal-arbiter.d.ts +0 -159
- package/dist/core/nocturnal-arbiter.js +0 -534
- package/dist/core/nocturnal-candidate-scoring.d.ts +0 -137
- package/dist/core/nocturnal-candidate-scoring.js +0 -266
- package/dist/core/nocturnal-compliance.d.ts +0 -175
- package/dist/core/nocturnal-compliance.js +0 -824
- package/dist/core/nocturnal-dataset.d.ts +0 -224
- package/dist/core/nocturnal-dataset.js +0 -443
- package/dist/core/nocturnal-executability.d.ts +0 -85
- package/dist/core/nocturnal-executability.js +0 -331
- package/dist/core/nocturnal-export.d.ts +0 -124
- package/dist/core/nocturnal-export.js +0 -275
- package/dist/core/nocturnal-paths.d.ts +0 -124
- package/dist/core/nocturnal-trajectory-extractor.d.ts +0 -242
- package/dist/core/nocturnal-trajectory-extractor.js +0 -307
- package/dist/core/nocturnal-trinity.d.ts +0 -311
- package/dist/core/nocturnal-trinity.js +0 -880
- package/dist/core/pain.d.ts +0 -4
- package/dist/core/pain.js +0 -70
- package/dist/core/path-resolver.d.ts +0 -46
- package/dist/core/paths.d.ts +0 -65
- package/dist/core/principle-training-state.d.ts +0 -121
- package/dist/core/principle-training-state.js +0 -321
- package/dist/core/profile.d.ts +0 -62
- package/dist/core/profile.js +0 -210
- package/dist/core/promotion-gate.d.ts +0 -238
- package/dist/core/promotion-gate.js +0 -529
- package/dist/core/risk-calculator.d.ts +0 -22
- package/dist/core/session-tracker.d.ts +0 -99
- package/dist/core/shadow-observation-registry.d.ts +0 -217
- package/dist/core/shadow-observation-registry.js +0 -308
- package/dist/core/system-logger.d.ts +0 -8
- package/dist/core/thinking-models.d.ts +0 -38
- package/dist/core/thinking-models.js +0 -170
- package/dist/core/training-program.d.ts +0 -233
- package/dist/core/training-program.js +0 -433
- package/dist/core/trajectory.d.ts +0 -411
- package/dist/core/trajectory.js +0 -1307
- package/dist/core/workspace-context.d.ts +0 -71
- package/dist/hooks/bash-risk.d.ts +0 -57
- package/dist/hooks/bash-risk.js +0 -137
- package/dist/hooks/edit-verification.d.ts +0 -62
- package/dist/hooks/edit-verification.js +0 -256
- package/dist/hooks/gate-block-helper.d.ts +0 -44
- package/dist/hooks/gate-block-helper.js +0 -119
- package/dist/hooks/gate.d.ts +0 -24
- package/dist/hooks/gate.js +0 -173
- package/dist/hooks/gfi-gate.d.ts +0 -40
- package/dist/hooks/gfi-gate.js +0 -113
- package/dist/hooks/lifecycle.d.ts +0 -5
- package/dist/hooks/lifecycle.js +0 -284
- package/dist/hooks/llm.d.ts +0 -12
- package/dist/hooks/message-sanitize.d.ts +0 -3
- package/dist/hooks/message-sanitize.js +0 -37
- package/dist/hooks/pain.d.ts +0 -5
- package/dist/hooks/pain.js +0 -301
- package/dist/hooks/progressive-trust-gate.d.ts +0 -51
- package/dist/hooks/progressive-trust-gate.js +0 -89
- package/dist/hooks/prompt.d.ts +0 -47
- package/dist/hooks/prompt.js +0 -884
- package/dist/hooks/subagent.d.ts +0 -10
- package/dist/hooks/subagent.js +0 -387
- package/dist/hooks/thinking-checkpoint.d.ts +0 -37
- package/dist/hooks/thinking-checkpoint.js +0 -51
- package/dist/hooks/trajectory-collector.d.ts +0 -32
- package/dist/hooks/trajectory-collector.js +0 -256
- package/dist/http/principles-console-route.d.ts +0 -9
- package/dist/http/principles-console-route.js +0 -567
- package/dist/i18n/commands.d.ts +0 -26
- package/dist/i18n/commands.js +0 -116
- package/dist/index.d.ts +0 -7
- package/dist/index.js +0 -581
- package/dist/service/central-database.d.ts +0 -104
- package/dist/service/central-database.js +0 -649
- package/dist/service/control-ui-query-service.d.ts +0 -221
- package/dist/service/control-ui-query-service.js +0 -543
- package/dist/service/empathy-observer-manager.d.ts +0 -52
- package/dist/service/empathy-observer-manager.js +0 -229
- package/dist/service/evolution-query-service.d.ts +0 -155
- package/dist/service/evolution-query-service.js +0 -258
- package/dist/service/evolution-worker.d.ts +0 -101
- package/dist/service/evolution-worker.js +0 -974
- package/dist/service/nocturnal-runtime.d.ts +0 -183
- package/dist/service/nocturnal-service.d.ts +0 -163
- package/dist/service/nocturnal-service.js +0 -787
- package/dist/service/nocturnal-target-selector.d.ts +0 -145
- package/dist/service/nocturnal-target-selector.js +0 -315
- package/dist/service/phase3-input-filter.d.ts +0 -73
- package/dist/service/phase3-input-filter.js +0 -172
- package/dist/service/runtime-summary-service.d.ts +0 -122
- package/dist/service/runtime-summary-service.js +0 -485
- package/dist/service/trajectory-service.d.ts +0 -2
- package/dist/service/trajectory-service.js +0 -15
- package/dist/tools/critique-prompt.d.ts +0 -14
- package/dist/tools/deep-reflect.d.ts +0 -39
- package/dist/tools/deep-reflect.js +0 -350
- package/dist/tools/model-index.d.ts +0 -9
- package/dist/types/event-types.d.ts +0 -306
- package/dist/types/event-types.js +0 -106
- package/dist/types/hygiene-types.d.ts +0 -20
- package/dist/types/hygiene-types.js +0 -12
- package/dist/types/runtime-summary.d.ts +0 -47
- package/dist/types/runtime-summary.js +0 -1
- package/dist/types.d.ts +0 -50
- package/dist/types.js +0 -22
- package/dist/utils/file-lock.d.ts +0 -71
- package/dist/utils/file-lock.js +0 -309
- package/dist/utils/glob-match.d.ts +0 -28
- package/dist/utils/hashing.d.ts +0 -9
- package/dist/utils/io.d.ts +0 -6
- package/dist/utils/io.js +0 -106
- package/dist/utils/nlp.d.ts +0 -9
- package/dist/utils/plugin-logger.d.ts +0 -39
- package/dist/utils/subagent-probe.d.ts +0 -34
- package/dist/utils/subagent-probe.js +0 -81
|
@@ -1,287 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Evolution Points System V2.0 - MVP
|
|
3
|
-
*
|
|
4
|
-
* Core Philosophy: Growth-driven替代Penalty-driven
|
|
5
|
-
* - 起点0分,只能增加,不扣分
|
|
6
|
-
* - 失败记录教训,不扣分
|
|
7
|
-
* - 同类任务失败后首次成功 = 双倍奖励(1小时冷却)
|
|
8
|
-
* - 5级成长路径:Seed → Forest
|
|
9
|
-
*/
|
|
10
|
-
export declare enum EvolutionTier {
|
|
11
|
-
Seed = 1,// 起步:150行 + 3文件 + 子智能体(现代 AI 能力已足够强)
|
|
12
|
-
Sprout = 2,// 成长:300行 + 5文件
|
|
13
|
-
Sapling = 3,// 独当:500行 + 10文件 + 风险路径
|
|
14
|
-
Tree = 4,// 专家:1000行 + 20文件
|
|
15
|
-
Forest = 5
|
|
16
|
-
}
|
|
17
|
-
export interface TierPermissions {
|
|
18
|
-
maxLinesPerWrite: number;
|
|
19
|
-
maxFilesPerTask: number;
|
|
20
|
-
allowRiskPath: boolean;
|
|
21
|
-
allowSubagentSpawn: boolean;
|
|
22
|
-
}
|
|
23
|
-
export interface TierDefinition {
|
|
24
|
-
tier: EvolutionTier;
|
|
25
|
-
name: string;
|
|
26
|
-
requiredPoints: number;
|
|
27
|
-
permissions: TierPermissions;
|
|
28
|
-
}
|
|
29
|
-
export declare const TIER_DEFINITIONS: readonly TierDefinition[];
|
|
30
|
-
export declare function getTierDefinition(tier: EvolutionTier): TierDefinition;
|
|
31
|
-
export declare function getTierByPoints(totalPoints: number): EvolutionTier;
|
|
32
|
-
export type TaskDifficulty = 'trivial' | 'normal' | 'hard';
|
|
33
|
-
export interface TaskDifficultyConfig {
|
|
34
|
-
basePoints: number;
|
|
35
|
-
description: string;
|
|
36
|
-
}
|
|
37
|
-
export declare const TASK_DIFFICULTY_CONFIG: Record<TaskDifficulty, TaskDifficultyConfig>;
|
|
38
|
-
export type EvolutionEventType = 'success' | 'failure';
|
|
39
|
-
export interface EvolutionEvent {
|
|
40
|
-
id: string;
|
|
41
|
-
timestamp: string;
|
|
42
|
-
type: EvolutionEventType;
|
|
43
|
-
taskHash: string;
|
|
44
|
-
taskDifficulty: TaskDifficulty;
|
|
45
|
-
toolName?: string;
|
|
46
|
-
filePath?: string;
|
|
47
|
-
reason?: string;
|
|
48
|
-
pointsAwarded: number;
|
|
49
|
-
isDoubleReward: boolean;
|
|
50
|
-
sessionId?: string;
|
|
51
|
-
}
|
|
52
|
-
export interface EvolutionScorecard {
|
|
53
|
-
version: '2.0';
|
|
54
|
-
agentId: string;
|
|
55
|
-
totalPoints: number;
|
|
56
|
-
availablePoints: number;
|
|
57
|
-
currentTier: EvolutionTier;
|
|
58
|
-
lastDoubleRewardTime?: string;
|
|
59
|
-
recentFailureHashes: Map<string, string>;
|
|
60
|
-
stats: EvolutionStats;
|
|
61
|
-
recentEvents: EvolutionEvent[];
|
|
62
|
-
lastUpdated: string;
|
|
63
|
-
}
|
|
64
|
-
export interface EvolutionStats {
|
|
65
|
-
totalSuccesses: number;
|
|
66
|
-
totalFailures: number;
|
|
67
|
-
consecutiveSuccesses: number;
|
|
68
|
-
consecutiveFailures: number;
|
|
69
|
-
doubleRewardsEarned: number;
|
|
70
|
-
tierPromotions: number;
|
|
71
|
-
pointsByDifficulty: Record<TaskDifficulty, number>;
|
|
72
|
-
}
|
|
73
|
-
export interface EvolutionStorage {
|
|
74
|
-
scorecard: EvolutionScorecard;
|
|
75
|
-
archivedStats: {
|
|
76
|
-
totalEventsProcessed: number;
|
|
77
|
-
pointsFromTrivial: number;
|
|
78
|
-
pointsFromNormal: number;
|
|
79
|
-
pointsFromHard: number;
|
|
80
|
-
};
|
|
81
|
-
}
|
|
82
|
-
export interface EvolutionConfig {
|
|
83
|
-
/** 双倍奖励冷却时间(毫秒),默认1小时 */
|
|
84
|
-
doubleRewardCooldownMs: number;
|
|
85
|
-
/** 保存的最近事件数量,默认50 */
|
|
86
|
-
maxRecentEvents: number;
|
|
87
|
-
/** 高等级做低级任务的积分衰减系数 */
|
|
88
|
-
difficultyPenalty: {
|
|
89
|
-
tier4Trivial: number;
|
|
90
|
-
tier4Normal: number;
|
|
91
|
-
tier5Trivial: number;
|
|
92
|
-
tier5Normal: number;
|
|
93
|
-
};
|
|
94
|
-
}
|
|
95
|
-
export declare const DEFAULT_EVOLUTION_CONFIG: EvolutionConfig;
|
|
96
|
-
export interface ArchivedEventStats {
|
|
97
|
-
totalEventsProcessed: number;
|
|
98
|
-
pointsFromTrivial: number;
|
|
99
|
-
pointsFromNormal: number;
|
|
100
|
-
pointsFromHard: number;
|
|
101
|
-
}
|
|
102
|
-
export interface GateDecision {
|
|
103
|
-
allowed: boolean;
|
|
104
|
-
reason?: string;
|
|
105
|
-
currentTier?: EvolutionTier;
|
|
106
|
-
requiredTier?: EvolutionTier;
|
|
107
|
-
}
|
|
108
|
-
export interface ToolCallContext {
|
|
109
|
-
toolName: string;
|
|
110
|
-
filePath?: string;
|
|
111
|
-
content?: string;
|
|
112
|
-
lineCount?: number;
|
|
113
|
-
isRiskPath?: boolean;
|
|
114
|
-
}
|
|
115
|
-
export interface TierPromotionEvent {
|
|
116
|
-
previousTier: EvolutionTier;
|
|
117
|
-
newTier: EvolutionTier;
|
|
118
|
-
totalPoints: number;
|
|
119
|
-
timestamp: string;
|
|
120
|
-
newPermissions: TierPermissions;
|
|
121
|
-
}
|
|
122
|
-
export type PrincipleStatus = 'candidate' | 'probation' | 'active' | 'deprecated';
|
|
123
|
-
/**
|
|
124
|
-
* Evaluability classification — determines whether a P_xxx principle can enter
|
|
125
|
-
* automatic nocturnal targeting.
|
|
126
|
-
*
|
|
127
|
-
* - deterministic: Machine-checkable via deterministic rules/tool detectors
|
|
128
|
-
* - weak_heuristic: Checkable via heuristic signals, may have false positives
|
|
129
|
-
* - manual_only: No machine-checkable detector — stays in prompts only
|
|
130
|
-
*/
|
|
131
|
-
export type PrincipleEvaluatorLevel = 'deterministic' | 'weak_heuristic' | 'manual_only';
|
|
132
|
-
/**
|
|
133
|
-
* Shared alias for PrincipleEvaluatorLevel — used by modules that reference
|
|
134
|
-
* the same evaluability classification without direct coupling to evolution-types.
|
|
135
|
-
* @deprecated Use PrincipleEvaluatorLevel directly. This alias exists for
|
|
136
|
-
* backwards compatibility with principle-training-state.ts.
|
|
137
|
-
*/
|
|
138
|
-
export type Evaluability = PrincipleEvaluatorLevel;
|
|
139
|
-
/**
|
|
140
|
-
* Structured detector metadata for P_xxx principles.
|
|
141
|
-
* Allows the principle to enter automatic nocturnal targeting.
|
|
142
|
-
*
|
|
143
|
-
* If any required field is missing, the principle defaults to 'manual_only'.
|
|
144
|
-
*/
|
|
145
|
-
export interface PrincipleDetectorSpec {
|
|
146
|
-
/** Topic/scenario tags where this detector applies */
|
|
147
|
-
applicabilityTags: string[];
|
|
148
|
-
/** Evidence that the principle was followed */
|
|
149
|
-
positiveSignals: string[];
|
|
150
|
-
/** Evidence that the principle was violated */
|
|
151
|
-
negativeSignals: string[];
|
|
152
|
-
/** Tool call sequences that indicate the principle is relevant */
|
|
153
|
-
toolSequenceHints: string[][];
|
|
154
|
-
/** Confidence in the detector's signal quality */
|
|
155
|
-
confidence: 'high' | 'medium' | 'low';
|
|
156
|
-
}
|
|
157
|
-
/**
|
|
158
|
-
* Validates that a detector metadata object has all required fields with non-empty values.
|
|
159
|
-
* Used as defense-in-depth before accepting detectorMetadata for auto-trainable principles.
|
|
160
|
-
*/
|
|
161
|
-
export declare function isCompleteDetectorMetadata(meta: unknown): meta is PrincipleDetectorSpec;
|
|
162
|
-
export interface Principle {
|
|
163
|
-
id: string;
|
|
164
|
-
version: number;
|
|
165
|
-
text: string;
|
|
166
|
-
source: {
|
|
167
|
-
painId: string;
|
|
168
|
-
painType: 'tool_failure' | 'subagent_error' | 'user_frustration';
|
|
169
|
-
timestamp: string;
|
|
170
|
-
};
|
|
171
|
-
trigger: string;
|
|
172
|
-
action: string;
|
|
173
|
-
guardrails?: string[];
|
|
174
|
-
contextTags: string[];
|
|
175
|
-
validation: {
|
|
176
|
-
successCount: number;
|
|
177
|
-
conflictCount: number;
|
|
178
|
-
};
|
|
179
|
-
status: PrincipleStatus;
|
|
180
|
-
feedbackScore: number;
|
|
181
|
-
usageCount: number;
|
|
182
|
-
createdAt: string;
|
|
183
|
-
activatedAt?: string;
|
|
184
|
-
deprecatedAt?: string;
|
|
185
|
-
/**
|
|
186
|
-
* Evaluability classification. Defaults to 'manual_only' if not set.
|
|
187
|
-
* Principles with 'manual_only' evaluability cannot enter automatic
|
|
188
|
-
* nocturnal targeting.
|
|
189
|
-
*/
|
|
190
|
-
evaluability: PrincipleEvaluatorLevel;
|
|
191
|
-
/**
|
|
192
|
-
* Structured detector metadata. If present and valid, the principle
|
|
193
|
-
* may be auto-trainable (deterministic / weak_heuristic).
|
|
194
|
-
* Absent or malformed = 'manual_only' evaluability.
|
|
195
|
-
*/
|
|
196
|
-
detectorMetadata?: PrincipleDetectorSpec;
|
|
197
|
-
}
|
|
198
|
-
export type EvolutionLoopEventType = 'pain_detected' | 'candidate_created' | 'principle_promoted' | 'principle_deprecated' | 'principle_rolled_back' | 'circuit_breaker_opened' | 'legacy_import';
|
|
199
|
-
export interface PainDetectedData {
|
|
200
|
-
painId: string;
|
|
201
|
-
painType: 'tool_failure' | 'subagent_error' | 'user_frustration';
|
|
202
|
-
source: string;
|
|
203
|
-
reason: string;
|
|
204
|
-
score?: number;
|
|
205
|
-
sessionId?: string;
|
|
206
|
-
agentId?: string;
|
|
207
|
-
taskId?: string;
|
|
208
|
-
traceId?: string;
|
|
209
|
-
}
|
|
210
|
-
export interface CandidateCreatedData {
|
|
211
|
-
painId: string;
|
|
212
|
-
principleId: string;
|
|
213
|
-
trigger: string;
|
|
214
|
-
action: string;
|
|
215
|
-
status: 'candidate';
|
|
216
|
-
/** Pain type that generated this candidate — preserved on replay */
|
|
217
|
-
painType?: 'tool_failure' | 'subagent_error' | 'user_frustration';
|
|
218
|
-
/** Optional evaluability — defaults to 'manual_only' if omitted */
|
|
219
|
-
evaluability?: PrincipleEvaluatorLevel;
|
|
220
|
-
/** Optional detector metadata — absent = manual_only */
|
|
221
|
-
detectorMetadata?: PrincipleDetectorSpec;
|
|
222
|
-
}
|
|
223
|
-
export interface PrinciplePromotedData {
|
|
224
|
-
principleId: string;
|
|
225
|
-
from: 'candidate' | 'probation';
|
|
226
|
-
to: 'probation' | 'active';
|
|
227
|
-
reason: string;
|
|
228
|
-
successCount?: number;
|
|
229
|
-
}
|
|
230
|
-
export interface PrincipleDeprecatedData {
|
|
231
|
-
principleId: string;
|
|
232
|
-
reason: string;
|
|
233
|
-
triggeredBy: 'auto' | 'manual';
|
|
234
|
-
}
|
|
235
|
-
export interface PrincipleRolledBackData {
|
|
236
|
-
principleId: string;
|
|
237
|
-
reason: string;
|
|
238
|
-
triggeredBy: 'user_command' | 'auto_conflict';
|
|
239
|
-
blacklistPattern?: string;
|
|
240
|
-
relatedPainId?: string;
|
|
241
|
-
}
|
|
242
|
-
export interface CircuitBreakerOpenedData {
|
|
243
|
-
taskId: string;
|
|
244
|
-
painId: string;
|
|
245
|
-
failCount: number;
|
|
246
|
-
reason: string;
|
|
247
|
-
requireHuman: boolean;
|
|
248
|
-
nextRetryAt?: string;
|
|
249
|
-
}
|
|
250
|
-
export interface LegacyImportData {
|
|
251
|
-
sourceFile: string;
|
|
252
|
-
content: string;
|
|
253
|
-
contentHash?: string;
|
|
254
|
-
}
|
|
255
|
-
export type EvolutionLoopEvent = {
|
|
256
|
-
ts: string;
|
|
257
|
-
type: 'pain_detected';
|
|
258
|
-
data: PainDetectedData;
|
|
259
|
-
} | {
|
|
260
|
-
ts: string;
|
|
261
|
-
type: 'pain_recorded';
|
|
262
|
-
data: PainDetectedData;
|
|
263
|
-
} | {
|
|
264
|
-
ts: string;
|
|
265
|
-
type: 'candidate_created';
|
|
266
|
-
data: CandidateCreatedData;
|
|
267
|
-
} | {
|
|
268
|
-
ts: string;
|
|
269
|
-
type: 'principle_promoted';
|
|
270
|
-
data: PrinciplePromotedData;
|
|
271
|
-
} | {
|
|
272
|
-
ts: string;
|
|
273
|
-
type: 'principle_deprecated';
|
|
274
|
-
data: PrincipleDeprecatedData;
|
|
275
|
-
} | {
|
|
276
|
-
ts: string;
|
|
277
|
-
type: 'principle_rolled_back';
|
|
278
|
-
data: PrincipleRolledBackData;
|
|
279
|
-
} | {
|
|
280
|
-
ts: string;
|
|
281
|
-
type: 'circuit_breaker_opened';
|
|
282
|
-
data: CircuitBreakerOpenedData;
|
|
283
|
-
} | {
|
|
284
|
-
ts: string;
|
|
285
|
-
type: 'legacy_import';
|
|
286
|
-
data: LegacyImportData;
|
|
287
|
-
};
|
|
@@ -1,78 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Evolution Points System V2.0 - MVP
|
|
3
|
-
*
|
|
4
|
-
* Core Philosophy: Growth-driven替代Penalty-driven
|
|
5
|
-
* - 起点0分,只能增加,不扣分
|
|
6
|
-
* - 失败记录教训,不扣分
|
|
7
|
-
* - 同类任务失败后首次成功 = 双倍奖励(1小时冷却)
|
|
8
|
-
* - 5级成长路径:Seed → Forest
|
|
9
|
-
*/
|
|
10
|
-
// ===== 等级定义 =====
|
|
11
|
-
export var EvolutionTier;
|
|
12
|
-
(function (EvolutionTier) {
|
|
13
|
-
EvolutionTier[EvolutionTier["Seed"] = 1] = "Seed";
|
|
14
|
-
EvolutionTier[EvolutionTier["Sprout"] = 2] = "Sprout";
|
|
15
|
-
EvolutionTier[EvolutionTier["Sapling"] = 3] = "Sapling";
|
|
16
|
-
EvolutionTier[EvolutionTier["Tree"] = 4] = "Tree";
|
|
17
|
-
EvolutionTier[EvolutionTier["Forest"] = 5] = "Forest"; // 大师:完全自主
|
|
18
|
-
})(EvolutionTier || (EvolutionTier = {}));
|
|
19
|
-
export const TIER_DEFINITIONS = [
|
|
20
|
-
// 2026-03-28: 大幅放宽限制,现代 AI 能力已很强
|
|
21
|
-
// Seed: 从 20 行提升到 150 行,允许 3 文件,允许子智能体
|
|
22
|
-
{ tier: EvolutionTier.Seed, name: 'Seed', requiredPoints: 0, permissions: { maxLinesPerWrite: 150, maxFilesPerTask: 3, allowRiskPath: false, allowSubagentSpawn: true } },
|
|
23
|
-
// Sprout: 中等规模开发
|
|
24
|
-
{ tier: EvolutionTier.Sprout, name: 'Sprout', requiredPoints: 50, permissions: { maxLinesPerWrite: 300, maxFilesPerTask: 5, allowRiskPath: false, allowSubagentSpawn: true } },
|
|
25
|
-
// Sapling: 较大规模开发,可访问风险路径(需 PLAN)
|
|
26
|
-
{ tier: EvolutionTier.Sapling, name: 'Sapling', requiredPoints: 200, permissions: { maxLinesPerWrite: 500, maxFilesPerTask: 10, allowRiskPath: true, allowSubagentSpawn: true } },
|
|
27
|
-
// Tree: 大型重构
|
|
28
|
-
{ tier: EvolutionTier.Tree, name: 'Tree', requiredPoints: 500, permissions: { maxLinesPerWrite: 1000, maxFilesPerTask: 20, allowRiskPath: true, allowSubagentSpawn: true } },
|
|
29
|
-
// Forest: 完全自主
|
|
30
|
-
{ tier: EvolutionTier.Forest, name: 'Forest', requiredPoints: 1000, permissions: { maxLinesPerWrite: Infinity, maxFilesPerTask: Infinity, allowRiskPath: true, allowSubagentSpawn: true } },
|
|
31
|
-
];
|
|
32
|
-
export function getTierDefinition(tier) {
|
|
33
|
-
return TIER_DEFINITIONS[tier - 1];
|
|
34
|
-
}
|
|
35
|
-
export function getTierByPoints(totalPoints) {
|
|
36
|
-
// 从高到低检查,找到最高匹配等级
|
|
37
|
-
for (let i = TIER_DEFINITIONS.length - 1; i >= 0; i--) {
|
|
38
|
-
if (totalPoints >= TIER_DEFINITIONS[i].requiredPoints) {
|
|
39
|
-
return TIER_DEFINITIONS[i].tier;
|
|
40
|
-
}
|
|
41
|
-
}
|
|
42
|
-
return EvolutionTier.Seed;
|
|
43
|
-
}
|
|
44
|
-
export const TASK_DIFFICULTY_CONFIG = {
|
|
45
|
-
trivial: { basePoints: 1, description: '简单任务:读取、搜索、状态查询' },
|
|
46
|
-
normal: { basePoints: 3, description: '常规任务:单文件编辑、测试编写' },
|
|
47
|
-
hard: { basePoints: 8, description: '困难任务:多文件重构、架构变更' },
|
|
48
|
-
};
|
|
49
|
-
export const DEFAULT_EVOLUTION_CONFIG = {
|
|
50
|
-
doubleRewardCooldownMs: 60 * 60 * 1000, // 1小时
|
|
51
|
-
maxRecentEvents: 50,
|
|
52
|
-
difficultyPenalty: {
|
|
53
|
-
tier4Trivial: 0.1,
|
|
54
|
-
tier4Normal: 0.5,
|
|
55
|
-
tier5Trivial: 0.1,
|
|
56
|
-
tier5Normal: 0.5,
|
|
57
|
-
},
|
|
58
|
-
};
|
|
59
|
-
/**
|
|
60
|
-
* Validates that a detector metadata object has all required fields with non-empty values.
|
|
61
|
-
* Used as defense-in-depth before accepting detectorMetadata for auto-trainable principles.
|
|
62
|
-
*/
|
|
63
|
-
export function isCompleteDetectorMetadata(meta) {
|
|
64
|
-
if (!meta || typeof meta !== 'object')
|
|
65
|
-
return false;
|
|
66
|
-
const m = meta;
|
|
67
|
-
const VALID_CONFIDENCE = ['high', 'medium', 'low'];
|
|
68
|
-
if (typeof m.confidence !== 'string' ||
|
|
69
|
-
!VALID_CONFIDENCE.includes(m.confidence)) {
|
|
70
|
-
return false;
|
|
71
|
-
}
|
|
72
|
-
const nonEmptyStringArray = (arr) => Array.isArray(arr) &&
|
|
73
|
-
arr.length > 0 &&
|
|
74
|
-
arr.every((s) => typeof s === 'string' && s.length > 0);
|
|
75
|
-
return (nonEmptyStringArray(m.applicabilityTags) &&
|
|
76
|
-
nonEmptyStringArray(m.positiveSignals) &&
|
|
77
|
-
nonEmptyStringArray(m.negativeSignals));
|
|
78
|
-
}
|
|
@@ -1,276 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* External Training Contract — Normalized Experiment Spec and Result Schema
|
|
3
|
-
* ========================================================================
|
|
4
|
-
*
|
|
5
|
-
* PURPOSE: Define the stable contract between the plugin and external trainer
|
|
6
|
-
* backends. The plugin produces a constrained experiment specification that an
|
|
7
|
-
* external trainer consumes. The trainer returns a normalized result that the
|
|
8
|
-
* plugin can register, evaluate, and gate for rollout.
|
|
9
|
-
*
|
|
10
|
-
* ARCHITECTURE:
|
|
11
|
-
* - Plugin is responsible for creating the experiment spec
|
|
12
|
-
* - Plugin is responsible for validating the trainer result
|
|
13
|
-
* - Plugin is responsible for registering lineage (train run → checkpoint → eval)
|
|
14
|
-
* - Plugin is responsible for invoking benchmark evaluation
|
|
15
|
-
* - Plugin is responsible for invoking promotion gate logic
|
|
16
|
-
* - Plugin is responsible for binding deployment only after gate approval
|
|
17
|
-
*
|
|
18
|
-
* DESIGN CONSTRAINTS:
|
|
19
|
-
* - ORPO-first: trainingMode must be 'orpo' for production runs
|
|
20
|
-
* - No real training inside the plugin
|
|
21
|
-
* - No direct deployment promotion from trainer output
|
|
22
|
-
* - No direct trainer writes to review/eval/deployment state
|
|
23
|
-
* - Backend-pluggable: same contract works for all backends
|
|
24
|
-
*
|
|
25
|
-
* CONTRACT GOALS:
|
|
26
|
-
* - support ORPO training for approved nocturnal exports
|
|
27
|
-
* - support multiple backend implementations behind one schema
|
|
28
|
-
* - preserve dataset / config / checkpoint lineage
|
|
29
|
-
* - remain valid on consumer hardware
|
|
30
|
-
* - fail closed when inputs are incomplete or inconsistent
|
|
31
|
-
*/
|
|
32
|
-
/**
|
|
33
|
-
* Allowed backend identifiers.
|
|
34
|
-
*
|
|
35
|
-
* - `peft-trl-orpo`: primary reference implementation using PEFT + TRL ORPO
|
|
36
|
-
* - `unsloth-orpo`: compatible accelerated implementation using Unsloth
|
|
37
|
-
* - `dry-run`: validates paths/spec/environment only, no real training
|
|
38
|
-
*/
|
|
39
|
-
export type TrainerBackendKind = 'peft-trl-orpo' | 'unsloth-orpo' | 'dry-run';
|
|
40
|
-
/**
|
|
41
|
-
* Hardware tier for training.
|
|
42
|
-
*
|
|
43
|
-
* - `consumer-gpu`: RTX 4090 24GB or equivalent (production target)
|
|
44
|
-
* - `small-gpu`: 8GB-16GB VRAM (compatibility target)
|
|
45
|
-
* - `cpu-experimental`: CPU-only experimental runs (dry-run or tiny models only)
|
|
46
|
-
*/
|
|
47
|
-
export type HardwareTier = 'consumer-gpu' | 'small-gpu' | 'cpu-experimental';
|
|
48
|
-
/**
|
|
49
|
-
* Worker profiles supported for training.
|
|
50
|
-
*
|
|
51
|
-
* Phase 7 first rollout: `local-reader` only.
|
|
52
|
-
* `local-editor` requires explicit human approval to enable.
|
|
53
|
-
*/
|
|
54
|
-
export type TrainableWorkerProfile = 'local-reader' | 'local-editor';
|
|
55
|
-
/**
|
|
56
|
-
* Training mode — Phase 7 production is ORPO-only.
|
|
57
|
-
*/
|
|
58
|
-
export type TrainingMode = 'orpo';
|
|
59
|
-
/**
|
|
60
|
-
* Hyperparameters for ORPO training.
|
|
61
|
-
*/
|
|
62
|
-
export interface TrainingHyperparameters {
|
|
63
|
-
learningRate: number;
|
|
64
|
-
batchSize: number;
|
|
65
|
-
gradientAccumulation: number;
|
|
66
|
-
loraRank: number;
|
|
67
|
-
loraAlpha: number;
|
|
68
|
-
loraDropout: number;
|
|
69
|
-
warmupRatio: number;
|
|
70
|
-
maxSteps: number;
|
|
71
|
-
maxSeqLength: number;
|
|
72
|
-
}
|
|
73
|
-
/**
|
|
74
|
-
* Budget constraints for a training experiment.
|
|
75
|
-
*/
|
|
76
|
-
export interface TrainingBudget {
|
|
77
|
-
maxWallClockMinutes: number;
|
|
78
|
-
maxTrainTokens?: number;
|
|
79
|
-
}
|
|
80
|
-
/**
|
|
81
|
-
* Expected artifact from a successful training run.
|
|
82
|
-
*/
|
|
83
|
-
export interface ExpectedArtifact {
|
|
84
|
-
checkpointName: string;
|
|
85
|
-
adapterFormat: 'peft-adapter';
|
|
86
|
-
}
|
|
87
|
-
/**
|
|
88
|
-
* The experiment specification sent to an external trainer.
|
|
89
|
-
* This defines WHAT to train, not HOW to train (backend-specific).
|
|
90
|
-
*/
|
|
91
|
-
export interface TrainingExperimentSpec {
|
|
92
|
-
/** Unique identifier for this experiment */
|
|
93
|
-
experimentId: string;
|
|
94
|
-
/** Which backend to use */
|
|
95
|
-
backend: TrainerBackendKind;
|
|
96
|
-
/** Training mode — only 'orpo' is supported in Phase 7 */
|
|
97
|
-
trainingMode: TrainingMode;
|
|
98
|
-
/** Target worker profile for this experiment */
|
|
99
|
-
targetWorkerProfile: TrainableWorkerProfile;
|
|
100
|
-
/** Target model family to train */
|
|
101
|
-
targetModelFamily: string;
|
|
102
|
-
/** Hardware tier for this experiment */
|
|
103
|
-
hardwareTier: HardwareTier;
|
|
104
|
-
/** Reference to the ORPO export providing training data */
|
|
105
|
-
datasetExportId: string;
|
|
106
|
-
datasetExportPath: string;
|
|
107
|
-
/** Fingerprint of the dataset for lineage verification */
|
|
108
|
-
datasetFingerprint: string;
|
|
109
|
-
/** Reference to the benchmark export for eval */
|
|
110
|
-
benchmarkExportId: string;
|
|
111
|
-
/** Output directory for checkpoint artifacts */
|
|
112
|
-
outputDir: string;
|
|
113
|
-
/** Fingerprint of the training configuration */
|
|
114
|
-
configFingerprint: string;
|
|
115
|
-
/** Hash of the training code/contract version */
|
|
116
|
-
codeHash: string;
|
|
117
|
-
/** Training hyperparameters */
|
|
118
|
-
hyperparameters: TrainingHyperparameters;
|
|
119
|
-
/** Budget constraints */
|
|
120
|
-
budget: TrainingBudget;
|
|
121
|
-
/** Expected artifact from training */
|
|
122
|
-
expectedArtifact: ExpectedArtifact;
|
|
123
|
-
}
|
|
124
|
-
/**
|
|
125
|
-
* Training metrics recorded by the backend.
|
|
126
|
-
*/
|
|
127
|
-
export interface TrainingMetrics {
|
|
128
|
-
wallClockMinutes: number;
|
|
129
|
-
finalLoss?: number;
|
|
130
|
-
tokensSeen?: number;
|
|
131
|
-
}
|
|
132
|
-
/**
|
|
133
|
-
* Artifact produced by a successful training run.
|
|
134
|
-
*/
|
|
135
|
-
export interface TrainingArtifact {
|
|
136
|
-
adapterFormat: 'peft-adapter';
|
|
137
|
-
artifactPath: string;
|
|
138
|
-
}
|
|
139
|
-
/**
|
|
140
|
-
* Status of a training experiment.
|
|
141
|
-
*/
|
|
142
|
-
export type ExperimentStatus = 'completed' | 'failed' | 'dry_run';
|
|
143
|
-
/**
|
|
144
|
-
* The result returned by an external trainer after execution.
|
|
145
|
-
* This defines the output contract — all backends must return the same shape.
|
|
146
|
-
*/
|
|
147
|
-
export interface TrainingExperimentResult {
|
|
148
|
-
/** Experiment ID (must match the spec's experimentId) */
|
|
149
|
-
experimentId: string;
|
|
150
|
-
/** Which backend was used */
|
|
151
|
-
backend: TrainerBackendKind;
|
|
152
|
-
/** Final status of the experiment */
|
|
153
|
-
status: ExperimentStatus;
|
|
154
|
-
/** Registered training run ID (plugin-side) */
|
|
155
|
-
trainRunId?: string;
|
|
156
|
-
/** Registered checkpoint ID (plugin-side) */
|
|
157
|
-
checkpointId?: string;
|
|
158
|
-
/** Checkpoint reference string (for lineage) */
|
|
159
|
-
checkpointRef?: string;
|
|
160
|
-
/** Target worker profile */
|
|
161
|
-
targetWorkerProfile: TrainableWorkerProfile;
|
|
162
|
-
/** Target model family */
|
|
163
|
-
targetModelFamily: string;
|
|
164
|
-
/** Dataset fingerprint (for lineage verification) */
|
|
165
|
-
datasetFingerprint: string;
|
|
166
|
-
/** Config fingerprint (for lineage verification) */
|
|
167
|
-
configFingerprint: string;
|
|
168
|
-
/** Code hash (for lineage verification) */
|
|
169
|
-
codeHash: string;
|
|
170
|
-
/** Training metrics */
|
|
171
|
-
metrics?: TrainingMetrics;
|
|
172
|
-
/** Produced artifact (only if status === 'completed') */
|
|
173
|
-
artifact?: TrainingArtifact;
|
|
174
|
-
/** Failure reason (only if status === 'failed') */
|
|
175
|
-
failureReason?: string;
|
|
176
|
-
/** ISO-8601 creation timestamp */
|
|
177
|
-
createdAt: string;
|
|
178
|
-
}
|
|
179
|
-
/**
|
|
180
|
-
* Validation error for trainer result verification.
|
|
181
|
-
*/
|
|
182
|
-
export interface ValidationError {
|
|
183
|
-
field: string;
|
|
184
|
-
expected: string;
|
|
185
|
-
actual: string;
|
|
186
|
-
reason: string;
|
|
187
|
-
}
|
|
188
|
-
/**
|
|
189
|
-
* Result of validating a trainer result against the experiment spec.
|
|
190
|
-
*/
|
|
191
|
-
export interface ValidationResult {
|
|
192
|
-
valid: boolean;
|
|
193
|
-
errors: ValidationError[];
|
|
194
|
-
}
|
|
195
|
-
/**
|
|
196
|
-
* Validate that a trainer result matches the experiment spec.
|
|
197
|
-
*
|
|
198
|
-
* FAILS CLOSED on any mismatch — a checkpoint with invalid lineage must not
|
|
199
|
-
* be registered or promoted.
|
|
200
|
-
*
|
|
201
|
-
* Validation rules:
|
|
202
|
-
* 1. experimentId must match
|
|
203
|
-
* 2. backend must match
|
|
204
|
-
* 3. targetWorkerProfile must match
|
|
205
|
-
* 4. targetModelFamily must match
|
|
206
|
-
* 5. datasetFingerprint must match
|
|
207
|
-
* 6. configFingerprint must match
|
|
208
|
-
* 7. codeHash must match
|
|
209
|
-
* 8. dry-run must not produce a deployable checkpoint
|
|
210
|
-
*
|
|
211
|
-
* @param spec - The original experiment spec
|
|
212
|
-
* @param result - The trainer result to validate
|
|
213
|
-
* @returns ValidationResult indicating pass/fail and any errors
|
|
214
|
-
*/
|
|
215
|
-
export declare function validateTrainerResult(spec: TrainingExperimentSpec, result: TrainingExperimentResult): ValidationResult;
|
|
216
|
-
/**
|
|
217
|
-
* Generate a fingerprint for a configuration object.
|
|
218
|
-
* Used for configFingerprint in the experiment spec.
|
|
219
|
-
*/
|
|
220
|
-
export declare function computeConfigFingerprint(config: Partial<TrainingHyperparameters>): string;
|
|
221
|
-
/**
|
|
222
|
-
* Generate a fingerprint for a dataset export.
|
|
223
|
-
* Used for datasetFingerprint in the experiment spec.
|
|
224
|
-
*
|
|
225
|
-
* Combines file content hash with sampleCount to detect:
|
|
226
|
-
* - Content changes (file modified/replaced)
|
|
227
|
-
* - Sample count changes (different export)
|
|
228
|
-
*
|
|
229
|
-
* If the file cannot be read, falls back to path+count hash (legacy behavior).
|
|
230
|
-
*/
|
|
231
|
-
export declare function computeDatasetFingerprint(exportPath: string, sampleCount: number): string;
|
|
232
|
-
/**
|
|
233
|
-
* Generate a code hash for the training contract version.
|
|
234
|
-
* Used for codeHash in the experiment spec.
|
|
235
|
-
*
|
|
236
|
-
* Hashes the actual contract source file content so any change to the
|
|
237
|
-
* contract produces a different hash, ensuring lineage integrity.
|
|
238
|
-
*
|
|
239
|
-
* Falls back to version string + timestamp if source cannot be read.
|
|
240
|
-
*/
|
|
241
|
-
export declare function computeCodeHash(): string;
|
|
242
|
-
/**
|
|
243
|
-
* Generate a new experiment ID.
|
|
244
|
-
*/
|
|
245
|
-
export declare function generateExperimentId(): string;
|
|
246
|
-
/**
|
|
247
|
-
* Validate that a hardware tier is appropriate for the backend.
|
|
248
|
-
*
|
|
249
|
-
* @param backend - The backend being used
|
|
250
|
-
* @param tier - The hardware tier
|
|
251
|
-
* @throws Error if the combination is not supported
|
|
252
|
-
*/
|
|
253
|
-
export declare function validateHardwareTier(backend: TrainerBackendKind, tier: HardwareTier): void;
|
|
254
|
-
/**
|
|
255
|
-
* Get the default hardware tier for a backend.
|
|
256
|
-
*/
|
|
257
|
-
export declare function getDefaultHardwareTier(backend: TrainerBackendKind): HardwareTier;
|
|
258
|
-
/**
|
|
259
|
-
* Valid model family patterns for local-reader profile.
|
|
260
|
-
* Used for family validation in the training contract.
|
|
261
|
-
*/
|
|
262
|
-
export declare const READER_FAMILY_PATTERNS: string[];
|
|
263
|
-
/**
|
|
264
|
-
* Valid model family patterns for local-editor profile.
|
|
265
|
-
* Used for family validation in the training contract.
|
|
266
|
-
*/
|
|
267
|
-
export declare const EDITOR_FAMILY_PATTERNS: string[];
|
|
268
|
-
/**
|
|
269
|
-
* Check if a model family is valid for a worker profile.
|
|
270
|
-
*/
|
|
271
|
-
export declare function isValidModelFamilyForProfile(family: string, profile: TrainableWorkerProfile): boolean;
|
|
272
|
-
/**
|
|
273
|
-
* Phase 7 first rollout is limited to local-reader.
|
|
274
|
-
* This flag controls whether local-editor is allowed.
|
|
275
|
-
*/
|
|
276
|
-
export declare const LOCAL_EDITOR_ENABLED = false;
|