@dragonflymcp/plugin 1.0.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/plugin.json +26 -0
- package/LICENSE +21 -0
- package/README.md +126 -0
- package/dist/core/annotations.d.ts +71 -0
- package/dist/core/annotations.d.ts.map +1 -0
- package/dist/core/annotations.js +61 -0
- package/dist/core/annotations.js.map +1 -0
- package/dist/core/config.d.ts +66 -0
- package/dist/core/config.d.ts.map +1 -0
- package/dist/core/config.js +131 -0
- package/dist/core/config.js.map +1 -0
- package/dist/core/dispatcher.d.ts +77 -0
- package/dist/core/dispatcher.d.ts.map +1 -0
- package/dist/core/dispatcher.js +132 -0
- package/dist/core/dispatcher.js.map +1 -0
- package/dist/core/server.d.ts +24 -0
- package/dist/core/server.d.ts.map +1 -0
- package/dist/core/server.js +41 -0
- package/dist/core/server.js.map +1 -0
- package/dist/core/store.d.ts +91 -0
- package/dist/core/store.d.ts.map +1 -0
- package/dist/core/store.js +157 -0
- package/dist/core/store.js.map +1 -0
- package/dist/core/types.d.ts +128 -0
- package/dist/core/types.d.ts.map +1 -0
- package/dist/core/types.js +5 -0
- package/dist/core/types.js.map +1 -0
- package/dist/index.d.ts +22 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +81 -0
- package/dist/index.js.map +1 -0
- package/dist/test-utils/store-harness.d.ts +41 -0
- package/dist/test-utils/store-harness.d.ts.map +1 -0
- package/dist/test-utils/store-harness.js +61 -0
- package/dist/test-utils/store-harness.js.map +1 -0
- package/dist/tools/analytics/aggregators.d.ts +18 -0
- package/dist/tools/analytics/aggregators.d.ts.map +1 -0
- package/dist/tools/analytics/aggregators.js +260 -0
- package/dist/tools/analytics/aggregators.js.map +1 -0
- package/dist/tools/analytics/aggregators.test.d.ts +2 -0
- package/dist/tools/analytics/aggregators.test.d.ts.map +1 -0
- package/dist/tools/analytics/aggregators.test.js +177 -0
- package/dist/tools/analytics/aggregators.test.js.map +1 -0
- package/dist/tools/analytics/drift.d.ts +15 -0
- package/dist/tools/analytics/drift.d.ts.map +1 -0
- package/dist/tools/analytics/drift.js +135 -0
- package/dist/tools/analytics/drift.js.map +1 -0
- package/dist/tools/analytics/drift.test.d.ts +2 -0
- package/dist/tools/analytics/drift.test.d.ts.map +1 -0
- package/dist/tools/analytics/drift.test.js +99 -0
- package/dist/tools/analytics/drift.test.js.map +1 -0
- package/dist/tools/analytics/index.d.ts +10 -0
- package/dist/tools/analytics/index.d.ts.map +1 -0
- package/dist/tools/analytics/index.js +192 -0
- package/dist/tools/analytics/index.js.map +1 -0
- package/dist/tools/analytics/learner.d.ts +29 -0
- package/dist/tools/analytics/learner.d.ts.map +1 -0
- package/dist/tools/analytics/learner.js +135 -0
- package/dist/tools/analytics/learner.js.map +1 -0
- package/dist/tools/analytics/learner.test.d.ts +2 -0
- package/dist/tools/analytics/learner.test.d.ts.map +1 -0
- package/dist/tools/analytics/learner.test.js +118 -0
- package/dist/tools/analytics/learner.test.js.map +1 -0
- package/dist/tools/analytics/observe.d.ts +22 -0
- package/dist/tools/analytics/observe.d.ts.map +1 -0
- package/dist/tools/analytics/observe.js +143 -0
- package/dist/tools/analytics/observe.js.map +1 -0
- package/dist/tools/analytics/observe.test.d.ts +2 -0
- package/dist/tools/analytics/observe.test.d.ts.map +1 -0
- package/dist/tools/analytics/observe.test.js +95 -0
- package/dist/tools/analytics/observe.test.js.map +1 -0
- package/dist/tools/analytics/store.d.ts +29 -0
- package/dist/tools/analytics/store.d.ts.map +1 -0
- package/dist/tools/analytics/store.js +192 -0
- package/dist/tools/analytics/store.js.map +1 -0
- package/dist/tools/analytics/types.d.ts +290 -0
- package/dist/tools/analytics/types.d.ts.map +1 -0
- package/dist/tools/analytics/types.js +7 -0
- package/dist/tools/analytics/types.js.map +1 -0
- package/dist/tools/ast/index.d.ts +8 -0
- package/dist/tools/ast/index.d.ts.map +1 -0
- package/dist/tools/ast/index.js +242 -0
- package/dist/tools/ast/index.js.map +1 -0
- package/dist/tools/ast/indexer.d.ts +41 -0
- package/dist/tools/ast/indexer.d.ts.map +1 -0
- package/dist/tools/ast/indexer.js +617 -0
- package/dist/tools/ast/indexer.js.map +1 -0
- package/dist/tools/ast/store.d.ts +87 -0
- package/dist/tools/ast/store.d.ts.map +1 -0
- package/dist/tools/ast/store.js +280 -0
- package/dist/tools/ast/store.js.map +1 -0
- package/dist/tools/ast/store.test.d.ts +6 -0
- package/dist/tools/ast/store.test.d.ts.map +1 -0
- package/dist/tools/ast/store.test.js +257 -0
- package/dist/tools/ast/store.test.js.map +1 -0
- package/dist/tools/bridge/bridge.d.ts +37 -0
- package/dist/tools/bridge/bridge.d.ts.map +1 -0
- package/dist/tools/bridge/bridge.js +82 -0
- package/dist/tools/bridge/bridge.js.map +1 -0
- package/dist/tools/bridge/bridge.test.d.ts +2 -0
- package/dist/tools/bridge/bridge.test.d.ts.map +1 -0
- package/dist/tools/bridge/bridge.test.js +119 -0
- package/dist/tools/bridge/bridge.test.js.map +1 -0
- package/dist/tools/bridge/index.d.ts +8 -0
- package/dist/tools/bridge/index.d.ts.map +1 -0
- package/dist/tools/bridge/index.js +153 -0
- package/dist/tools/bridge/index.js.map +1 -0
- package/dist/tools/bridge/store.d.ts +45 -0
- package/dist/tools/bridge/store.d.ts.map +1 -0
- package/dist/tools/bridge/store.js +307 -0
- package/dist/tools/bridge/store.js.map +1 -0
- package/dist/tools/bridge/store.test.d.ts +2 -0
- package/dist/tools/bridge/store.test.d.ts.map +1 -0
- package/dist/tools/bridge/store.test.js +180 -0
- package/dist/tools/bridge/store.test.js.map +1 -0
- package/dist/tools/bridge/types.d.ts +44 -0
- package/dist/tools/bridge/types.d.ts.map +1 -0
- package/dist/tools/bridge/types.js +6 -0
- package/dist/tools/bridge/types.js.map +1 -0
- package/dist/tools/evolve/algorithm.d.ts +33 -0
- package/dist/tools/evolve/algorithm.d.ts.map +1 -0
- package/dist/tools/evolve/algorithm.js +64 -0
- package/dist/tools/evolve/algorithm.js.map +1 -0
- package/dist/tools/evolve/algorithm.test.d.ts +6 -0
- package/dist/tools/evolve/algorithm.test.d.ts.map +1 -0
- package/dist/tools/evolve/algorithm.test.js +138 -0
- package/dist/tools/evolve/algorithm.test.js.map +1 -0
- package/dist/tools/evolve/index.d.ts +11 -0
- package/dist/tools/evolve/index.d.ts.map +1 -0
- package/dist/tools/evolve/index.js +300 -0
- package/dist/tools/evolve/index.js.map +1 -0
- package/dist/tools/evolve/store.d.ts +27 -0
- package/dist/tools/evolve/store.d.ts.map +1 -0
- package/dist/tools/evolve/store.js +147 -0
- package/dist/tools/evolve/store.js.map +1 -0
- package/dist/tools/evolve/store.test.d.ts +6 -0
- package/dist/tools/evolve/store.test.d.ts.map +1 -0
- package/dist/tools/evolve/store.test.js +162 -0
- package/dist/tools/evolve/store.test.js.map +1 -0
- package/dist/tools/evolve/types.d.ts +38 -0
- package/dist/tools/evolve/types.d.ts.map +1 -0
- package/dist/tools/evolve/types.js +6 -0
- package/dist/tools/evolve/types.js.map +1 -0
- package/dist/tools/framework/content-loader.d.ts +45 -0
- package/dist/tools/framework/content-loader.d.ts.map +1 -0
- package/dist/tools/framework/content-loader.js +258 -0
- package/dist/tools/framework/content-loader.js.map +1 -0
- package/dist/tools/framework/content-loader.test.d.ts +5 -0
- package/dist/tools/framework/content-loader.test.d.ts.map +1 -0
- package/dist/tools/framework/content-loader.test.js +262 -0
- package/dist/tools/framework/content-loader.test.js.map +1 -0
- package/dist/tools/framework/index.d.ts +30 -0
- package/dist/tools/framework/index.d.ts.map +1 -0
- package/dist/tools/framework/index.js +517 -0
- package/dist/tools/framework/index.js.map +1 -0
- package/dist/tools/framework/session.d.ts +85 -0
- package/dist/tools/framework/session.d.ts.map +1 -0
- package/dist/tools/framework/session.js +311 -0
- package/dist/tools/framework/session.js.map +1 -0
- package/dist/tools/framework/session.test.d.ts +5 -0
- package/dist/tools/framework/session.test.d.ts.map +1 -0
- package/dist/tools/framework/session.test.js +291 -0
- package/dist/tools/framework/session.test.js.map +1 -0
- package/dist/tools/framework/sync-evaluator.d.ts +41 -0
- package/dist/tools/framework/sync-evaluator.d.ts.map +1 -0
- package/dist/tools/framework/sync-evaluator.js +298 -0
- package/dist/tools/framework/sync-evaluator.js.map +1 -0
- package/dist/tools/framework/sync-evaluator.test.d.ts +5 -0
- package/dist/tools/framework/sync-evaluator.test.d.ts.map +1 -0
- package/dist/tools/framework/sync-evaluator.test.js +288 -0
- package/dist/tools/framework/sync-evaluator.test.js.map +1 -0
- package/dist/tools/framework/types.d.ts +279 -0
- package/dist/tools/framework/types.d.ts.map +1 -0
- package/dist/tools/framework/types.js +6 -0
- package/dist/tools/framework/types.js.map +1 -0
- package/dist/tools/framework/workflow-intelligence.d.ts +55 -0
- package/dist/tools/framework/workflow-intelligence.d.ts.map +1 -0
- package/dist/tools/framework/workflow-intelligence.js +199 -0
- package/dist/tools/framework/workflow-intelligence.js.map +1 -0
- package/dist/tools/framework/workflow-intelligence.test.d.ts +6 -0
- package/dist/tools/framework/workflow-intelligence.test.d.ts.map +1 -0
- package/dist/tools/framework/workflow-intelligence.test.js +257 -0
- package/dist/tools/framework/workflow-intelligence.test.js.map +1 -0
- package/dist/tools/framework/workflow-planner.d.ts +10 -0
- package/dist/tools/framework/workflow-planner.d.ts.map +1 -0
- package/dist/tools/framework/workflow-planner.js +214 -0
- package/dist/tools/framework/workflow-planner.js.map +1 -0
- package/dist/tools/framework/workflow-planner.test.d.ts +5 -0
- package/dist/tools/framework/workflow-planner.test.d.ts.map +1 -0
- package/dist/tools/framework/workflow-planner.test.js +137 -0
- package/dist/tools/framework/workflow-planner.test.js.map +1 -0
- package/dist/tools/knowledge/bridge.d.ts +34 -0
- package/dist/tools/knowledge/bridge.d.ts.map +1 -0
- package/dist/tools/knowledge/bridge.js +249 -0
- package/dist/tools/knowledge/bridge.js.map +1 -0
- package/dist/tools/knowledge/bridge.test.d.ts +5 -0
- package/dist/tools/knowledge/bridge.test.d.ts.map +1 -0
- package/dist/tools/knowledge/bridge.test.js +221 -0
- package/dist/tools/knowledge/bridge.test.js.map +1 -0
- package/dist/tools/knowledge/extractor.d.ts +22 -0
- package/dist/tools/knowledge/extractor.d.ts.map +1 -0
- package/dist/tools/knowledge/extractor.js +154 -0
- package/dist/tools/knowledge/extractor.js.map +1 -0
- package/dist/tools/knowledge/index.d.ts +12 -0
- package/dist/tools/knowledge/index.d.ts.map +1 -0
- package/dist/tools/knowledge/index.js +505 -0
- package/dist/tools/knowledge/index.js.map +1 -0
- package/dist/tools/knowledge/retrieval.d.ts +28 -0
- package/dist/tools/knowledge/retrieval.d.ts.map +1 -0
- package/dist/tools/knowledge/retrieval.js +164 -0
- package/dist/tools/knowledge/retrieval.js.map +1 -0
- package/dist/tools/knowledge/store.d.ts +96 -0
- package/dist/tools/knowledge/store.d.ts.map +1 -0
- package/dist/tools/knowledge/store.js +562 -0
- package/dist/tools/knowledge/store.js.map +1 -0
- package/dist/tools/knowledge/store.test.d.ts +6 -0
- package/dist/tools/knowledge/store.test.d.ts.map +1 -0
- package/dist/tools/knowledge/store.test.js +385 -0
- package/dist/tools/knowledge/store.test.js.map +1 -0
- package/dist/tools/knowledge/types.d.ts +168 -0
- package/dist/tools/knowledge/types.d.ts.map +1 -0
- package/dist/tools/knowledge/types.js +6 -0
- package/dist/tools/knowledge/types.js.map +1 -0
- package/dist/tools/memory/evolution.d.ts +31 -0
- package/dist/tools/memory/evolution.d.ts.map +1 -0
- package/dist/tools/memory/evolution.js +130 -0
- package/dist/tools/memory/evolution.js.map +1 -0
- package/dist/tools/memory/index.d.ts +11 -0
- package/dist/tools/memory/index.d.ts.map +1 -0
- package/dist/tools/memory/index.js +239 -0
- package/dist/tools/memory/index.js.map +1 -0
- package/dist/tools/memory/store.d.ts +75 -0
- package/dist/tools/memory/store.d.ts.map +1 -0
- package/dist/tools/memory/store.js +398 -0
- package/dist/tools/memory/store.js.map +1 -0
- package/dist/tools/memory/store.test.d.ts +6 -0
- package/dist/tools/memory/store.test.d.ts.map +1 -0
- package/dist/tools/memory/store.test.js +429 -0
- package/dist/tools/memory/store.test.js.map +1 -0
- package/dist/tools/memory/types.d.ts +171 -0
- package/dist/tools/memory/types.d.ts.map +1 -0
- package/dist/tools/memory/types.js +6 -0
- package/dist/tools/memory/types.js.map +1 -0
- package/dist/tools/pipeline/composer.d.ts +29 -0
- package/dist/tools/pipeline/composer.d.ts.map +1 -0
- package/dist/tools/pipeline/composer.js +225 -0
- package/dist/tools/pipeline/composer.js.map +1 -0
- package/dist/tools/pipeline/composer.test.d.ts +2 -0
- package/dist/tools/pipeline/composer.test.d.ts.map +1 -0
- package/dist/tools/pipeline/composer.test.js +162 -0
- package/dist/tools/pipeline/composer.test.js.map +1 -0
- package/dist/tools/pipeline/index.d.ts +8 -0
- package/dist/tools/pipeline/index.d.ts.map +1 -0
- package/dist/tools/pipeline/index.js +102 -0
- package/dist/tools/pipeline/index.js.map +1 -0
- package/dist/tools/pipeline/planner.d.ts +10 -0
- package/dist/tools/pipeline/planner.d.ts.map +1 -0
- package/dist/tools/pipeline/planner.js +147 -0
- package/dist/tools/pipeline/planner.js.map +1 -0
- package/dist/tools/pipeline/planner.test.d.ts +2 -0
- package/dist/tools/pipeline/planner.test.d.ts.map +1 -0
- package/dist/tools/pipeline/planner.test.js +96 -0
- package/dist/tools/pipeline/planner.test.js.map +1 -0
- package/dist/tools/pipeline/preconditions.d.ts +14 -0
- package/dist/tools/pipeline/preconditions.d.ts.map +1 -0
- package/dist/tools/pipeline/preconditions.js +65 -0
- package/dist/tools/pipeline/preconditions.js.map +1 -0
- package/dist/tools/pipeline/preconditions.test.d.ts +2 -0
- package/dist/tools/pipeline/preconditions.test.d.ts.map +1 -0
- package/dist/tools/pipeline/preconditions.test.js +74 -0
- package/dist/tools/pipeline/preconditions.test.js.map +1 -0
- package/dist/tools/pipeline/types.d.ts +105 -0
- package/dist/tools/pipeline/types.d.ts.map +1 -0
- package/dist/tools/pipeline/types.js +6 -0
- package/dist/tools/pipeline/types.js.map +1 -0
- package/dist/tools/repair/index.d.ts +8 -0
- package/dist/tools/repair/index.d.ts.map +1 -0
- package/dist/tools/repair/index.js +384 -0
- package/dist/tools/repair/index.js.map +1 -0
- package/dist/tools/repair/repairer.d.ts +67 -0
- package/dist/tools/repair/repairer.d.ts.map +1 -0
- package/dist/tools/repair/repairer.js +257 -0
- package/dist/tools/repair/repairer.js.map +1 -0
- package/dist/tools/repair/repairer.test.d.ts +6 -0
- package/dist/tools/repair/repairer.test.d.ts.map +1 -0
- package/dist/tools/repair/repairer.test.js +159 -0
- package/dist/tools/repair/repairer.test.js.map +1 -0
- package/dist/tools/semantic/chunker.d.ts +23 -0
- package/dist/tools/semantic/chunker.d.ts.map +1 -0
- package/dist/tools/semantic/chunker.js +244 -0
- package/dist/tools/semantic/chunker.js.map +1 -0
- package/dist/tools/semantic/embedder.d.ts +16 -0
- package/dist/tools/semantic/embedder.d.ts.map +1 -0
- package/dist/tools/semantic/embedder.js +88 -0
- package/dist/tools/semantic/embedder.js.map +1 -0
- package/dist/tools/semantic/index.d.ts +8 -0
- package/dist/tools/semantic/index.d.ts.map +1 -0
- package/dist/tools/semantic/index.js +144 -0
- package/dist/tools/semantic/index.js.map +1 -0
- package/dist/tools/semantic/store.d.ts +31 -0
- package/dist/tools/semantic/store.d.ts.map +1 -0
- package/dist/tools/semantic/store.js +168 -0
- package/dist/tools/semantic/store.js.map +1 -0
- package/dist/tools/semantic/store.test.d.ts +6 -0
- package/dist/tools/semantic/store.test.d.ts.map +1 -0
- package/dist/tools/semantic/store.test.js +240 -0
- package/dist/tools/semantic/store.test.js.map +1 -0
- package/dist/tools/spec/generator.d.ts +32 -0
- package/dist/tools/spec/generator.d.ts.map +1 -0
- package/dist/tools/spec/generator.js +278 -0
- package/dist/tools/spec/generator.js.map +1 -0
- package/dist/tools/spec/generator.test.d.ts +6 -0
- package/dist/tools/spec/generator.test.d.ts.map +1 -0
- package/dist/tools/spec/generator.test.js +208 -0
- package/dist/tools/spec/generator.test.js.map +1 -0
- package/dist/tools/spec/index.d.ts +11 -0
- package/dist/tools/spec/index.d.ts.map +1 -0
- package/dist/tools/spec/index.js +426 -0
- package/dist/tools/spec/index.js.map +1 -0
- package/dist/tools/spec/store.d.ts +24 -0
- package/dist/tools/spec/store.d.ts.map +1 -0
- package/dist/tools/spec/store.js +104 -0
- package/dist/tools/spec/store.js.map +1 -0
- package/dist/tools/spec/store.test.d.ts +6 -0
- package/dist/tools/spec/store.test.d.ts.map +1 -0
- package/dist/tools/spec/store.test.js +173 -0
- package/dist/tools/spec/store.test.js.map +1 -0
- package/dist/tools/spec/types.d.ts +61 -0
- package/dist/tools/spec/types.d.ts.map +1 -0
- package/dist/tools/spec/types.js +6 -0
- package/dist/tools/spec/types.js.map +1 -0
- package/dist/tools/state/index.d.ts +11 -0
- package/dist/tools/state/index.d.ts.map +1 -0
- package/dist/tools/state/index.js +386 -0
- package/dist/tools/state/index.js.map +1 -0
- package/dist/tools/state/migrate.d.ts +39 -0
- package/dist/tools/state/migrate.d.ts.map +1 -0
- package/dist/tools/state/migrate.js +242 -0
- package/dist/tools/state/migrate.js.map +1 -0
- package/dist/tools/state/migrate.test.d.ts +2 -0
- package/dist/tools/state/migrate.test.d.ts.map +1 -0
- package/dist/tools/state/migrate.test.js +265 -0
- package/dist/tools/state/migrate.test.js.map +1 -0
- package/dist/tools/state/store.d.ts +107 -0
- package/dist/tools/state/store.d.ts.map +1 -0
- package/dist/tools/state/store.js +365 -0
- package/dist/tools/state/store.js.map +1 -0
- package/dist/tools/state/store.test.d.ts +5 -0
- package/dist/tools/state/store.test.d.ts.map +1 -0
- package/dist/tools/state/store.test.js +293 -0
- package/dist/tools/state/store.test.js.map +1 -0
- package/dist/tools/state/types.d.ts +90 -0
- package/dist/tools/state/types.d.ts.map +1 -0
- package/dist/tools/state/types.js +6 -0
- package/dist/tools/state/types.js.map +1 -0
- package/dist/tools/testing/analyzer.d.ts +44 -0
- package/dist/tools/testing/analyzer.d.ts.map +1 -0
- package/dist/tools/testing/analyzer.js +280 -0
- package/dist/tools/testing/analyzer.js.map +1 -0
- package/dist/tools/testing/generator.d.ts +57 -0
- package/dist/tools/testing/generator.d.ts.map +1 -0
- package/dist/tools/testing/generator.js +478 -0
- package/dist/tools/testing/generator.js.map +1 -0
- package/dist/tools/testing/generator.test.d.ts +6 -0
- package/dist/tools/testing/generator.test.d.ts.map +1 -0
- package/dist/tools/testing/generator.test.js +285 -0
- package/dist/tools/testing/generator.test.js.map +1 -0
- package/dist/tools/testing/index.d.ts +8 -0
- package/dist/tools/testing/index.d.ts.map +1 -0
- package/dist/tools/testing/index.js +373 -0
- package/dist/tools/testing/index.js.map +1 -0
- package/dist/utils/embedder.d.ts +7 -0
- package/dist/utils/embedder.d.ts.map +1 -0
- package/dist/utils/embedder.js +13 -0
- package/dist/utils/embedder.js.map +1 -0
- package/dist/utils/execution.d.ts +68 -0
- package/dist/utils/execution.d.ts.map +1 -0
- package/dist/utils/execution.js +467 -0
- package/dist/utils/execution.js.map +1 -0
- package/dist/utils/graph.d.ts +26 -0
- package/dist/utils/graph.d.ts.map +1 -0
- package/dist/utils/graph.js +32 -0
- package/dist/utils/graph.js.map +1 -0
- package/dist/utils/guards.d.ts +32 -0
- package/dist/utils/guards.d.ts.map +1 -0
- package/dist/utils/guards.js +40 -0
- package/dist/utils/guards.js.map +1 -0
- package/dist/utils/ids.d.ts +5 -0
- package/dist/utils/ids.d.ts.map +1 -0
- package/dist/utils/ids.js +7 -0
- package/dist/utils/ids.js.map +1 -0
- package/dist/utils/languages.d.ts +34 -0
- package/dist/utils/languages.d.ts.map +1 -0
- package/dist/utils/languages.js +153 -0
- package/dist/utils/languages.js.map +1 -0
- package/dist/utils/lazy.d.ts +17 -0
- package/dist/utils/lazy.d.ts.map +1 -0
- package/dist/utils/lazy.js +35 -0
- package/dist/utils/lazy.js.map +1 -0
- package/dist/utils/project.d.ts +41 -0
- package/dist/utils/project.d.ts.map +1 -0
- package/dist/utils/project.js +82 -0
- package/dist/utils/project.js.map +1 -0
- package/dist/utils/responses.d.ts +27 -0
- package/dist/utils/responses.d.ts.map +1 -0
- package/dist/utils/responses.js +72 -0
- package/dist/utils/responses.js.map +1 -0
- package/dist/utils/vectors.d.ts +33 -0
- package/dist/utils/vectors.d.ts.map +1 -0
- package/dist/utils/vectors.js +80 -0
- package/dist/utils/vectors.js.map +1 -0
- package/dist/utils/vectors.test.d.ts +6 -0
- package/dist/utils/vectors.test.d.ts.map +1 -0
- package/dist/utils/vectors.test.js +96 -0
- package/dist/utils/vectors.test.js.map +1 -0
- package/package.json +69 -0
- package/scripts/init.js +142 -0
- package/templates/CLAUDE.md.template +96 -0
- package/templates/agents/architecture-concept.md +237 -0
- package/templates/agents/checkpoint-concept.md +218 -0
- package/templates/agents/code-analysis-concept.md +171 -0
- package/templates/agents/compete-control.md +44 -0
- package/templates/agents/compete-evaluator.md +87 -0
- package/templates/agents/compete-treatment.md +55 -0
- package/templates/agents/context-concept.md +254 -0
- package/templates/agents/debate-advocate.md +127 -0
- package/templates/agents/debate-critic.md +119 -0
- package/templates/agents/debate-synthesis.md +160 -0
- package/templates/agents/documentation-concept.md +294 -0
- package/templates/agents/implementation-concept.md +165 -0
- package/templates/agents/quality-concept.md +299 -0
- package/templates/agents/research-concept.md +169 -0
- package/templates/agents/security-concept.md +255 -0
- package/templates/agents/story-concept.md +207 -0
- package/templates/agents/verification-concept.md +456 -0
- package/templates/agents/version-concept.md +163 -0
- package/templates/anchors/directory.anchor.yaml.template +53 -0
- package/templates/anchors/rules.anchor.yaml.template +70 -0
- package/templates/anchors/safety.anchor.yaml.template +96 -0
- package/templates/claude-md-managed.template +105 -0
- package/templates/commands/cache.md.template +439 -0
- package/templates/commands/checkpoint.md.template +121 -0
- package/templates/commands/classify.md.template +138 -0
- package/templates/commands/compete.md.template +90 -0
- package/templates/commands/costs.md.template +111 -0
- package/templates/commands/estimate.md.template +196 -0
- package/templates/commands/explore.md.template +186 -0
- package/templates/commands/feature.md.template +216 -0
- package/templates/commands/forget.md.template +104 -0
- package/templates/commands/global-recall.md.template +250 -0
- package/templates/commands/global-remember.md.template +187 -0
- package/templates/commands/health.md.template +107 -0
- package/templates/commands/help.md.template +253 -0
- package/templates/commands/observe.md.template +211 -0
- package/templates/commands/pr-review.md.template +164 -0
- package/templates/commands/predict-cost.md.template +251 -0
- package/templates/commands/profile.md.template +142 -0
- package/templates/commands/reasoning.md.template +228 -0
- package/templates/commands/recall.md.template +197 -0
- package/templates/commands/remember.md.template +148 -0
- package/templates/commands/replay.md.template +449 -0
- package/templates/commands/restore.md.template +87 -0
- package/templates/commands/retrospective.md.template +47 -0
- package/templates/commands/slo.md.template +286 -0
- package/templates/commands/spec.md.template +164 -0
- package/templates/commands/status.md.template +53 -0
- package/templates/commands/sync.md.template +321 -0
- package/templates/commands/task.md.template +86 -0
- package/templates/commands/trace.md.template +86 -0
- package/templates/commands/visualize.md.template +216 -0
- package/templates/commands/workflow.md.template +375 -0
- package/templates/concepts/README.md +329 -0
- package/templates/concepts/architecture.md.template +74 -0
- package/templates/concepts/code-analysis.md.template +186 -0
- package/templates/concepts/context-compactor.md.template +393 -0
- package/templates/concepts/context.md.template +62 -0
- package/templates/concepts/documentation.md.template +452 -0
- package/templates/concepts/estimator.md.template +214 -0
- package/templates/concepts/exploration.md.template +257 -0
- package/templates/concepts/global-memory.md.template +222 -0
- package/templates/concepts/implementation.md.template +62 -0
- package/templates/concepts/pr-review.md.template +277 -0
- package/templates/concepts/project-profile.md.template +358 -0
- package/templates/concepts/quality.md.template +63 -0
- package/templates/concepts/react-fallback.md.template +286 -0
- package/templates/concepts/research.md.template +221 -0
- package/templates/concepts/retrospective.md.template +93 -0
- package/templates/concepts/security.md.template +442 -0
- package/templates/concepts/slo.md.template +274 -0
- package/templates/concepts/spec.md.template +71 -0
- package/templates/concepts/story.md.template +50 -0
- package/templates/concepts/tool-router.md.template +289 -0
- package/templates/concepts/verification-synthesizer.md.template +279 -0
- package/templates/concepts/version.md.template +61 -0
- package/templates/config.yaml.template +347 -0
- package/templates/examples/README.md +77 -0
- package/templates/examples/architecture/api-design.yaml.template +286 -0
- package/templates/examples/architecture/oauth-authentication.yaml.template +305 -0
- package/templates/health/status.yaml.template +120 -0
- package/templates/hooks/concept-complete.sh.template +45 -0
- package/templates/hooks/lib/common.sh.template +160 -0
- package/templates/hooks/post-commit.sh.template +37 -0
- package/templates/hooks/post-concept-action.template +39 -0
- package/templates/hooks/post-tool-structure-check.sh.template +138 -0
- package/templates/hooks/post-tool-use.sh.template +51 -0
- package/templates/hooks/pre-compact.sh.template +48 -0
- package/templates/hooks/pre-tool-grounding.template +148 -0
- package/templates/hooks/session-exit-checkpoint.sh.template +35 -0
- package/templates/hooks/session-start.sh.template +67 -0
- package/templates/hooks/statusline.sh.template +148 -0
- package/templates/hooks/stop.sh.template +45 -0
- package/templates/hooks/subagent-stop.sh.template +40 -0
- package/templates/hooks/sync-blocked.sh.template +45 -0
- package/templates/hooks/timeout.sh.template +48 -0
- package/templates/hooks/user-prompt-submit.sh.template +68 -0
- package/templates/koan/README.md +58 -0
- package/templates/memory/index.yaml.template +48 -0
- package/templates/memory/procedural/debugging.yaml.template +24 -0
- package/templates/memory/procedural/workflows.yaml.template +22 -0
- package/templates/memory/semantic/architecture.yaml.template +21 -0
- package/templates/memory/semantic/conventions.yaml.template +18 -0
- package/templates/memory/semantic/patterns.yaml.template +21 -0
- package/templates/memory/semantic/preferences.yaml.template +18 -0
- package/templates/prompts/architecture.yaml.template +349 -0
- package/templates/prompts/context.yaml.template +384 -0
- package/templates/prompts/implementation.yaml.template +365 -0
- package/templates/prompts/planning.yaml.template +303 -0
- package/templates/prompts/quality.yaml.template +345 -0
- package/templates/prompts/retrospective.yaml.template +231 -0
- package/templates/prompts/slo.yaml.template +360 -0
- package/templates/prompts/story.yaml.template +236 -0
- package/templates/prompts/tree-of-thoughts.yaml.template +299 -0
- package/templates/prompts/verification.yaml.template +286 -0
- package/templates/prompts/version.yaml.template +279 -0
- package/templates/schemas/agent-schema.json +98 -0
- package/templates/schemas/architecture.schema.json +69 -0
- package/templates/schemas/config-schema.json +165 -0
- package/templates/schemas/implementation.schema.json +75 -0
- package/templates/schemas/planning.schema.json +243 -0
- package/templates/schemas/provenance.schema.json +111 -0
- package/templates/schemas/retrospective.schema.json +174 -0
- package/templates/schemas/review.schema.json +284 -0
- package/templates/schemas/slo.schema.json +443 -0
- package/templates/schemas/story.schema.json +68 -0
- package/templates/schemas/sync-schema.json +196 -0
- package/templates/schemas/task.schema.json +127 -0
- package/templates/schemas/tree-of-thoughts.schema.json +175 -0
- package/templates/schemas/verification.schema.json +106 -0
- package/templates/settings.full.json.template +135 -0
- package/templates/settings.minimal.json.template +68 -0
- package/templates/settings.standard.json.template +135 -0
- package/templates/skills/acceptance-criteria-generation.md.template +330 -0
- package/templates/skills/accessibility-checking.md.template +341 -0
- package/templates/skills/api-design-patterns.md.template +395 -0
- package/templates/skills/batch-processing.md.template +605 -0
- package/templates/skills/branch-strategy.md.template +362 -0
- package/templates/skills/changelog-generation.md.template +403 -0
- package/templates/skills/code-coverage-analysis.md.template +362 -0
- package/templates/skills/code-style-enforcement.md.template +294 -0
- package/templates/skills/code-template-patterns.md.template +419 -0
- package/templates/skills/concept-development.md.template +159 -0
- package/templates/skills/context-prioritization.md.template +306 -0
- package/templates/skills/cost-optimization.md.template +482 -0
- package/templates/skills/cross-project-knowledge.md.template +316 -0
- package/templates/skills/dependency-impact-analysis.md.template +263 -0
- package/templates/skills/documentation-generation.md.template +409 -0
- package/templates/skills/effort-estimation.md.template +350 -0
- package/templates/skills/error-classification.md.template +709 -0
- package/templates/skills/error-messages.md.template +339 -0
- package/templates/skills/ide-diagnostics.md.template +480 -0
- package/templates/skills/incremental-loading.md.template +574 -0
- package/templates/skills/output-caching.md.template +524 -0
- package/templates/skills/performance-estimation.md.template +325 -0
- package/templates/skills/performance-testing-patterns.md.template +341 -0
- package/templates/skills/phase2-optimizations-summary.md.template +458 -0
- package/templates/skills/progressive-disclosure-pattern.md.template +190 -0
- package/templates/skills/project-structure.md.template +372 -0
- package/templates/skills/provenance-analysis.md.template +609 -0
- package/templates/skills/react-executor.md.template +366 -0
- package/templates/skills/refactoring-patterns.md.template +422 -0
- package/templates/skills/release-management.md.template +373 -0
- package/templates/skills/requirement-prioritization.md.template +357 -0
- package/templates/skills/schema-validation.md.template +321 -0
- package/templates/skills/security-design-patterns.md.template +692 -0
- package/templates/skills/security-vulnerability-scanning.md.template +663 -0
- package/templates/skills/semantic-memory.md.template +266 -0
- package/templates/skills/semantic-versioning.md.template +371 -0
- package/templates/skills/smart-retry.md.template +676 -0
- package/templates/skills/smart-summarization.md.template +358 -0
- package/templates/skills/story-decomposition.md.template +278 -0
- package/templates/skills/synchronization-patterns.md.template +303 -0
- package/templates/skills/test-generation-strategy.md.template +247 -0
- package/templates/skills/workflow-replay.md.template +478 -0
- package/templates/skills/wysiwid-principles.md.template +364 -0
- package/templates/skills-manifest.yaml.template +526 -0
- package/templates/stubs/agents/architecture-concept.md +20 -0
- package/templates/stubs/agents/checkpoint-concept.md +19 -0
- package/templates/stubs/agents/code-analysis-concept.md +36 -0
- package/templates/stubs/agents/context-concept.md +37 -0
- package/templates/stubs/agents/debate-advocate.md +12 -0
- package/templates/stubs/agents/debate-critic.md +12 -0
- package/templates/stubs/agents/debate-synthesis.md +12 -0
- package/templates/stubs/agents/documentation-concept.md +39 -0
- package/templates/stubs/agents/implementation-concept.md +41 -0
- package/templates/stubs/agents/quality-concept.md +41 -0
- package/templates/stubs/agents/research-concept.md +35 -0
- package/templates/stubs/agents/security-concept.md +40 -0
- package/templates/stubs/agents/spec-concept.md +35 -0
- package/templates/stubs/agents/story-concept.md +36 -0
- package/templates/stubs/agents/verification-concept.md +39 -0
- package/templates/stubs/agents/version-concept.md +37 -0
- package/templates/stubs/commands/cache.md.template +2 -0
- package/templates/stubs/commands/checkpoint.md.template +2 -0
- package/templates/stubs/commands/classify.md.template +2 -0
- package/templates/stubs/commands/compete.md.template +2 -0
- package/templates/stubs/commands/costs.md.template +2 -0
- package/templates/stubs/commands/estimate.md.template +2 -0
- package/templates/stubs/commands/explore.md.template +2 -0
- package/templates/stubs/commands/feature.md.template +2 -0
- package/templates/stubs/commands/forget.md.template +2 -0
- package/templates/stubs/commands/global-recall.md.template +2 -0
- package/templates/stubs/commands/global-remember.md.template +2 -0
- package/templates/stubs/commands/health.md.template +2 -0
- package/templates/stubs/commands/help.md.template +2 -0
- package/templates/stubs/commands/observe.md.template +2 -0
- package/templates/stubs/commands/pr-review.md.template +2 -0
- package/templates/stubs/commands/predict-cost.md.template +2 -0
- package/templates/stubs/commands/profile.md.template +2 -0
- package/templates/stubs/commands/reasoning.md.template +2 -0
- package/templates/stubs/commands/recall.md.template +2 -0
- package/templates/stubs/commands/remember.md.template +2 -0
- package/templates/stubs/commands/replay.md.template +2 -0
- package/templates/stubs/commands/restore.md.template +2 -0
- package/templates/stubs/commands/retrospective.md.template +2 -0
- package/templates/stubs/commands/slo.md.template +2 -0
- package/templates/stubs/commands/spec.md.template +2 -0
- package/templates/stubs/commands/sync.md.template +2 -0
- package/templates/stubs/commands/task.md.template +2 -0
- package/templates/stubs/commands/trace.md.template +2 -0
- package/templates/stubs/commands/visualize.md.template +2 -0
- package/templates/stubs/commands/workflow.md.template +2 -0
- package/templates/synchronizations/archive/adaptive-learning.yaml.template +595 -0
- package/templates/synchronizations/archive/code-understanding-flow.yaml.template +533 -0
- package/templates/synchronizations/archive/collaboration-flow.yaml.template +521 -0
- package/templates/synchronizations/archive/context-folding.yaml.template +353 -0
- package/templates/synchronizations/archive/dead-letter-queue.yaml.template +530 -0
- package/templates/synchronizations/archive/documentation-flow.yaml.template +560 -0
- package/templates/synchronizations/archive/error-recovery-flow.yaml.template +1031 -0
- package/templates/synchronizations/archive/execution-loop.yaml.template +336 -0
- package/templates/synchronizations/archive/exploration-flow.yaml.template +369 -0
- package/templates/synchronizations/archive/feature-development.yaml.template +2145 -0
- package/templates/synchronizations/archive/learning-loop.yaml.template +657 -0
- package/templates/synchronizations/archive/multi-verify.yaml.template +346 -0
- package/templates/synchronizations/archive/planning-flow.yaml.template +312 -0
- package/templates/synchronizations/archive/retrospective-flow.yaml.template +277 -0
- package/templates/synchronizations/archive/security-flow.yaml.template +477 -0
- package/templates/synchronizations/archive/slo-monitoring.yaml.template +209 -0
- package/templates/synchronizations/archive/task-routing.yaml.template +489 -0
- package/templates/synchronizations/archive/test-driven.yaml.template +291 -0
- package/templates/synchronizations/archive/tool-routing.yaml.template +326 -0
- package/templates/synchronizations/archive/verification-flow.yaml.template +407 -0
- package/templates/synchronizations/error-policy.yaml.template +188 -0
- package/templates/synchronizations/main.sync.template +319 -0
- package/templates/synchronizations/slo-registry.yaml.template +229 -0
- package/templates/tasks/task.yaml.template +67 -0
- package/templates/zen-profile.yaml.template +14 -0
|
@@ -0,0 +1,530 @@
|
|
|
1
|
+
# Dead Letter Queue Synchronization Rules
|
|
2
|
+
# Captures and manages failed operations for later retry/analysis
|
|
3
|
+
#
|
|
4
|
+
# WYSIWID Principle: This YAML IS the failure handling logic
|
|
5
|
+
# Read this file to understand exactly how failures are captured and retried
|
|
6
|
+
#
|
|
7
|
+
# Dead Letter Queue (DLQ) Pattern:
|
|
8
|
+
# - Failed operations are captured with full context
|
|
9
|
+
# - Retries follow exponential backoff
|
|
10
|
+
# - Old entries are pruned after max attempts
|
|
11
|
+
# - Patterns are analyzed to prevent recurring failures
|
|
12
|
+
|
|
13
|
+
version: "1.0.0"
|
|
14
|
+
|
|
15
|
+
# Global SLO defaults for DLQ operations (mostly local, low-cost)
|
|
16
|
+
slo_defaults:
|
|
17
|
+
expected_duration_ms: 1000
|
|
18
|
+
max_duration_ms: 10000
|
|
19
|
+
expected_cost_usd: 0.0
|
|
20
|
+
max_cost_usd: 0.001
|
|
21
|
+
expected_context_tokens: 500
|
|
22
|
+
success_rate_target: 0.99
|
|
23
|
+
on_timeout:
|
|
24
|
+
action: "skip"
|
|
25
|
+
message: "DLQ operation timed out - will retry later"
|
|
26
|
+
on_cost_exceeded:
|
|
27
|
+
action: "alert"
|
|
28
|
+
continue: true
|
|
29
|
+
|
|
30
|
+
# Configuration
|
|
31
|
+
dlq_config:
|
|
32
|
+
storage_path: "koan/dlq"
|
|
33
|
+
max_entries: 500
|
|
34
|
+
max_retry_attempts: 3
|
|
35
|
+
backoff_base_ms: 2000 # 2s, 4s, 8s for retries
|
|
36
|
+
backoff_multiplier: 2
|
|
37
|
+
entry_ttl_hours: 168 # 7 days before auto-cleanup
|
|
38
|
+
critical_alert_threshold: 10 # Alert if > 10 failures in 1 hour
|
|
39
|
+
|
|
40
|
+
synchronizations:
|
|
41
|
+
# ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
|
|
42
|
+
# Capture: Concept Action Failures
|
|
43
|
+
# ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
|
|
44
|
+
|
|
45
|
+
- id: "concept-failure-to-dlq"
|
|
46
|
+
description: "Capture failed concept actions in dead letter queue"
|
|
47
|
+
when:
|
|
48
|
+
concept: "*" # Any concept
|
|
49
|
+
action: "*" # Any action
|
|
50
|
+
status: "failed"
|
|
51
|
+
where:
|
|
52
|
+
query: "error.type != 'user_cancelled'" # Don't queue user cancellations
|
|
53
|
+
then:
|
|
54
|
+
- action: "store_to_dlq"
|
|
55
|
+
inputs:
|
|
56
|
+
entry_type: "concept_failure"
|
|
57
|
+
concept: "${concept.name}"
|
|
58
|
+
action: "${action.name}"
|
|
59
|
+
flow_id: "${flow.id}"
|
|
60
|
+
story_id: "${story.id}"
|
|
61
|
+
error:
|
|
62
|
+
type: "${error.type}"
|
|
63
|
+
message: "${error.message}"
|
|
64
|
+
stack: "${error.stack}"
|
|
65
|
+
timestamp: "${timestamp}"
|
|
66
|
+
context:
|
|
67
|
+
inputs: "${action.inputs}"
|
|
68
|
+
state_snapshot: "${state.snapshot}"
|
|
69
|
+
retry_info:
|
|
70
|
+
attempts: 0
|
|
71
|
+
next_retry_at: null
|
|
72
|
+
backoff_ms: 2000
|
|
73
|
+
|
|
74
|
+
slo_expectations:
|
|
75
|
+
expected_duration_ms: 500
|
|
76
|
+
max_duration_ms: 5000
|
|
77
|
+
expected_cost_usd: 0.0
|
|
78
|
+
max_cost_usd: 0.0
|
|
79
|
+
expected_context_tokens: 200
|
|
80
|
+
on_timeout:
|
|
81
|
+
action: "skip"
|
|
82
|
+
fallback: "Log error and continue - entry may be lost"
|
|
83
|
+
|
|
84
|
+
provenance:
|
|
85
|
+
flow_id: "${flow.id}"
|
|
86
|
+
reason: "Concept action failed - storing in DLQ for retry"
|
|
87
|
+
category: "recovery"
|
|
88
|
+
|
|
89
|
+
# ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
|
|
90
|
+
# Capture: Sync Rule Failures
|
|
91
|
+
# ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
|
|
92
|
+
|
|
93
|
+
- id: "sync-failure-to-dlq"
|
|
94
|
+
description: "Capture failed sync rule evaluations in DLQ"
|
|
95
|
+
when:
|
|
96
|
+
sync_rule: "*" # Any sync rule
|
|
97
|
+
status: "failed"
|
|
98
|
+
then:
|
|
99
|
+
- action: "store_to_dlq"
|
|
100
|
+
inputs:
|
|
101
|
+
entry_type: "sync_failure"
|
|
102
|
+
sync_rule_id: "${sync.id}"
|
|
103
|
+
flow_id: "${flow.id}"
|
|
104
|
+
trigger:
|
|
105
|
+
concept: "${trigger.concept}"
|
|
106
|
+
action: "${trigger.action}"
|
|
107
|
+
error:
|
|
108
|
+
type: "${error.type}"
|
|
109
|
+
message: "${error.message}"
|
|
110
|
+
timestamp: "${timestamp}"
|
|
111
|
+
context:
|
|
112
|
+
inputs: "${sync.inputs}"
|
|
113
|
+
where_clause: "${sync.where}"
|
|
114
|
+
retry_info:
|
|
115
|
+
attempts: 0
|
|
116
|
+
next_retry_at: null
|
|
117
|
+
backoff_ms: 2000
|
|
118
|
+
|
|
119
|
+
slo_expectations:
|
|
120
|
+
expected_duration_ms: 500
|
|
121
|
+
max_duration_ms: 5000
|
|
122
|
+
expected_cost_usd: 0.0
|
|
123
|
+
max_cost_usd: 0.0
|
|
124
|
+
expected_context_tokens: 200
|
|
125
|
+
on_timeout:
|
|
126
|
+
action: "skip"
|
|
127
|
+
fallback: "Log error and continue"
|
|
128
|
+
|
|
129
|
+
provenance:
|
|
130
|
+
flow_id: "${flow.id}"
|
|
131
|
+
reason: "Sync rule failed - storing in DLQ"
|
|
132
|
+
category: "recovery"
|
|
133
|
+
|
|
134
|
+
# ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
|
|
135
|
+
# Capture: MCP Server Failures
|
|
136
|
+
# ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
|
|
137
|
+
|
|
138
|
+
- id: "mcp-failure-to-dlq"
|
|
139
|
+
description: "Capture MCP server failures after retries exhausted"
|
|
140
|
+
when:
|
|
141
|
+
mcp_server: "*"
|
|
142
|
+
status: "failed"
|
|
143
|
+
where:
|
|
144
|
+
query: "error.retry_count >= config.max_retries"
|
|
145
|
+
then:
|
|
146
|
+
- action: "store_to_dlq"
|
|
147
|
+
inputs:
|
|
148
|
+
entry_type: "mcp_failure"
|
|
149
|
+
server: "${mcp.server}"
|
|
150
|
+
tool: "${mcp.tool}"
|
|
151
|
+
flow_id: "${flow.id}"
|
|
152
|
+
error:
|
|
153
|
+
type: "${error.type}"
|
|
154
|
+
message: "${error.message}"
|
|
155
|
+
retry_count: "${error.retry_count}"
|
|
156
|
+
timestamp: "${timestamp}"
|
|
157
|
+
context:
|
|
158
|
+
inputs: "${mcp.inputs}"
|
|
159
|
+
server_status: "${mcp.server_status}"
|
|
160
|
+
retry_info:
|
|
161
|
+
attempts: 0
|
|
162
|
+
next_retry_at: null
|
|
163
|
+
backoff_ms: 5000 # Longer backoff for MCP
|
|
164
|
+
|
|
165
|
+
slo_expectations:
|
|
166
|
+
expected_duration_ms: 500
|
|
167
|
+
max_duration_ms: 5000
|
|
168
|
+
expected_cost_usd: 0.0
|
|
169
|
+
max_cost_usd: 0.0
|
|
170
|
+
expected_context_tokens: 200
|
|
171
|
+
on_timeout:
|
|
172
|
+
action: "skip"
|
|
173
|
+
fallback: "Log error and continue"
|
|
174
|
+
|
|
175
|
+
provenance:
|
|
176
|
+
flow_id: "${flow.id}"
|
|
177
|
+
reason: "MCP operation failed after max retries - storing in DLQ"
|
|
178
|
+
category: "recovery"
|
|
179
|
+
|
|
180
|
+
# ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
|
|
181
|
+
# Capture: Timeout Failures
|
|
182
|
+
# ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
|
|
183
|
+
|
|
184
|
+
- id: "timeout-to-dlq"
|
|
185
|
+
description: "Capture operations that timed out"
|
|
186
|
+
when:
|
|
187
|
+
status: "timeout"
|
|
188
|
+
then:
|
|
189
|
+
- action: "store_to_dlq"
|
|
190
|
+
inputs:
|
|
191
|
+
entry_type: "timeout"
|
|
192
|
+
operation_type: "${operation.type}"
|
|
193
|
+
operation_id: "${operation.id}"
|
|
194
|
+
flow_id: "${flow.id}"
|
|
195
|
+
timeout_info:
|
|
196
|
+
configured_timeout_ms: "${timeout.configured}"
|
|
197
|
+
actual_duration_ms: "${timeout.actual}"
|
|
198
|
+
timestamp: "${timestamp}"
|
|
199
|
+
context:
|
|
200
|
+
operation_inputs: "${operation.inputs}"
|
|
201
|
+
partial_output: "${operation.partial_output}"
|
|
202
|
+
retry_info:
|
|
203
|
+
attempts: 0
|
|
204
|
+
next_retry_at: null
|
|
205
|
+
backoff_ms: 3000
|
|
206
|
+
|
|
207
|
+
slo_expectations:
|
|
208
|
+
expected_duration_ms: 500
|
|
209
|
+
max_duration_ms: 5000
|
|
210
|
+
expected_cost_usd: 0.0
|
|
211
|
+
max_cost_usd: 0.0
|
|
212
|
+
expected_context_tokens: 300
|
|
213
|
+
on_timeout:
|
|
214
|
+
action: "skip"
|
|
215
|
+
fallback: "Log timeout and continue"
|
|
216
|
+
|
|
217
|
+
provenance:
|
|
218
|
+
flow_id: "${flow.id}"
|
|
219
|
+
reason: "Operation timed out - storing in DLQ"
|
|
220
|
+
category: "recovery"
|
|
221
|
+
|
|
222
|
+
# ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
|
|
223
|
+
# Retry: Automatic Retry with Backoff
|
|
224
|
+
# ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
|
|
225
|
+
|
|
226
|
+
- id: "dlq-auto-retry"
|
|
227
|
+
description: "Automatically retry failed operations with exponential backoff"
|
|
228
|
+
when:
|
|
229
|
+
schedule: "every_5_minutes"
|
|
230
|
+
where:
|
|
231
|
+
query: |
|
|
232
|
+
dlq.entries.any(e =>
|
|
233
|
+
e.retry_info.attempts < config.max_retry_attempts AND
|
|
234
|
+
e.retry_info.next_retry_at <= now() AND
|
|
235
|
+
e.entry_type != 'permanent_failure'
|
|
236
|
+
)
|
|
237
|
+
then:
|
|
238
|
+
- action: "process_dlq_retries"
|
|
239
|
+
inputs:
|
|
240
|
+
max_retries_per_run: 5
|
|
241
|
+
backoff_strategy: "exponential"
|
|
242
|
+
on_retry_success:
|
|
243
|
+
- action: "remove_from_dlq"
|
|
244
|
+
- action: "log_recovery"
|
|
245
|
+
message: "DLQ entry recovered: ${entry.id}"
|
|
246
|
+
on_retry_failure:
|
|
247
|
+
- action: "update_dlq_entry"
|
|
248
|
+
updates:
|
|
249
|
+
retry_info.attempts: "${entry.retry_info.attempts + 1}"
|
|
250
|
+
retry_info.next_retry_at: "${now() + (entry.retry_info.backoff_ms * 2)}"
|
|
251
|
+
retry_info.backoff_ms: "${entry.retry_info.backoff_ms * 2}"
|
|
252
|
+
last_error: "${error.message}"
|
|
253
|
+
on_max_attempts_reached:
|
|
254
|
+
- action: "mark_permanent_failure"
|
|
255
|
+
- action: "notify_user"
|
|
256
|
+
message: "DLQ entry exhausted retries: ${entry.id}"
|
|
257
|
+
|
|
258
|
+
slo_expectations:
|
|
259
|
+
expected_duration_ms: 30000
|
|
260
|
+
max_duration_ms: 120000
|
|
261
|
+
expected_cost_usd: 0.0
|
|
262
|
+
max_cost_usd: 0.001
|
|
263
|
+
expected_context_tokens: 1000
|
|
264
|
+
on_timeout:
|
|
265
|
+
action: "skip"
|
|
266
|
+
fallback: "Abort retry batch - will continue next run"
|
|
267
|
+
|
|
268
|
+
provenance:
|
|
269
|
+
flow_id: "scheduled"
|
|
270
|
+
reason: "Scheduled DLQ retry processing"
|
|
271
|
+
category: "core"
|
|
272
|
+
|
|
273
|
+
# ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
|
|
274
|
+
# Cleanup: Prune Old Entries
|
|
275
|
+
# ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
|
|
276
|
+
|
|
277
|
+
- id: "dlq-cleanup"
|
|
278
|
+
description: "Clean up old DLQ entries that exceeded TTL"
|
|
279
|
+
when:
|
|
280
|
+
schedule: "daily"
|
|
281
|
+
where:
|
|
282
|
+
query: "dlq.entries.any(e => age(e.timestamp) > config.entry_ttl_hours * 3600000)"
|
|
283
|
+
then:
|
|
284
|
+
- action: "cleanup_dlq"
|
|
285
|
+
inputs:
|
|
286
|
+
ttl_hours: 168 # 7 days
|
|
287
|
+
archive_before_delete: true
|
|
288
|
+
archive_path: "koan/dlq/archive"
|
|
289
|
+
keep_count: 100 # Keep last 100 entries even if old
|
|
290
|
+
|
|
291
|
+
slo_expectations:
|
|
292
|
+
expected_duration_ms: 5000
|
|
293
|
+
max_duration_ms: 30000
|
|
294
|
+
expected_cost_usd: 0.0
|
|
295
|
+
max_cost_usd: 0.0
|
|
296
|
+
expected_context_tokens: 100
|
|
297
|
+
on_timeout:
|
|
298
|
+
action: "skip"
|
|
299
|
+
fallback: "Skip cleanup - will retry tomorrow"
|
|
300
|
+
|
|
301
|
+
provenance:
|
|
302
|
+
flow_id: "scheduled"
|
|
303
|
+
reason: "Scheduled DLQ cleanup"
|
|
304
|
+
category: "maintenance"
|
|
305
|
+
|
|
306
|
+
# ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
|
|
307
|
+
# Analysis: Pattern Detection
|
|
308
|
+
# ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
|
|
309
|
+
|
|
310
|
+
- id: "dlq-pattern-analysis"
|
|
311
|
+
description: "Analyze DLQ for recurring failure patterns"
|
|
312
|
+
when:
|
|
313
|
+
schedule: "daily"
|
|
314
|
+
where:
|
|
315
|
+
query: "dlq.entries.count > 5"
|
|
316
|
+
then:
|
|
317
|
+
- concept: "retrospective"
|
|
318
|
+
action: "analyze_failures"
|
|
319
|
+
model: "sonnet"
|
|
320
|
+
inputs:
|
|
321
|
+
entries: "${dlq.entries}"
|
|
322
|
+
analysis_type: "pattern_detection"
|
|
323
|
+
group_by: ["error.type", "concept", "action"]
|
|
324
|
+
threshold: 3 # Flag patterns with 3+ occurrences
|
|
325
|
+
|
|
326
|
+
slo_expectations:
|
|
327
|
+
expected_duration_ms: 10000
|
|
328
|
+
max_duration_ms: 60000
|
|
329
|
+
expected_cost_usd: 0.002
|
|
330
|
+
max_cost_usd: 0.01
|
|
331
|
+
expected_context_tokens: 2000
|
|
332
|
+
on_timeout:
|
|
333
|
+
action: "skip"
|
|
334
|
+
fallback: "Skip analysis - will retry tomorrow"
|
|
335
|
+
|
|
336
|
+
provenance:
|
|
337
|
+
flow_id: "scheduled"
|
|
338
|
+
reason: "Daily DLQ pattern analysis"
|
|
339
|
+
category: "learning"
|
|
340
|
+
|
|
341
|
+
# ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
|
|
342
|
+
# Alert: Critical Failure Threshold
|
|
343
|
+
# ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
|
|
344
|
+
|
|
345
|
+
- id: "dlq-critical-alert"
|
|
346
|
+
description: "Alert when failure rate exceeds threshold"
|
|
347
|
+
when:
|
|
348
|
+
dlq_entries: "added"
|
|
349
|
+
where:
|
|
350
|
+
query: |
|
|
351
|
+
dlq.entries.filter(e =>
|
|
352
|
+
age(e.timestamp) < 3600000
|
|
353
|
+
).count >= config.critical_alert_threshold
|
|
354
|
+
then:
|
|
355
|
+
- action: "notify_user"
|
|
356
|
+
priority: "high"
|
|
357
|
+
message: |
|
|
358
|
+
Critical failure rate detected!
|
|
359
|
+
${dlq.recent_count} failures in the last hour.
|
|
360
|
+
|
|
361
|
+
Most common errors:
|
|
362
|
+
${dlq.error_summary}
|
|
363
|
+
|
|
364
|
+
Consider pausing workflow or investigating.
|
|
365
|
+
|
|
366
|
+
slo_expectations:
|
|
367
|
+
expected_duration_ms: 1000
|
|
368
|
+
max_duration_ms: 5000
|
|
369
|
+
expected_cost_usd: 0.0
|
|
370
|
+
max_cost_usd: 0.0
|
|
371
|
+
expected_context_tokens: 500
|
|
372
|
+
on_timeout:
|
|
373
|
+
action: "escalate"
|
|
374
|
+
message: "Critical alert timed out - manual intervention needed"
|
|
375
|
+
|
|
376
|
+
provenance:
|
|
377
|
+
flow_id: "${flow.id}"
|
|
378
|
+
reason: "Critical failure threshold exceeded"
|
|
379
|
+
category: "recovery"
|
|
380
|
+
|
|
381
|
+
# ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
|
|
382
|
+
# Manual: User Retry Request
|
|
383
|
+
# ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
|
|
384
|
+
|
|
385
|
+
- id: "dlq-manual-retry"
|
|
386
|
+
description: "Allow user to manually retry DLQ entries"
|
|
387
|
+
when:
|
|
388
|
+
command: "dlq_retry"
|
|
389
|
+
then:
|
|
390
|
+
- action: "ask_user"
|
|
391
|
+
questions:
|
|
392
|
+
- question: "Which DLQ entries should be retried?"
|
|
393
|
+
header: "Retry"
|
|
394
|
+
multiSelect: true
|
|
395
|
+
options:
|
|
396
|
+
- label: "All pending"
|
|
397
|
+
description: "Retry all entries that haven't exceeded max attempts"
|
|
398
|
+
- label: "Recent failures"
|
|
399
|
+
description: "Retry entries from the last 24 hours"
|
|
400
|
+
- label: "Specific type"
|
|
401
|
+
description: "Choose a specific failure type to retry"
|
|
402
|
+
|
|
403
|
+
on_answer:
|
|
404
|
+
"All pending":
|
|
405
|
+
- action: "retry_dlq_entries"
|
|
406
|
+
filter: "retry_info.attempts < max_retry_attempts"
|
|
407
|
+
"Recent failures":
|
|
408
|
+
- action: "retry_dlq_entries"
|
|
409
|
+
filter: "age(timestamp) < 86400000"
|
|
410
|
+
"Specific type":
|
|
411
|
+
- action: "ask_user"
|
|
412
|
+
questions:
|
|
413
|
+
- question: "Which failure type?"
|
|
414
|
+
header: "Type"
|
|
415
|
+
options:
|
|
416
|
+
- label: "Concept failures"
|
|
417
|
+
- label: "Sync failures"
|
|
418
|
+
- label: "MCP failures"
|
|
419
|
+
- label: "Timeouts"
|
|
420
|
+
|
|
421
|
+
slo_expectations:
|
|
422
|
+
expected_duration_ms: 60000
|
|
423
|
+
max_duration_ms: 300000
|
|
424
|
+
expected_cost_usd: 0.0
|
|
425
|
+
max_cost_usd: 0.005
|
|
426
|
+
expected_context_tokens: 1000
|
|
427
|
+
on_timeout:
|
|
428
|
+
action: "escalate"
|
|
429
|
+
message: "Manual retry timed out"
|
|
430
|
+
|
|
431
|
+
provenance:
|
|
432
|
+
flow_id: "${flow.id}"
|
|
433
|
+
reason: "Manual DLQ retry requested"
|
|
434
|
+
user_interaction: true
|
|
435
|
+
category: "core"
|
|
436
|
+
|
|
437
|
+
# ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
|
|
438
|
+
# Manual: View DLQ Status
|
|
439
|
+
# ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
|
|
440
|
+
|
|
441
|
+
- id: "dlq-status"
|
|
442
|
+
description: "Show DLQ status summary"
|
|
443
|
+
when:
|
|
444
|
+
command: "dlq_status"
|
|
445
|
+
then:
|
|
446
|
+
- action: "generate_report"
|
|
447
|
+
format: "markdown"
|
|
448
|
+
template: |
|
|
449
|
+
# Dead Letter Queue Status
|
|
450
|
+
|
|
451
|
+
## Summary
|
|
452
|
+
- **Total Entries**: ${dlq.total_count}
|
|
453
|
+
- **Pending Retry**: ${dlq.pending_count}
|
|
454
|
+
- **Permanent Failures**: ${dlq.permanent_count}
|
|
455
|
+
- **Oldest Entry**: ${dlq.oldest_entry.age} ago
|
|
456
|
+
|
|
457
|
+
## By Type
|
|
458
|
+
| Type | Count | Avg Retries |
|
|
459
|
+
|------|-------|-------------|
|
|
460
|
+
| Concept | ${dlq.concept_count} | ${dlq.concept_avg_retries} |
|
|
461
|
+
| Sync | ${dlq.sync_count} | ${dlq.sync_avg_retries} |
|
|
462
|
+
| MCP | ${dlq.mcp_count} | ${dlq.mcp_avg_retries} |
|
|
463
|
+
| Timeout | ${dlq.timeout_count} | ${dlq.timeout_avg_retries} |
|
|
464
|
+
|
|
465
|
+
## Recent Errors
|
|
466
|
+
${dlq.recent_errors.map(e => '- ' + e.summary).join('\n')}
|
|
467
|
+
|
|
468
|
+
## Actions
|
|
469
|
+
- `/dlq retry` - Retry pending entries
|
|
470
|
+
- `/dlq clear` - Clear permanent failures
|
|
471
|
+
- `/dlq analyze` - Analyze failure patterns
|
|
472
|
+
|
|
473
|
+
slo_expectations:
|
|
474
|
+
expected_duration_ms: 1000
|
|
475
|
+
max_duration_ms: 5000
|
|
476
|
+
expected_cost_usd: 0.0
|
|
477
|
+
max_cost_usd: 0.0
|
|
478
|
+
expected_context_tokens: 800
|
|
479
|
+
on_timeout:
|
|
480
|
+
action: "skip"
|
|
481
|
+
fallback: "Unable to generate status report"
|
|
482
|
+
|
|
483
|
+
provenance:
|
|
484
|
+
flow_id: "${flow.id}"
|
|
485
|
+
reason: "DLQ status requested"
|
|
486
|
+
category: "core"
|
|
487
|
+
|
|
488
|
+
# ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
|
|
489
|
+
# Dead Letter Queue Summary
|
|
490
|
+
# ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
|
|
491
|
+
#
|
|
492
|
+
# Entry Lifecycle:
|
|
493
|
+
#
|
|
494
|
+
# Operation Failed ──> Store in DLQ
|
|
495
|
+
# │ │
|
|
496
|
+
# │ v
|
|
497
|
+
# │ Wait for Retry
|
|
498
|
+
# │ │
|
|
499
|
+
# │ v
|
|
500
|
+
# │ Retry (1..3)
|
|
501
|
+
# │ │ │
|
|
502
|
+
# │ Success─┘ └─Failure
|
|
503
|
+
# │ │ │
|
|
504
|
+
# │ v v
|
|
505
|
+
# │ Remove Entry Mark Permanent
|
|
506
|
+
# │ │
|
|
507
|
+
# │ v
|
|
508
|
+
# └──────────────> Archive & Cleanup
|
|
509
|
+
#
|
|
510
|
+
# Storage Structure:
|
|
511
|
+
# koan/dlq/
|
|
512
|
+
# ├── pending/
|
|
513
|
+
# │ ├── entry-001.yaml
|
|
514
|
+
# │ └── entry-002.yaml
|
|
515
|
+
# ├── permanent/
|
|
516
|
+
# │ └── failed-003.yaml
|
|
517
|
+
# └── archive/
|
|
518
|
+
# └── 2025-01/
|
|
519
|
+
#
|
|
520
|
+
# Retry Schedule:
|
|
521
|
+
# Attempt 1: Immediate + 2s
|
|
522
|
+
# Attempt 2: After 4s backoff
|
|
523
|
+
# Attempt 3: After 8s backoff
|
|
524
|
+
# Permanent: After 3 failed attempts
|
|
525
|
+
#
|
|
526
|
+
# Commands:
|
|
527
|
+
# /dlq status - View DLQ summary
|
|
528
|
+
# /dlq retry - Manually retry entries
|
|
529
|
+
# /dlq clear - Clear permanent failures
|
|
530
|
+
# /dlq analyze - Analyze failure patterns
|