@alan512/experienceengine 0.1.2 → 0.2.0
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/.claude-plugin/marketplace.json +0 -0
- package/.claude-plugin/plugin.json +1 -1
- package/.env.example +0 -0
- package/.mcp.json +4 -8
- package/LICENSE +21 -0
- package/README.md +288 -95
- package/README.zh-CN.md +316 -65
- package/dist/adapters/claude-code/event-store.d.ts +0 -0
- package/dist/adapters/claude-code/event-store.js +0 -0
- package/dist/adapters/claude-code/event-store.js.map +0 -0
- package/dist/adapters/claude-code/hook-normalizer.d.ts +0 -0
- package/dist/adapters/claude-code/hook-normalizer.js +0 -0
- package/dist/adapters/claude-code/hook-normalizer.js.map +0 -0
- package/dist/adapters/claude-code/runtime-projection.d.ts +0 -0
- package/dist/adapters/claude-code/runtime-projection.js +0 -0
- package/dist/adapters/claude-code/runtime-projection.js.map +0 -0
- package/dist/adapters/claude-code/session-store.d.ts +1 -0
- package/dist/adapters/claude-code/session-store.js +24 -1
- package/dist/adapters/claude-code/session-store.js.map +1 -1
- package/dist/adapters/codex/action-registry.d.ts +84 -0
- package/dist/adapters/codex/action-registry.js +277 -0
- package/dist/adapters/codex/action-registry.js.map +1 -0
- package/dist/adapters/codex/broker-tools.d.ts +114 -0
- package/dist/adapters/codex/broker-tools.js +130 -0
- package/dist/adapters/codex/broker-tools.js.map +1 -0
- package/dist/adapters/codex/instruction-template.d.ts +3 -0
- package/dist/adapters/codex/instruction-template.js +12 -0
- package/dist/adapters/codex/instruction-template.js.map +1 -0
- package/dist/adapters/codex/mcp-server.d.ts +59 -41
- package/dist/adapters/codex/mcp-server.js +177 -728
- package/dist/adapters/codex/mcp-server.js.map +1 -1
- package/dist/analyzer/candidate-signals.d.ts +3 -1
- package/dist/analyzer/candidate-signals.js +159 -0
- package/dist/analyzer/candidate-signals.js.map +1 -1
- package/dist/analyzer/experience-analyzer.d.ts +0 -0
- package/dist/analyzer/experience-analyzer.js +0 -0
- package/dist/analyzer/experience-analyzer.js.map +0 -0
- package/dist/analyzer/extraction-evidence.d.ts +0 -0
- package/dist/analyzer/extraction-evidence.js +0 -0
- package/dist/analyzer/extraction-evidence.js.map +0 -0
- package/dist/analyzer/llm-learning-gate.d.ts +12 -1
- package/dist/analyzer/llm-learning-gate.js +672 -16
- package/dist/analyzer/llm-learning-gate.js.map +1 -1
- package/dist/analyzer/node-deduper.d.ts +0 -0
- package/dist/analyzer/node-deduper.js +0 -0
- package/dist/analyzer/node-deduper.js.map +0 -0
- package/dist/analyzer/node-normalizer.d.ts +0 -0
- package/dist/analyzer/node-normalizer.js +0 -0
- package/dist/analyzer/node-normalizer.js.map +0 -0
- package/dist/analyzer/storage-gate.d.ts +0 -0
- package/dist/analyzer/storage-gate.js +0 -0
- package/dist/analyzer/storage-gate.js.map +0 -0
- package/dist/analyzer/strategy-extractor.d.ts +0 -0
- package/dist/analyzer/strategy-extractor.js +0 -0
- package/dist/analyzer/strategy-extractor.js.map +0 -0
- package/dist/analyzer/warning-extractor.d.ts +0 -0
- package/dist/analyzer/warning-extractor.js +0 -0
- package/dist/analyzer/warning-extractor.js.map +0 -0
- package/dist/cli/commands/backup.d.ts +0 -0
- package/dist/cli/commands/backup.js +0 -0
- package/dist/cli/commands/backup.js.map +0 -0
- package/dist/cli/commands/claude-hook.d.ts +0 -0
- package/dist/cli/commands/claude-hook.js +23 -7
- package/dist/cli/commands/claude-hook.js.map +1 -1
- package/dist/cli/commands/codex-mcp-server.d.ts +0 -0
- package/dist/cli/commands/codex-mcp-server.js +0 -0
- package/dist/cli/commands/codex-mcp-server.js.map +0 -0
- package/dist/cli/commands/codex.d.ts +60 -0
- package/dist/cli/commands/codex.js +188 -0
- package/dist/cli/commands/codex.js.map +1 -0
- package/dist/cli/commands/config.d.ts +0 -0
- package/dist/cli/commands/config.js +88 -2
- package/dist/cli/commands/config.js.map +1 -1
- package/dist/cli/commands/cool.d.ts +0 -0
- package/dist/cli/commands/cool.js +0 -0
- package/dist/cli/commands/cool.js.map +0 -0
- package/dist/cli/commands/disable.d.ts +0 -0
- package/dist/cli/commands/disable.js +0 -0
- package/dist/cli/commands/disable.js.map +0 -0
- package/dist/cli/commands/doctor.d.ts +4 -28
- package/dist/cli/commands/doctor.js +156 -68
- package/dist/cli/commands/doctor.js.map +1 -1
- package/dist/cli/commands/enable.d.ts +0 -0
- package/dist/cli/commands/enable.js +0 -0
- package/dist/cli/commands/enable.js.map +0 -0
- package/dist/cli/commands/evaluate.d.ts +9 -3
- package/dist/cli/commands/evaluate.js +31 -5
- package/dist/cli/commands/evaluate.js.map +1 -1
- package/dist/cli/commands/export.d.ts +0 -0
- package/dist/cli/commands/export.js +0 -0
- package/dist/cli/commands/export.js.map +0 -0
- package/dist/cli/commands/feedback.d.ts +0 -0
- package/dist/cli/commands/feedback.js +4 -0
- package/dist/cli/commands/feedback.js.map +1 -1
- package/dist/cli/commands/import.d.ts +0 -0
- package/dist/cli/commands/import.js +0 -0
- package/dist/cli/commands/import.js.map +0 -0
- package/dist/cli/commands/init.d.ts +28 -0
- package/dist/cli/commands/init.js +432 -0
- package/dist/cli/commands/init.js.map +1 -0
- package/dist/cli/commands/inspect.d.ts +0 -0
- package/dist/cli/commands/inspect.js +271 -37
- package/dist/cli/commands/inspect.js.map +1 -1
- package/dist/cli/commands/install.d.ts +0 -0
- package/dist/cli/commands/install.js +9 -0
- package/dist/cli/commands/install.js.map +1 -1
- package/dist/cli/commands/maintenance.d.ts +0 -0
- package/dist/cli/commands/maintenance.js +1 -1
- package/dist/cli/commands/maintenance.js.map +1 -1
- package/dist/cli/commands/mcp-server.d.ts +0 -0
- package/dist/cli/commands/mcp-server.js +4 -0
- package/dist/cli/commands/mcp-server.js.map +1 -1
- package/dist/cli/commands/models.d.ts +0 -0
- package/dist/cli/commands/models.js +0 -0
- package/dist/cli/commands/models.js.map +0 -0
- package/dist/cli/commands/repair.d.ts +0 -0
- package/dist/cli/commands/repair.js +3 -3
- package/dist/cli/commands/repair.js.map +1 -1
- package/dist/cli/commands/retire.d.ts +0 -0
- package/dist/cli/commands/retire.js +0 -0
- package/dist/cli/commands/retire.js.map +0 -0
- package/dist/cli/commands/rollback.d.ts +0 -0
- package/dist/cli/commands/rollback.js +0 -0
- package/dist/cli/commands/rollback.js.map +0 -0
- package/dist/cli/commands/stats.d.ts +0 -0
- package/dist/cli/commands/stats.js +0 -0
- package/dist/cli/commands/stats.js.map +0 -0
- package/dist/cli/commands/status.d.ts +0 -0
- package/dist/cli/commands/status.js +89 -7
- package/dist/cli/commands/status.js.map +1 -1
- package/dist/cli/commands/upgrade.d.ts +0 -0
- package/dist/cli/commands/upgrade.js +0 -0
- package/dist/cli/commands/upgrade.js.map +0 -0
- package/dist/cli/dispatch.d.ts +0 -0
- package/dist/cli/dispatch.js +36 -9
- package/dist/cli/dispatch.js.map +1 -1
- package/dist/cli/index.d.ts +0 -0
- package/dist/cli/index.js.map +0 -0
- package/dist/cli/state-model.d.ts +14 -0
- package/dist/cli/state-model.js +23 -0
- package/dist/cli/state-model.js.map +1 -0
- package/dist/config/config-schema.d.ts +209 -0
- package/dist/config/config-schema.js +168 -1
- package/dist/config/config-schema.js.map +1 -1
- package/dist/config/default-config.d.ts +0 -0
- package/dist/config/default-config.js +22 -1
- package/dist/config/default-config.js.map +1 -1
- package/dist/config/load-config.d.ts +0 -0
- package/dist/config/load-config.js +91 -2
- package/dist/config/load-config.js.map +1 -1
- package/dist/config/path-resolver.d.ts +0 -1
- package/dist/config/path-resolver.js +0 -2
- package/dist/config/path-resolver.js.map +1 -1
- package/dist/config/runtime-env.d.ts +8 -0
- package/dist/config/runtime-env.js +14 -0
- package/dist/config/runtime-env.js.map +1 -0
- package/dist/config/secrets-store.d.ts +15 -0
- package/dist/config/secrets-store.js +56 -0
- package/dist/config/secrets-store.js.map +1 -0
- package/dist/config/settings-store.d.ts +29 -0
- package/dist/config/settings-store.js +55 -0
- package/dist/config/settings-store.js.map +1 -1
- package/dist/controller/candidate-retriever.d.ts +49 -2
- package/dist/controller/candidate-retriever.js +258 -125
- package/dist/controller/candidate-retriever.js.map +1 -1
- package/dist/controller/injection-renderer.d.ts +0 -0
- package/dist/controller/injection-renderer.js +52 -1
- package/dist/controller/injection-renderer.js.map +1 -1
- package/dist/controller/injection-scorecard.d.ts +2 -2
- package/dist/controller/injection-scorecard.js +47 -1
- package/dist/controller/injection-scorecard.js.map +1 -1
- package/dist/controller/inline-notice.d.ts +0 -0
- package/dist/controller/inline-notice.js +0 -0
- package/dist/controller/inline-notice.js.map +0 -0
- package/dist/controller/intervention-controller.d.ts +3 -2
- package/dist/controller/intervention-controller.js +339 -17
- package/dist/controller/intervention-controller.js.map +1 -1
- package/dist/controller/lexical-retriever.d.ts +14 -0
- package/dist/controller/lexical-retriever.js +117 -0
- package/dist/controller/lexical-retriever.js.map +1 -0
- package/dist/controller/model-reranker.d.ts +20 -0
- package/dist/controller/model-reranker.js +187 -0
- package/dist/controller/model-reranker.js.map +1 -0
- package/dist/controller/node-ranker.d.ts +0 -0
- package/dist/controller/node-ranker.js +1 -0
- package/dist/controller/node-ranker.js.map +1 -1
- package/dist/controller/policy-enricher.d.ts +10 -0
- package/dist/controller/policy-enricher.js +186 -0
- package/dist/controller/policy-enricher.js.map +1 -0
- package/dist/controller/query-rewrite.d.ts +8 -0
- package/dist/controller/query-rewrite.js +69 -0
- package/dist/controller/query-rewrite.js.map +1 -0
- package/dist/controller/retrieval-context.d.ts +3 -0
- package/dist/controller/retrieval-context.js +37 -0
- package/dist/controller/retrieval-context.js.map +1 -0
- package/dist/controller/second-opinion-gate.d.ts +41 -0
- package/dist/controller/second-opinion-gate.js +225 -0
- package/dist/controller/second-opinion-gate.js.map +1 -0
- package/dist/controller/trigger-evaluator.d.ts +27 -2
- package/dist/controller/trigger-evaluator.js +63 -3
- package/dist/controller/trigger-evaluator.js.map +1 -1
- package/dist/distillation/errors.d.ts +0 -0
- package/dist/distillation/errors.js +0 -0
- package/dist/distillation/errors.js.map +0 -0
- package/dist/distillation/experience-family.d.ts +4 -0
- package/dist/distillation/experience-family.js +14 -0
- package/dist/distillation/experience-family.js.map +1 -0
- package/dist/distillation/host-llm.d.ts +1 -0
- package/dist/distillation/host-llm.js +5 -1
- package/dist/distillation/host-llm.js.map +1 -1
- package/dist/distillation/llm-distiller.d.ts +0 -0
- package/dist/distillation/llm-distiller.js +4 -0
- package/dist/distillation/llm-distiller.js.map +1 -1
- package/dist/distillation/merge-decider.d.ts +0 -0
- package/dist/distillation/merge-decider.js +4 -0
- package/dist/distillation/merge-decider.js.map +1 -1
- package/dist/distillation/model-catalog.d.ts +0 -0
- package/dist/distillation/model-catalog.js +0 -0
- package/dist/distillation/model-catalog.js.map +0 -0
- package/dist/distillation/prompt-contract.d.ts +1 -1
- package/dist/distillation/prompt-contract.js +6 -1
- package/dist/distillation/prompt-contract.js.map +1 -1
- package/dist/distillation/providers/anthropic.d.ts +0 -0
- package/dist/distillation/providers/anthropic.js +0 -0
- package/dist/distillation/providers/anthropic.js.map +0 -0
- package/dist/distillation/providers/azure-openai.d.ts +0 -0
- package/dist/distillation/providers/azure-openai.js +0 -0
- package/dist/distillation/providers/azure-openai.js.map +0 -0
- package/dist/distillation/providers/baidu-qianfan.d.ts +0 -0
- package/dist/distillation/providers/baidu-qianfan.js +0 -0
- package/dist/distillation/providers/baidu-qianfan.js.map +0 -0
- package/dist/distillation/providers/bedrock.d.ts +0 -0
- package/dist/distillation/providers/bedrock.js +0 -0
- package/dist/distillation/providers/bedrock.js.map +0 -0
- package/dist/distillation/providers/dashscope.d.ts +0 -0
- package/dist/distillation/providers/dashscope.js +0 -0
- package/dist/distillation/providers/dashscope.js.map +0 -0
- package/dist/distillation/providers/deepseek.d.ts +0 -0
- package/dist/distillation/providers/deepseek.js +0 -0
- package/dist/distillation/providers/deepseek.js.map +0 -0
- package/dist/distillation/providers/gemini.d.ts +0 -0
- package/dist/distillation/providers/gemini.js +5 -1
- package/dist/distillation/providers/gemini.js.map +1 -1
- package/dist/distillation/providers/google-adc.d.ts +0 -0
- package/dist/distillation/providers/google-adc.js +0 -0
- package/dist/distillation/providers/google-adc.js.map +0 -0
- package/dist/distillation/providers/minimax.d.ts +0 -0
- package/dist/distillation/providers/minimax.js +0 -0
- package/dist/distillation/providers/minimax.js.map +0 -0
- package/dist/distillation/providers/moonshot.d.ts +0 -0
- package/dist/distillation/providers/moonshot.js +0 -0
- package/dist/distillation/providers/moonshot.js.map +0 -0
- package/dist/distillation/providers/openai-compatible-factory.d.ts +0 -0
- package/dist/distillation/providers/openai-compatible-factory.js +0 -0
- package/dist/distillation/providers/openai-compatible-factory.js.map +0 -0
- package/dist/distillation/providers/openai-compatible.d.ts +0 -0
- package/dist/distillation/providers/openai-compatible.js +0 -0
- package/dist/distillation/providers/openai-compatible.js.map +0 -0
- package/dist/distillation/providers/openai.d.ts +0 -0
- package/dist/distillation/providers/openai.js +0 -0
- package/dist/distillation/providers/openai.js.map +0 -0
- package/dist/distillation/providers/openrouter.d.ts +0 -0
- package/dist/distillation/providers/openrouter.js +0 -0
- package/dist/distillation/providers/openrouter.js.map +0 -0
- package/dist/distillation/providers/registry.d.ts +0 -0
- package/dist/distillation/providers/registry.js +0 -0
- package/dist/distillation/providers/registry.js.map +0 -0
- package/dist/distillation/providers/siliconflow.d.ts +0 -0
- package/dist/distillation/providers/siliconflow.js +0 -0
- package/dist/distillation/providers/siliconflow.js.map +0 -0
- package/dist/distillation/providers/tencent-hunyuan.d.ts +0 -0
- package/dist/distillation/providers/tencent-hunyuan.js +0 -0
- package/dist/distillation/providers/tencent-hunyuan.js.map +0 -0
- package/dist/distillation/providers/types.d.ts +0 -0
- package/dist/distillation/providers/types.js +0 -0
- package/dist/distillation/providers/types.js.map +0 -0
- package/dist/distillation/providers/volcengine-ark.d.ts +0 -0
- package/dist/distillation/providers/volcengine-ark.js +0 -0
- package/dist/distillation/providers/volcengine-ark.js.map +0 -0
- package/dist/distillation/providers/zhipu.d.ts +0 -0
- package/dist/distillation/providers/zhipu.js +0 -0
- package/dist/distillation/providers/zhipu.js.map +0 -0
- package/dist/distillation/queue-worker.d.ts +0 -0
- package/dist/distillation/queue-worker.js +78 -9
- package/dist/distillation/queue-worker.js.map +1 -1
- package/dist/distillation/types.d.ts +0 -0
- package/dist/distillation/types.js +0 -0
- package/dist/distillation/types.js.map +0 -0
- package/dist/evaluation/benchmark-report.d.ts +0 -0
- package/dist/evaluation/benchmark-report.js +0 -0
- package/dist/evaluation/benchmark-report.js.map +0 -0
- package/dist/evaluation/benchmark-summary.d.ts +0 -0
- package/dist/evaluation/benchmark-summary.js +0 -0
- package/dist/evaluation/benchmark-summary.js.map +0 -0
- package/dist/evaluation/codex-lifecycle-validation.d.ts +60 -0
- package/dist/evaluation/codex-lifecycle-validation.js +233 -0
- package/dist/evaluation/codex-lifecycle-validation.js.map +1 -0
- package/dist/evaluation/hybrid-phase1-rollout-summary.d.ts +63 -0
- package/dist/evaluation/hybrid-phase1-rollout-summary.js +108 -0
- package/dist/evaluation/hybrid-phase1-rollout-summary.js.map +1 -0
- package/dist/evaluation/hybrid-phase3-gate-metrics.d.ts +26 -0
- package/dist/evaluation/hybrid-phase3-gate-metrics.js +23 -0
- package/dist/evaluation/hybrid-phase3-gate-metrics.js.map +1 -0
- package/dist/evaluation/openclaw-baseline.d.ts +8 -0
- package/dist/evaluation/openclaw-baseline.js +27 -0
- package/dist/evaluation/openclaw-baseline.js.map +1 -1
- package/dist/evaluation/openclaw-scenarios.d.ts +0 -0
- package/dist/evaluation/openclaw-scenarios.js +0 -0
- package/dist/evaluation/openclaw-scenarios.js.map +0 -0
- package/dist/experience-management/governance-observability.d.ts +13 -0
- package/dist/experience-management/governance-observability.js +37 -0
- package/dist/experience-management/governance-observability.js.map +1 -0
- package/dist/experience-management/node-lifecycle-governance.d.ts +8 -0
- package/dist/experience-management/node-lifecycle-governance.js +80 -0
- package/dist/experience-management/node-lifecycle-governance.js.map +1 -0
- package/dist/experience-management/task-management-signals.d.ts +29 -0
- package/dist/experience-management/task-management-signals.js +148 -0
- package/dist/experience-management/task-management-signals.js.map +1 -0
- package/dist/feedback/automatic-attribution.d.ts +0 -0
- package/dist/feedback/automatic-attribution.js +0 -0
- package/dist/feedback/automatic-attribution.js.map +0 -0
- package/dist/feedback/feedback-manager.d.ts +4 -1
- package/dist/feedback/feedback-manager.js +11 -22
- package/dist/feedback/feedback-manager.js.map +1 -1
- package/dist/feedback/harm-detector.d.ts +0 -0
- package/dist/feedback/harm-detector.js +0 -0
- package/dist/feedback/harm-detector.js.map +0 -0
- package/dist/feedback/state-transition.d.ts +6 -1
- package/dist/feedback/state-transition.js +14 -2
- package/dist/feedback/state-transition.js.map +1 -1
- package/dist/feedback/stats-updater.d.ts +0 -0
- package/dist/feedback/stats-updater.js +0 -0
- package/dist/feedback/stats-updater.js.map +0 -0
- package/dist/hybrid/capsule-builder.d.ts +23 -0
- package/dist/hybrid/capsule-builder.js +114 -0
- package/dist/hybrid/capsule-builder.js.map +1 -0
- package/dist/hybrid/explain-provider-client.d.ts +19 -0
- package/dist/hybrid/explain-provider-client.js +34 -0
- package/dist/hybrid/explain-provider-client.js.map +1 -0
- package/dist/hybrid/postmortem-provider-client.d.ts +19 -0
- package/dist/hybrid/postmortem-provider-client.js +34 -0
- package/dist/hybrid/postmortem-provider-client.js.map +1 -0
- package/dist/hybrid/rollout.d.ts +9 -0
- package/dist/hybrid/rollout.js +49 -0
- package/dist/hybrid/rollout.js.map +1 -0
- package/dist/hybrid/router.d.ts +4 -0
- package/dist/hybrid/router.js +62 -0
- package/dist/hybrid/router.js.map +1 -0
- package/dist/hybrid/types.d.ts +140 -0
- package/dist/{compiler → hybrid}/types.js +0 -0
- package/dist/{packs → hybrid}/types.js.map +1 -1
- package/dist/hybrid/validators.d.ts +5 -0
- package/dist/hybrid/validators.js +94 -0
- package/dist/hybrid/validators.js.map +1 -0
- package/dist/hybrid/worker-client.d.ts +61 -0
- package/dist/hybrid/worker-client.js +196 -0
- package/dist/hybrid/worker-client.js.map +1 -0
- package/dist/hybrid/workers/explain-decision-llm.d.ts +8 -0
- package/dist/hybrid/workers/explain-decision-llm.js +152 -0
- package/dist/hybrid/workers/explain-decision-llm.js.map +1 -0
- package/dist/hybrid/workers/explain-decision.d.ts +2 -0
- package/dist/hybrid/workers/explain-decision.js +40 -0
- package/dist/hybrid/workers/explain-decision.js.map +1 -0
- package/dist/hybrid/workers/postmortem-review-llm.d.ts +8 -0
- package/dist/hybrid/workers/postmortem-review-llm.js +398 -0
- package/dist/hybrid/workers/postmortem-review-llm.js.map +1 -0
- package/dist/hybrid/workers/postmortem-review.d.ts +2 -0
- package/dist/hybrid/workers/postmortem-review.js +66 -0
- package/dist/hybrid/workers/postmortem-review.js.map +1 -0
- package/dist/index.d.ts +0 -0
- package/dist/index.js +0 -0
- package/dist/index.js.map +0 -0
- package/dist/input/context-summary-adapter.d.ts +0 -0
- package/dist/input/context-summary-adapter.js +0 -0
- package/dist/input/context-summary-adapter.js.map +0 -0
- package/dist/input/input-adapter.d.ts +0 -0
- package/dist/input/input-adapter.js +2 -1
- package/dist/input/input-adapter.js.map +1 -1
- package/dist/input/outcome-resolver.d.ts +0 -0
- package/dist/input/outcome-resolver.js +5 -5
- package/dist/input/outcome-resolver.js.map +1 -1
- package/dist/input/scope-resolver.d.ts +0 -0
- package/dist/input/scope-resolver.js +0 -0
- package/dist/input/scope-resolver.js.map +0 -0
- package/dist/input/tasktype-resolver.d.ts +0 -0
- package/dist/input/tasktype-resolver.js +2 -0
- package/dist/input/tasktype-resolver.js.map +1 -1
- package/dist/input/tool-event-significance.d.ts +5 -0
- package/dist/input/tool-event-significance.js +7 -0
- package/dist/input/tool-event-significance.js.map +1 -0
- package/dist/install/claude-cli.d.ts +0 -0
- package/dist/install/claude-cli.js +0 -0
- package/dist/install/claude-cli.js.map +0 -0
- package/dist/install/claude-code-doctor.d.ts +8 -2
- package/dist/install/claude-code-doctor.js +54 -9
- package/dist/install/claude-code-doctor.js.map +1 -1
- package/dist/install/claude-code-installer.d.ts +0 -0
- package/dist/install/claude-code-installer.js +50 -1
- package/dist/install/claude-code-installer.js.map +1 -1
- package/dist/install/claude-marketplace-state.d.ts +14 -0
- package/dist/install/claude-marketplace-state.js +47 -0
- package/dist/install/claude-marketplace-state.js.map +1 -0
- package/dist/install/claude-runtime-target.d.ts +0 -0
- package/dist/install/claude-runtime-target.js +0 -0
- package/dist/install/claude-runtime-target.js.map +0 -0
- package/dist/install/codex-cli.d.ts +15 -0
- package/dist/install/codex-cli.js +55 -3
- package/dist/install/codex-cli.js.map +1 -1
- package/dist/install/codex-installer.d.ts +18 -0
- package/dist/install/codex-installer.js +91 -1
- package/dist/install/codex-installer.js.map +1 -1
- package/dist/install/codex-runtime-target.d.ts +0 -0
- package/dist/install/codex-runtime-target.js +0 -0
- package/dist/install/codex-runtime-target.js.map +0 -0
- package/dist/install/host-detection.d.ts +0 -0
- package/dist/install/host-detection.js +0 -0
- package/dist/install/host-detection.js.map +0 -0
- package/dist/install/openclaw-cli.d.ts +11 -0
- package/dist/install/openclaw-cli.js +0 -0
- package/dist/install/openclaw-cli.js.map +1 -1
- package/dist/install/openclaw-installer.d.ts +12 -0
- package/dist/install/openclaw-installer.js +198 -31
- package/dist/install/openclaw-installer.js.map +1 -1
- package/dist/install/public-install.d.ts +14 -4
- package/dist/install/public-install.js +20 -7
- package/dist/install/public-install.js.map +1 -1
- package/dist/install/registry-health.d.ts +0 -0
- package/dist/install/registry-health.js +0 -0
- package/dist/install/registry-health.js.map +0 -0
- package/dist/interaction/operational-actions-service.d.ts +0 -0
- package/dist/interaction/operational-actions-service.js +0 -0
- package/dist/interaction/operational-actions-service.js.map +0 -0
- package/dist/interaction/operational-service.d.ts +0 -0
- package/dist/interaction/operational-service.js +0 -0
- package/dist/interaction/operational-service.js.map +0 -0
- package/dist/interaction/repo-summary.d.ts +3 -17
- package/dist/interaction/repo-summary.js +10 -27
- package/dist/interaction/repo-summary.js.map +1 -1
- package/dist/interaction/service.d.ts +59 -95
- package/dist/interaction/service.js +505 -266
- package/dist/interaction/service.js.map +1 -1
- package/dist/interaction/state-artifact-service.d.ts +0 -0
- package/dist/interaction/state-artifact-service.js +0 -0
- package/dist/interaction/state-artifact-service.js.map +0 -0
- package/dist/maintenance/claude-validate-print.d.ts +0 -0
- package/dist/maintenance/claude-validate-print.js +0 -0
- package/dist/maintenance/claude-validate-print.js.map +0 -0
- package/dist/maintenance/embedding-smoke.d.ts +0 -0
- package/dist/maintenance/embedding-smoke.js +0 -0
- package/dist/maintenance/embedding-smoke.js.map +0 -0
- package/dist/maintenance/redistill-rule-nodes.d.ts +0 -0
- package/dist/maintenance/redistill-rule-nodes.js +0 -0
- package/dist/maintenance/redistill-rule-nodes.js.map +0 -0
- package/dist/maintenance/scope-merge.d.ts +0 -1
- package/dist/maintenance/scope-merge.js +0 -20
- package/dist/maintenance/scope-merge.js.map +1 -1
- package/dist/maintenance/warning-variant-cleanup.d.ts +0 -0
- package/dist/maintenance/warning-variant-cleanup.js +0 -0
- package/dist/maintenance/warning-variant-cleanup.js.map +0 -0
- package/dist/plugin/fixture-sanitizer.d.ts +0 -0
- package/dist/plugin/fixture-sanitizer.js +0 -0
- package/dist/plugin/fixture-sanitizer.js.map +0 -0
- package/dist/plugin/hooks/before-prompt-build.d.ts +1 -0
- package/dist/plugin/hooks/before-prompt-build.js +4 -1
- package/dist/plugin/hooks/before-prompt-build.js.map +1 -1
- package/dist/plugin/hooks/message-sent.d.ts +0 -0
- package/dist/plugin/hooks/message-sent.js +0 -0
- package/dist/plugin/hooks/message-sent.js.map +0 -0
- package/dist/plugin/hooks/tool-result-persist.d.ts +0 -0
- package/dist/plugin/hooks/tool-result-persist.js +0 -0
- package/dist/plugin/hooks/tool-result-persist.js.map +0 -0
- package/dist/plugin/openclaw-install-state.d.ts +39 -0
- package/dist/plugin/openclaw-install-state.js +24 -0
- package/dist/plugin/openclaw-install-state.js.map +1 -0
- package/dist/plugin/openclaw-plugin.d.ts +148 -0
- package/dist/plugin/openclaw-plugin.js +98 -7
- package/dist/plugin/openclaw-plugin.js.map +1 -1
- package/dist/plugin/openclaw-routine-interaction.d.ts +7 -0
- package/dist/plugin/openclaw-routine-interaction.js +301 -0
- package/dist/plugin/openclaw-routine-interaction.js.map +1 -0
- package/dist/plugin/openclaw-runtime-defaults.d.ts +16 -0
- package/dist/plugin/openclaw-runtime-defaults.js +16 -0
- package/dist/plugin/openclaw-runtime-defaults.js.map +1 -0
- package/dist/plugin/runtime-capture.d.ts +0 -0
- package/dist/plugin/runtime-capture.js +0 -0
- package/dist/plugin/runtime-capture.js.map +0 -0
- package/dist/plugin/runtime-helpers.d.ts +0 -0
- package/dist/plugin/runtime-helpers.js +0 -0
- package/dist/plugin/runtime-helpers.js.map +0 -0
- package/dist/runtime/service.d.ts +33 -6
- package/dist/runtime/service.js +427 -50
- package/dist/runtime/service.js.map +1 -1
- package/dist/store/logs/jsonl-logger.d.ts +0 -0
- package/dist/store/logs/jsonl-logger.js +0 -0
- package/dist/store/logs/jsonl-logger.js.map +0 -0
- package/dist/store/sqlite/db.d.ts +0 -0
- package/dist/store/sqlite/db.js +37 -0
- package/dist/store/sqlite/db.js.map +1 -1
- package/dist/store/sqlite/migrations.d.ts +0 -0
- package/dist/store/sqlite/migrations.js +0 -0
- package/dist/store/sqlite/migrations.js.map +0 -0
- package/dist/store/sqlite/repositories/candidate-repo.d.ts +0 -0
- package/dist/store/sqlite/repositories/candidate-repo.js +8 -2
- package/dist/store/sqlite/repositories/candidate-repo.js.map +1 -1
- package/dist/store/sqlite/repositories/distillation-job-repo.d.ts +0 -0
- package/dist/store/sqlite/repositories/distillation-job-repo.js +0 -0
- package/dist/store/sqlite/repositories/distillation-job-repo.js.map +0 -0
- package/dist/store/sqlite/repositories/hybrid-invocation-trace-repo.d.ts +11 -0
- package/dist/store/sqlite/repositories/hybrid-invocation-trace-repo.js +76 -0
- package/dist/store/sqlite/repositories/hybrid-invocation-trace-repo.js.map +1 -0
- package/dist/store/sqlite/repositories/hybrid-review-artifact-repo.d.ts +11 -0
- package/dist/store/sqlite/repositories/hybrid-review-artifact-repo.js +73 -0
- package/dist/store/sqlite/repositories/hybrid-review-artifact-repo.js.map +1 -0
- package/dist/store/sqlite/repositories/injection-repo.d.ts +1 -0
- package/dist/store/sqlite/repositories/injection-repo.js +11 -0
- package/dist/store/sqlite/repositories/injection-repo.js.map +1 -1
- package/dist/store/sqlite/repositories/input-record-repo.d.ts +3 -0
- package/dist/store/sqlite/repositories/input-record-repo.js +35 -0
- package/dist/store/sqlite/repositories/input-record-repo.js.map +1 -1
- package/dist/store/sqlite/repositories/node-repo.d.ts +3 -0
- package/dist/store/sqlite/repositories/node-repo.js +62 -8
- package/dist/store/sqlite/repositories/node-repo.js.map +1 -1
- package/dist/store/sqlite/repositories/outcome-record-repo.d.ts +0 -0
- package/dist/store/sqlite/repositories/outcome-record-repo.js +0 -0
- package/dist/store/sqlite/repositories/outcome-record-repo.js.map +0 -0
- package/dist/store/sqlite/repositories/review-event-repo.d.ts +0 -0
- package/dist/store/sqlite/repositories/review-event-repo.js +0 -0
- package/dist/store/sqlite/repositories/review-event-repo.js.map +0 -0
- package/dist/store/sqlite/repositories/scope-repo.d.ts +0 -0
- package/dist/store/sqlite/repositories/scope-repo.js +0 -0
- package/dist/store/sqlite/repositories/scope-repo.js.map +0 -0
- package/dist/store/sqlite/repositories/stats-repo.d.ts +0 -0
- package/dist/store/sqlite/repositories/stats-repo.js +0 -0
- package/dist/store/sqlite/repositories/stats-repo.js.map +0 -0
- package/dist/store/sqlite/repositories/task-run-repo.d.ts +2 -0
- package/dist/store/sqlite/repositories/task-run-repo.js +18 -2
- package/dist/store/sqlite/repositories/task-run-repo.js.map +1 -1
- package/dist/store/sqlite/schema.sql +49 -49
- package/dist/store/vector/api-embedding-provider.d.ts +2 -0
- package/dist/store/vector/api-embedding-provider.js +23 -19
- package/dist/store/vector/api-embedding-provider.js.map +1 -1
- package/dist/store/vector/embeddings.d.ts +1 -1
- package/dist/store/vector/embeddings.js +26 -5
- package/dist/store/vector/embeddings.js.map +1 -1
- package/dist/store/vector/lancedb.d.ts +0 -0
- package/dist/store/vector/lancedb.js +0 -0
- package/dist/store/vector/lancedb.js.map +0 -0
- package/dist/store/vector/local-provider.d.ts +0 -0
- package/dist/store/vector/local-provider.js +0 -0
- package/dist/store/vector/local-provider.js.map +0 -0
- package/dist/store/vector/node-index.d.ts +0 -0
- package/dist/store/vector/node-index.js +0 -0
- package/dist/store/vector/node-index.js.map +0 -0
- package/dist/store/vector/provider-types.d.ts +0 -0
- package/dist/store/vector/provider-types.js +0 -0
- package/dist/store/vector/provider-types.js.map +0 -0
- package/dist/types/analyzer.d.ts +0 -0
- package/dist/types/analyzer.js +0 -0
- package/dist/types/analyzer.js.map +0 -0
- package/dist/types/domain.d.ts +166 -47
- package/dist/types/domain.js +0 -0
- package/dist/types/domain.js.map +0 -0
- package/dist/types/plugin.d.ts +3 -1
- package/dist/types/plugin.js +0 -0
- package/dist/types/plugin.js.map +0 -0
- package/dist/types/storage.d.ts +0 -0
- package/dist/types/storage.js +0 -0
- package/dist/types/storage.js.map +0 -0
- package/dist/utils/clock.d.ts +0 -0
- package/dist/utils/clock.js +0 -0
- package/dist/utils/clock.js.map +0 -0
- package/dist/utils/errors.d.ts +0 -0
- package/dist/utils/errors.js +0 -0
- package/dist/utils/errors.js.map +0 -0
- package/dist/utils/hashing.d.ts +0 -0
- package/dist/utils/hashing.js +0 -0
- package/dist/utils/hashing.js.map +0 -0
- package/dist/utils/ids.d.ts +0 -0
- package/dist/utils/ids.js +0 -0
- package/dist/utils/ids.js.map +0 -0
- package/dist/utils/text.d.ts +0 -0
- package/dist/utils/text.js +0 -0
- package/dist/utils/text.js.map +0 -0
- package/dist/version/package-version.d.ts +0 -0
- package/dist/version/package-version.js +0 -0
- package/dist/version/package-version.js.map +0 -0
- package/dist/version/remote-release.d.ts +0 -0
- package/dist/version/remote-release.js +0 -0
- package/dist/version/remote-release.js.map +0 -0
- package/docs/releases/v0.1.0.md +0 -0
- package/docs/releases/v0.1.1.md +0 -0
- package/docs/releases/v0.1.2.md +3 -3
- package/docs/releases/v0.1.3.md +95 -0
- package/docs/releases/v0.2.0.md +85 -0
- package/docs/user-guide.md +263 -133
- package/hooks/hooks.json +0 -0
- package/openclaw.plugin.json +81 -1
- package/package.json +25 -16
- package/plugins/claude-code-experienceengine/.claude-plugin/plugin.json +1 -1
- package/plugins/claude-code-experienceengine/.mcp.json +4 -3
- package/plugins/claude-code-experienceengine/hooks/hooks.json +0 -0
- package/plugins/claude-code-experienceengine/scripts/claude-hook.sh +30 -1
- package/plugins/claude-code-experienceengine/scripts/install-deps.sh +41 -6
- package/scripts/claude-plugin/claude-hook.sh +0 -0
- package/scripts/claude-plugin/install-deps.sh +0 -0
- package/dist/cli/commands/pack.d.ts +0 -1
- package/dist/cli/commands/pack.js +0 -321
- package/dist/cli/commands/pack.js.map +0 -1
- package/dist/compiler/agents-renderer.d.ts +0 -4
- package/dist/compiler/agents-renderer.js +0 -105
- package/dist/compiler/agents-renderer.js.map +0 -1
- package/dist/compiler/claude-renderer.d.ts +0 -2
- package/dist/compiler/claude-renderer.js +0 -40
- package/dist/compiler/claude-renderer.js.map +0 -1
- package/dist/compiler/codex-renderer.d.ts +0 -2
- package/dist/compiler/codex-renderer.js +0 -40
- package/dist/compiler/codex-renderer.js.map +0 -1
- package/dist/compiler/compiler.d.ts +0 -4
- package/dist/compiler/compiler.js +0 -87
- package/dist/compiler/compiler.js.map +0 -1
- package/dist/compiler/deployer.d.ts +0 -21
- package/dist/compiler/deployer.js +0 -64
- package/dist/compiler/deployer.js.map +0 -1
- package/dist/compiler/github-renderer.d.ts +0 -2
- package/dist/compiler/github-renderer.js +0 -63
- package/dist/compiler/github-renderer.js.map +0 -1
- package/dist/compiler/types.d.ts +0 -45
- package/dist/compiler/types.js.map +0 -1
- package/dist/interaction/pack-actions-service.d.ts +0 -59
- package/dist/interaction/pack-actions-service.js +0 -172
- package/dist/interaction/pack-actions-service.js.map +0 -1
- package/dist/packs/fs-registry.d.ts +0 -27
- package/dist/packs/fs-registry.js +0 -216
- package/dist/packs/fs-registry.js.map +0 -1
- package/dist/packs/index-sync.d.ts +0 -9
- package/dist/packs/index-sync.js +0 -54
- package/dist/packs/index-sync.js.map +0 -1
- package/dist/packs/types.d.ts +0 -55
- package/dist/packs/types.js +0 -2
- package/dist/store/sqlite/repositories/pack-repo.d.ts +0 -16
- package/dist/store/sqlite/repositories/pack-repo.js +0 -192
- package/dist/store/sqlite/repositories/pack-repo.js.map +0 -1
package/openclaw.plugin.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"id": "experienceengine",
|
|
3
3
|
"name": "ExperienceEngine",
|
|
4
|
-
"version": "0.
|
|
4
|
+
"version": "0.2.0",
|
|
5
5
|
"description": "Context-aware experience intervention controller for coding and debugging tasks.",
|
|
6
6
|
"configSchema": {
|
|
7
7
|
"type": "object",
|
|
@@ -28,6 +28,15 @@
|
|
|
28
28
|
"type": "string",
|
|
29
29
|
"description": "Directory used to store raw runtime payload captures."
|
|
30
30
|
},
|
|
31
|
+
"distillerProvider": {
|
|
32
|
+
"type": "string",
|
|
33
|
+
"enum": ["openai", "anthropic", "gemini", "openrouter", "deepseek", "bedrock", "vertex_gemini", "groq", "openai_compatible"],
|
|
34
|
+
"description": "Distillation provider reused by phase 2 provider-backed explain."
|
|
35
|
+
},
|
|
36
|
+
"distillerModel": {
|
|
37
|
+
"type": "string",
|
|
38
|
+
"description": "Distillation model identifier reused by phase 2 provider-backed explain."
|
|
39
|
+
},
|
|
31
40
|
"maxHints": {
|
|
32
41
|
"type": "integer",
|
|
33
42
|
"minimum": 1,
|
|
@@ -39,6 +48,44 @@
|
|
|
39
48
|
"minimum": 0,
|
|
40
49
|
"maximum": 1,
|
|
41
50
|
"description": "Trigger threshold for intervention gating."
|
|
51
|
+
},
|
|
52
|
+
"hybridEnabled": {
|
|
53
|
+
"type": "boolean",
|
|
54
|
+
"description": "Enable the hybrid routing layer."
|
|
55
|
+
},
|
|
56
|
+
"hybridSyncExplainEnabled": {
|
|
57
|
+
"type": "boolean",
|
|
58
|
+
"description": "Allow bounded sync escalation for explicit explanation requests."
|
|
59
|
+
},
|
|
60
|
+
"hybridAsyncPostmortemEnabled": {
|
|
61
|
+
"type": "boolean",
|
|
62
|
+
"description": "Allow bounded async postmortem review for eligible completed runs."
|
|
63
|
+
},
|
|
64
|
+
"hybridAsyncPostmortemLlmEnabled": {
|
|
65
|
+
"type": "boolean",
|
|
66
|
+
"description": "Enable provider-backed postmortem_review in phase 3."
|
|
67
|
+
},
|
|
68
|
+
"hybridExplainLlmEnabled": {
|
|
69
|
+
"type": "boolean",
|
|
70
|
+
"description": "Enable provider-backed explain_decision in phase 2."
|
|
71
|
+
},
|
|
72
|
+
"hybridExplainProviderMode": {
|
|
73
|
+
"type": "string",
|
|
74
|
+
"enum": ["shared_distiller"],
|
|
75
|
+
"description": "Provider resolution mode for phase 2 explain_decision."
|
|
76
|
+
},
|
|
77
|
+
"hybridExplainModelProfileVersion": {
|
|
78
|
+
"type": "string",
|
|
79
|
+
"description": "Version label for the provider-backed explain_decision model profile."
|
|
80
|
+
},
|
|
81
|
+
"hybridPostmortemProviderMode": {
|
|
82
|
+
"type": "string",
|
|
83
|
+
"enum": ["shared_distiller"],
|
|
84
|
+
"description": "Provider resolution mode for phase 3 postmortem_review."
|
|
85
|
+
},
|
|
86
|
+
"hybridPostmortemModelProfileVersion": {
|
|
87
|
+
"type": "string",
|
|
88
|
+
"description": "Version label for the provider-backed postmortem_review model profile."
|
|
42
89
|
}
|
|
43
90
|
}
|
|
44
91
|
},
|
|
@@ -61,11 +108,44 @@
|
|
|
61
108
|
"label": "Capture Directory",
|
|
62
109
|
"placeholder": "./data/runtime-captures"
|
|
63
110
|
},
|
|
111
|
+
"distillerProvider": {
|
|
112
|
+
"label": "Distiller Provider"
|
|
113
|
+
},
|
|
114
|
+
"distillerModel": {
|
|
115
|
+
"label": "Distiller Model"
|
|
116
|
+
},
|
|
64
117
|
"maxHints": {
|
|
65
118
|
"label": "Max Hints"
|
|
66
119
|
},
|
|
67
120
|
"triggerThreshold": {
|
|
68
121
|
"label": "Trigger Threshold"
|
|
122
|
+
},
|
|
123
|
+
"hybridEnabled": {
|
|
124
|
+
"label": "Hybrid Enabled"
|
|
125
|
+
},
|
|
126
|
+
"hybridSyncExplainEnabled": {
|
|
127
|
+
"label": "Hybrid Sync Explain Enabled"
|
|
128
|
+
},
|
|
129
|
+
"hybridAsyncPostmortemEnabled": {
|
|
130
|
+
"label": "Hybrid Async Postmortem Enabled"
|
|
131
|
+
},
|
|
132
|
+
"hybridAsyncPostmortemLlmEnabled": {
|
|
133
|
+
"label": "Hybrid Async Postmortem LLM Enabled"
|
|
134
|
+
},
|
|
135
|
+
"hybridExplainLlmEnabled": {
|
|
136
|
+
"label": "Hybrid Explain LLM Enabled"
|
|
137
|
+
},
|
|
138
|
+
"hybridExplainProviderMode": {
|
|
139
|
+
"label": "Hybrid Explain Provider Mode"
|
|
140
|
+
},
|
|
141
|
+
"hybridExplainModelProfileVersion": {
|
|
142
|
+
"label": "Hybrid Explain Model Profile Version"
|
|
143
|
+
},
|
|
144
|
+
"hybridPostmortemProviderMode": {
|
|
145
|
+
"label": "Hybrid Postmortem Provider Mode"
|
|
146
|
+
},
|
|
147
|
+
"hybridPostmortemModelProfileVersion": {
|
|
148
|
+
"label": "Hybrid Postmortem Model Profile Version"
|
|
69
149
|
}
|
|
70
150
|
}
|
|
71
151
|
}
|
package/package.json
CHANGED
|
@@ -1,8 +1,9 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@alan512/experienceengine",
|
|
3
|
-
"version": "0.
|
|
3
|
+
"version": "0.2.0",
|
|
4
4
|
"type": "module",
|
|
5
|
-
"description": "
|
|
5
|
+
"description": "Experience governance for coding agents: learn from real task outcomes, inject reusable hints, and retire low-value guidance.",
|
|
6
|
+
"license": "MIT",
|
|
6
7
|
"repository": {
|
|
7
8
|
"type": "git",
|
|
8
9
|
"url": "https://github.com/Alan-512/ExperienceEngine.git"
|
|
@@ -10,7 +11,15 @@
|
|
|
10
11
|
"openclaw": {
|
|
11
12
|
"extensions": [
|
|
12
13
|
"./dist/plugin/openclaw-plugin.js"
|
|
13
|
-
]
|
|
14
|
+
],
|
|
15
|
+
"compat": {
|
|
16
|
+
"pluginApi": ">=2026.4.1",
|
|
17
|
+
"minGatewayVersion": "2026.4.1"
|
|
18
|
+
},
|
|
19
|
+
"build": {
|
|
20
|
+
"openclawVersion": "2026.4.1",
|
|
21
|
+
"pluginSdkVersion": "2026.4.1"
|
|
22
|
+
}
|
|
14
23
|
},
|
|
15
24
|
"engines": {
|
|
16
25
|
"node": ">=20.0.0"
|
|
@@ -31,28 +40,28 @@
|
|
|
31
40
|
"scripts/claude-plugin",
|
|
32
41
|
".env.example"
|
|
33
42
|
],
|
|
43
|
+
"dependencies": {
|
|
44
|
+
"@huggingface/transformers": "^3.8.1",
|
|
45
|
+
"@modelcontextprotocol/sdk": "^1.27.1",
|
|
46
|
+
"zod": "^3.25.76"
|
|
47
|
+
},
|
|
48
|
+
"devDependencies": {
|
|
49
|
+
"@types/node": "^22.13.14",
|
|
50
|
+
"tsx": "^4.19.3",
|
|
51
|
+
"typescript": "^5.8.2",
|
|
52
|
+
"vitest": "^3.0.9"
|
|
53
|
+
},
|
|
34
54
|
"scripts": {
|
|
35
55
|
"build": "node scripts/build/clean-dist.mjs && tsc -p tsconfig.build.json && node scripts/build/copy-sqlite-schema.mjs",
|
|
36
56
|
"dev": "tsx watch src/cli/index.ts",
|
|
37
57
|
"evaluate:openclaw-baseline": "tsx src/cli/index.ts evaluate openclaw-baseline",
|
|
38
58
|
"evaluate:openclaw-scenarios": "tsx src/cli/index.ts evaluate openclaw-scenarios --pack high-confidence",
|
|
59
|
+
"evaluate:codex-lifecycle": "tsx src/cli/index.ts evaluate codex-lifecycle",
|
|
39
60
|
"maintenance:merge-warning-variants": "tsx scripts/maintenance/merge-warning-variants.ts",
|
|
40
61
|
"runtime:promote-payload": "tsx scripts/openclaw/promote-runtime-payload.ts",
|
|
41
62
|
"runtime:replay-fixture": "tsx scripts/openclaw/replay-runtime-fixture.ts",
|
|
42
|
-
"prepack": "pnpm build",
|
|
43
63
|
"typecheck": "tsc --noEmit",
|
|
44
64
|
"test": "vitest run",
|
|
45
65
|
"check": "pnpm typecheck && pnpm test && pnpm build"
|
|
46
|
-
},
|
|
47
|
-
"dependencies": {
|
|
48
|
-
"@huggingface/transformers": "^3.8.1",
|
|
49
|
-
"@modelcontextprotocol/sdk": "^1.27.1",
|
|
50
|
-
"zod": "^3.25.76"
|
|
51
|
-
},
|
|
52
|
-
"devDependencies": {
|
|
53
|
-
"@types/node": "^22.13.14",
|
|
54
|
-
"tsx": "^4.19.3",
|
|
55
|
-
"typescript": "^5.8.2",
|
|
56
|
-
"vitest": "^3.0.9"
|
|
57
66
|
}
|
|
58
|
-
}
|
|
67
|
+
}
|
|
@@ -4,12 +4,13 @@
|
|
|
4
4
|
"type": "stdio",
|
|
5
5
|
"command": "node",
|
|
6
6
|
"args": [
|
|
7
|
-
"${
|
|
7
|
+
"${CLAUDE_PLUGIN_ROOT}/node_modules/@alan512/experienceengine/dist/cli/index.js",
|
|
8
8
|
"mcp-server"
|
|
9
9
|
],
|
|
10
10
|
"env": {
|
|
11
|
-
"NODE_PATH": "${
|
|
12
|
-
"EXPERIENCE_ENGINE_HOME": "${
|
|
11
|
+
"NODE_PATH": "${CLAUDE_PLUGIN_ROOT}/node_modules",
|
|
12
|
+
"EXPERIENCE_ENGINE_HOME": "${CLAUDE_PLUGIN_ROOT}/experienceengine-home",
|
|
13
|
+
"EXPERIENCE_ENGINE_CLAUDE_HOOK_SOURCE": "marketplace"
|
|
13
14
|
}
|
|
14
15
|
}
|
|
15
16
|
}
|
|
File without changes
|
|
@@ -1,9 +1,38 @@
|
|
|
1
1
|
#!/usr/bin/env bash
|
|
2
2
|
set -euo pipefail
|
|
3
3
|
|
|
4
|
-
PLUGIN_DATA="${CLAUDE_PLUGIN_DATA
|
|
4
|
+
PLUGIN_DATA="${CLAUDE_PLUGIN_DATA:-${CLAUDE_PLUGIN_ROOT:-}}"
|
|
5
|
+
if [[ -z "${PLUGIN_DATA}" ]]; then
|
|
6
|
+
echo "CLAUDE_PLUGIN_DATA or CLAUDE_PLUGIN_ROOT is required" >&2
|
|
7
|
+
exit 1
|
|
8
|
+
fi
|
|
5
9
|
|
|
6
10
|
export NODE_PATH="${PLUGIN_DATA}/node_modules${NODE_PATH:+:${NODE_PATH}}"
|
|
7
11
|
export EXPERIENCE_ENGINE_HOME="${EXPERIENCE_ENGINE_HOME:-${PLUGIN_DATA}/experienceengine-home}"
|
|
12
|
+
STATE_PATH="${EXPERIENCE_ENGINE_HOME}/claude-marketplace-state.json"
|
|
13
|
+
|
|
14
|
+
node - "${STATE_PATH}" <<'NODE'
|
|
15
|
+
const fs = require("node:fs");
|
|
16
|
+
const path = require("node:path");
|
|
17
|
+
|
|
18
|
+
const [statePath] = process.argv.slice(2);
|
|
19
|
+
let current = {};
|
|
20
|
+
try {
|
|
21
|
+
current = JSON.parse(fs.readFileSync(statePath, "utf8"));
|
|
22
|
+
} catch {}
|
|
23
|
+
|
|
24
|
+
const next = {
|
|
25
|
+
adapter: "claude-code",
|
|
26
|
+
install_mode: "marketplace",
|
|
27
|
+
hook_source: "marketplace",
|
|
28
|
+
package_version: current.package_version,
|
|
29
|
+
written_at: current.written_at ?? new Date().toISOString(),
|
|
30
|
+
last_hook_seen_at: new Date().toISOString(),
|
|
31
|
+
last_mcp_seen_at: current.last_mcp_seen_at
|
|
32
|
+
};
|
|
33
|
+
|
|
34
|
+
fs.mkdirSync(path.dirname(statePath), { recursive: true });
|
|
35
|
+
fs.writeFileSync(statePath, `${JSON.stringify(next, null, 2)}\n`);
|
|
36
|
+
NODE
|
|
8
37
|
|
|
9
38
|
exec node --no-warnings "${PLUGIN_DATA}/node_modules/@alan512/experienceengine/dist/cli/index.js" claude-hook "$@"
|
|
@@ -1,19 +1,54 @@
|
|
|
1
1
|
#!/usr/bin/env bash
|
|
2
2
|
set -euo pipefail
|
|
3
3
|
|
|
4
|
-
PLUGIN_DATA="${CLAUDE_PLUGIN_DATA
|
|
4
|
+
PLUGIN_DATA="${CLAUDE_PLUGIN_DATA:-${CLAUDE_PLUGIN_ROOT:-}}"
|
|
5
|
+
if [[ -z "${PLUGIN_DATA}" ]]; then
|
|
6
|
+
echo "CLAUDE_PLUGIN_DATA or CLAUDE_PLUGIN_ROOT is required" >&2
|
|
7
|
+
exit 1
|
|
8
|
+
fi
|
|
5
9
|
PACKAGE_DIR="${PLUGIN_DATA}/node_modules/@alan512/experienceengine"
|
|
10
|
+
PACKAGE_ENTRY="${PACKAGE_DIR}/dist/cli/index.js"
|
|
6
11
|
STAMP_PATH="${PLUGIN_DATA}/.experienceengine-plugin-version"
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
PACKAGE_VERSION="0.
|
|
12
|
+
EXPERIENCE_ENGINE_HOME_PATH="${EXPERIENCE_ENGINE_HOME:-${PLUGIN_DATA}/experienceengine-home}"
|
|
13
|
+
STATE_PATH="${EXPERIENCE_ENGINE_HOME_PATH}/claude-marketplace-state.json"
|
|
14
|
+
PACKAGE_VERSION="0.2.0"
|
|
15
|
+
PACKAGE_SPEC="${EXPERIENCE_ENGINE_PLUGIN_PACKAGE_SPEC:-@alan512/experienceengine@${PACKAGE_VERSION}}"
|
|
10
16
|
|
|
11
17
|
mkdir -p "${PLUGIN_DATA}"
|
|
18
|
+
mkdir -p "${EXPERIENCE_ENGINE_HOME_PATH}"
|
|
19
|
+
|
|
20
|
+
write_marketplace_state() {
|
|
21
|
+
node - "${STATE_PATH}" "${PACKAGE_VERSION}" <<'NODE'
|
|
22
|
+
const fs = require("node:fs");
|
|
23
|
+
const path = require("node:path");
|
|
24
|
+
|
|
25
|
+
const [statePath, packageVersion] = process.argv.slice(2);
|
|
26
|
+
let current = {};
|
|
27
|
+
try {
|
|
28
|
+
current = JSON.parse(fs.readFileSync(statePath, "utf8"));
|
|
29
|
+
} catch {}
|
|
30
|
+
|
|
31
|
+
const next = {
|
|
32
|
+
adapter: "claude-code",
|
|
33
|
+
install_mode: "marketplace",
|
|
34
|
+
hook_source: "marketplace",
|
|
35
|
+
package_version: packageVersion,
|
|
36
|
+
written_at: current.written_at ?? new Date().toISOString(),
|
|
37
|
+
last_hook_seen_at: current.last_hook_seen_at,
|
|
38
|
+
last_mcp_seen_at: current.last_mcp_seen_at
|
|
39
|
+
};
|
|
40
|
+
|
|
41
|
+
fs.mkdirSync(path.dirname(statePath), { recursive: true });
|
|
42
|
+
fs.writeFileSync(statePath, `${JSON.stringify(next, null, 2)}\n`);
|
|
43
|
+
NODE
|
|
44
|
+
}
|
|
12
45
|
|
|
13
|
-
if [[ -f "${STAMP_PATH}" ]] && [[ "$(cat "${STAMP_PATH}")" == "${PACKAGE_VERSION}" ]] && [[ -
|
|
46
|
+
if [[ -f "${STAMP_PATH}" ]] && [[ "$(cat "${STAMP_PATH}")" == "${PACKAGE_VERSION}" ]] && [[ -f "${PACKAGE_ENTRY}" ]]; then
|
|
47
|
+
write_marketplace_state
|
|
14
48
|
exit 0
|
|
15
49
|
fi
|
|
16
50
|
|
|
17
51
|
rm -rf "${PLUGIN_DATA}/node_modules"
|
|
18
|
-
npm install --prefix "${PLUGIN_DATA}" --no-package-lock --omit=dev "${
|
|
52
|
+
npm install --prefix "${PLUGIN_DATA}" --no-package-lock --omit=dev --ignore-scripts "${PACKAGE_SPEC}"
|
|
19
53
|
printf '%s' "${PACKAGE_VERSION}" > "${STAMP_PATH}"
|
|
54
|
+
write_marketplace_state
|
|
File without changes
|
|
File without changes
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export declare const runPackCommand: (args: string[]) => void;
|
|
@@ -1,321 +0,0 @@
|
|
|
1
|
-
import { loadConfig } from "../../config/load-config.js";
|
|
2
|
-
import { compilePack } from "../../compiler/compiler.js";
|
|
3
|
-
import { deployCompiledPack } from "../../compiler/deployer.js";
|
|
4
|
-
import { resolveExperienceEnginePaths } from "../../config/path-resolver.js";
|
|
5
|
-
import { ExperiencePackRegistry } from "../../packs/fs-registry.js";
|
|
6
|
-
import { ExperiencePackIndexSync } from "../../packs/index-sync.js";
|
|
7
|
-
import { basename } from "node:path";
|
|
8
|
-
import { bootstrapDatabase, openDatabase } from "../../store/sqlite/db.js";
|
|
9
|
-
import { NodeRepository } from "../../store/sqlite/repositories/node-repo.js";
|
|
10
|
-
import { ExperiencePackRepository } from "../../store/sqlite/repositories/pack-repo.js";
|
|
11
|
-
import { resolveScope } from "../../input/scope-resolver.js";
|
|
12
|
-
import { nowIso } from "../../utils/clock.js";
|
|
13
|
-
const ALL_HOSTS = ["openclaw", "claude-code", "codex"];
|
|
14
|
-
const usage = () => {
|
|
15
|
-
console.log("Usage: ee pack <list|inspect <pack-id>|status <pack-id> [version] [agents|codex|github|claude] [repo-path]|draft create <pack-id> <node-id[,node-id...]> [name...]|review <pack-id> <description...>|publish <pack-id>|compile <pack-id> [version] [agents|codex|github|claude]|deploy <pack-id> [version] [agents|codex|github|claude] [repo-path] [--dry-run] [--force] [--status-only]|rollback <pack-id> <version>>");
|
|
16
|
-
};
|
|
17
|
-
const openServices = () => {
|
|
18
|
-
const config = loadConfig();
|
|
19
|
-
const paths = resolveExperienceEnginePaths();
|
|
20
|
-
const db = openDatabase(config);
|
|
21
|
-
bootstrapDatabase(db);
|
|
22
|
-
const nodeRepo = new NodeRepository(db);
|
|
23
|
-
const packRepo = new ExperiencePackRepository(db);
|
|
24
|
-
const registry = new ExperiencePackRegistry({ packsDir: paths.packsDir });
|
|
25
|
-
const indexSync = new ExperiencePackIndexSync(registry, packRepo);
|
|
26
|
-
return { nodeRepo, packRepo, registry, indexSync };
|
|
27
|
-
};
|
|
28
|
-
const unique = (values) => Array.from(new Set(values));
|
|
29
|
-
export const runPackCommand = (args) => {
|
|
30
|
-
const [action, ...rest] = args;
|
|
31
|
-
const { nodeRepo, packRepo, registry, indexSync } = openServices();
|
|
32
|
-
if (!action || action === "help") {
|
|
33
|
-
usage();
|
|
34
|
-
return;
|
|
35
|
-
}
|
|
36
|
-
if (action === "list") {
|
|
37
|
-
const packs = registry.listPacks();
|
|
38
|
-
if (!packs.length) {
|
|
39
|
-
console.log("No experience packs created yet.");
|
|
40
|
-
return;
|
|
41
|
-
}
|
|
42
|
-
console.table(packs.map((pack) => {
|
|
43
|
-
const compileStatus = registry.getCompileStatus(pack.packId, pack.currentVersion);
|
|
44
|
-
return {
|
|
45
|
-
pack_id: pack.packId,
|
|
46
|
-
status: pack.status,
|
|
47
|
-
current_version: pack.currentVersion,
|
|
48
|
-
current_version_compiled: compileStatus.currentVersionCompiledTargets.join(", ") || "none",
|
|
49
|
-
stale: compileStatus.stale,
|
|
50
|
-
latest_compile_target: compileStatus.latestArtifact?.target ?? "",
|
|
51
|
-
latest_compile_at: compileStatus.latestArtifact?.generatedAt ?? "",
|
|
52
|
-
owner: pack.owner,
|
|
53
|
-
updated_at: pack.updatedAt
|
|
54
|
-
};
|
|
55
|
-
}));
|
|
56
|
-
return;
|
|
57
|
-
}
|
|
58
|
-
if (action === "inspect") {
|
|
59
|
-
const packId = rest[0];
|
|
60
|
-
if (!packId) {
|
|
61
|
-
usage();
|
|
62
|
-
return;
|
|
63
|
-
}
|
|
64
|
-
const pack = registry.readPack(packId);
|
|
65
|
-
const versions = registry.listVersions(packId);
|
|
66
|
-
const current = registry.readVersionManifest(packId, pack.currentVersion);
|
|
67
|
-
const nodes = registry.readVersionNodes(packId, pack.currentVersion);
|
|
68
|
-
const activations = packRepo.listActivationsByPack(packId);
|
|
69
|
-
const activationSummary = activations.length
|
|
70
|
-
? activations
|
|
71
|
-
.map((activation) => `${activation.scope_id}@${activation.pinned_version ?? pack.currentVersion} [${activation.enabled ? "enabled" : "disabled"}]`)
|
|
72
|
-
.join(", ")
|
|
73
|
-
: "none";
|
|
74
|
-
console.log(`Pack: ${pack.packId}`);
|
|
75
|
-
console.log(`Name: ${pack.name}`);
|
|
76
|
-
console.log(`Status: ${pack.status}`);
|
|
77
|
-
console.log(`Current version: ${pack.currentVersion}`);
|
|
78
|
-
console.log(`Owner: ${pack.owner}`);
|
|
79
|
-
console.log(`Description: ${pack.description}`);
|
|
80
|
-
console.log(`Task families: ${pack.taskFamilies.join(", ")}`);
|
|
81
|
-
console.log(`Hosts: ${pack.hostCompatibility.join(", ")}`);
|
|
82
|
-
console.log(`Version count: ${versions.length}`);
|
|
83
|
-
console.log(`Evidence: ${current.evidenceSummary}`);
|
|
84
|
-
console.log(`Nodes: ${nodes.map((node) => node.id).join(", ")}`);
|
|
85
|
-
console.log(`Activations: ${activationSummary}`);
|
|
86
|
-
const compileStatus = registry.getCompileStatus(packId, pack.currentVersion);
|
|
87
|
-
console.log(`Current version compiled targets: ${compileStatus.currentVersionCompiledTargets.join(", ") || "none"}`);
|
|
88
|
-
console.log(`Compile stale: ${compileStatus.stale}`);
|
|
89
|
-
const compiledArtifacts = registry.listCompiledArtifacts(packId);
|
|
90
|
-
if (compiledArtifacts.length) {
|
|
91
|
-
console.log("Compiled targets:");
|
|
92
|
-
for (const artifact of compiledArtifacts) {
|
|
93
|
-
console.log(`- ${artifact.target}@${artifact.version} (${artifact.renderedNodeCount} nodes)`);
|
|
94
|
-
console.log(` Output: ${artifact.outputPath}`);
|
|
95
|
-
}
|
|
96
|
-
}
|
|
97
|
-
else {
|
|
98
|
-
console.log("Compiled targets: none");
|
|
99
|
-
}
|
|
100
|
-
const compileTarget = (value) => value === "agents" || value === "codex" || value === "github" || value === "claude" ? value : undefined;
|
|
101
|
-
const arg2Target = compileTarget(rest[1]);
|
|
102
|
-
const arg3Target = compileTarget(rest[2]);
|
|
103
|
-
const version = arg2Target ? undefined : rest[1];
|
|
104
|
-
const target = arg2Target ?? arg3Target;
|
|
105
|
-
const repoPath = target ? rest[arg2Target ? 2 : arg3Target ? 3 : version ? 2 : 1] : undefined;
|
|
106
|
-
if (target && repoPath) {
|
|
107
|
-
const paths = resolveExperienceEnginePaths();
|
|
108
|
-
const deployment = deployCompiledPack({
|
|
109
|
-
packsDir: paths.packsDir,
|
|
110
|
-
packId,
|
|
111
|
-
version,
|
|
112
|
-
target,
|
|
113
|
-
repoPath,
|
|
114
|
-
statusOnly: true
|
|
115
|
-
});
|
|
116
|
-
console.log("Deployment status:");
|
|
117
|
-
console.log(` Target: ${deployment.target}`);
|
|
118
|
-
console.log(` Destination: ${deployment.destinationPath}`);
|
|
119
|
-
console.log(` Status: ${deployment.deploymentStatus}`);
|
|
120
|
-
}
|
|
121
|
-
return;
|
|
122
|
-
}
|
|
123
|
-
if (action === "draft" && rest[0] === "create") {
|
|
124
|
-
const packId = rest[1];
|
|
125
|
-
const nodeIdsCsv = rest[2];
|
|
126
|
-
const name = rest.slice(3).join(" ").trim() || packId;
|
|
127
|
-
if (!packId || !nodeIdsCsv) {
|
|
128
|
-
usage();
|
|
129
|
-
return;
|
|
130
|
-
}
|
|
131
|
-
const nodeIds = nodeIdsCsv.split(",").map((value) => value.trim()).filter(Boolean);
|
|
132
|
-
const nodes = nodeIds
|
|
133
|
-
.map((id) => nodeRepo.getById(id))
|
|
134
|
-
.filter((node) => Boolean(node));
|
|
135
|
-
if (nodes.length !== nodeIds.length) {
|
|
136
|
-
throw new Error(`Unknown node id in pack draft: ${nodeIds.join(", ")}`);
|
|
137
|
-
}
|
|
138
|
-
const typedNodes = nodes;
|
|
139
|
-
registry.createDraft({
|
|
140
|
-
packId,
|
|
141
|
-
name,
|
|
142
|
-
description: name,
|
|
143
|
-
owner: process.env.USER ?? process.env.USERNAME ?? "unknown",
|
|
144
|
-
scopeHints: unique(typedNodes.map((node) => `scope:${node.scope_id}`)),
|
|
145
|
-
taskFamilies: unique(typedNodes.map((node) => node.task_type)),
|
|
146
|
-
hostCompatibility: [...ALL_HOSTS],
|
|
147
|
-
nodes: typedNodes
|
|
148
|
-
});
|
|
149
|
-
indexSync.syncPack(packId);
|
|
150
|
-
console.log(`[ExperienceEngine] Drafted experience pack ${packId}.`);
|
|
151
|
-
return;
|
|
152
|
-
}
|
|
153
|
-
if (action === "review") {
|
|
154
|
-
const packId = rest[0];
|
|
155
|
-
const description = rest.slice(1).join(" ").trim();
|
|
156
|
-
if (!packId || !description) {
|
|
157
|
-
usage();
|
|
158
|
-
return;
|
|
159
|
-
}
|
|
160
|
-
registry.reviewPack(packId, {
|
|
161
|
-
description,
|
|
162
|
-
evidenceSummary: description,
|
|
163
|
-
riskLevel: "medium"
|
|
164
|
-
});
|
|
165
|
-
indexSync.syncPack(packId);
|
|
166
|
-
console.log(`[ExperienceEngine] Reviewed experience pack ${packId}.`);
|
|
167
|
-
return;
|
|
168
|
-
}
|
|
169
|
-
if (action === "publish") {
|
|
170
|
-
const packId = rest[0];
|
|
171
|
-
if (!packId) {
|
|
172
|
-
usage();
|
|
173
|
-
return;
|
|
174
|
-
}
|
|
175
|
-
registry.publishPack(packId);
|
|
176
|
-
indexSync.syncPack(packId);
|
|
177
|
-
console.log(`[ExperienceEngine] Published experience pack ${packId}.`);
|
|
178
|
-
return;
|
|
179
|
-
}
|
|
180
|
-
if (action === "compile") {
|
|
181
|
-
const packId = rest[0];
|
|
182
|
-
const compileTarget = (value) => value === "agents" || value === "codex" || value === "github" || value === "claude" ? value : undefined;
|
|
183
|
-
const arg2Target = compileTarget(rest[1]);
|
|
184
|
-
const arg3Target = compileTarget(rest[2]);
|
|
185
|
-
const version = arg2Target ? undefined : rest[1];
|
|
186
|
-
const target = arg2Target ?? arg3Target ?? "agents";
|
|
187
|
-
if (!packId) {
|
|
188
|
-
usage();
|
|
189
|
-
return;
|
|
190
|
-
}
|
|
191
|
-
const paths = resolveExperienceEnginePaths();
|
|
192
|
-
const result = compilePack({
|
|
193
|
-
packsDir: paths.packsDir,
|
|
194
|
-
packId,
|
|
195
|
-
version,
|
|
196
|
-
target
|
|
197
|
-
});
|
|
198
|
-
console.log(`[ExperienceEngine] Compiled experience pack ${packId}.`);
|
|
199
|
-
console.log(`${basename(result.outputPath)}: ${result.outputPath}`);
|
|
200
|
-
console.log(`compile-report.json: ${result.reportPath}`);
|
|
201
|
-
return;
|
|
202
|
-
}
|
|
203
|
-
if (action === "status") {
|
|
204
|
-
const compileTarget = (value) => value === "agents" || value === "codex" || value === "github" || value === "claude" ? value : undefined;
|
|
205
|
-
const packId = rest[0];
|
|
206
|
-
const arg2Target = compileTarget(rest[1]);
|
|
207
|
-
const arg3Target = compileTarget(rest[2]);
|
|
208
|
-
const version = arg2Target ? undefined : rest[1];
|
|
209
|
-
const target = arg2Target ?? arg3Target ?? "agents";
|
|
210
|
-
const repoPath = rest[arg2Target ? 2 : arg3Target ? 3 : version ? 2 : 1] ?? process.cwd();
|
|
211
|
-
if (!packId) {
|
|
212
|
-
usage();
|
|
213
|
-
return;
|
|
214
|
-
}
|
|
215
|
-
const paths = resolveExperienceEnginePaths();
|
|
216
|
-
const result = deployCompiledPack({
|
|
217
|
-
packsDir: paths.packsDir,
|
|
218
|
-
packId,
|
|
219
|
-
version,
|
|
220
|
-
target,
|
|
221
|
-
repoPath,
|
|
222
|
-
statusOnly: true
|
|
223
|
-
});
|
|
224
|
-
console.log(`Pack status: ${packId}`);
|
|
225
|
-
console.log(`Target: ${result.target}`);
|
|
226
|
-
console.log(`Source: ${result.sourcePath}`);
|
|
227
|
-
console.log(`Destination: ${result.destinationPath}`);
|
|
228
|
-
console.log(`Status: ${result.deploymentStatus}`);
|
|
229
|
-
console.log(`Status only: ${result.statusOnly}`);
|
|
230
|
-
return;
|
|
231
|
-
}
|
|
232
|
-
if (action === "deploy") {
|
|
233
|
-
const compileTarget = (value) => value === "agents" || value === "codex" || value === "github" || value === "claude" ? value : undefined;
|
|
234
|
-
const positional = rest.filter((value) => value !== "--dry-run" && value !== "--force" && value !== "--status-only");
|
|
235
|
-
const packId = positional[0];
|
|
236
|
-
const arg2Target = compileTarget(positional[1]);
|
|
237
|
-
const arg3Target = compileTarget(positional[2]);
|
|
238
|
-
const version = arg2Target ? undefined : positional[1];
|
|
239
|
-
const target = arg2Target ?? arg3Target ?? "agents";
|
|
240
|
-
const repoPath = positional[arg2Target ? 2 : arg3Target ? 3 : version ? 2 : 1] ?? process.cwd();
|
|
241
|
-
const dryRun = rest.includes("--dry-run");
|
|
242
|
-
const force = rest.includes("--force");
|
|
243
|
-
const statusOnly = rest.includes("--status-only");
|
|
244
|
-
if (!packId) {
|
|
245
|
-
usage();
|
|
246
|
-
return;
|
|
247
|
-
}
|
|
248
|
-
const paths = resolveExperienceEnginePaths();
|
|
249
|
-
const result = deployCompiledPack({
|
|
250
|
-
packsDir: paths.packsDir,
|
|
251
|
-
packId,
|
|
252
|
-
version,
|
|
253
|
-
target,
|
|
254
|
-
repoPath,
|
|
255
|
-
dryRun,
|
|
256
|
-
force,
|
|
257
|
-
statusOnly
|
|
258
|
-
});
|
|
259
|
-
console.log(`[ExperienceEngine] Deployed compiled pack ${packId}.`);
|
|
260
|
-
console.log(`Deploy target: ${result.target}`);
|
|
261
|
-
console.log(`Source: ${result.sourcePath}`);
|
|
262
|
-
console.log(`Destination: ${result.destinationPath}`);
|
|
263
|
-
console.log(`Status: ${result.deploymentStatus}`);
|
|
264
|
-
console.log(`Status only: ${result.statusOnly}`);
|
|
265
|
-
console.log(`Dry run: ${result.dryRun}`);
|
|
266
|
-
console.log(`Overwrote existing file: ${result.overwritten}`);
|
|
267
|
-
return;
|
|
268
|
-
}
|
|
269
|
-
if (action === "enable") {
|
|
270
|
-
const packId = rest[0];
|
|
271
|
-
const scopeId = rest[1] ?? resolveScope(process.cwd()).scope_id;
|
|
272
|
-
if (!packId) {
|
|
273
|
-
usage();
|
|
274
|
-
return;
|
|
275
|
-
}
|
|
276
|
-
const pack = registry.readPack(packId);
|
|
277
|
-
packRepo.upsertActivation({
|
|
278
|
-
scope_id: scopeId,
|
|
279
|
-
pack_id: packId,
|
|
280
|
-
enabled: true,
|
|
281
|
-
pinned_version: pack.currentVersion,
|
|
282
|
-
created_at: nowIso(),
|
|
283
|
-
updated_at: nowIso()
|
|
284
|
-
});
|
|
285
|
-
console.log(`[ExperienceEngine] Enabled experience pack ${packId} for scope ${scopeId}.`);
|
|
286
|
-
return;
|
|
287
|
-
}
|
|
288
|
-
if (action === "disable") {
|
|
289
|
-
const packId = rest[0];
|
|
290
|
-
const scopeId = rest[1] ?? resolveScope(process.cwd()).scope_id;
|
|
291
|
-
if (!packId) {
|
|
292
|
-
usage();
|
|
293
|
-
return;
|
|
294
|
-
}
|
|
295
|
-
const existing = packRepo.listActivations(scopeId).find((activation) => activation.pack_id === packId);
|
|
296
|
-
packRepo.upsertActivation({
|
|
297
|
-
scope_id: scopeId,
|
|
298
|
-
pack_id: packId,
|
|
299
|
-
enabled: false,
|
|
300
|
-
pinned_version: existing?.pinned_version,
|
|
301
|
-
created_at: existing?.created_at ?? nowIso(),
|
|
302
|
-
updated_at: nowIso()
|
|
303
|
-
});
|
|
304
|
-
console.log(`[ExperienceEngine] Disabled experience pack ${packId} for scope ${scopeId}.`);
|
|
305
|
-
return;
|
|
306
|
-
}
|
|
307
|
-
if (action === "rollback") {
|
|
308
|
-
const packId = rest[0];
|
|
309
|
-
const version = rest[1];
|
|
310
|
-
if (!packId || !version) {
|
|
311
|
-
usage();
|
|
312
|
-
return;
|
|
313
|
-
}
|
|
314
|
-
registry.rollbackPack(packId, version);
|
|
315
|
-
indexSync.syncPack(packId);
|
|
316
|
-
console.log(`[ExperienceEngine] Rolled back experience pack ${packId} to ${version}.`);
|
|
317
|
-
return;
|
|
318
|
-
}
|
|
319
|
-
usage();
|
|
320
|
-
};
|
|
321
|
-
//# sourceMappingURL=pack.js.map
|