@su-record/vibe 2.9.32 → 2.9.33
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/.env.example +37 -37
- package/CLAUDE.md +109 -109
- package/LICENSE +21 -21
- package/README.en.md +220 -220
- package/README.md +171 -171
- package/agents/architect-low.md +41 -41
- package/agents/architect-medium.md +59 -59
- package/agents/architect.md +80 -80
- package/agents/build-error-resolver.md +115 -115
- package/agents/compounder.md +261 -261
- package/agents/diagrammer.md +178 -178
- package/agents/docs/api-documenter.md +99 -99
- package/agents/docs/changelog-writer.md +93 -93
- package/agents/e2e-tester.md +294 -294
- package/agents/event/event-comms.md +78 -78
- package/agents/event/event-content.md +68 -68
- package/agents/event/event-image.md +95 -95
- package/agents/event/event-ops.md +84 -84
- package/agents/event/event-scheduler.md +69 -69
- package/agents/event/event-speaker.md +86 -86
- package/agents/explorer-low.md +42 -42
- package/agents/explorer-medium.md +59 -59
- package/agents/explorer.md +48 -48
- package/agents/implementer-low.md +43 -43
- package/agents/implementer-medium.md +52 -52
- package/agents/implementer.md +54 -54
- package/agents/junior-mentor.md +141 -141
- package/agents/planning/requirements-analyst.md +84 -84
- package/agents/planning/ux-advisor.md +83 -83
- package/agents/qa/acceptance-tester.md +86 -86
- package/agents/qa/edge-case-finder.md +93 -93
- package/agents/qa/qa-coordinator.md +131 -131
- package/agents/refactor-cleaner.md +143 -143
- package/agents/research/best-practices-agent.md +199 -199
- package/agents/research/codebase-patterns-agent.md +157 -157
- package/agents/research/framework-docs-agent.md +188 -188
- package/agents/research/security-advisory-agent.md +213 -213
- package/agents/review/architecture-reviewer.md +107 -107
- package/agents/review/complexity-reviewer.md +116 -116
- package/agents/review/data-integrity-reviewer.md +88 -88
- package/agents/review/git-history-reviewer.md +103 -103
- package/agents/review/performance-reviewer.md +86 -86
- package/agents/review/python-reviewer.md +150 -150
- package/agents/review/rails-reviewer.md +139 -139
- package/agents/review/react-reviewer.md +144 -144
- package/agents/review/security-reviewer.md +80 -80
- package/agents/review/simplicity-reviewer.md +140 -140
- package/agents/review/test-coverage-reviewer.md +116 -116
- package/agents/review/typescript-reviewer.md +127 -127
- package/agents/searcher.md +54 -54
- package/agents/simplifier.md +120 -120
- package/agents/teams/debug-team.md +70 -70
- package/agents/teams/dev-team.md +88 -88
- package/agents/teams/docs-team.md +80 -80
- package/agents/teams/figma/figma-analyst.md +52 -52
- package/agents/teams/figma/figma-architect.md +112 -112
- package/agents/teams/figma/figma-auditor.md +82 -82
- package/agents/teams/figma/figma-builder.md +100 -100
- package/agents/teams/figma-team.md +85 -85
- package/agents/teams/fullstack-team.md +83 -83
- package/agents/teams/lite-team.md +69 -69
- package/agents/teams/migration-team.md +78 -78
- package/agents/teams/refactor-team.md +94 -94
- package/agents/teams/research-team.md +86 -86
- package/agents/teams/review-debate-team.md +125 -125
- package/agents/teams/security-team.md +81 -81
- package/agents/tester.md +49 -49
- package/agents/ui/ui-a11y-auditor.md +93 -93
- package/agents/ui/ui-antipattern-detector.md +102 -102
- package/agents/ui/ui-dataviz-advisor.md +69 -69
- package/agents/ui/ui-design-system-gen.md +57 -57
- package/agents/ui/ui-industry-analyzer.md +49 -49
- package/agents/ui/ui-layout-architect.md +65 -65
- package/agents/ui/ui-stack-implementer.md +68 -68
- package/agents/ui/ux-compliance-reviewer.md +81 -81
- package/agents/ui-previewer.md +258 -258
- package/commands/vibe.analyze.md +533 -533
- package/commands/vibe.contract.md +105 -105
- package/commands/vibe.docs.md +33 -33
- package/commands/vibe.event.md +163 -163
- package/commands/vibe.figma.md +600 -600
- package/commands/vibe.harness.md +177 -177
- package/commands/vibe.regress.md +73 -73
- package/commands/vibe.review.md +624 -624
- package/commands/vibe.run.md +1946 -1946
- package/commands/vibe.scaffold.md +195 -195
- package/commands/vibe.spec.md +577 -577
- package/commands/vibe.test.md +49 -49
- package/commands/vibe.trace.md +276 -276
- package/commands/vibe.utils.md +413 -413
- package/commands/vibe.verify.md +572 -572
- package/dist/cli/collaborator.js +52 -52
- package/dist/cli/commands/codex-proxy.js +15 -15
- package/dist/cli/commands/config.js +9 -9
- package/dist/cli/commands/evolution.js +12 -12
- package/dist/cli/commands/figma.js +20 -20
- package/dist/cli/commands/info.js +46 -46
- package/dist/cli/commands/init.d.ts.map +1 -1
- package/dist/cli/commands/init.js +15 -10
- package/dist/cli/commands/init.js.map +1 -1
- package/dist/cli/commands/remove.js +14 -14
- package/dist/cli/commands/sentinel.js +27 -27
- package/dist/cli/commands/skills.js +5 -5
- package/dist/cli/commands/slack.js +10 -10
- package/dist/cli/commands/stats.js +6 -6
- package/dist/cli/commands/telegram.js +12 -12
- package/dist/cli/commands/update.d.ts.map +1 -1
- package/dist/cli/commands/update.js +5 -3
- package/dist/cli/commands/update.js.map +1 -1
- package/dist/cli/detect.js +32 -32
- package/dist/cli/index.js +33 -33
- package/dist/cli/llm/claude-commands.js +16 -16
- package/dist/cli/llm/config.js +18 -18
- package/dist/cli/llm/gemini-commands.js +16 -16
- package/dist/cli/llm/gpt-commands.js +19 -19
- package/dist/cli/llm/help.js +21 -21
- package/dist/cli/postinstall/cursor-agents.js +32 -32
- package/dist/cli/postinstall/cursor-rules.js +83 -83
- package/dist/cli/postinstall/cursor-skills.js +743 -743
- package/dist/cli/postinstall/main.d.ts.map +1 -1
- package/dist/cli/postinstall/main.js +11 -0
- package/dist/cli/postinstall/main.js.map +1 -1
- package/dist/cli/setup/ProjectSetup.d.ts +9 -4
- package/dist/cli/setup/ProjectSetup.d.ts.map +1 -1
- package/dist/cli/setup/ProjectSetup.js +95 -79
- package/dist/cli/setup/ProjectSetup.js.map +1 -1
- package/dist/cli/setup/Provisioner.js +42 -42
- package/dist/cli/setup.d.ts +1 -1
- package/dist/cli/setup.d.ts.map +1 -1
- package/dist/cli/setup.js +1 -1
- package/dist/cli/setup.js.map +1 -1
- package/dist/infra/lib/DeepInit.js +24 -24
- package/dist/infra/lib/IterationTracker.js +11 -11
- package/dist/infra/lib/PythonParser.js +108 -108
- package/dist/infra/lib/ReviewRace.js +96 -96
- package/dist/infra/lib/SkillFrontmatter.js +28 -28
- package/dist/infra/lib/SkillQualityGate.js +9 -9
- package/dist/infra/lib/SkillRepository.js +159 -159
- package/dist/infra/lib/UltraQA.js +99 -99
- package/dist/infra/lib/autonomy/AuditStore.js +41 -41
- package/dist/infra/lib/autonomy/ConfirmationStore.js +30 -30
- package/dist/infra/lib/autonomy/EventOutbox.js +38 -38
- package/dist/infra/lib/autonomy/PolicyEngine.d.ts +3 -3
- package/dist/infra/lib/autonomy/PolicyEngine.js +18 -18
- package/dist/infra/lib/autonomy/SecuritySentinel.js +1 -1
- package/dist/infra/lib/autonomy/SuggestionStore.js +33 -33
- package/dist/infra/lib/embedding/VectorStore.js +22 -22
- package/dist/infra/lib/evolution/AgentAnalyzer.js +10 -10
- package/dist/infra/lib/evolution/DescriptionOptimizer.js +21 -21
- package/dist/infra/lib/evolution/GenerationRegistry.js +36 -36
- package/dist/infra/lib/evolution/InsightStore.js +90 -90
- package/dist/infra/lib/evolution/ParityTester.js +57 -57
- package/dist/infra/lib/evolution/RollbackManager.js +5 -5
- package/dist/infra/lib/evolution/SkillBenchmark.js +23 -23
- package/dist/infra/lib/evolution/SkillEvalRunner.js +50 -50
- package/dist/infra/lib/evolution/SkillGapDetector.js +10 -10
- package/dist/infra/lib/evolution/UsageTracker.js +28 -28
- package/dist/infra/lib/gemini/orchestration.js +5 -5
- package/dist/infra/lib/gpt/orchestration.js +4 -4
- package/dist/infra/lib/memory/KnowledgeGraph.js +4 -4
- package/dist/infra/lib/memory/MemorySearch.js +57 -57
- package/dist/infra/lib/memory/MemoryStorage.js +181 -181
- package/dist/infra/lib/memory/ObservationStore.js +28 -28
- package/dist/infra/lib/memory/ReflectionStore.js +30 -30
- package/dist/infra/lib/memory/SessionRAGRetriever.js +7 -7
- package/dist/infra/lib/memory/SessionRAGStore.js +225 -225
- package/dist/infra/lib/memory/SessionSummarizer.js +9 -9
- package/dist/infra/orchestrator/AgentManager.js +12 -12
- package/dist/infra/orchestrator/AgentRegistry.js +65 -65
- package/dist/infra/orchestrator/MultiLlmResearch.js +8 -8
- package/dist/infra/orchestrator/SwarmOrchestrator.test.js +16 -16
- package/dist/infra/orchestrator/parallelResearch.js +24 -24
- package/dist/tools/convention/analyzeComplexity.test.js +115 -115
- package/dist/tools/convention/validateCodeQuality.test.js +104 -104
- package/dist/tools/memory/createMemoryTimeline.js +10 -10
- package/dist/tools/memory/getMemoryGraph.js +12 -12
- package/dist/tools/memory/getSessionContext.js +9 -9
- package/dist/tools/memory/linkMemories.js +14 -14
- package/dist/tools/memory/listMemories.js +4 -4
- package/dist/tools/memory/recallMemory.js +4 -4
- package/dist/tools/memory/saveMemory.js +4 -4
- package/dist/tools/memory/searchMemoriesAdvanced.js +23 -23
- package/dist/tools/semantic/analyzeDependencyGraph.js +12 -12
- package/dist/tools/semantic/astGrep.test.js +6 -6
- package/dist/tools/spec/prdParser.test.js +171 -171
- package/dist/tools/spec/specGenerator.js +169 -169
- package/dist/tools/spec/traceabilityMatrix.js +64 -64
- package/dist/tools/spec/traceabilityMatrix.test.js +28 -28
- package/hooks/gemini-hooks.json +73 -73
- package/hooks/hooks.json +134 -134
- package/hooks/scripts/__tests__/keyword-detector.test.js +199 -199
- package/hooks/scripts/__tests__/pre-tool-guard.test.js +409 -409
- package/hooks/scripts/__tests__/sentinel-guard.test.js +208 -208
- package/hooks/scripts/auto-commit.js +97 -97
- package/hooks/scripts/auto-format.js +64 -64
- package/hooks/scripts/auto-test.js +81 -81
- package/hooks/scripts/code-check.js +271 -271
- package/hooks/scripts/codex-detect.js +46 -46
- package/hooks/scripts/codex-review-gate.js +80 -80
- package/hooks/scripts/command-log.js +32 -32
- package/hooks/scripts/context-save.js +353 -353
- package/hooks/scripts/evolution-engine.js +91 -91
- package/hooks/scripts/figma-extract.js +768 -768
- package/hooks/scripts/figma-guard.js +219 -219
- package/hooks/scripts/figma-refine.js +315 -315
- package/hooks/scripts/figma-to-scss.js +394 -394
- package/hooks/scripts/figma-validate.js +353 -353
- package/hooks/scripts/hud-status.js +321 -321
- package/hooks/scripts/keyword-detector.js +214 -214
- package/hooks/scripts/lib/dispatcher.js +87 -87
- package/hooks/scripts/lib/scope-from-spec.js +276 -276
- package/hooks/scripts/llm-orchestrate.js +645 -645
- package/hooks/scripts/post-edit.js +35 -35
- package/hooks/scripts/pr-test-gate.js +52 -52
- package/hooks/scripts/pre-tool-guard.js +259 -259
- package/hooks/scripts/prompt-dispatcher.js +192 -192
- package/hooks/scripts/scope-guard.js +145 -145
- package/hooks/scripts/sentinel-guard.js +130 -130
- package/hooks/scripts/session-start.js +186 -186
- package/hooks/scripts/skill-injector.js +83 -83
- package/hooks/scripts/step-counter.js +45 -45
- package/hooks/scripts/stop-notify.js +209 -209
- package/hooks/scripts/utils.js +315 -315
- package/languages/csharp-unity.md +515 -515
- package/languages/gdscript-godot.md +470 -470
- package/languages/ruby-rails.md +489 -489
- package/languages/typescript-angular.md +433 -433
- package/languages/typescript-astro.md +416 -416
- package/languages/typescript-electron.md +406 -406
- package/languages/typescript-nestjs.md +524 -524
- package/languages/typescript-svelte.md +407 -407
- package/languages/typescript-tauri.md +365 -365
- package/package.json +106 -106
- package/skills/agents-md/SKILL.md +121 -121
- package/skills/agents-md/rubrics/what-to-keep.md +49 -49
- package/skills/agents-md/templates/agents-md.md +36 -36
- package/skills/arch-guard/SKILL.md +181 -181
- package/skills/arch-guard/agents/detector.md +48 -48
- package/skills/arch-guard/agents/reporter.md +48 -48
- package/skills/arch-guard/agents/rule-generator.md +49 -49
- package/skills/arch-guard/agents/violation-checker.md +51 -51
- package/skills/arch-guard/frameworks/clean-architecture.md +108 -108
- package/skills/arch-guard/frameworks/solid.md +102 -102
- package/skills/arch-guard/scripts/check-boundaries.js +90 -90
- package/skills/arch-guard/templates/arch-rules.json +47 -47
- package/skills/arch-guard/templates/violation-report.md +53 -53
- package/skills/brand-assets/SKILL.md +147 -147
- package/skills/brand-assets/rubrics/asset-checklist.md +98 -98
- package/skills/brand-assets/templates/brand-guide.md +161 -161
- package/skills/capability-loop/SKILL.md +272 -272
- package/skills/capability-loop/agents/capability-designer.md +61 -61
- package/skills/capability-loop/agents/failure-analyst.md +55 -55
- package/skills/capability-loop/agents/implementer.md +50 -50
- package/skills/capability-loop/agents/tester.md +53 -53
- package/skills/capability-loop/templates/capability-spec.md +118 -118
- package/skills/capability-loop/templates/failure-analysis.md +118 -118
- package/skills/characterization-test/SKILL.md +207 -207
- package/skills/characterization-test/agents/behavior-capturer.md +50 -50
- package/skills/characterization-test/agents/coverage-checker.md +54 -54
- package/skills/characterization-test/agents/reporter.md +50 -50
- package/skills/characterization-test/agents/test-writer.md +49 -49
- package/skills/characterization-test/rubrics/coverage-criteria.md +53 -53
- package/skills/characterization-test/templates/test-template.ts +101 -101
- package/skills/chub-usage/SKILL.md +139 -139
- package/skills/claude-md-guide/SKILL.md +351 -351
- package/skills/claude-md-guide/rubrics/anti-patterns.md +88 -88
- package/skills/claude-md-guide/templates/claude-md.md +54 -54
- package/skills/commerce-patterns/SKILL.md +64 -64
- package/skills/commerce-patterns/rubrics/checkout-flow.md +48 -48
- package/skills/commerce-patterns/templates/product-schema.md +85 -85
- package/skills/commit-push-pr/SKILL.md +77 -77
- package/skills/commit-push-pr/agents/change-analyzer.md +55 -55
- package/skills/commit-push-pr/agents/message-writer.md +50 -50
- package/skills/commit-push-pr/agents/pr-writer.md +58 -58
- package/skills/commit-push-pr/agents/reviewer.md +52 -52
- package/skills/commit-push-pr/rubrics/commit-message.md +73 -73
- package/skills/commit-push-pr/templates/pr-body.md +63 -63
- package/skills/context7-usage/SKILL.md +106 -106
- package/skills/context7-usage/rubrics/when-to-use.md +50 -50
- package/skills/create-prd/SKILL.md +90 -90
- package/skills/create-prd/agents/edge-case-finder.md +48 -48
- package/skills/create-prd/agents/prioritizer.md +60 -60
- package/skills/create-prd/agents/requirements-writer.md +48 -48
- package/skills/create-prd/agents/researcher.md +55 -55
- package/skills/create-prd/agents/reviewer.md +54 -54
- package/skills/create-prd/frameworks/jobs-to-be-done.md +96 -96
- package/skills/create-prd/frameworks/rice-scoring.md +97 -97
- package/skills/create-prd/orchestrator.md +70 -70
- package/skills/create-prd/rubrics/completeness.md +58 -58
- package/skills/create-prd/templates/prd.md +139 -139
- package/skills/design-audit/SKILL.md +152 -152
- package/skills/design-audit/agents/a11y-auditor.md +43 -43
- package/skills/design-audit/agents/performance-auditor.md +46 -46
- package/skills/design-audit/agents/responsive-auditor.md +46 -46
- package/skills/design-audit/agents/scorer.md +47 -47
- package/skills/design-audit/agents/slop-detector.md +47 -47
- package/skills/design-audit/frameworks/core-web-vitals.md +107 -107
- package/skills/design-audit/frameworks/wcag-checklist.md +64 -64
- package/skills/design-audit/orchestrator.md +64 -64
- package/skills/design-audit/rubrics/ai-slop-patterns.md +83 -83
- package/skills/design-audit/rubrics/scoring.md +63 -63
- package/skills/design-audit/templates/report.md +88 -88
- package/skills/design-critique/SKILL.md +139 -139
- package/skills/design-critique/rubrics/ux-heuristics.md +143 -143
- package/skills/design-critique/templates/critique-report.md +86 -86
- package/skills/design-distill/SKILL.md +130 -130
- package/skills/design-distill/templates/design-system.md +132 -132
- package/skills/design-normalize/SKILL.md +133 -133
- package/skills/design-normalize/rubrics/token-naming.md +117 -117
- package/skills/design-normalize/templates/token-audit.md +89 -89
- package/skills/design-polish/SKILL.md +131 -131
- package/skills/design-polish/rubrics/polish-checklist.md +68 -68
- package/skills/design-polish/templates/polish-report.md +64 -64
- package/skills/design-teach/SKILL.md +182 -182
- package/skills/design-teach/rubrics/brand-personality.md +73 -73
- package/skills/design-teach/templates/design-context.json +36 -36
- package/skills/devlog/SKILL.md +143 -143
- package/skills/e2e-commerce/SKILL.md +62 -62
- package/skills/e2e-commerce/templates/test-scenarios.md +170 -170
- package/skills/event-comms/SKILL.md +172 -172
- package/skills/event-comms/templates/email-invite.md +99 -99
- package/skills/event-comms/templates/sns-post.md +133 -133
- package/skills/event-ops/SKILL.md +207 -207
- package/skills/event-ops/rubrics/contingency.md +85 -85
- package/skills/event-ops/templates/d-day-checklist.md +65 -65
- package/skills/event-planning/SKILL.md +144 -144
- package/skills/event-planning/rubrics/timeline.md +70 -70
- package/skills/event-planning/templates/event-plan.md +91 -91
- package/skills/exec-plan/SKILL.md +149 -149
- package/skills/exec-plan/agents/decomposer.md +47 -47
- package/skills/exec-plan/agents/dependency-mapper.md +44 -44
- package/skills/exec-plan/agents/estimator.md +43 -43
- package/skills/exec-plan/agents/validator.md +55 -55
- package/skills/exec-plan/orchestrator.md +70 -70
- package/skills/exec-plan/rubrics/complexity-scoring.md +75 -75
- package/skills/exec-plan/templates/plan.md +147 -147
- package/skills/git-worktree/SKILL.md +73 -73
- package/skills/git-worktree/rubrics/when-to-use.md +55 -55
- package/skills/handoff/SKILL.md +110 -110
- package/skills/handoff/agents/context-summarizer.md +51 -51
- package/skills/handoff/agents/document-writer.md +63 -63
- package/skills/handoff/agents/state-collector.md +53 -53
- package/skills/handoff/agents/verifier.md +48 -48
- package/skills/handoff/rubrics/completeness.md +62 -62
- package/skills/handoff/templates/handoff.md +107 -107
- package/skills/parallel-research/SKILL.md +104 -104
- package/skills/parallel-research/agents/best-practices.md +43 -43
- package/skills/parallel-research/agents/codebase-patterns.md +46 -46
- package/skills/parallel-research/agents/framework-docs.md +45 -45
- package/skills/parallel-research/agents/security-advisory.md +46 -46
- package/skills/parallel-research/agents/synthesizer.md +57 -57
- package/skills/parallel-research/experts/best-practices.md +50 -50
- package/skills/parallel-research/experts/codebase-patterns.md +70 -70
- package/skills/parallel-research/experts/framework-docs.md +65 -65
- package/skills/parallel-research/experts/security-advisory.md +69 -69
- package/skills/parallel-research/orchestrator.md +79 -79
- package/skills/parallel-research/templates/awesome-list.md +32 -32
- package/skills/parallel-research/templates/paper.md +88 -88
- package/skills/parallel-research/templates/synthesis.md +101 -101
- package/skills/prioritization-frameworks/SKILL.md +87 -87
- package/skills/prioritization-frameworks/rubrics/frameworks.md +79 -79
- package/skills/prioritization-frameworks/templates/scoring-matrix.md +69 -69
- package/skills/priority-todos/SKILL.md +64 -64
- package/skills/priority-todos/rubrics/prioritization.md +70 -70
- package/skills/priority-todos/templates/todo-board.md +59 -59
- package/skills/seo-checklist/SKILL.md +58 -58
- package/skills/seo-checklist/frameworks/structured-data.md +153 -153
- package/skills/seo-checklist/rubrics/content-seo.md +42 -42
- package/skills/seo-checklist/rubrics/technical-seo.md +48 -48
- package/skills/techdebt/SKILL.md +124 -124
- package/skills/techdebt/agents/analyzer.md +50 -50
- package/skills/techdebt/agents/fixer.md +41 -41
- package/skills/techdebt/agents/reviewer.md +47 -47
- package/skills/techdebt/agents/scanner.md +44 -44
- package/skills/techdebt/orchestrator.md +70 -70
- package/skills/techdebt/rubrics/severity.md +51 -51
- package/skills/techdebt/scripts/scan.js +90 -90
- package/skills/techdebt/templates/report.md +86 -86
- package/skills/tool-fallback/SKILL.md +104 -104
- package/skills/tool-fallback/rubrics/fallback-chain.md +58 -58
- package/skills/typescript-advanced-types/SKILL.md +67 -67
- package/skills/typescript-advanced-types/rubrics/type-patterns.md +109 -109
- package/skills/ui-ux-pro-max/SKILL.md +236 -236
- package/skills/ui-ux-pro-max/reference/color-and-contrast.md +517 -517
- package/skills/ui-ux-pro-max/reference/interaction-design.md +544 -544
- package/skills/ui-ux-pro-max/reference/motion-design.md +591 -591
- package/skills/ui-ux-pro-max/reference/responsive-design.md +463 -463
- package/skills/ui-ux-pro-max/reference/spatial-design.md +390 -390
- package/skills/ui-ux-pro-max/reference/typography.md +455 -455
- package/skills/ui-ux-pro-max/reference/ux-writing.md +469 -469
- package/skills/ui-ux-pro-max/rubrics/interaction-states.md +83 -83
- package/skills/ui-ux-pro-max/rubrics/responsive-breakpoints.md +99 -99
- package/skills/user-personas/SKILL.md +75 -75
- package/skills/user-personas/rubrics/research-methods.md +56 -56
- package/skills/user-personas/templates/persona.md +89 -89
- package/skills/vercel-react-best-practices/SKILL.md +60 -60
- package/skills/vercel-react-best-practices/rubrics/performance.md +82 -82
- package/skills/vercel-react-best-practices/rubrics/server-components.md +86 -86
- package/skills/vibe-contract/SKILL.md +166 -166
- package/skills/vibe-docs/templates/architecture.md +80 -80
- package/skills/vibe-docs/templates/readme.md +84 -84
- package/skills/vibe-docs/templates/release-notes.md +74 -74
- package/skills/vibe-figma/SKILL.md +363 -363
- package/skills/vibe-figma/rubrics/extraction-checklist.md +51 -51
- package/skills/vibe-figma/templates/component-index.md +126 -126
- package/skills/vibe-figma/templates/component-spec.md +168 -168
- package/skills/vibe-figma/templates/figma-handoff.md +100 -100
- package/skills/vibe-figma/templates/remapped-tree.md +277 -277
- package/skills/vibe-figma-convert/SKILL.md +235 -235
- package/skills/vibe-figma-convert/rubrics/conversion-rules.md +141 -141
- package/skills/vibe-figma-convert/templates/component.md +140 -140
- package/skills/vibe-figma-extract/SKILL.md +241 -241
- package/skills/vibe-figma-extract/rubrics/image-rules.md +157 -157
- package/skills/vibe-interview/SKILL.md +358 -358
- package/skills/vibe-interview/checklists/api.md +101 -101
- package/skills/vibe-interview/checklists/feature.md +88 -88
- package/skills/vibe-interview/checklists/library.md +95 -95
- package/skills/vibe-interview/checklists/mobile.md +89 -89
- package/skills/vibe-interview/checklists/webapp.md +97 -97
- package/skills/vibe-interview/checklists/website.md +99 -99
- package/skills/vibe-plan/SKILL.md +254 -254
- package/skills/vibe-regress/SKILL.md +174 -174
- package/skills/vibe-regress/templates/bug.md +44 -44
- package/skills/vibe-regress/templates/test-jest.md +29 -29
- package/skills/vibe-regress/templates/test-vitest.md +30 -30
- package/skills/vibe-spec/SKILL.md +1195 -1195
- package/skills/vibe-spec-review/SKILL.md +726 -726
- package/skills/vibe-test/SKILL.md +140 -140
- package/skills/video-production/SKILL.md +52 -52
- package/skills/video-production/rubrics/quality-checklist.md +58 -58
- package/skills/video-production/templates/production-plan.md +104 -104
- package/vibe/config.json +29 -29
- package/vibe/constitution.md +227 -227
- package/vibe/rules/principles/communication-guide.md +98 -98
- package/vibe/rules/principles/development-philosophy.md +52 -52
- package/vibe/rules/principles/quick-start.md +102 -102
- package/vibe/rules/quality/bdd-contract-testing.md +393 -393
- package/vibe/rules/quality/checklist.md +276 -276
- package/vibe/rules/quality/performance.md +236 -236
- package/vibe/rules/quality/testing-strategy.md +440 -440
- package/vibe/rules/standards/anti-patterns.md +541 -541
- package/vibe/rules/standards/code-structure.md +291 -291
- package/vibe/rules/standards/complexity-metrics.md +313 -313
- package/vibe/rules/standards/git-workflow.md +237 -237
- package/vibe/rules/standards/naming-conventions.md +198 -198
- package/vibe/rules/standards/security.md +305 -305
- package/vibe/rules/writing/document-style.md +74 -74
- package/vibe/setup.sh +31 -31
- package/vibe/templates/claudemd-template.md +74 -74
- package/vibe/templates/constitution-template.md +267 -267
- package/vibe/templates/contract-backend-template.md +526 -526
- package/vibe/templates/contract-frontend-template.md +599 -599
- package/vibe/templates/feature-template.md +96 -96
- package/vibe/templates/plan-template.md +194 -194
- package/vibe/templates/spec-template.md +221 -221
- package/vibe/ui-ux-data/charts.csv +26 -26
- package/vibe/ui-ux-data/colors.csv +97 -97
- package/vibe/ui-ux-data/icons.csv +101 -101
- package/vibe/ui-ux-data/landing.csv +31 -31
- package/vibe/ui-ux-data/products.csv +96 -96
- package/vibe/ui-ux-data/react-performance.csv +45 -45
- package/vibe/ui-ux-data/stacks/astro.csv +54 -54
- package/vibe/ui-ux-data/stacks/flutter.csv +53 -53
- package/vibe/ui-ux-data/stacks/html-tailwind.csv +56 -56
- package/vibe/ui-ux-data/stacks/jetpack-compose.csv +53 -53
- package/vibe/ui-ux-data/stacks/nextjs.csv +53 -53
- package/vibe/ui-ux-data/stacks/nuxt-ui.csv +51 -51
- package/vibe/ui-ux-data/stacks/nuxtjs.csv +59 -59
- package/vibe/ui-ux-data/stacks/react-native.csv +52 -52
- package/vibe/ui-ux-data/stacks/react.csv +54 -54
- package/vibe/ui-ux-data/stacks/shadcn.csv +61 -61
- package/vibe/ui-ux-data/stacks/svelte.csv +54 -54
- package/vibe/ui-ux-data/stacks/swiftui.csv +51 -51
- package/vibe/ui-ux-data/stacks/vue.csv +50 -50
- package/vibe/ui-ux-data/styles.csv +68 -68
- package/vibe/ui-ux-data/typography.csv +57 -57
- package/vibe/ui-ux-data/ui-reasoning.csv +101 -101
- package/vibe/ui-ux-data/ux-guidelines.csv +99 -99
- package/vibe/ui-ux-data/version.json +31 -31
- package/vibe/ui-ux-data/web-interface.csv +31 -31
|
@@ -20,41 +20,41 @@ export class ConfirmationStore {
|
|
|
20
20
|
constructor(storage) {
|
|
21
21
|
this.db = storage.getDatabase();
|
|
22
22
|
this.initTables();
|
|
23
|
-
this.insertStmt = this.db.prepare(`
|
|
24
|
-
INSERT INTO confirmations
|
|
25
|
-
(id, correlationId, actionType, actionSummary, riskLevel, riskScore, riskFactors,
|
|
26
|
-
status, expiresAt, idempotencyKey, createdAt)
|
|
27
|
-
VALUES (?, ?, ?, ?, ?, ?, ?, 'pending', ?, ?, ?)
|
|
23
|
+
this.insertStmt = this.db.prepare(`
|
|
24
|
+
INSERT INTO confirmations
|
|
25
|
+
(id, correlationId, actionType, actionSummary, riskLevel, riskScore, riskFactors,
|
|
26
|
+
status, expiresAt, idempotencyKey, createdAt)
|
|
27
|
+
VALUES (?, ?, ?, ?, ?, ?, ?, 'pending', ?, ?, ?)
|
|
28
28
|
`);
|
|
29
|
-
this.resolveStmt = this.db.prepare(`
|
|
30
|
-
UPDATE confirmations SET status = ?, respondedAt = ?, ownerResponse = ?
|
|
31
|
-
WHERE id = ? AND status = 'pending'
|
|
29
|
+
this.resolveStmt = this.db.prepare(`
|
|
30
|
+
UPDATE confirmations SET status = ?, respondedAt = ?, ownerResponse = ?
|
|
31
|
+
WHERE id = ? AND status = 'pending'
|
|
32
32
|
`);
|
|
33
33
|
this.getByIdStmt = this.db.prepare('SELECT * FROM confirmations WHERE id = ?');
|
|
34
34
|
}
|
|
35
35
|
initTables() {
|
|
36
|
-
this.db.exec(`
|
|
37
|
-
CREATE TABLE IF NOT EXISTS confirmations (
|
|
38
|
-
id TEXT PRIMARY KEY,
|
|
39
|
-
correlationId TEXT NOT NULL,
|
|
40
|
-
actionType TEXT NOT NULL,
|
|
41
|
-
actionSummary TEXT NOT NULL,
|
|
42
|
-
riskLevel TEXT NOT NULL,
|
|
43
|
-
riskScore INTEGER NOT NULL,
|
|
44
|
-
riskFactors TEXT NOT NULL,
|
|
45
|
-
status TEXT NOT NULL DEFAULT 'pending'
|
|
46
|
-
CHECK(status IN ('pending', 'approved', 'rejected', 'expired', 'cancelled')),
|
|
47
|
-
channel TEXT,
|
|
48
|
-
notifiedAt TEXT,
|
|
49
|
-
respondedAt TEXT,
|
|
50
|
-
ownerResponse TEXT,
|
|
51
|
-
expiresAt TEXT NOT NULL,
|
|
52
|
-
idempotencyKey TEXT UNIQUE,
|
|
53
|
-
createdAt TEXT NOT NULL
|
|
54
|
-
);
|
|
55
|
-
CREATE INDEX IF NOT EXISTS idx_confirmation_status_expires ON confirmations(status, expiresAt);
|
|
56
|
-
CREATE INDEX IF NOT EXISTS idx_confirmation_correlation ON confirmations(correlationId);
|
|
57
|
-
CREATE INDEX IF NOT EXISTS idx_confirmation_idempotency ON confirmations(idempotencyKey);
|
|
36
|
+
this.db.exec(`
|
|
37
|
+
CREATE TABLE IF NOT EXISTS confirmations (
|
|
38
|
+
id TEXT PRIMARY KEY,
|
|
39
|
+
correlationId TEXT NOT NULL,
|
|
40
|
+
actionType TEXT NOT NULL,
|
|
41
|
+
actionSummary TEXT NOT NULL,
|
|
42
|
+
riskLevel TEXT NOT NULL,
|
|
43
|
+
riskScore INTEGER NOT NULL,
|
|
44
|
+
riskFactors TEXT NOT NULL,
|
|
45
|
+
status TEXT NOT NULL DEFAULT 'pending'
|
|
46
|
+
CHECK(status IN ('pending', 'approved', 'rejected', 'expired', 'cancelled')),
|
|
47
|
+
channel TEXT,
|
|
48
|
+
notifiedAt TEXT,
|
|
49
|
+
respondedAt TEXT,
|
|
50
|
+
ownerResponse TEXT,
|
|
51
|
+
expiresAt TEXT NOT NULL,
|
|
52
|
+
idempotencyKey TEXT UNIQUE,
|
|
53
|
+
createdAt TEXT NOT NULL
|
|
54
|
+
);
|
|
55
|
+
CREATE INDEX IF NOT EXISTS idx_confirmation_status_expires ON confirmations(status, expiresAt);
|
|
56
|
+
CREATE INDEX IF NOT EXISTS idx_confirmation_correlation ON confirmations(correlationId);
|
|
57
|
+
CREATE INDEX IF NOT EXISTS idx_confirmation_idempotency ON confirmations(idempotencyKey);
|
|
58
58
|
`);
|
|
59
59
|
}
|
|
60
60
|
create(input) {
|
|
@@ -18,52 +18,52 @@ export class EventOutbox {
|
|
|
18
18
|
this.db = storage.getDatabase();
|
|
19
19
|
this.eventBus = eventBus;
|
|
20
20
|
this.initTables();
|
|
21
|
-
this.enqueueStmt = this.db.prepare(`
|
|
22
|
-
INSERT INTO event_outbox (id, eventType, payload, status, retryCount, createdAt)
|
|
23
|
-
VALUES (?, ?, ?, 'pending', 0, ?)
|
|
21
|
+
this.enqueueStmt = this.db.prepare(`
|
|
22
|
+
INSERT INTO event_outbox (id, eventType, payload, status, retryCount, createdAt)
|
|
23
|
+
VALUES (?, ?, ?, 'pending', 0, ?)
|
|
24
24
|
`);
|
|
25
|
-
this.markProcessingStmt = this.db.prepare(`
|
|
26
|
-
UPDATE event_outbox SET status = 'processing' WHERE id = ? AND status = 'pending'
|
|
25
|
+
this.markProcessingStmt = this.db.prepare(`
|
|
26
|
+
UPDATE event_outbox SET status = 'processing' WHERE id = ? AND status = 'pending'
|
|
27
27
|
`);
|
|
28
|
-
this.markPublishedStmt = this.db.prepare(`
|
|
29
|
-
UPDATE event_outbox SET status = 'published', publishedAt = ? WHERE id = ?
|
|
28
|
+
this.markPublishedStmt = this.db.prepare(`
|
|
29
|
+
UPDATE event_outbox SET status = 'published', publishedAt = ? WHERE id = ?
|
|
30
30
|
`);
|
|
31
|
-
this.markPendingRetryStmt = this.db.prepare(`
|
|
32
|
-
UPDATE event_outbox SET status = 'pending', retryCount = retryCount + 1, lastRetryAt = ? WHERE id = ?
|
|
31
|
+
this.markPendingRetryStmt = this.db.prepare(`
|
|
32
|
+
UPDATE event_outbox SET status = 'pending', retryCount = retryCount + 1, lastRetryAt = ? WHERE id = ?
|
|
33
33
|
`);
|
|
34
|
-
this.markFailedStmt = this.db.prepare(`
|
|
35
|
-
UPDATE event_outbox SET status = 'failed' WHERE id = ?
|
|
34
|
+
this.markFailedStmt = this.db.prepare(`
|
|
35
|
+
UPDATE event_outbox SET status = 'failed' WHERE id = ?
|
|
36
36
|
`);
|
|
37
|
-
this.moveToDeadLetterStmt = this.db.prepare(`
|
|
38
|
-
INSERT INTO dead_letter_events (id, originalEventId, eventType, payload, error, retryCount, failedAt)
|
|
39
|
-
VALUES (?, ?, ?, ?, ?, ?, ?)
|
|
37
|
+
this.moveToDeadLetterStmt = this.db.prepare(`
|
|
38
|
+
INSERT INTO dead_letter_events (id, originalEventId, eventType, payload, error, retryCount, failedAt)
|
|
39
|
+
VALUES (?, ?, ?, ?, ?, ?, ?)
|
|
40
40
|
`);
|
|
41
41
|
}
|
|
42
42
|
initTables() {
|
|
43
|
-
this.db.exec(`
|
|
44
|
-
CREATE TABLE IF NOT EXISTS event_outbox (
|
|
45
|
-
id TEXT PRIMARY KEY,
|
|
46
|
-
eventType TEXT NOT NULL,
|
|
47
|
-
payload TEXT NOT NULL,
|
|
48
|
-
status TEXT DEFAULT 'pending' CHECK(status IN ('pending', 'processing', 'published', 'failed')),
|
|
49
|
-
retryCount INTEGER DEFAULT 0,
|
|
50
|
-
lastRetryAt TEXT,
|
|
51
|
-
createdAt TEXT NOT NULL,
|
|
52
|
-
publishedAt TEXT
|
|
53
|
-
);
|
|
54
|
-
CREATE INDEX IF NOT EXISTS idx_outbox_status ON event_outbox(status, createdAt);
|
|
55
|
-
|
|
56
|
-
CREATE TABLE IF NOT EXISTS dead_letter_events (
|
|
57
|
-
id TEXT PRIMARY KEY,
|
|
58
|
-
originalEventId TEXT NOT NULL,
|
|
59
|
-
eventType TEXT NOT NULL,
|
|
60
|
-
payload TEXT NOT NULL,
|
|
61
|
-
error TEXT NOT NULL,
|
|
62
|
-
retryCount INTEGER NOT NULL,
|
|
63
|
-
failedAt TEXT NOT NULL,
|
|
64
|
-
resolvedAt TEXT,
|
|
65
|
-
status TEXT DEFAULT 'failed' CHECK(status IN ('failed', 'retried', 'discarded'))
|
|
66
|
-
);
|
|
43
|
+
this.db.exec(`
|
|
44
|
+
CREATE TABLE IF NOT EXISTS event_outbox (
|
|
45
|
+
id TEXT PRIMARY KEY,
|
|
46
|
+
eventType TEXT NOT NULL,
|
|
47
|
+
payload TEXT NOT NULL,
|
|
48
|
+
status TEXT DEFAULT 'pending' CHECK(status IN ('pending', 'processing', 'published', 'failed')),
|
|
49
|
+
retryCount INTEGER DEFAULT 0,
|
|
50
|
+
lastRetryAt TEXT,
|
|
51
|
+
createdAt TEXT NOT NULL,
|
|
52
|
+
publishedAt TEXT
|
|
53
|
+
);
|
|
54
|
+
CREATE INDEX IF NOT EXISTS idx_outbox_status ON event_outbox(status, createdAt);
|
|
55
|
+
|
|
56
|
+
CREATE TABLE IF NOT EXISTS dead_letter_events (
|
|
57
|
+
id TEXT PRIMARY KEY,
|
|
58
|
+
originalEventId TEXT NOT NULL,
|
|
59
|
+
eventType TEXT NOT NULL,
|
|
60
|
+
payload TEXT NOT NULL,
|
|
61
|
+
error TEXT NOT NULL,
|
|
62
|
+
retryCount INTEGER NOT NULL,
|
|
63
|
+
failedAt TEXT NOT NULL,
|
|
64
|
+
resolvedAt TEXT,
|
|
65
|
+
status TEXT DEFAULT 'failed' CHECK(status IN ('failed', 'retried', 'discarded'))
|
|
66
|
+
);
|
|
67
67
|
`);
|
|
68
68
|
}
|
|
69
69
|
enqueue(event) {
|
|
@@ -11,13 +11,13 @@ declare const PolicyRuleSchema: z.ZodObject<{
|
|
|
11
11
|
params: "params";
|
|
12
12
|
}>;
|
|
13
13
|
operator: z.ZodEnum<{
|
|
14
|
-
in: "in";
|
|
15
|
-
eq: "eq";
|
|
16
|
-
neq: "neq";
|
|
17
14
|
contains: "contains";
|
|
15
|
+
eq: "eq";
|
|
18
16
|
matches: "matches";
|
|
19
17
|
gt: "gt";
|
|
20
18
|
lt: "lt";
|
|
19
|
+
in: "in";
|
|
20
|
+
neq: "neq";
|
|
21
21
|
}>;
|
|
22
22
|
value: z.ZodUnion<readonly [z.ZodString, z.ZodArray<z.ZodString>, z.ZodNumber]>;
|
|
23
23
|
}, z.core.$strip>;
|
|
@@ -63,26 +63,26 @@ export class PolicyEngine {
|
|
|
63
63
|
this.allPoliciesStmt = this.db.prepare(`SELECT * FROM policies WHERE enabled = 1 ORDER BY priority DESC, createdAt ASC`);
|
|
64
64
|
}
|
|
65
65
|
initTables() {
|
|
66
|
-
this.db.exec(`
|
|
67
|
-
CREATE TABLE IF NOT EXISTS policies (
|
|
68
|
-
id TEXT PRIMARY KEY,
|
|
69
|
-
name TEXT NOT NULL UNIQUE,
|
|
70
|
-
description TEXT,
|
|
71
|
-
rules TEXT NOT NULL,
|
|
72
|
-
action TEXT NOT NULL DEFAULT 'block'
|
|
73
|
-
CHECK(action IN ('block', 'require_confirmation', 'allow')),
|
|
74
|
-
priority INTEGER DEFAULT 0,
|
|
75
|
-
enabled INTEGER DEFAULT 1,
|
|
76
|
-
version INTEGER DEFAULT 1,
|
|
77
|
-
createdAt TEXT NOT NULL,
|
|
78
|
-
updatedAt TEXT NOT NULL
|
|
79
|
-
);
|
|
66
|
+
this.db.exec(`
|
|
67
|
+
CREATE TABLE IF NOT EXISTS policies (
|
|
68
|
+
id TEXT PRIMARY KEY,
|
|
69
|
+
name TEXT NOT NULL UNIQUE,
|
|
70
|
+
description TEXT,
|
|
71
|
+
rules TEXT NOT NULL,
|
|
72
|
+
action TEXT NOT NULL DEFAULT 'block'
|
|
73
|
+
CHECK(action IN ('block', 'require_confirmation', 'allow')),
|
|
74
|
+
priority INTEGER DEFAULT 0,
|
|
75
|
+
enabled INTEGER DEFAULT 1,
|
|
76
|
+
version INTEGER DEFAULT 1,
|
|
77
|
+
createdAt TEXT NOT NULL,
|
|
78
|
+
updatedAt TEXT NOT NULL
|
|
79
|
+
);
|
|
80
80
|
`);
|
|
81
81
|
}
|
|
82
82
|
seedDefaultPolicies() {
|
|
83
|
-
const insertOrIgnore = this.db.prepare(`
|
|
84
|
-
INSERT OR IGNORE INTO policies (id, name, description, rules, action, priority, enabled, version, createdAt, updatedAt)
|
|
85
|
-
VALUES (?, ?, ?, ?, ?, ?, 1, 1, ?, ?)
|
|
83
|
+
const insertOrIgnore = this.db.prepare(`
|
|
84
|
+
INSERT OR IGNORE INTO policies (id, name, description, rules, action, priority, enabled, version, createdAt, updatedAt)
|
|
85
|
+
VALUES (?, ?, ?, ?, ?, ?, 1, 1, ?, ?)
|
|
86
86
|
`);
|
|
87
87
|
const now = new Date().toISOString();
|
|
88
88
|
const txn = this.db.transaction(() => {
|
|
@@ -114,7 +114,7 @@ export class PolicyEngine {
|
|
|
114
114
|
PolicyRuleSchema.parse(rule);
|
|
115
115
|
}
|
|
116
116
|
this.db
|
|
117
|
-
.prepare(`INSERT INTO policies (id, name, description, rules, action, priority, enabled, version, createdAt, updatedAt)
|
|
117
|
+
.prepare(`INSERT INTO policies (id, name, description, rules, action, priority, enabled, version, createdAt, updatedAt)
|
|
118
118
|
VALUES (?, ?, ?, ?, ?, ?, 1, 1, ?, ?)`)
|
|
119
119
|
.run(id, policy.name, policy.description ?? null, JSON.stringify(policy.rules), policy.action, policy.priority ?? 0, now, now);
|
|
120
120
|
return id;
|
|
@@ -30,7 +30,7 @@ export class SecuritySentinel {
|
|
|
30
30
|
this.auditStore = deps.auditStore;
|
|
31
31
|
this.db = deps.storage.getDatabase();
|
|
32
32
|
this.projectRoot = deps.projectRoot ?? process.cwd();
|
|
33
|
-
this.recentDeleteStmt = this.db.prepare(`SELECT COUNT(*) as count FROM audit_events
|
|
33
|
+
this.recentDeleteStmt = this.db.prepare(`SELECT COUNT(*) as count FROM audit_events
|
|
34
34
|
WHERE agentId = ? AND actionType = 'file_delete' AND createdAt >= ?`);
|
|
35
35
|
}
|
|
36
36
|
static getInstance(deps) {
|
|
@@ -8,41 +8,41 @@ export class SuggestionStore {
|
|
|
8
8
|
constructor(storage) {
|
|
9
9
|
this.db = storage.getDatabase();
|
|
10
10
|
this.initTables();
|
|
11
|
-
this.insertStmt = this.db.prepare(`
|
|
12
|
-
INSERT INTO suggestions
|
|
13
|
-
(id, type, title, description, priority, evidence, suggestedAction, status, riskLevel, sourceModule, createdAt)
|
|
14
|
-
VALUES (?, ?, ?, ?, ?, ?, ?, 'pending', ?, ?, ?)
|
|
11
|
+
this.insertStmt = this.db.prepare(`
|
|
12
|
+
INSERT INTO suggestions
|
|
13
|
+
(id, type, title, description, priority, evidence, suggestedAction, status, riskLevel, sourceModule, createdAt)
|
|
14
|
+
VALUES (?, ?, ?, ?, ?, ?, ?, 'pending', ?, ?, ?)
|
|
15
15
|
`);
|
|
16
16
|
}
|
|
17
17
|
initTables() {
|
|
18
|
-
this.db.exec(`
|
|
19
|
-
CREATE TABLE IF NOT EXISTS suggestions (
|
|
20
|
-
id TEXT PRIMARY KEY,
|
|
21
|
-
type TEXT NOT NULL CHECK(type IN ('security','performance','quality','dependency','pattern')),
|
|
22
|
-
title TEXT NOT NULL,
|
|
23
|
-
description TEXT NOT NULL,
|
|
24
|
-
priority INTEGER NOT NULL CHECK(priority BETWEEN 1 AND 5),
|
|
25
|
-
evidence TEXT NOT NULL,
|
|
26
|
-
suggestedAction TEXT,
|
|
27
|
-
status TEXT DEFAULT 'pending' CHECK(status IN ('pending','accepted','dismissed','auto_applied')),
|
|
28
|
-
riskLevel TEXT DEFAULT 'LOW',
|
|
29
|
-
sourceModule TEXT NOT NULL,
|
|
30
|
-
createdAt TEXT NOT NULL,
|
|
31
|
-
resolvedAt TEXT
|
|
32
|
-
);
|
|
33
|
-
CREATE INDEX IF NOT EXISTS idx_suggestion_status_priority ON suggestions(status, priority);
|
|
34
|
-
CREATE INDEX IF NOT EXISTS idx_suggestion_type_created ON suggestions(type, createdAt);
|
|
18
|
+
this.db.exec(`
|
|
19
|
+
CREATE TABLE IF NOT EXISTS suggestions (
|
|
20
|
+
id TEXT PRIMARY KEY,
|
|
21
|
+
type TEXT NOT NULL CHECK(type IN ('security','performance','quality','dependency','pattern')),
|
|
22
|
+
title TEXT NOT NULL,
|
|
23
|
+
description TEXT NOT NULL,
|
|
24
|
+
priority INTEGER NOT NULL CHECK(priority BETWEEN 1 AND 5),
|
|
25
|
+
evidence TEXT NOT NULL,
|
|
26
|
+
suggestedAction TEXT,
|
|
27
|
+
status TEXT DEFAULT 'pending' CHECK(status IN ('pending','accepted','dismissed','auto_applied')),
|
|
28
|
+
riskLevel TEXT DEFAULT 'LOW',
|
|
29
|
+
sourceModule TEXT NOT NULL,
|
|
30
|
+
createdAt TEXT NOT NULL,
|
|
31
|
+
resolvedAt TEXT
|
|
32
|
+
);
|
|
33
|
+
CREATE INDEX IF NOT EXISTS idx_suggestion_status_priority ON suggestions(status, priority);
|
|
34
|
+
CREATE INDEX IF NOT EXISTS idx_suggestion_type_created ON suggestions(type, createdAt);
|
|
35
35
|
`);
|
|
36
36
|
try {
|
|
37
|
-
this.db.exec(`
|
|
38
|
-
CREATE VIRTUAL TABLE IF NOT EXISTS suggestions_fts USING fts5(
|
|
39
|
-
title, description,
|
|
40
|
-
content='suggestions', content_rowid='rowid'
|
|
41
|
-
);
|
|
42
|
-
CREATE TRIGGER IF NOT EXISTS suggestions_fts_ai AFTER INSERT ON suggestions BEGIN
|
|
43
|
-
INSERT INTO suggestions_fts(rowid, title, description)
|
|
44
|
-
VALUES (new.rowid, new.title, new.description);
|
|
45
|
-
END;
|
|
37
|
+
this.db.exec(`
|
|
38
|
+
CREATE VIRTUAL TABLE IF NOT EXISTS suggestions_fts USING fts5(
|
|
39
|
+
title, description,
|
|
40
|
+
content='suggestions', content_rowid='rowid'
|
|
41
|
+
);
|
|
42
|
+
CREATE TRIGGER IF NOT EXISTS suggestions_fts_ai AFTER INSERT ON suggestions BEGIN
|
|
43
|
+
INSERT INTO suggestions_fts(rowid, title, description)
|
|
44
|
+
VALUES (new.rowid, new.title, new.description);
|
|
45
|
+
END;
|
|
46
46
|
`);
|
|
47
47
|
this.fts5Available = true;
|
|
48
48
|
}
|
|
@@ -102,9 +102,9 @@ export class SuggestionStore {
|
|
|
102
102
|
return [];
|
|
103
103
|
try {
|
|
104
104
|
return this.db
|
|
105
|
-
.prepare(`SELECT s.* FROM suggestions s
|
|
106
|
-
JOIN suggestions_fts f ON s.rowid = f.rowid
|
|
107
|
-
WHERE suggestions_fts MATCH ?
|
|
105
|
+
.prepare(`SELECT s.* FROM suggestions s
|
|
106
|
+
JOIN suggestions_fts f ON s.rowid = f.rowid
|
|
107
|
+
WHERE suggestions_fts MATCH ?
|
|
108
108
|
ORDER BY rank LIMIT ?`)
|
|
109
109
|
.all(sanitized, limit);
|
|
110
110
|
}
|
|
@@ -13,22 +13,22 @@ export class VectorStore {
|
|
|
13
13
|
this.initializeTables();
|
|
14
14
|
}
|
|
15
15
|
initializeTables() {
|
|
16
|
-
this.db.exec(`
|
|
17
|
-
CREATE TABLE IF NOT EXISTS memory_vectors (
|
|
18
|
-
key TEXT PRIMARY KEY,
|
|
19
|
-
embedding BLOB NOT NULL,
|
|
20
|
-
dimension INTEGER NOT NULL,
|
|
21
|
-
updatedAt TEXT NOT NULL
|
|
22
|
-
);
|
|
23
|
-
|
|
24
|
-
CREATE TABLE IF NOT EXISTS session_vectors (
|
|
25
|
-
entityType TEXT NOT NULL,
|
|
26
|
-
entityId INTEGER NOT NULL,
|
|
27
|
-
embedding BLOB NOT NULL,
|
|
28
|
-
dimension INTEGER NOT NULL,
|
|
29
|
-
updatedAt TEXT NOT NULL,
|
|
30
|
-
PRIMARY KEY (entityType, entityId)
|
|
31
|
-
);
|
|
16
|
+
this.db.exec(`
|
|
17
|
+
CREATE TABLE IF NOT EXISTS memory_vectors (
|
|
18
|
+
key TEXT PRIMARY KEY,
|
|
19
|
+
embedding BLOB NOT NULL,
|
|
20
|
+
dimension INTEGER NOT NULL,
|
|
21
|
+
updatedAt TEXT NOT NULL
|
|
22
|
+
);
|
|
23
|
+
|
|
24
|
+
CREATE TABLE IF NOT EXISTS session_vectors (
|
|
25
|
+
entityType TEXT NOT NULL,
|
|
26
|
+
entityId INTEGER NOT NULL,
|
|
27
|
+
embedding BLOB NOT NULL,
|
|
28
|
+
dimension INTEGER NOT NULL,
|
|
29
|
+
updatedAt TEXT NOT NULL,
|
|
30
|
+
PRIMARY KEY (entityType, entityId)
|
|
31
|
+
);
|
|
32
32
|
`);
|
|
33
33
|
}
|
|
34
34
|
/**
|
|
@@ -37,9 +37,9 @@ export class VectorStore {
|
|
|
37
37
|
saveMemoryVector(key, embedding) {
|
|
38
38
|
const blob = serializeVector(embedding);
|
|
39
39
|
const now = new Date().toISOString();
|
|
40
|
-
this.db.prepare(`
|
|
41
|
-
INSERT OR REPLACE INTO memory_vectors (key, embedding, dimension, updatedAt)
|
|
42
|
-
VALUES (?, ?, ?, ?)
|
|
40
|
+
this.db.prepare(`
|
|
41
|
+
INSERT OR REPLACE INTO memory_vectors (key, embedding, dimension, updatedAt)
|
|
42
|
+
VALUES (?, ?, ?, ?)
|
|
43
43
|
`).run(key, blob, embedding.length, now);
|
|
44
44
|
}
|
|
45
45
|
/**
|
|
@@ -48,9 +48,9 @@ export class VectorStore {
|
|
|
48
48
|
saveSessionVector(entityType, entityId, embedding) {
|
|
49
49
|
const blob = serializeVector(embedding);
|
|
50
50
|
const now = new Date().toISOString();
|
|
51
|
-
this.db.prepare(`
|
|
52
|
-
INSERT OR REPLACE INTO session_vectors (entityType, entityId, embedding, dimension, updatedAt)
|
|
53
|
-
VALUES (?, ?, ?, ?, ?)
|
|
51
|
+
this.db.prepare(`
|
|
52
|
+
INSERT OR REPLACE INTO session_vectors (entityType, entityId, embedding, dimension, updatedAt)
|
|
53
|
+
VALUES (?, ?, ?, ?, ?)
|
|
54
54
|
`).run(entityType, entityId, blob, embedding.length, now);
|
|
55
55
|
}
|
|
56
56
|
/**
|
|
@@ -23,16 +23,16 @@ export class AgentAnalyzer {
|
|
|
23
23
|
if (!this.agentDb)
|
|
24
24
|
return result;
|
|
25
25
|
try {
|
|
26
|
-
const stats = this.agentDb.prepare(`
|
|
27
|
-
SELECT
|
|
28
|
-
agentName,
|
|
29
|
-
COUNT(*) as totalRuns,
|
|
30
|
-
SUM(CASE WHEN status = 'failed' THEN 1 ELSE 0 END) as failedRuns,
|
|
31
|
-
AVG(duration) as avgDuration
|
|
32
|
-
FROM agent_executions
|
|
33
|
-
WHERE createdAt > datetime('now', '-7 days')
|
|
34
|
-
GROUP BY agentName
|
|
35
|
-
HAVING totalRuns >= 5
|
|
26
|
+
const stats = this.agentDb.prepare(`
|
|
27
|
+
SELECT
|
|
28
|
+
agentName,
|
|
29
|
+
COUNT(*) as totalRuns,
|
|
30
|
+
SUM(CASE WHEN status = 'failed' THEN 1 ELSE 0 END) as failedRuns,
|
|
31
|
+
AVG(duration) as avgDuration
|
|
32
|
+
FROM agent_executions
|
|
33
|
+
WHERE createdAt > datetime('now', '-7 days')
|
|
34
|
+
GROUP BY agentName
|
|
35
|
+
HAVING totalRuns >= 5
|
|
36
36
|
`).all();
|
|
37
37
|
result.agentsAnalyzed = stats.length;
|
|
38
38
|
for (const stat of stats) {
|
|
@@ -17,20 +17,20 @@ export class DescriptionOptimizer {
|
|
|
17
17
|
this.initializeTables();
|
|
18
18
|
}
|
|
19
19
|
initializeTables() {
|
|
20
|
-
this.db.exec(`
|
|
21
|
-
CREATE TABLE IF NOT EXISTS description_optimizations (
|
|
22
|
-
id TEXT PRIMARY KEY,
|
|
23
|
-
skillName TEXT NOT NULL,
|
|
24
|
-
originalDescription TEXT NOT NULL,
|
|
25
|
-
bestDescription TEXT NOT NULL,
|
|
26
|
-
candidates TEXT NOT NULL,
|
|
27
|
-
trainQueries TEXT NOT NULL,
|
|
28
|
-
testQueries TEXT NOT NULL,
|
|
29
|
-
improvement REAL DEFAULT 0,
|
|
30
|
-
createdAt TEXT NOT NULL
|
|
31
|
-
);
|
|
32
|
-
|
|
33
|
-
CREATE INDEX IF NOT EXISTS idx_do_skill ON description_optimizations(skillName);
|
|
20
|
+
this.db.exec(`
|
|
21
|
+
CREATE TABLE IF NOT EXISTS description_optimizations (
|
|
22
|
+
id TEXT PRIMARY KEY,
|
|
23
|
+
skillName TEXT NOT NULL,
|
|
24
|
+
originalDescription TEXT NOT NULL,
|
|
25
|
+
bestDescription TEXT NOT NULL,
|
|
26
|
+
candidates TEXT NOT NULL,
|
|
27
|
+
trainQueries TEXT NOT NULL,
|
|
28
|
+
testQueries TEXT NOT NULL,
|
|
29
|
+
improvement REAL DEFAULT 0,
|
|
30
|
+
createdAt TEXT NOT NULL
|
|
31
|
+
);
|
|
32
|
+
|
|
33
|
+
CREATE INDEX IF NOT EXISTS idx_do_skill ON description_optimizations(skillName);
|
|
34
34
|
`);
|
|
35
35
|
}
|
|
36
36
|
/**
|
|
@@ -183,9 +183,9 @@ export class DescriptionOptimizer {
|
|
|
183
183
|
createdAt: now,
|
|
184
184
|
};
|
|
185
185
|
// Persist
|
|
186
|
-
this.db.prepare(`
|
|
187
|
-
INSERT INTO description_optimizations (id, skillName, originalDescription, bestDescription, candidates, trainQueries, testQueries, improvement, createdAt)
|
|
188
|
-
VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?)
|
|
186
|
+
this.db.prepare(`
|
|
187
|
+
INSERT INTO description_optimizations (id, skillName, originalDescription, bestDescription, candidates, trainQueries, testQueries, improvement, createdAt)
|
|
188
|
+
VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?)
|
|
189
189
|
`).run(id, skillName, description, run.bestDescription, JSON.stringify(candidates), JSON.stringify(train), JSON.stringify(test), improvement, now);
|
|
190
190
|
return run;
|
|
191
191
|
}
|
|
@@ -193,8 +193,8 @@ export class DescriptionOptimizer {
|
|
|
193
193
|
* Get optimization history for a skill
|
|
194
194
|
*/
|
|
195
195
|
getHistory(skillName) {
|
|
196
|
-
const rows = this.db.prepare(`
|
|
197
|
-
SELECT * FROM description_optimizations WHERE skillName = ? ORDER BY createdAt ASC
|
|
196
|
+
const rows = this.db.prepare(`
|
|
197
|
+
SELECT * FROM description_optimizations WHERE skillName = ? ORDER BY createdAt ASC
|
|
198
198
|
`).all(skillName);
|
|
199
199
|
return rows.map(this.rowToRun);
|
|
200
200
|
}
|
|
@@ -202,8 +202,8 @@ export class DescriptionOptimizer {
|
|
|
202
202
|
* Get latest optimization for a skill
|
|
203
203
|
*/
|
|
204
204
|
getLatest(skillName) {
|
|
205
|
-
const row = this.db.prepare(`
|
|
206
|
-
SELECT * FROM description_optimizations WHERE skillName = ? ORDER BY createdAt DESC LIMIT 1
|
|
205
|
+
const row = this.db.prepare(`
|
|
206
|
+
SELECT * FROM description_optimizations WHERE skillName = ? ORDER BY createdAt DESC LIMIT 1
|
|
207
207
|
`).get(skillName);
|
|
208
208
|
return row ? this.rowToRun(row) : null;
|
|
209
209
|
}
|
|
@@ -8,38 +8,38 @@ export class GenerationRegistry {
|
|
|
8
8
|
this.initializeTables();
|
|
9
9
|
}
|
|
10
10
|
initializeTables() {
|
|
11
|
-
this.db.exec(`
|
|
12
|
-
CREATE TABLE IF NOT EXISTS generations (
|
|
13
|
-
id TEXT PRIMARY KEY,
|
|
14
|
-
insightId TEXT,
|
|
15
|
-
type TEXT NOT NULL CHECK(type IN ('skill','agent','rule')),
|
|
16
|
-
name TEXT NOT NULL,
|
|
17
|
-
content TEXT NOT NULL,
|
|
18
|
-
filePath TEXT,
|
|
19
|
-
status TEXT NOT NULL DEFAULT 'draft' CHECK(status IN ('draft','testing','active','disabled','deleted')),
|
|
20
|
-
qualityScore INTEGER DEFAULT 0,
|
|
21
|
-
triggerPatterns TEXT,
|
|
22
|
-
usageCount INTEGER DEFAULT 0,
|
|
23
|
-
lastUsedAt TEXT,
|
|
24
|
-
ttlDays INTEGER DEFAULT 7,
|
|
25
|
-
version INTEGER DEFAULT 1,
|
|
26
|
-
parentId TEXT,
|
|
27
|
-
createdAt TEXT NOT NULL,
|
|
28
|
-
updatedAt TEXT NOT NULL
|
|
29
|
-
);
|
|
30
|
-
|
|
31
|
-
CREATE INDEX IF NOT EXISTS idx_gen_type ON generations(type);
|
|
32
|
-
CREATE INDEX IF NOT EXISTS idx_gen_status ON generations(status);
|
|
33
|
-
CREATE INDEX IF NOT EXISTS idx_gen_insight ON generations(insightId);
|
|
34
|
-
CREATE INDEX IF NOT EXISTS idx_gen_name ON generations(name);
|
|
11
|
+
this.db.exec(`
|
|
12
|
+
CREATE TABLE IF NOT EXISTS generations (
|
|
13
|
+
id TEXT PRIMARY KEY,
|
|
14
|
+
insightId TEXT,
|
|
15
|
+
type TEXT NOT NULL CHECK(type IN ('skill','agent','rule')),
|
|
16
|
+
name TEXT NOT NULL,
|
|
17
|
+
content TEXT NOT NULL,
|
|
18
|
+
filePath TEXT,
|
|
19
|
+
status TEXT NOT NULL DEFAULT 'draft' CHECK(status IN ('draft','testing','active','disabled','deleted')),
|
|
20
|
+
qualityScore INTEGER DEFAULT 0,
|
|
21
|
+
triggerPatterns TEXT,
|
|
22
|
+
usageCount INTEGER DEFAULT 0,
|
|
23
|
+
lastUsedAt TEXT,
|
|
24
|
+
ttlDays INTEGER DEFAULT 7,
|
|
25
|
+
version INTEGER DEFAULT 1,
|
|
26
|
+
parentId TEXT,
|
|
27
|
+
createdAt TEXT NOT NULL,
|
|
28
|
+
updatedAt TEXT NOT NULL
|
|
29
|
+
);
|
|
30
|
+
|
|
31
|
+
CREATE INDEX IF NOT EXISTS idx_gen_type ON generations(type);
|
|
32
|
+
CREATE INDEX IF NOT EXISTS idx_gen_status ON generations(status);
|
|
33
|
+
CREATE INDEX IF NOT EXISTS idx_gen_insight ON generations(insightId);
|
|
34
|
+
CREATE INDEX IF NOT EXISTS idx_gen_name ON generations(name);
|
|
35
35
|
`);
|
|
36
36
|
}
|
|
37
37
|
save(input) {
|
|
38
38
|
const id = `gen-${Date.now().toString(36)}-${randomUUID().replace(/-/g, '').slice(0, 8)}`;
|
|
39
39
|
const now = new Date().toISOString();
|
|
40
|
-
this.db.prepare(`
|
|
41
|
-
INSERT INTO generations (id, insightId, type, name, content, filePath, status, qualityScore, triggerPatterns, ttlDays, version, parentId, createdAt, updatedAt)
|
|
42
|
-
VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)
|
|
40
|
+
this.db.prepare(`
|
|
41
|
+
INSERT INTO generations (id, insightId, type, name, content, filePath, status, qualityScore, triggerPatterns, ttlDays, version, parentId, createdAt, updatedAt)
|
|
42
|
+
VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)
|
|
43
43
|
`).run(id, input.insightId, input.type, input.name, input.content, input.filePath || null, input.status || 'draft', input.qualityScore || 0, JSON.stringify(input.triggerPatterns || []), input.ttlDays || 7, input.parentId ? 2 : 1, // version 2 if has parent
|
|
44
44
|
input.parentId || null, now, now);
|
|
45
45
|
return id;
|
|
@@ -64,20 +64,20 @@ export class GenerationRegistry {
|
|
|
64
64
|
return rows.map(this.rowToGeneration);
|
|
65
65
|
}
|
|
66
66
|
getByStatus(status, limit = 50) {
|
|
67
|
-
const rows = this.db.prepare(`
|
|
68
|
-
SELECT * FROM generations WHERE status = ? ORDER BY updatedAt DESC LIMIT ?
|
|
67
|
+
const rows = this.db.prepare(`
|
|
68
|
+
SELECT * FROM generations WHERE status = ? ORDER BY updatedAt DESC LIMIT ?
|
|
69
69
|
`).all(status, limit);
|
|
70
70
|
return rows.map(this.rowToGeneration);
|
|
71
71
|
}
|
|
72
72
|
updateStatus(id, status) {
|
|
73
|
-
const result = this.db.prepare(`
|
|
74
|
-
UPDATE generations SET status = ?, updatedAt = ? WHERE id = ?
|
|
73
|
+
const result = this.db.prepare(`
|
|
74
|
+
UPDATE generations SET status = ?, updatedAt = ? WHERE id = ?
|
|
75
75
|
`).run(status, new Date().toISOString(), id);
|
|
76
76
|
return result.changes > 0;
|
|
77
77
|
}
|
|
78
78
|
incrementUsage(id) {
|
|
79
|
-
this.db.prepare(`
|
|
80
|
-
UPDATE generations SET usageCount = usageCount + 1, lastUsedAt = ?, updatedAt = ? WHERE id = ?
|
|
79
|
+
this.db.prepare(`
|
|
80
|
+
UPDATE generations SET usageCount = usageCount + 1, lastUsedAt = ?, updatedAt = ? WHERE id = ?
|
|
81
81
|
`).run(new Date().toISOString(), new Date().toISOString(), id);
|
|
82
82
|
}
|
|
83
83
|
getStats() {
|
|
@@ -91,9 +91,9 @@ export class GenerationRegistry {
|
|
|
91
91
|
return { total, byType, byStatus };
|
|
92
92
|
}
|
|
93
93
|
getRecentFailures(limit = 10) {
|
|
94
|
-
const result = this.db.prepare(`
|
|
95
|
-
SELECT COUNT(*) as cnt FROM generations
|
|
96
|
-
WHERE status = 'deleted' AND createdAt > datetime('now', '-1 hour')
|
|
94
|
+
const result = this.db.prepare(`
|
|
95
|
+
SELECT COUNT(*) as cnt FROM generations
|
|
96
|
+
WHERE status = 'deleted' AND createdAt > datetime('now', '-1 hour')
|
|
97
97
|
`).get();
|
|
98
98
|
return result.cnt;
|
|
99
99
|
}
|