@agentlensai/server 0.3.0 → 0.6.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/db/embedding-store.d.ts +74 -0
- package/dist/db/embedding-store.d.ts.map +1 -0
- package/dist/db/embedding-store.js +177 -0
- package/dist/db/embedding-store.js.map +1 -0
- package/dist/db/health-snapshot-store.d.ts +33 -0
- package/dist/db/health-snapshot-store.d.ts.map +1 -0
- package/dist/db/health-snapshot-store.js +112 -0
- package/dist/db/health-snapshot-store.js.map +1 -0
- package/dist/db/lesson-store.d.ts +57 -0
- package/dist/db/lesson-store.d.ts.map +1 -0
- package/dist/db/lesson-store.js +217 -0
- package/dist/db/lesson-store.js.map +1 -0
- package/dist/db/migrate.d.ts.map +1 -1
- package/dist/db/migrate.js +256 -8
- package/dist/db/migrate.js.map +1 -1
- package/dist/db/schema.sqlite.d.ts +822 -47
- package/dist/db/schema.sqlite.d.ts.map +1 -1
- package/dist/db/schema.sqlite.js +79 -4
- package/dist/db/schema.sqlite.js.map +1 -1
- package/dist/db/session-summary-store.d.ts +45 -0
- package/dist/db/session-summary-store.d.ts.map +1 -0
- package/dist/db/session-summary-store.js +112 -0
- package/dist/db/session-summary-store.js.map +1 -0
- package/dist/db/sqlite-store.d.ts +19 -12
- package/dist/db/sqlite-store.d.ts.map +1 -1
- package/dist/db/sqlite-store.js +145 -44
- package/dist/db/sqlite-store.js.map +1 -1
- package/dist/db/tenant-scoped-store.d.ts +61 -0
- package/dist/db/tenant-scoped-store.d.ts.map +1 -0
- package/dist/db/tenant-scoped-store.js +94 -0
- package/dist/db/tenant-scoped-store.js.map +1 -0
- package/dist/index.d.ts +18 -2
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +78 -5
- package/dist/index.js.map +1 -1
- package/dist/lib/alert-engine.d.ts +11 -0
- package/dist/lib/alert-engine.d.ts.map +1 -1
- package/dist/lib/alert-engine.js +65 -24
- package/dist/lib/alert-engine.js.map +1 -1
- package/dist/lib/analysis/cost-analysis.d.ts +20 -0
- package/dist/lib/analysis/cost-analysis.d.ts.map +1 -0
- package/dist/lib/analysis/cost-analysis.js +161 -0
- package/dist/lib/analysis/cost-analysis.js.map +1 -0
- package/dist/lib/analysis/error-patterns.d.ts +26 -0
- package/dist/lib/analysis/error-patterns.d.ts.map +1 -0
- package/dist/lib/analysis/error-patterns.js +158 -0
- package/dist/lib/analysis/error-patterns.js.map +1 -0
- package/dist/lib/analysis/index.d.ts +23 -0
- package/dist/lib/analysis/index.d.ts.map +1 -0
- package/dist/lib/analysis/index.js +144 -0
- package/dist/lib/analysis/index.js.map +1 -0
- package/dist/lib/analysis/performance-trends.d.ts +19 -0
- package/dist/lib/analysis/performance-trends.d.ts.map +1 -0
- package/dist/lib/analysis/performance-trends.js +121 -0
- package/dist/lib/analysis/performance-trends.js.map +1 -0
- package/dist/lib/analysis/tool-sequences.d.ts +19 -0
- package/dist/lib/analysis/tool-sequences.d.ts.map +1 -0
- package/dist/lib/analysis/tool-sequences.js +148 -0
- package/dist/lib/analysis/tool-sequences.js.map +1 -0
- package/dist/lib/context/index.d.ts +5 -0
- package/dist/lib/context/index.d.ts.map +1 -0
- package/dist/lib/context/index.js +5 -0
- package/dist/lib/context/index.js.map +1 -0
- package/dist/lib/context/retrieval.d.ts +60 -0
- package/dist/lib/context/retrieval.d.ts.map +1 -0
- package/dist/lib/context/retrieval.js +233 -0
- package/dist/lib/context/retrieval.js.map +1 -0
- package/dist/lib/embeddings/index.d.ts +31 -0
- package/dist/lib/embeddings/index.d.ts.map +1 -0
- package/dist/lib/embeddings/index.js +31 -0
- package/dist/lib/embeddings/index.js.map +1 -0
- package/dist/lib/embeddings/local.d.ts +15 -0
- package/dist/lib/embeddings/local.d.ts.map +1 -0
- package/dist/lib/embeddings/local.js +65 -0
- package/dist/lib/embeddings/local.js.map +1 -0
- package/dist/lib/embeddings/math.d.ts +13 -0
- package/dist/lib/embeddings/math.d.ts.map +1 -0
- package/dist/lib/embeddings/math.js +35 -0
- package/dist/lib/embeddings/math.js.map +1 -0
- package/dist/lib/embeddings/openai.d.ts +15 -0
- package/dist/lib/embeddings/openai.d.ts.map +1 -0
- package/dist/lib/embeddings/openai.js +58 -0
- package/dist/lib/embeddings/openai.js.map +1 -0
- package/dist/lib/embeddings/summarizer.d.ts +26 -0
- package/dist/lib/embeddings/summarizer.d.ts.map +1 -0
- package/dist/lib/embeddings/summarizer.js +181 -0
- package/dist/lib/embeddings/summarizer.js.map +1 -0
- package/dist/lib/embeddings/types.d.ts +17 -0
- package/dist/lib/embeddings/types.d.ts.map +1 -0
- package/dist/lib/embeddings/types.js +5 -0
- package/dist/lib/embeddings/types.js.map +1 -0
- package/dist/lib/embeddings/worker.d.ts +56 -0
- package/dist/lib/embeddings/worker.d.ts.map +1 -0
- package/dist/lib/embeddings/worker.js +109 -0
- package/dist/lib/embeddings/worker.js.map +1 -0
- package/dist/lib/health/computer.d.ts +28 -0
- package/dist/lib/health/computer.d.ts.map +1 -0
- package/dist/lib/health/computer.js +270 -0
- package/dist/lib/health/computer.js.map +1 -0
- package/dist/lib/optimization/classifier.d.ts +34 -0
- package/dist/lib/optimization/classifier.d.ts.map +1 -0
- package/dist/lib/optimization/classifier.js +108 -0
- package/dist/lib/optimization/classifier.js.map +1 -0
- package/dist/lib/optimization/engine.d.ts +24 -0
- package/dist/lib/optimization/engine.d.ts.map +1 -0
- package/dist/lib/optimization/engine.js +202 -0
- package/dist/lib/optimization/engine.js.map +1 -0
- package/dist/lib/optimization/index.d.ts +10 -0
- package/dist/lib/optimization/index.d.ts.map +1 -0
- package/dist/lib/optimization/index.js +9 -0
- package/dist/lib/optimization/index.js.map +1 -0
- package/dist/lib/sse.d.ts +1 -0
- package/dist/lib/sse.d.ts.map +1 -1
- package/dist/lib/sse.js +8 -1
- package/dist/lib/sse.js.map +1 -1
- package/dist/middleware/auth.d.ts +1 -0
- package/dist/middleware/auth.d.ts.map +1 -1
- package/dist/middleware/auth.js +2 -1
- package/dist/middleware/auth.js.map +1 -1
- package/dist/routes/agents.d.ts.map +1 -1
- package/dist/routes/agents.js +6 -3
- package/dist/routes/agents.js.map +1 -1
- package/dist/routes/alerts.d.ts.map +1 -1
- package/dist/routes/alerts.js +15 -7
- package/dist/routes/alerts.js.map +1 -1
- package/dist/routes/analytics.d.ts.map +1 -1
- package/dist/routes/analytics.js +16 -2
- package/dist/routes/analytics.js.map +1 -1
- package/dist/routes/api-keys.d.ts.map +1 -1
- package/dist/routes/api-keys.js +30 -5
- package/dist/routes/api-keys.js.map +1 -1
- package/dist/routes/context.d.ts +23 -0
- package/dist/routes/context.d.ts.map +1 -0
- package/dist/routes/context.js +52 -0
- package/dist/routes/context.js.map +1 -0
- package/dist/routes/events.d.ts +6 -1
- package/dist/routes/events.d.ts.map +1 -1
- package/dist/routes/events.js +61 -6
- package/dist/routes/events.js.map +1 -1
- package/dist/routes/health.d.ts +21 -0
- package/dist/routes/health.d.ts.map +1 -0
- package/dist/routes/health.js +142 -0
- package/dist/routes/health.js.map +1 -0
- package/dist/routes/ingest.d.ts +6 -0
- package/dist/routes/ingest.d.ts.map +1 -1
- package/dist/routes/ingest.js +23 -4
- package/dist/routes/ingest.js.map +1 -1
- package/dist/routes/lessons.d.ts +19 -0
- package/dist/routes/lessons.d.ts.map +1 -0
- package/dist/routes/lessons.js +164 -0
- package/dist/routes/lessons.js.map +1 -0
- package/dist/routes/optimize.d.ts +15 -0
- package/dist/routes/optimize.d.ts.map +1 -0
- package/dist/routes/optimize.js +55 -0
- package/dist/routes/optimize.js.map +1 -0
- package/dist/routes/recall.d.ts +22 -0
- package/dist/routes/recall.d.ts.map +1 -0
- package/dist/routes/recall.js +91 -0
- package/dist/routes/recall.js.map +1 -0
- package/dist/routes/reflect.d.ts +15 -0
- package/dist/routes/reflect.d.ts.map +1 -0
- package/dist/routes/reflect.js +54 -0
- package/dist/routes/reflect.js.map +1 -0
- package/dist/routes/sessions.d.ts.map +1 -1
- package/dist/routes/sessions.js +8 -6
- package/dist/routes/sessions.js.map +1 -1
- package/dist/routes/stats.d.ts.map +1 -1
- package/dist/routes/stats.js +3 -1
- package/dist/routes/stats.js.map +1 -1
- package/dist/routes/stream.d.ts +9 -2
- package/dist/routes/stream.d.ts.map +1 -1
- package/dist/routes/stream.js +55 -2
- package/dist/routes/stream.js.map +1 -1
- package/dist/routes/tenant-helper.d.ts +20 -0
- package/dist/routes/tenant-helper.d.ts.map +1 -0
- package/dist/routes/tenant-helper.js +35 -0
- package/dist/routes/tenant-helper.js.map +1 -0
- package/package.json +11 -11
- package/LICENSE +0 -21
- package/dist/__tests__/agents-stats.test.d.ts +0 -5
- package/dist/__tests__/agents-stats.test.d.ts.map +0 -1
- package/dist/__tests__/agents-stats.test.js +0 -134
- package/dist/__tests__/agents-stats.test.js.map +0 -1
- package/dist/__tests__/alerts.test.d.ts +0 -5
- package/dist/__tests__/alerts.test.d.ts.map +0 -1
- package/dist/__tests__/alerts.test.js +0 -245
- package/dist/__tests__/alerts.test.js.map +0 -1
- package/dist/__tests__/analytics.test.d.ts +0 -5
- package/dist/__tests__/analytics.test.d.ts.map +0 -1
- package/dist/__tests__/analytics.test.js +0 -218
- package/dist/__tests__/analytics.test.js.map +0 -1
- package/dist/__tests__/api-keys.test.d.ts +0 -5
- package/dist/__tests__/api-keys.test.d.ts.map +0 -1
- package/dist/__tests__/api-keys.test.js +0 -118
- package/dist/__tests__/api-keys.test.js.map +0 -1
- package/dist/__tests__/auth-no-db.test.d.ts +0 -2
- package/dist/__tests__/auth-no-db.test.d.ts.map +0 -1
- package/dist/__tests__/auth-no-db.test.js +0 -43
- package/dist/__tests__/auth-no-db.test.js.map +0 -1
- package/dist/__tests__/auth.test.d.ts +0 -5
- package/dist/__tests__/auth.test.d.ts.map +0 -1
- package/dist/__tests__/auth.test.js +0 -86
- package/dist/__tests__/auth.test.js.map +0 -1
- package/dist/__tests__/config.test.d.ts +0 -2
- package/dist/__tests__/config.test.d.ts.map +0 -1
- package/dist/__tests__/config.test.js +0 -37
- package/dist/__tests__/config.test.js.map +0 -1
- package/dist/__tests__/events-ingest.test.d.ts +0 -5
- package/dist/__tests__/events-ingest.test.d.ts.map +0 -1
- package/dist/__tests__/events-ingest.test.js +0 -248
- package/dist/__tests__/events-ingest.test.js.map +0 -1
- package/dist/__tests__/events-query.test.d.ts +0 -5
- package/dist/__tests__/events-query.test.d.ts.map +0 -1
- package/dist/__tests__/events-query.test.js +0 -205
- package/dist/__tests__/events-query.test.js.map +0 -1
- package/dist/__tests__/health.test.d.ts +0 -5
- package/dist/__tests__/health.test.d.ts.map +0 -1
- package/dist/__tests__/health.test.js +0 -40
- package/dist/__tests__/health.test.js.map +0 -1
- package/dist/__tests__/ingest.test.d.ts +0 -8
- package/dist/__tests__/ingest.test.d.ts.map +0 -1
- package/dist/__tests__/ingest.test.js +0 -469
- package/dist/__tests__/ingest.test.js.map +0 -1
- package/dist/__tests__/llm-tracking.test.d.ts +0 -10
- package/dist/__tests__/llm-tracking.test.d.ts.map +0 -1
- package/dist/__tests__/llm-tracking.test.js +0 -602
- package/dist/__tests__/llm-tracking.test.js.map +0 -1
- package/dist/__tests__/sessions.test.d.ts +0 -5
- package/dist/__tests__/sessions.test.d.ts.map +0 -1
- package/dist/__tests__/sessions.test.js +0 -176
- package/dist/__tests__/sessions.test.js.map +0 -1
- package/dist/__tests__/stream.test.d.ts +0 -5
- package/dist/__tests__/stream.test.d.ts.map +0 -1
- package/dist/__tests__/stream.test.js +0 -352
- package/dist/__tests__/stream.test.js.map +0 -1
- package/dist/__tests__/test-helpers.d.ts +0 -24
- package/dist/__tests__/test-helpers.d.ts.map +0 -1
- package/dist/__tests__/test-helpers.js +0 -45
- package/dist/__tests__/test-helpers.js.map +0 -1
- package/dist/db/__tests__/init.test.d.ts +0 -2
- package/dist/db/__tests__/init.test.d.ts.map +0 -1
- package/dist/db/__tests__/init.test.js +0 -73
- package/dist/db/__tests__/init.test.js.map +0 -1
- package/dist/db/__tests__/sqlite-store-read.test.d.ts +0 -2
- package/dist/db/__tests__/sqlite-store-read.test.d.ts.map +0 -1
- package/dist/db/__tests__/sqlite-store-read.test.js +0 -749
- package/dist/db/__tests__/sqlite-store-read.test.js.map +0 -1
- package/dist/db/__tests__/sqlite-store-write.test.d.ts +0 -2
- package/dist/db/__tests__/sqlite-store-write.test.d.ts.map +0 -1
- package/dist/db/__tests__/sqlite-store-write.test.js +0 -418
- package/dist/db/__tests__/sqlite-store-write.test.js.map +0 -1
- package/dist/lib/__tests__/alert-engine.test.d.ts +0 -5
- package/dist/lib/__tests__/alert-engine.test.d.ts.map +0 -1
- package/dist/lib/__tests__/alert-engine.test.js +0 -211
- package/dist/lib/__tests__/alert-engine.test.js.map +0 -1
- package/dist/lib/__tests__/retention.test.d.ts +0 -2
- package/dist/lib/__tests__/retention.test.d.ts.map +0 -1
- package/dist/lib/__tests__/retention.test.js +0 -238
- package/dist/lib/__tests__/retention.test.js.map +0 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"schema.sqlite.d.ts","sourceRoot":"","sources":["../../src/db/schema.sqlite.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAKH,eAAO,MAAM,MAAM
|
|
1
|
+
{"version":3,"file":"schema.sqlite.d.ts","sourceRoot":"","sources":["../../src/db/schema.sqlite.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAKH,eAAO,MAAM,MAAM;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EA4BlB,CAAC;AAGF,eAAO,MAAM,QAAQ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAiCpB,CAAC;AAGF,eAAO,MAAM,MAAM;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAelB,CAAC;AAGF,eAAO,MAAM,UAAU;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAYrB,CAAC;AAGH,eAAO,MAAM,YAAY;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAexB,CAAC;AAGF,eAAO,MAAM,OAAO;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EA0BnB,CAAC;AAGF,eAAO,MAAM,OAAO;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAcnB,CAAC;AAGF,eAAO,MAAM,UAAU;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAoBtB,CAAC;AAGF,eAAO,MAAM,gBAAgB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAiB5B,CAAC"}
|
package/dist/db/schema.sqlite.js
CHANGED
|
@@ -4,7 +4,7 @@
|
|
|
4
4
|
* Tables: events, sessions, agents, alertRules, alertHistory, apiKeys
|
|
5
5
|
* All indexes per Architecture §6.2.
|
|
6
6
|
*/
|
|
7
|
-
import { sqliteTable, text, integer, real, index } from 'drizzle-orm/sqlite-core';
|
|
7
|
+
import { sqliteTable, text, integer, real, blob, index, primaryKey } from 'drizzle-orm/sqlite-core';
|
|
8
8
|
// ─── Events Table ──────────────────────────────────────────
|
|
9
9
|
export const events = sqliteTable('events', {
|
|
10
10
|
id: text('id').primaryKey(), // ULID
|
|
@@ -17,6 +17,7 @@ export const events = sqliteTable('events', {
|
|
|
17
17
|
metadata: text('metadata').notNull().default('{}'), // JSON
|
|
18
18
|
prevHash: text('prev_hash'),
|
|
19
19
|
hash: text('hash').notNull(),
|
|
20
|
+
tenantId: text('tenant_id').notNull().default('default'),
|
|
20
21
|
}, (table) => [
|
|
21
22
|
index('idx_events_timestamp').on(table.timestamp),
|
|
22
23
|
index('idx_events_session_id').on(table.sessionId),
|
|
@@ -25,10 +26,14 @@ export const events = sqliteTable('events', {
|
|
|
25
26
|
index('idx_events_session_ts').on(table.sessionId, table.timestamp),
|
|
26
27
|
// Composite index for dashboard query: "recent events for agent X of type Y"
|
|
27
28
|
index('idx_events_agent_type_ts').on(table.agentId, table.eventType, table.timestamp),
|
|
29
|
+
// Tenant isolation indexes
|
|
30
|
+
index('idx_events_tenant_id').on(table.tenantId),
|
|
31
|
+
index('idx_events_tenant_session').on(table.tenantId, table.sessionId),
|
|
32
|
+
index('idx_events_tenant_agent_ts').on(table.tenantId, table.agentId, table.timestamp),
|
|
28
33
|
]);
|
|
29
34
|
// ─── Sessions Table (materialized) ────────────────────────
|
|
30
35
|
export const sessions = sqliteTable('sessions', {
|
|
31
|
-
id: text('id').
|
|
36
|
+
id: text('id').notNull(),
|
|
32
37
|
agentId: text('agent_id').notNull(),
|
|
33
38
|
agentName: text('agent_name'),
|
|
34
39
|
startedAt: text('started_at').notNull(), // ISO 8601
|
|
@@ -46,20 +51,30 @@ export const sessions = sqliteTable('sessions', {
|
|
|
46
51
|
totalInputTokens: integer('total_input_tokens').notNull().default(0),
|
|
47
52
|
totalOutputTokens: integer('total_output_tokens').notNull().default(0),
|
|
48
53
|
tags: text('tags').notNull().default('[]'), // JSON array
|
|
54
|
+
tenantId: text('tenant_id').notNull().default('default'),
|
|
49
55
|
}, (table) => [
|
|
56
|
+
primaryKey({ columns: [table.id, table.tenantId] }),
|
|
50
57
|
index('idx_sessions_agent_id').on(table.agentId),
|
|
51
58
|
index('idx_sessions_started_at').on(table.startedAt),
|
|
52
59
|
index('idx_sessions_status').on(table.status),
|
|
60
|
+
// Tenant isolation indexes
|
|
61
|
+
index('idx_sessions_tenant_id').on(table.tenantId),
|
|
62
|
+
index('idx_sessions_tenant_agent').on(table.tenantId, table.agentId),
|
|
63
|
+
index('idx_sessions_tenant_started').on(table.tenantId, table.startedAt),
|
|
53
64
|
]);
|
|
54
65
|
// ─── Agents Table (materialized) ──────────────────────────
|
|
55
66
|
export const agents = sqliteTable('agents', {
|
|
56
|
-
id: text('id').
|
|
67
|
+
id: text('id').notNull(),
|
|
57
68
|
name: text('name').notNull(),
|
|
58
69
|
description: text('description'),
|
|
59
70
|
firstSeenAt: text('first_seen_at').notNull(),
|
|
60
71
|
lastSeenAt: text('last_seen_at').notNull(),
|
|
61
72
|
sessionCount: integer('session_count').notNull().default(0),
|
|
62
|
-
|
|
73
|
+
tenantId: text('tenant_id').notNull().default('default'),
|
|
74
|
+
}, (table) => [
|
|
75
|
+
primaryKey({ columns: [table.id, table.tenantId] }),
|
|
76
|
+
index('idx_agents_tenant_id').on(table.tenantId),
|
|
77
|
+
]);
|
|
63
78
|
// ─── Alert Rules Table ────────────────────────────────────
|
|
64
79
|
export const alertRules = sqliteTable('alert_rules', {
|
|
65
80
|
id: text('id').primaryKey(),
|
|
@@ -72,6 +87,7 @@ export const alertRules = sqliteTable('alert_rules', {
|
|
|
72
87
|
notifyChannels: text('notify_channels').notNull().default('[]'), // JSON
|
|
73
88
|
createdAt: text('created_at').notNull(),
|
|
74
89
|
updatedAt: text('updated_at').notNull(),
|
|
90
|
+
tenantId: text('tenant_id').notNull().default('default'),
|
|
75
91
|
});
|
|
76
92
|
// ─── Alert History ────────────────────────────────────────
|
|
77
93
|
export const alertHistory = sqliteTable('alert_history', {
|
|
@@ -84,7 +100,32 @@ export const alertHistory = sqliteTable('alert_history', {
|
|
|
84
100
|
currentValue: real('current_value').notNull(),
|
|
85
101
|
threshold: real('threshold').notNull(),
|
|
86
102
|
message: text('message').notNull(),
|
|
103
|
+
tenantId: text('tenant_id').notNull().default('default'),
|
|
87
104
|
}, (table) => [index('idx_alert_history_rule_id').on(table.ruleId)]);
|
|
105
|
+
// ─── Lessons Table (Epic 3) ────────────────────────────────
|
|
106
|
+
export const lessons = sqliteTable('lessons', {
|
|
107
|
+
id: text('id').notNull(),
|
|
108
|
+
tenantId: text('tenant_id').notNull(),
|
|
109
|
+
agentId: text('agent_id'),
|
|
110
|
+
category: text('category').notNull().default('general'),
|
|
111
|
+
title: text('title').notNull(),
|
|
112
|
+
content: text('content').notNull(),
|
|
113
|
+
context: text('context').notNull().default('{}'), // JSON
|
|
114
|
+
importance: text('importance').notNull().default('normal'),
|
|
115
|
+
sourceSessionId: text('source_session_id'),
|
|
116
|
+
sourceEventId: text('source_event_id'),
|
|
117
|
+
accessCount: integer('access_count').notNull().default(0),
|
|
118
|
+
lastAccessedAt: text('last_accessed_at'),
|
|
119
|
+
createdAt: text('created_at').notNull(),
|
|
120
|
+
updatedAt: text('updated_at').notNull(),
|
|
121
|
+
archivedAt: text('archived_at'),
|
|
122
|
+
}, (table) => [
|
|
123
|
+
primaryKey({ columns: [table.id, table.tenantId] }),
|
|
124
|
+
index('idx_lessons_tenant').on(table.tenantId),
|
|
125
|
+
index('idx_lessons_tenant_agent').on(table.tenantId, table.agentId),
|
|
126
|
+
index('idx_lessons_tenant_category').on(table.tenantId, table.category),
|
|
127
|
+
index('idx_lessons_tenant_importance').on(table.tenantId, table.importance),
|
|
128
|
+
]);
|
|
88
129
|
// ─── API Keys ─────────────────────────────────────────────
|
|
89
130
|
export const apiKeys = sqliteTable('api_keys', {
|
|
90
131
|
id: text('id').primaryKey(),
|
|
@@ -95,5 +136,39 @@ export const apiKeys = sqliteTable('api_keys', {
|
|
|
95
136
|
lastUsedAt: integer('last_used_at'),
|
|
96
137
|
revokedAt: integer('revoked_at'),
|
|
97
138
|
rateLimit: integer('rate_limit'),
|
|
139
|
+
tenantId: text('tenant_id').notNull().default('default'),
|
|
98
140
|
}, (table) => [index('idx_api_keys_hash').on(table.keyHash)]);
|
|
141
|
+
// ─── Embeddings Table (Epic 2) ────────────────────────────
|
|
142
|
+
export const embeddings = sqliteTable('embeddings', {
|
|
143
|
+
id: text('id').primaryKey(),
|
|
144
|
+
tenantId: text('tenant_id').notNull(),
|
|
145
|
+
sourceType: text('source_type').notNull(), // 'event', 'session', 'lesson'
|
|
146
|
+
sourceId: text('source_id').notNull(),
|
|
147
|
+
contentHash: text('content_hash').notNull(), // SHA-256 of embedded text
|
|
148
|
+
textContent: text('text_content').notNull(),
|
|
149
|
+
embedding: blob('embedding', { mode: 'buffer' }).notNull(), // Float32Array as binary
|
|
150
|
+
embeddingModel: text('embedding_model').notNull(),
|
|
151
|
+
dimensions: integer('dimensions').notNull(),
|
|
152
|
+
createdAt: text('created_at').notNull(),
|
|
153
|
+
}, (table) => [
|
|
154
|
+
index('idx_embeddings_tenant').on(table.tenantId),
|
|
155
|
+
index('idx_embeddings_source').on(table.sourceType, table.sourceId),
|
|
156
|
+
index('idx_embeddings_content_hash').on(table.tenantId, table.contentHash),
|
|
157
|
+
index('idx_embeddings_tenant_source_time').on(table.tenantId, table.sourceType, table.createdAt),
|
|
158
|
+
]);
|
|
159
|
+
// ─── Session Summaries Table (Epic 2) ─────────────────────
|
|
160
|
+
export const sessionSummaries = sqliteTable('session_summaries', {
|
|
161
|
+
sessionId: text('session_id').notNull(),
|
|
162
|
+
tenantId: text('tenant_id').notNull(),
|
|
163
|
+
summary: text('summary').notNull(),
|
|
164
|
+
topics: text('topics').notNull().default('[]'), // JSON array
|
|
165
|
+
toolSequence: text('tool_sequence').notNull().default('[]'), // JSON array
|
|
166
|
+
errorSummary: text('error_summary'),
|
|
167
|
+
outcome: text('outcome'),
|
|
168
|
+
createdAt: text('created_at').notNull(),
|
|
169
|
+
updatedAt: text('updated_at').notNull(),
|
|
170
|
+
}, (table) => [
|
|
171
|
+
primaryKey({ columns: [table.sessionId, table.tenantId] }),
|
|
172
|
+
index('idx_session_summaries_tenant').on(table.tenantId),
|
|
173
|
+
]);
|
|
99
174
|
//# sourceMappingURL=schema.sqlite.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"schema.sqlite.js","sourceRoot":"","sources":["../../src/db/schema.sqlite.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,EAAE,WAAW,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,EAAE,KAAK,EAAE,MAAM,yBAAyB,CAAC;
|
|
1
|
+
{"version":3,"file":"schema.sqlite.js","sourceRoot":"","sources":["../../src/db/schema.sqlite.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Session Summary Store (Story 5.1)
|
|
3
|
+
*
|
|
4
|
+
* CRUD operations for the session_summaries table with tenant isolation.
|
|
5
|
+
* Stores auto-generated session summaries for cross-session context retrieval.
|
|
6
|
+
*/
|
|
7
|
+
import type { SqliteDb } from './index.js';
|
|
8
|
+
/** Stored session summary record */
|
|
9
|
+
export interface SessionSummaryRecord {
|
|
10
|
+
sessionId: string;
|
|
11
|
+
tenantId: string;
|
|
12
|
+
summary: string;
|
|
13
|
+
topics: string[];
|
|
14
|
+
toolSequence: string[];
|
|
15
|
+
errorSummary: string | null;
|
|
16
|
+
outcome: string | null;
|
|
17
|
+
createdAt: string;
|
|
18
|
+
updatedAt: string;
|
|
19
|
+
}
|
|
20
|
+
export declare class SessionSummaryStore {
|
|
21
|
+
private readonly db;
|
|
22
|
+
constructor(db: SqliteDb);
|
|
23
|
+
/**
|
|
24
|
+
* Upsert a session summary. If one already exists for (tenantId, sessionId),
|
|
25
|
+
* it is updated; otherwise a new row is inserted.
|
|
26
|
+
*/
|
|
27
|
+
save(tenantId: string, sessionId: string, summary: string, topics: string[], toolSequence: string[], errorSummary: string | null, outcome: string | null): SessionSummaryRecord;
|
|
28
|
+
/**
|
|
29
|
+
* Get a session summary by sessionId.
|
|
30
|
+
*/
|
|
31
|
+
get(tenantId: string, sessionId: string): SessionSummaryRecord | null;
|
|
32
|
+
/**
|
|
33
|
+
* List session summaries for a tenant, ordered by creation time descending.
|
|
34
|
+
*/
|
|
35
|
+
getByTenant(tenantId: string, opts?: {
|
|
36
|
+
limit?: number;
|
|
37
|
+
offset?: number;
|
|
38
|
+
}): SessionSummaryRecord[];
|
|
39
|
+
/**
|
|
40
|
+
* Text search over session summaries (LIKE-based).
|
|
41
|
+
* Searches summary text, topics JSON, and error_summary.
|
|
42
|
+
*/
|
|
43
|
+
search(tenantId: string, query: string, limit?: number): SessionSummaryRecord[];
|
|
44
|
+
}
|
|
45
|
+
//# sourceMappingURL=session-summary-store.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"session-summary-store.d.ts","sourceRoot":"","sources":["../../src/db/session-summary-store.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAGH,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AAQ3C,oCAAoC;AACpC,MAAM,WAAW,oBAAoB;IACnC,SAAS,EAAE,MAAM,CAAC;IAClB,QAAQ,EAAE,MAAM,CAAC;IACjB,OAAO,EAAE,MAAM,CAAC;IAChB,MAAM,EAAE,MAAM,EAAE,CAAC;IACjB,YAAY,EAAE,MAAM,EAAE,CAAC;IACvB,YAAY,EAAE,MAAM,GAAG,IAAI,CAAC;IAC5B,OAAO,EAAE,MAAM,GAAG,IAAI,CAAC;IACvB,SAAS,EAAE,MAAM,CAAC;IAClB,SAAS,EAAE,MAAM,CAAC;CACnB;AAiBD,qBAAa,mBAAmB;IAClB,OAAO,CAAC,QAAQ,CAAC,EAAE;gBAAF,EAAE,EAAE,QAAQ;IAEzC;;;OAGG;IACH,IAAI,CACF,QAAQ,EAAE,MAAM,EAChB,SAAS,EAAE,MAAM,EACjB,OAAO,EAAE,MAAM,EACf,MAAM,EAAE,MAAM,EAAE,EAChB,YAAY,EAAE,MAAM,EAAE,EACtB,YAAY,EAAE,MAAM,GAAG,IAAI,EAC3B,OAAO,EAAE,MAAM,GAAG,IAAI,GACrB,oBAAoB;IAiCvB;;OAEG;IACH,GAAG,CAAC,QAAQ,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,GAAG,oBAAoB,GAAG,IAAI;IAgBrE;;OAEG;IACH,WAAW,CACT,QAAQ,EAAE,MAAM,EAChB,IAAI,CAAC,EAAE;QAAE,KAAK,CAAC,EAAE,MAAM,CAAC;QAAC,MAAM,CAAC,EAAE,MAAM,CAAA;KAAE,GACzC,oBAAoB,EAAE;IAgBzB;;;OAGG;IACH,MAAM,CAAC,QAAQ,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,CAAC,EAAE,MAAM,GAAG,oBAAoB,EAAE;CAuBhF"}
|
|
@@ -0,0 +1,112 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Session Summary Store (Story 5.1)
|
|
3
|
+
*
|
|
4
|
+
* CRUD operations for the session_summaries table with tenant isolation.
|
|
5
|
+
* Stores auto-generated session summaries for cross-session context retrieval.
|
|
6
|
+
*/
|
|
7
|
+
import { eq, and, or, sql } from 'drizzle-orm';
|
|
8
|
+
import { sessionSummaries } from './schema.sqlite.js';
|
|
9
|
+
/** Escape LIKE wildcard characters to prevent injection */
|
|
10
|
+
function escapeLike(s) {
|
|
11
|
+
return s.replace(/[%_]/g, '\\$&');
|
|
12
|
+
}
|
|
13
|
+
/** Parse a DB row into a SessionSummaryRecord */
|
|
14
|
+
function rowToRecord(row) {
|
|
15
|
+
return {
|
|
16
|
+
sessionId: row.sessionId,
|
|
17
|
+
tenantId: row.tenantId,
|
|
18
|
+
summary: row.summary,
|
|
19
|
+
topics: JSON.parse(row.topics),
|
|
20
|
+
toolSequence: JSON.parse(row.toolSequence),
|
|
21
|
+
errorSummary: row.errorSummary ?? null,
|
|
22
|
+
outcome: row.outcome ?? null,
|
|
23
|
+
createdAt: row.createdAt,
|
|
24
|
+
updatedAt: row.updatedAt,
|
|
25
|
+
};
|
|
26
|
+
}
|
|
27
|
+
export class SessionSummaryStore {
|
|
28
|
+
db;
|
|
29
|
+
constructor(db) {
|
|
30
|
+
this.db = db;
|
|
31
|
+
}
|
|
32
|
+
/**
|
|
33
|
+
* Upsert a session summary. If one already exists for (tenantId, sessionId),
|
|
34
|
+
* it is updated; otherwise a new row is inserted.
|
|
35
|
+
*/
|
|
36
|
+
save(tenantId, sessionId, summary, topics, toolSequence, errorSummary, outcome) {
|
|
37
|
+
const now = new Date().toISOString();
|
|
38
|
+
this.db
|
|
39
|
+
.insert(sessionSummaries)
|
|
40
|
+
.values({
|
|
41
|
+
sessionId,
|
|
42
|
+
tenantId,
|
|
43
|
+
summary,
|
|
44
|
+
topics: JSON.stringify(topics),
|
|
45
|
+
toolSequence: JSON.stringify(toolSequence),
|
|
46
|
+
errorSummary,
|
|
47
|
+
outcome,
|
|
48
|
+
createdAt: now,
|
|
49
|
+
updatedAt: now,
|
|
50
|
+
})
|
|
51
|
+
.onConflictDoUpdate({
|
|
52
|
+
target: [sessionSummaries.sessionId, sessionSummaries.tenantId],
|
|
53
|
+
set: {
|
|
54
|
+
summary,
|
|
55
|
+
topics: JSON.stringify(topics),
|
|
56
|
+
toolSequence: JSON.stringify(toolSequence),
|
|
57
|
+
errorSummary,
|
|
58
|
+
outcome,
|
|
59
|
+
updatedAt: now,
|
|
60
|
+
},
|
|
61
|
+
})
|
|
62
|
+
.run();
|
|
63
|
+
// Return the saved record
|
|
64
|
+
return this.get(tenantId, sessionId);
|
|
65
|
+
}
|
|
66
|
+
/**
|
|
67
|
+
* Get a session summary by sessionId.
|
|
68
|
+
*/
|
|
69
|
+
get(tenantId, sessionId) {
|
|
70
|
+
const row = this.db
|
|
71
|
+
.select()
|
|
72
|
+
.from(sessionSummaries)
|
|
73
|
+
.where(and(eq(sessionSummaries.sessionId, sessionId), eq(sessionSummaries.tenantId, tenantId)))
|
|
74
|
+
.get();
|
|
75
|
+
if (!row)
|
|
76
|
+
return null;
|
|
77
|
+
return rowToRecord(row);
|
|
78
|
+
}
|
|
79
|
+
/**
|
|
80
|
+
* List session summaries for a tenant, ordered by creation time descending.
|
|
81
|
+
*/
|
|
82
|
+
getByTenant(tenantId, opts) {
|
|
83
|
+
const limit = opts?.limit ?? 50;
|
|
84
|
+
const offset = opts?.offset ?? 0;
|
|
85
|
+
const rows = this.db
|
|
86
|
+
.select()
|
|
87
|
+
.from(sessionSummaries)
|
|
88
|
+
.where(eq(sessionSummaries.tenantId, tenantId))
|
|
89
|
+
.limit(limit)
|
|
90
|
+
.offset(offset)
|
|
91
|
+
.orderBy(sql `${sessionSummaries.createdAt} DESC`)
|
|
92
|
+
.all();
|
|
93
|
+
return rows.map(rowToRecord);
|
|
94
|
+
}
|
|
95
|
+
/**
|
|
96
|
+
* Text search over session summaries (LIKE-based).
|
|
97
|
+
* Searches summary text, topics JSON, and error_summary.
|
|
98
|
+
*/
|
|
99
|
+
search(tenantId, query, limit) {
|
|
100
|
+
const maxResults = limit ?? 10;
|
|
101
|
+
const pattern = `%${escapeLike(query)}%`;
|
|
102
|
+
const rows = this.db
|
|
103
|
+
.select()
|
|
104
|
+
.from(sessionSummaries)
|
|
105
|
+
.where(and(eq(sessionSummaries.tenantId, tenantId), or(sql `${sessionSummaries.summary} LIKE ${pattern} ESCAPE '\\'`, sql `${sessionSummaries.topics} LIKE ${pattern} ESCAPE '\\'`, sql `${sessionSummaries.errorSummary} LIKE ${pattern} ESCAPE '\\'`)))
|
|
106
|
+
.limit(maxResults)
|
|
107
|
+
.orderBy(sql `${sessionSummaries.createdAt} DESC`)
|
|
108
|
+
.all();
|
|
109
|
+
return rows.map(rowToRecord);
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
//# sourceMappingURL=session-summary-store.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"session-summary-store.js","sourceRoot":"","sources":["../../src/db/session-summary-store.ts"],"names":[],"mappings":"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"}
|
|
@@ -23,6 +23,11 @@ export declare function safeJsonParse<T>(raw: string, fallback: T): T;
|
|
|
23
23
|
export declare class SqliteEventStore implements IEventStore {
|
|
24
24
|
private db;
|
|
25
25
|
constructor(db: SqliteDb);
|
|
26
|
+
/**
|
|
27
|
+
* Defense-in-depth: warn when a query method is called without tenantId.
|
|
28
|
+
* This helps catch missing tenant scoping in call chains.
|
|
29
|
+
*/
|
|
30
|
+
private warnIfNoTenant;
|
|
26
31
|
insertEvents(eventList: AgentLensEvent[]): Promise<void>;
|
|
27
32
|
private _handleSessionUpdate;
|
|
28
33
|
private _handleAgentUpsert;
|
|
@@ -33,41 +38,43 @@ export declare class SqliteEventStore implements IEventStore {
|
|
|
33
38
|
id: string;
|
|
34
39
|
}): Promise<void>;
|
|
35
40
|
queryEvents(query: EventQuery): Promise<EventQueryResult>;
|
|
36
|
-
getEvent(id: string): Promise<AgentLensEvent | null>;
|
|
37
|
-
getSessionTimeline(sessionId: string): Promise<AgentLensEvent[]>;
|
|
38
|
-
getLastEventHash(sessionId: string): Promise<string | null>;
|
|
41
|
+
getEvent(id: string, tenantId?: string): Promise<AgentLensEvent | null>;
|
|
42
|
+
getSessionTimeline(sessionId: string, tenantId?: string): Promise<AgentLensEvent[]>;
|
|
43
|
+
getLastEventHash(sessionId: string, tenantId?: string): Promise<string | null>;
|
|
39
44
|
countEvents(query: Omit<EventQuery, 'limit' | 'offset'>): Promise<number>;
|
|
40
45
|
querySessions(query: SessionQuery): Promise<{
|
|
41
46
|
sessions: Session[];
|
|
42
47
|
total: number;
|
|
43
48
|
}>;
|
|
44
|
-
getSession(id: string): Promise<Session | null>;
|
|
45
|
-
listAgents(): Promise<Agent[]>;
|
|
46
|
-
getAgent(id: string): Promise<Agent | null>;
|
|
49
|
+
getSession(id: string, tenantId?: string): Promise<Session | null>;
|
|
50
|
+
listAgents(tenantId?: string): Promise<Agent[]>;
|
|
51
|
+
getAgent(id: string, tenantId?: string): Promise<Agent | null>;
|
|
47
52
|
getAnalytics(params: {
|
|
48
53
|
from: string;
|
|
49
54
|
to: string;
|
|
50
55
|
agentId?: string;
|
|
51
56
|
granularity: 'hour' | 'day' | 'week';
|
|
57
|
+
tenantId?: string;
|
|
52
58
|
}): Promise<AnalyticsResult>;
|
|
53
59
|
createAlertRule(rule: AlertRule): Promise<void>;
|
|
54
|
-
updateAlertRule(id: string, updates: Partial<AlertRule
|
|
55
|
-
deleteAlertRule(id: string): Promise<void>;
|
|
56
|
-
listAlertRules(): Promise<AlertRule[]>;
|
|
57
|
-
getAlertRule(id: string): Promise<AlertRule | null>;
|
|
60
|
+
updateAlertRule(id: string, updates: Partial<AlertRule>, tenantId?: string): Promise<void>;
|
|
61
|
+
deleteAlertRule(id: string, tenantId?: string): Promise<void>;
|
|
62
|
+
listAlertRules(tenantId?: string): Promise<AlertRule[]>;
|
|
63
|
+
getAlertRule(id: string, tenantId?: string): Promise<AlertRule | null>;
|
|
58
64
|
insertAlertHistory(entry: AlertHistory): Promise<void>;
|
|
59
65
|
listAlertHistory(opts?: {
|
|
60
66
|
ruleId?: string;
|
|
61
67
|
limit?: number;
|
|
62
68
|
offset?: number;
|
|
69
|
+
tenantId?: string;
|
|
63
70
|
}): Promise<{
|
|
64
71
|
entries: AlertHistory[];
|
|
65
72
|
total: number;
|
|
66
73
|
}>;
|
|
67
|
-
applyRetention(olderThan: string): Promise<{
|
|
74
|
+
applyRetention(olderThan: string, tenantId?: string): Promise<{
|
|
68
75
|
deletedCount: number;
|
|
69
76
|
}>;
|
|
70
|
-
getStats(): Promise<StorageStats>;
|
|
77
|
+
getStats(tenantId?: string): Promise<StorageStats>;
|
|
71
78
|
private _buildEventConditions;
|
|
72
79
|
private _buildSessionConditions;
|
|
73
80
|
private _mapEventRow;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"sqlite-store.d.ts","sourceRoot":"","sources":["../../src/db/sqlite-store.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;GAcG;AAIH,OAAO,KAAK,EACV,cAAc,EACd,UAAU,EACV,gBAAgB,EAChB,OAAO,EACP,YAAY,EACZ,KAAK,EACL,SAAS,EACT,YAAY,EACb,MAAM,mBAAmB,CAAC;AAC3B,OAAO,KAAK,EAAE,WAAW,EAAE,eAAe,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AACpF,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AAM3C;;GAEG;AACH,wBAAgB,aAAa,CAAC,CAAC,EAAE,GAAG,EAAE,MAAM,EAAE,QAAQ,EAAE,CAAC,GAAG,CAAC,CAM5D;AAED,qBAAa,gBAAiB,YAAW,WAAW;IACtC,OAAO,CAAC,EAAE;gBAAF,EAAE,EAAE,QAAQ;
|
|
1
|
+
{"version":3,"file":"sqlite-store.d.ts","sourceRoot":"","sources":["../../src/db/sqlite-store.ts"],"names":[],"mappings":"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"}
|