@su-record/vibe 2.7.13 → 2.7.15
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 +134 -126
- package/LICENSE +21 -21
- package/README.md +449 -449
- 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/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/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/tester.md +49 -49
- package/agents/ui/ui-a11y-auditor.md +93 -93
- package/agents/ui/ui-antipattern-detector.md +94 -94
- 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 -260
- package/commands/vibe.analyze.md +11 -13
- package/commands/vibe.review.md +43 -1
- package/commands/vibe.run.md +2124 -2078
- package/commands/vibe.spec.md +9 -4
- package/commands/vibe.spec.review.md +569 -565
- package/commands/vibe.utils.md +413 -413
- package/commands/vibe.verify.md +33 -8
- package/dist/cli/collaborator.js +52 -52
- package/dist/cli/commands/evolution.js +12 -12
- package/dist/cli/commands/info.js +54 -54
- package/dist/cli/commands/init.js +5 -5
- 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/telegram.js +12 -12
- package/dist/cli/detect.js +32 -32
- package/dist/cli/index.js +51 -51
- package/dist/cli/llm/claude-commands.js +16 -16
- package/dist/cli/llm/config.js +19 -19
- package/dist/cli/llm/config.js.map +1 -1
- 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/setup/Provisioner.js +42 -42
- package/dist/cli/types.d.ts +0 -2
- package/dist/cli/types.d.ts.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.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/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 +137 -137
- package/hooks/scripts/code-check.js +77 -70
- package/hooks/scripts/context-save.js +212 -212
- package/hooks/scripts/hud-status.js +291 -291
- package/hooks/scripts/keyword-detector.js +214 -214
- package/hooks/scripts/llm-orchestrate.js +475 -475
- package/hooks/scripts/post-edit.js +32 -32
- package/hooks/scripts/pre-tool-guard.js +125 -125
- package/hooks/scripts/prompt-dispatcher.js +185 -185
- package/hooks/scripts/sentinel-guard.js +104 -104
- package/hooks/scripts/session-start.js +106 -106
- package/hooks/scripts/stop-notify.js +209 -209
- package/hooks/scripts/utils.js +100 -100
- 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 +121 -121
- package/skills/agents-md/SKILL.md +120 -120
- package/skills/arch-guard/SKILL.md +180 -180
- package/skills/brand-assets/SKILL.md +146 -146
- package/skills/capability-loop/SKILL.md +167 -167
- package/skills/characterization-test/SKILL.md +206 -206
- package/skills/commerce-patterns/SKILL.md +59 -59
- package/skills/commit-push-pr/SKILL.md +75 -75
- package/skills/context7-usage/SKILL.md +105 -105
- package/skills/core-capabilities/SKILL.md +48 -48
- package/skills/e2e-commerce/SKILL.md +57 -57
- package/skills/exec-plan/SKILL.md +147 -147
- package/skills/frontend-design/SKILL.md +73 -73
- package/skills/git-worktree/SKILL.md +72 -72
- package/skills/handoff/SKILL.md +109 -109
- package/skills/parallel-research/SKILL.md +87 -87
- package/skills/priority-todos/SKILL.md +63 -63
- package/skills/seo-checklist/SKILL.md +57 -57
- package/skills/techdebt/SKILL.md +122 -122
- package/skills/tool-fallback/SKILL.md +103 -103
- package/skills/typescript-advanced-types/SKILL.md +66 -65
- package/skills/ui-ux-pro-max/SKILL.md +206 -206
- package/skills/vercel-react-best-practices/SKILL.md +59 -59
- package/skills/video-production/SKILL.md +51 -51
- 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/constitution-template.md +252 -252
- 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/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
|
@@ -16,55 +16,55 @@ export class AuditStore {
|
|
|
16
16
|
constructor(storage) {
|
|
17
17
|
this.db = storage.getDatabase();
|
|
18
18
|
this.initTables();
|
|
19
|
-
this.insertStmt = this.db.prepare(`
|
|
20
|
-
INSERT INTO audit_events
|
|
21
|
-
(id, correlationId, causationId, eventType, agentId, actionType, riskLevel, payload, outcome, createdAt)
|
|
22
|
-
VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?)
|
|
19
|
+
this.insertStmt = this.db.prepare(`
|
|
20
|
+
INSERT INTO audit_events
|
|
21
|
+
(id, correlationId, causationId, eventType, agentId, actionType, riskLevel, payload, outcome, createdAt)
|
|
22
|
+
VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?)
|
|
23
23
|
`);
|
|
24
24
|
}
|
|
25
25
|
initTables() {
|
|
26
|
-
this.db.exec(`
|
|
27
|
-
CREATE TABLE IF NOT EXISTS audit_events (
|
|
28
|
-
id TEXT PRIMARY KEY,
|
|
29
|
-
correlationId TEXT NOT NULL,
|
|
30
|
-
causationId TEXT,
|
|
31
|
-
eventType TEXT NOT NULL,
|
|
32
|
-
agentId TEXT,
|
|
33
|
-
actionType TEXT,
|
|
34
|
-
riskLevel TEXT,
|
|
35
|
-
payload TEXT NOT NULL,
|
|
36
|
-
outcome TEXT CHECK(outcome IS NULL OR outcome IN ('allowed', 'blocked', 'pending', 'expired')),
|
|
37
|
-
createdAt TEXT NOT NULL
|
|
38
|
-
);
|
|
39
|
-
CREATE INDEX IF NOT EXISTS idx_audit_agent_time ON audit_events(agentId, createdAt);
|
|
40
|
-
CREATE INDEX IF NOT EXISTS idx_audit_type_time ON audit_events(eventType, createdAt);
|
|
41
|
-
CREATE INDEX IF NOT EXISTS idx_audit_correlation ON audit_events(correlationId);
|
|
26
|
+
this.db.exec(`
|
|
27
|
+
CREATE TABLE IF NOT EXISTS audit_events (
|
|
28
|
+
id TEXT PRIMARY KEY,
|
|
29
|
+
correlationId TEXT NOT NULL,
|
|
30
|
+
causationId TEXT,
|
|
31
|
+
eventType TEXT NOT NULL,
|
|
32
|
+
agentId TEXT,
|
|
33
|
+
actionType TEXT,
|
|
34
|
+
riskLevel TEXT,
|
|
35
|
+
payload TEXT NOT NULL,
|
|
36
|
+
outcome TEXT CHECK(outcome IS NULL OR outcome IN ('allowed', 'blocked', 'pending', 'expired')),
|
|
37
|
+
createdAt TEXT NOT NULL
|
|
38
|
+
);
|
|
39
|
+
CREATE INDEX IF NOT EXISTS idx_audit_agent_time ON audit_events(agentId, createdAt);
|
|
40
|
+
CREATE INDEX IF NOT EXISTS idx_audit_type_time ON audit_events(eventType, createdAt);
|
|
41
|
+
CREATE INDEX IF NOT EXISTS idx_audit_correlation ON audit_events(correlationId);
|
|
42
42
|
`);
|
|
43
43
|
try {
|
|
44
|
-
this.db.exec(`
|
|
45
|
-
CREATE VIRTUAL TABLE IF NOT EXISTS audit_events_fts USING fts5(
|
|
46
|
-
eventType, agentId, payload,
|
|
47
|
-
content='audit_events', content_rowid='rowid'
|
|
48
|
-
);
|
|
44
|
+
this.db.exec(`
|
|
45
|
+
CREATE VIRTUAL TABLE IF NOT EXISTS audit_events_fts USING fts5(
|
|
46
|
+
eventType, agentId, payload,
|
|
47
|
+
content='audit_events', content_rowid='rowid'
|
|
48
|
+
);
|
|
49
49
|
`);
|
|
50
|
-
this.db.exec(`
|
|
51
|
-
CREATE TRIGGER IF NOT EXISTS audit_events_fts_ai AFTER INSERT ON audit_events BEGIN
|
|
52
|
-
INSERT INTO audit_events_fts(rowid, eventType, agentId, payload)
|
|
53
|
-
VALUES (new.rowid, new.eventType, new.agentId, new.payload);
|
|
54
|
-
END;
|
|
50
|
+
this.db.exec(`
|
|
51
|
+
CREATE TRIGGER IF NOT EXISTS audit_events_fts_ai AFTER INSERT ON audit_events BEGIN
|
|
52
|
+
INSERT INTO audit_events_fts(rowid, eventType, agentId, payload)
|
|
53
|
+
VALUES (new.rowid, new.eventType, new.agentId, new.payload);
|
|
54
|
+
END;
|
|
55
55
|
`);
|
|
56
56
|
this.fts5Available = true;
|
|
57
57
|
}
|
|
58
58
|
catch {
|
|
59
59
|
this.fts5Available = false;
|
|
60
60
|
}
|
|
61
|
-
this.db.exec(`
|
|
62
|
-
CREATE TRIGGER IF NOT EXISTS prevent_audit_update
|
|
63
|
-
BEFORE UPDATE ON audit_events
|
|
64
|
-
BEGIN SELECT RAISE(ABORT, 'Audit logs are immutable'); END;
|
|
65
|
-
CREATE TRIGGER IF NOT EXISTS prevent_audit_delete
|
|
66
|
-
BEFORE DELETE ON audit_events
|
|
67
|
-
BEGIN SELECT RAISE(ABORT, 'Audit logs are immutable'); END;
|
|
61
|
+
this.db.exec(`
|
|
62
|
+
CREATE TRIGGER IF NOT EXISTS prevent_audit_update
|
|
63
|
+
BEFORE UPDATE ON audit_events
|
|
64
|
+
BEGIN SELECT RAISE(ABORT, 'Audit logs are immutable'); END;
|
|
65
|
+
CREATE TRIGGER IF NOT EXISTS prevent_audit_delete
|
|
66
|
+
BEFORE DELETE ON audit_events
|
|
67
|
+
BEGIN SELECT RAISE(ABORT, 'Audit logs are immutable'); END;
|
|
68
68
|
`);
|
|
69
69
|
}
|
|
70
70
|
static redactSensitive(payload) {
|
|
@@ -170,10 +170,10 @@ export class AuditStore {
|
|
|
170
170
|
const pageSize = Math.min(limit || DEFAULT_PAGE_SIZE, MAX_PAGE_SIZE);
|
|
171
171
|
try {
|
|
172
172
|
return this.db
|
|
173
|
-
.prepare(`SELECT a.* FROM audit_events a
|
|
174
|
-
JOIN audit_events_fts f ON a.rowid = f.rowid
|
|
175
|
-
WHERE audit_events_fts MATCH ?
|
|
176
|
-
ORDER BY rank
|
|
173
|
+
.prepare(`SELECT a.* FROM audit_events a
|
|
174
|
+
JOIN audit_events_fts f ON a.rowid = f.rowid
|
|
175
|
+
WHERE audit_events_fts MATCH ?
|
|
176
|
+
ORDER BY rank
|
|
177
177
|
LIMIT ?`)
|
|
178
178
|
.all(sanitized, pageSize);
|
|
179
179
|
}
|
|
@@ -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) {
|
|
@@ -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
|
}
|