@sochdb/sochdb 0.4.0 → 0.4.1

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.
Files changed (69) hide show
  1. package/README.md +220 -33
  2. package/_bin/aarch64-apple-darwin/libsochdb_storage.dylib +0 -0
  3. package/_bin/aarch64-apple-darwin/sochdb-bulk +0 -0
  4. package/_bin/aarch64-apple-darwin/sochdb-grpc-server +0 -0
  5. package/_bin/aarch64-apple-darwin/sochdb-server +0 -0
  6. package/_bin/x86_64-pc-windows-msvc/sochdb-bulk.exe +0 -0
  7. package/_bin/x86_64-pc-windows-msvc/sochdb-grpc-server.exe +0 -0
  8. package/_bin/x86_64-pc-windows-msvc/sochdb_storage.dll +0 -0
  9. package/_bin/x86_64-unknown-linux-gnu/libsochdb_storage.so +0 -0
  10. package/_bin/x86_64-unknown-linux-gnu/sochdb-bulk +0 -0
  11. package/_bin/x86_64-unknown-linux-gnu/sochdb-grpc-server +0 -0
  12. package/_bin/x86_64-unknown-linux-gnu/sochdb-server +0 -0
  13. package/bin/sochdb-bulk.js +1 -1
  14. package/bin/sochdb-grpc-server.js +1 -1
  15. package/bin/sochdb-server.js +1 -1
  16. package/dist/cjs/context-builder.js +280 -0
  17. package/dist/cjs/database.js +2 -2
  18. package/dist/cjs/embedded/database.js +2 -2
  19. package/dist/cjs/errors.js +99 -7
  20. package/dist/cjs/index.js +40 -3
  21. package/dist/cjs/ipc-client.js +2 -2
  22. package/dist/cjs/memory/consolidation.js +202 -0
  23. package/dist/cjs/memory/extraction.js +181 -0
  24. package/dist/cjs/memory/index.js +26 -0
  25. package/dist/cjs/memory/retrieval.js +232 -0
  26. package/dist/cjs/memory/types.js +69 -0
  27. package/dist/cjs/namespace.js +255 -0
  28. package/dist/cjs/queue.js +289 -0
  29. package/dist/cjs/semantic-cache.js +220 -0
  30. package/dist/esm/context-builder.js +280 -0
  31. package/dist/esm/database.js +2 -2
  32. package/dist/esm/embedded/database.js +2 -2
  33. package/dist/esm/errors.js +107 -7
  34. package/dist/esm/index.js +40 -3
  35. package/dist/esm/ipc-client.js +2 -2
  36. package/dist/esm/memory/consolidation.js +206 -0
  37. package/dist/esm/memory/extraction.js +185 -0
  38. package/dist/esm/memory/index.js +26 -0
  39. package/dist/esm/memory/retrieval.js +243 -0
  40. package/dist/esm/memory/types.js +72 -0
  41. package/dist/esm/namespace.js +262 -0
  42. package/dist/esm/queue.js +291 -0
  43. package/dist/esm/semantic-cache.js +223 -0
  44. package/dist/types/context-builder.d.ts +97 -0
  45. package/dist/types/context-builder.d.ts.map +1 -0
  46. package/dist/types/database.d.ts +1 -1
  47. package/dist/types/embedded/database.d.ts +1 -1
  48. package/dist/types/errors.d.ts +57 -1
  49. package/dist/types/errors.d.ts.map +1 -1
  50. package/dist/types/index.d.ts +12 -2
  51. package/dist/types/index.d.ts.map +1 -1
  52. package/dist/types/ipc-client.d.ts +1 -1
  53. package/dist/types/memory/consolidation.d.ts +66 -0
  54. package/dist/types/memory/consolidation.d.ts.map +1 -0
  55. package/dist/types/memory/extraction.d.ts +82 -0
  56. package/dist/types/memory/extraction.d.ts.map +1 -0
  57. package/dist/types/memory/index.d.ts +10 -0
  58. package/dist/types/memory/index.d.ts.map +1 -0
  59. package/dist/types/memory/retrieval.d.ts +46 -0
  60. package/dist/types/memory/retrieval.d.ts.map +1 -0
  61. package/dist/types/memory/types.d.ts +147 -0
  62. package/dist/types/memory/types.d.ts.map +1 -0
  63. package/dist/types/namespace.d.ts +129 -0
  64. package/dist/types/namespace.d.ts.map +1 -0
  65. package/dist/types/queue.d.ts +120 -0
  66. package/dist/types/queue.d.ts.map +1 -0
  67. package/dist/types/semantic-cache.d.ts +84 -0
  68. package/dist/types/semantic-cache.d.ts.map +1 -0
  69. package/package.json +1 -1
@@ -0,0 +1,223 @@
1
+ "use strict";
2
+ /**
3
+ * Semantic Cache for LLM responses
4
+ *
5
+ * Cache LLM responses with similarity-based retrieval for cost savings.
6
+ * Uses database prefix scanning to store and retrieve cached responses.
7
+ */
8
+ Object.defineProperty(exports, "__esModule", { value: true });
9
+ exports.SemanticCache = void 0;
10
+ /**
11
+ * Calculate cosine similarity between two vectors
12
+ */
13
+ function cosineSimilarity(a, b) {
14
+ if (a.length !== b.length) {
15
+ throw new Error('Vectors must have same length');
16
+ }
17
+ let dotProduct = 0;
18
+ let normA = 0;
19
+ let normB = 0;
20
+ for (let i = 0; i < a.length; i++) {
21
+ dotProduct += a[i] * b[i];
22
+ normA += a[i] * a[i];
23
+ normB += b[i] * b[i];
24
+ }
25
+ if (normA === 0 || normB === 0) {
26
+ return 0;
27
+ }
28
+ return dotProduct / (Math.sqrt(normA) * Math.sqrt(normB));
29
+ }
30
+ /**
31
+ * Semantic Cache with vector similarity matching
32
+ *
33
+ * @example
34
+ * ```typescript
35
+ * const cache = new SemanticCache(db, 'llm_responses');
36
+ *
37
+ * // Store response
38
+ * await cache.put(
39
+ * 'What is Python?',
40
+ * 'Python is a high-level programming language...',
41
+ * embedding,
42
+ * 3600 // TTL in seconds
43
+ * );
44
+ *
45
+ * // Check cache
46
+ * const hit = await cache.get(queryEmbedding, 0.85);
47
+ * if (hit) {
48
+ * console.log(`Cache HIT: ${hit.value} (similarity: ${hit.score})`);
49
+ * }
50
+ * ```
51
+ */
52
+ class SemanticCache {
53
+ db;
54
+ cacheName;
55
+ prefix;
56
+ hits = 0;
57
+ misses = 0;
58
+ constructor(db, cacheName) {
59
+ this.db = db;
60
+ this.cacheName = cacheName;
61
+ this.prefix = Buffer.from(`cache:${cacheName}:`);
62
+ }
63
+ /**
64
+ * Store a cached response
65
+ */
66
+ async put(key, value, embedding, ttlSeconds = 0, metadata) {
67
+ const entry = {
68
+ key,
69
+ value,
70
+ embedding,
71
+ timestamp: Date.now(),
72
+ ttl: ttlSeconds > 0 ? ttlSeconds : undefined,
73
+ metadata,
74
+ };
75
+ const entryKey = Buffer.concat([
76
+ this.prefix,
77
+ Buffer.from(key),
78
+ ]);
79
+ await this.db.put(entryKey, Buffer.from(JSON.stringify(entry)));
80
+ }
81
+ /**
82
+ * Retrieve cached response by similarity
83
+ *
84
+ * @param queryEmbedding - Query embedding vector
85
+ * @param threshold - Minimum cosine similarity (0-1)
86
+ * @returns Best matching cache entry or null
87
+ */
88
+ async get(queryEmbedding, threshold = 0.85) {
89
+ const now = Date.now();
90
+ let bestMatch = null;
91
+ let bestScore = threshold;
92
+ // Scan all cache entries with this prefix
93
+ try {
94
+ for await (const [_, valueBuffer] of this.db.scanPrefix(this.prefix)) {
95
+ const entry = JSON.parse(valueBuffer.toString());
96
+ // Check TTL expiration
97
+ if (entry.ttl && entry.timestamp) {
98
+ const expiresAt = entry.timestamp + entry.ttl * 1000;
99
+ if (now > expiresAt) {
100
+ continue; // Skip expired entries
101
+ }
102
+ }
103
+ // Calculate similarity
104
+ const score = cosineSimilarity(queryEmbedding, entry.embedding);
105
+ // Update best match
106
+ if (score > bestScore) {
107
+ bestScore = score;
108
+ bestMatch = { ...entry, score };
109
+ }
110
+ }
111
+ }
112
+ catch (error) {
113
+ // If scan fails, return null
114
+ this.misses++;
115
+ return null;
116
+ }
117
+ if (bestMatch) {
118
+ this.hits++;
119
+ }
120
+ else {
121
+ this.misses++;
122
+ }
123
+ return bestMatch;
124
+ }
125
+ /**
126
+ * Delete a specific cache entry
127
+ */
128
+ async delete(key) {
129
+ const entryKey = Buffer.concat([
130
+ this.prefix,
131
+ Buffer.from(key),
132
+ ]);
133
+ await this.db.delete(entryKey);
134
+ }
135
+ /**
136
+ * Clear all entries in this cache
137
+ */
138
+ async clear() {
139
+ let deleted = 0;
140
+ try {
141
+ const toDelete = [];
142
+ for await (const [key] of this.db.scanPrefix(this.prefix)) {
143
+ toDelete.push(key);
144
+ }
145
+ for (const key of toDelete) {
146
+ await this.db.delete(key);
147
+ deleted++;
148
+ }
149
+ }
150
+ catch (error) {
151
+ // If operation fails, return count so far
152
+ return deleted;
153
+ }
154
+ // Reset stats
155
+ this.hits = 0;
156
+ this.misses = 0;
157
+ return deleted;
158
+ }
159
+ /**
160
+ * Get cache statistics
161
+ */
162
+ async stats() {
163
+ const now = Date.now();
164
+ let count = 0;
165
+ let memoryUsage = 0;
166
+ try {
167
+ for await (const [key, value] of this.db.scanPrefix(this.prefix)) {
168
+ const entry = JSON.parse(value.toString());
169
+ // Skip expired entries
170
+ if (entry.ttl && entry.timestamp) {
171
+ const expiresAt = entry.timestamp + entry.ttl * 1000;
172
+ if (now > expiresAt) {
173
+ continue;
174
+ }
175
+ }
176
+ count++;
177
+ memoryUsage += key.length + value.length;
178
+ }
179
+ }
180
+ catch (error) {
181
+ // Return partial stats if operation fails
182
+ }
183
+ const total = this.hits + this.misses;
184
+ const hitRate = total > 0 ? this.hits / total : 0;
185
+ return {
186
+ count,
187
+ hits: this.hits,
188
+ misses: this.misses,
189
+ hitRate,
190
+ memoryUsage,
191
+ };
192
+ }
193
+ /**
194
+ * Purge expired entries
195
+ */
196
+ async purgeExpired() {
197
+ const now = Date.now();
198
+ let purged = 0;
199
+ try {
200
+ const toDelete = [];
201
+ for await (const [key, value] of this.db.scanPrefix(this.prefix)) {
202
+ const entry = JSON.parse(value.toString());
203
+ if (entry.ttl && entry.timestamp) {
204
+ const expiresAt = entry.timestamp + entry.ttl * 1000;
205
+ if (now > expiresAt) {
206
+ toDelete.push(key);
207
+ }
208
+ }
209
+ }
210
+ for (const key of toDelete) {
211
+ await this.db.delete(key);
212
+ purged++;
213
+ }
214
+ }
215
+ catch (error) {
216
+ // Return count so far
217
+ return purged;
218
+ }
219
+ return purged;
220
+ }
221
+ }
222
+ exports.SemanticCache = SemanticCache;
223
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"semantic-cache.js","sourceRoot":"","sources":["../../src/semantic-cache.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Semantic Cache for LLM responses\n * \n * Cache LLM responses with similarity-based retrieval for cost savings.\n * Uses database prefix scanning to store and retrieve cached responses.\n */\n\nimport { EmbeddedDatabase } from './embedded';\n\n/**\n * Calculate cosine similarity between two vectors\n */\nfunction cosineSimilarity(a: number[], b: number[]): number {\n  if (a.length !== b.length) {\n    throw new Error('Vectors must have same length');\n  }\n\n  let dotProduct = 0;\n  let normA = 0;\n  let normB = 0;\n\n  for (let i = 0; i < a.length; i++) {\n    dotProduct += a[i] * b[i];\n    normA += a[i] * a[i];\n    normB += b[i] * b[i];\n  }\n\n  if (normA === 0 || normB === 0) {\n    return 0;\n  }\n\n  return dotProduct / (Math.sqrt(normA) * Math.sqrt(normB));\n}\n\nexport interface CacheEntry {\n  key: string;\n  value: string;\n  embedding: number[];\n  timestamp: number;\n  ttl?: number;\n  metadata?: Record<string, any>;\n}\n\nexport interface CacheHit extends CacheEntry {\n  score: number;\n}\n\nexport interface CacheStats {\n  count: number;\n  hits: number;\n  misses: number;\n  hitRate: number;\n  memoryUsage: number;\n}\n\n/**\n * Semantic Cache with vector similarity matching\n * \n * @example\n * ```typescript\n * const cache = new SemanticCache(db, 'llm_responses');\n * \n * // Store response\n * await cache.put(\n *   'What is Python?',\n *   'Python is a high-level programming language...',\n *   embedding,\n *   3600  // TTL in seconds\n * );\n * \n * // Check cache\n * const hit = await cache.get(queryEmbedding, 0.85);\n * if (hit) {\n *   console.log(`Cache HIT: ${hit.value} (similarity: ${hit.score})`);\n * }\n * ```\n */\nexport class SemanticCache {\n  private db: EmbeddedDatabase;\n  private cacheName: string;\n  private prefix: Buffer;\n  private hits = 0;\n  private misses = 0;\n\n  constructor(db: EmbeddedDatabase, cacheName: string) {\n    this.db = db;\n    this.cacheName = cacheName;\n    this.prefix = Buffer.from(`cache:${cacheName}:`);\n  }\n\n  /**\n   * Store a cached response\n   */\n  async put(\n    key: string,\n    value: string,\n    embedding: number[],\n    ttlSeconds = 0,\n    metadata?: Record<string, any>\n  ): Promise<void> {\n    const entry: CacheEntry = {\n      key,\n      value,\n      embedding,\n      timestamp: Date.now(),\n      ttl: ttlSeconds > 0 ? ttlSeconds : undefined,\n      metadata,\n    };\n\n    const entryKey = Buffer.concat([\n      this.prefix,\n      Buffer.from(key),\n    ]);\n\n    await this.db.put(entryKey, Buffer.from(JSON.stringify(entry)));\n  }\n\n  /**\n   * Retrieve cached response by similarity\n   * \n   * @param queryEmbedding - Query embedding vector\n   * @param threshold - Minimum cosine similarity (0-1)\n   * @returns Best matching cache entry or null\n   */\n  async get(\n    queryEmbedding: number[],\n    threshold = 0.85\n  ): Promise<CacheHit | null> {\n    const now = Date.now();\n    let bestMatch: CacheHit | null = null;\n    let bestScore = threshold;\n\n    // Scan all cache entries with this prefix\n    try {\n      for await (const [_, valueBuffer] of this.db.scanPrefix(this.prefix)) {\n        const entry: CacheEntry = JSON.parse(valueBuffer.toString());\n\n        // Check TTL expiration\n        if (entry.ttl && entry.timestamp) {\n          const expiresAt = entry.timestamp + entry.ttl * 1000;\n          if (now > expiresAt) {\n            continue; // Skip expired entries\n          }\n        }\n\n        // Calculate similarity\n        const score = cosineSimilarity(queryEmbedding, entry.embedding);\n\n        // Update best match\n        if (score > bestScore) {\n          bestScore = score;\n          bestMatch = { ...entry, score };\n        }\n      }\n    } catch (error) {\n      // If scan fails, return null\n      this.misses++;\n      return null;\n    }\n\n    if (bestMatch) {\n      this.hits++;\n    } else {\n      this.misses++;\n    }\n\n    return bestMatch;\n  }\n\n  /**\n   * Delete a specific cache entry\n   */\n  async delete(key: string): Promise<void> {\n    const entryKey = Buffer.concat([\n      this.prefix,\n      Buffer.from(key),\n    ]);\n    await this.db.delete(entryKey);\n  }\n\n  /**\n   * Clear all entries in this cache\n   */\n  async clear(): Promise<number> {\n    let deleted = 0;\n\n    try {\n      const toDelete: Buffer[] = [];\n      for await (const [key] of this.db.scanPrefix(this.prefix)) {\n        toDelete.push(key);\n      }\n\n      for (const key of toDelete) {\n        await this.db.delete(key);\n        deleted++;\n      }\n    } catch (error) {\n      // If operation fails, return count so far\n      return deleted;\n    }\n\n    // Reset stats\n    this.hits = 0;\n    this.misses = 0;\n\n    return deleted;\n  }\n\n  /**\n   * Get cache statistics\n   */\n  async stats(): Promise<CacheStats> {\n    const now = Date.now();\n    let count = 0;\n    let memoryUsage = 0;\n\n    try {\n      for await (const [key, value] of this.db.scanPrefix(this.prefix)) {\n        const entry: CacheEntry = JSON.parse(value.toString());\n        \n        // Skip expired entries\n        if (entry.ttl && entry.timestamp) {\n          const expiresAt = entry.timestamp + entry.ttl * 1000;\n          if (now > expiresAt) {\n            continue;\n          }\n        }\n\n        count++;\n        memoryUsage += key.length + value.length;\n      }\n    } catch (error) {\n      // Return partial stats if operation fails\n    }\n\n    const total = this.hits + this.misses;\n    const hitRate = total > 0 ? this.hits / total : 0;\n\n    return {\n      count,\n      hits: this.hits,\n      misses: this.misses,\n      hitRate,\n      memoryUsage,\n    };\n  }\n\n  /**\n   * Purge expired entries\n   */\n  async purgeExpired(): Promise<number> {\n    const now = Date.now();\n    let purged = 0;\n\n    try {\n      const toDelete: Buffer[] = [];\n\n      for await (const [key, value] of this.db.scanPrefix(this.prefix)) {\n        const entry: CacheEntry = JSON.parse(value.toString());\n        \n        if (entry.ttl && entry.timestamp) {\n          const expiresAt = entry.timestamp + entry.ttl * 1000;\n          if (now > expiresAt) {\n            toDelete.push(key);\n          }\n        }\n      }\n\n      for (const key of toDelete) {\n        await this.db.delete(key);\n        purged++;\n      }\n    } catch (error) {\n      // Return count so far\n      return purged;\n    }\n\n    return purged;\n  }\n}\n"]}
@@ -0,0 +1,97 @@
1
+ /**
2
+ * Context Query Builder for LLM Context Assembly
3
+ *
4
+ * Token-aware context assembly with priority-based truncation.
5
+ */
6
+ export declare enum ContextOutputFormat {
7
+ TOON = "toon",
8
+ JSON = "json",
9
+ MARKDOWN = "markdown"
10
+ }
11
+ export declare enum TruncationStrategy {
12
+ TAIL_DROP = "tail_drop",// Drop from end
13
+ HEAD_DROP = "head_drop",// Drop from beginning
14
+ PROPORTIONAL = "proportional"
15
+ }
16
+ export interface ContextResult {
17
+ text: string;
18
+ tokenCount: number;
19
+ sections: Array<{
20
+ name: string;
21
+ tokenCount: number;
22
+ truncated: boolean;
23
+ }>;
24
+ }
25
+ /**
26
+ * Context Query Builder for assembling LLM context
27
+ */
28
+ export declare class ContextQueryBuilder {
29
+ private sessionId?;
30
+ private tokenBudget;
31
+ private format;
32
+ private truncation;
33
+ private sections;
34
+ private currentSection?;
35
+ /**
36
+ * Set session ID for context
37
+ */
38
+ forSession(sessionId: string): this;
39
+ /**
40
+ * Set token budget
41
+ */
42
+ withBudget(tokens: number): this;
43
+ /**
44
+ * Set output format
45
+ */
46
+ setFormat(format: ContextOutputFormat): this;
47
+ /**
48
+ * Set truncation strategy
49
+ */
50
+ setTruncation(strategy: TruncationStrategy): this;
51
+ /**
52
+ * Add literal text section
53
+ */
54
+ literal(name: string, priority: number, text: string): this;
55
+ /**
56
+ * Start a new section
57
+ */
58
+ section(name: string, priority: number): this;
59
+ /**
60
+ * Add content to current section
61
+ */
62
+ get(path: string): this;
63
+ /**
64
+ * Add last N records query
65
+ */
66
+ last(n: number, table: string): this;
67
+ /**
68
+ * Add where equals condition
69
+ */
70
+ whereEq(field: string, value: any): this;
71
+ /**
72
+ * Add vector search
73
+ */
74
+ search(collection: string, embedding: string, k: number): this;
75
+ /**
76
+ * Add SQL query
77
+ */
78
+ sql(query: string): this;
79
+ /**
80
+ * Finish current section
81
+ */
82
+ done(): this;
83
+ /**
84
+ * Execute and build context
85
+ */
86
+ execute(): ContextResult;
87
+ private estimateTokens;
88
+ private truncateText;
89
+ private buildToonFormat;
90
+ private buildJsonFormat;
91
+ private buildMarkdownFormat;
92
+ }
93
+ /**
94
+ * Create a context query builder
95
+ */
96
+ export declare function createContextBuilder(): ContextQueryBuilder;
97
+ //# sourceMappingURL=context-builder.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"context-builder.d.ts","sourceRoot":"","sources":["../../src/context-builder.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,oBAAY,mBAAmB;IAC7B,IAAI,SAAS;IACb,IAAI,SAAS;IACb,QAAQ,aAAa;CACtB;AAED,oBAAY,kBAAkB;IAC5B,SAAS,cAAc,CAAQ,gBAAgB;IAC/C,SAAS,cAAc,CAAQ,sBAAsB;IACrD,YAAY,iBAAiB;CAC9B;AASD,MAAM,WAAW,aAAa;IAC5B,IAAI,EAAE,MAAM,CAAC;IACb,UAAU,EAAE,MAAM,CAAC;IACnB,QAAQ,EAAE,KAAK,CAAC;QAAE,IAAI,EAAE,MAAM,CAAC;QAAC,UAAU,EAAE,MAAM,CAAC;QAAC,SAAS,EAAE,OAAO,CAAA;KAAE,CAAC,CAAC;CAC3E;AAED;;GAEG;AACH,qBAAa,mBAAmB;IAC9B,OAAO,CAAC,SAAS,CAAC,CAAS;IAC3B,OAAO,CAAC,WAAW,CAAgB;IACnC,OAAO,CAAC,MAAM,CAAiD;IAC/D,OAAO,CAAC,UAAU,CAAoD;IACtE,OAAO,CAAC,QAAQ,CAAiB;IACjC,OAAO,CAAC,cAAc,CAAC,CAAU;IAEjC;;OAEG;IACH,UAAU,CAAC,SAAS,EAAE,MAAM,GAAG,IAAI;IAKnC;;OAEG;IACH,UAAU,CAAC,MAAM,EAAE,MAAM,GAAG,IAAI;IAKhC;;OAEG;IACH,SAAS,CAAC,MAAM,EAAE,mBAAmB,GAAG,IAAI;IAK5C;;OAEG;IACH,aAAa,CAAC,QAAQ,EAAE,kBAAkB,GAAG,IAAI;IAKjD;;OAEG;IACH,OAAO,CAAC,IAAI,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,GAAG,IAAI;IAW3D;;OAEG;IACH,OAAO,CAAC,IAAI,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,GAAG,IAAI;IAU7C;;OAEG;IACH,GAAG,CAAC,IAAI,EAAE,MAAM,GAAG,IAAI;IAQvB;;OAEG;IACH,IAAI,CAAC,CAAC,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,IAAI;IAQpC;;OAEG;IACH,OAAO,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,GAAG,GAAG,IAAI;IAQxC;;OAEG;IACH,MAAM,CAAC,UAAU,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM,GAAG,IAAI;IAQ9D;;OAEG;IACH,GAAG,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI;IAQxB;;OAEG;IACH,IAAI,IAAI,IAAI;IASZ;;OAEG;IACH,OAAO,IAAI,aAAa;IA2FxB,OAAO,CAAC,cAAc;IAKtB,OAAO,CAAC,YAAY;IAQpB,OAAO,CAAC,eAAe;IAYvB,OAAO,CAAC,eAAe;IAUvB,OAAO,CAAC,mBAAmB;CAY5B;AAED;;GAEG;AACH,wBAAgB,oBAAoB,IAAI,mBAAmB,CAE1D"}
@@ -99,7 +99,7 @@ export declare class Transaction {
99
99
  *
100
100
  * @example
101
101
  * ```typescript
102
- * import { Database } from '@sushanth/sochdb';
102
+ * import { Database } from '@sochdb/sochdb';
103
103
  *
104
104
  * // Open a database
105
105
  * const db = await Database.open('./my_database');
@@ -18,7 +18,7 @@ export interface EmbeddedDatabaseConfig {
18
18
  *
19
19
  * @example
20
20
  * ```typescript
21
- * import { EmbeddedDatabase } from '@sushanth/sochdb';
21
+ * import { EmbeddedDatabase } from '@sochdb/sochdb';
22
22
  *
23
23
  * const db = await EmbeddedDatabase.open('./mydb');
24
24
  * await db.put(Buffer.from('key'), Buffer.from('value'));
@@ -3,11 +3,31 @@
3
3
  *
4
4
  * @packageDocumentation
5
5
  */
6
+ /**
7
+ * Error codes matching Rust error codes.
8
+ */
9
+ export declare enum ErrorCode {
10
+ CONNECTION_FAILED = 1001,
11
+ CONNECTION_TIMEOUT = 1002,
12
+ CONNECTION_CLOSED = 1003,
13
+ PROTOCOL_ERROR = 1004,
14
+ TRANSACTION_ABORTED = 2001,
15
+ TRANSACTION_CONFLICT = 2002,
16
+ INTERNAL_ERROR = 9001,
17
+ STORAGE_ERROR = 9003,
18
+ DATABASE_LOCKED = 10001,
19
+ LOCK_TIMEOUT = 10002,
20
+ EPOCH_MISMATCH = 10003,
21
+ SPLIT_BRAIN = 10004,
22
+ STALE_LOCK = 10005
23
+ }
6
24
  /**
7
25
  * Base error class for all SochDB errors.
8
26
  */
9
27
  export declare class SochDBError extends Error {
10
- constructor(message: string);
28
+ readonly code: ErrorCode;
29
+ readonly remediation?: string;
30
+ constructor(message: string, code?: ErrorCode, remediation?: string);
11
31
  }
12
32
  /**
13
33
  * Error thrown when connection to the database fails.
@@ -33,4 +53,40 @@ export declare class ProtocolError extends SochDBError {
33
53
  export declare class DatabaseError extends SochDBError {
34
54
  constructor(message: string);
35
55
  }
56
+ /**
57
+ * Base class for lock-related errors.
58
+ */
59
+ export declare class LockError extends SochDBError {
60
+ constructor(message: string, code?: ErrorCode, remediation?: string);
61
+ }
62
+ /**
63
+ * Error thrown when database is locked by another process.
64
+ */
65
+ export declare class DatabaseLockedError extends LockError {
66
+ readonly path: string;
67
+ readonly holderPid?: number;
68
+ constructor(path: string, holderPid?: number);
69
+ }
70
+ /**
71
+ * Error thrown when timed out waiting for database lock.
72
+ */
73
+ export declare class LockTimeoutError extends LockError {
74
+ readonly path: string;
75
+ readonly timeoutSecs: number;
76
+ constructor(path: string, timeoutSecs: number);
77
+ }
78
+ /**
79
+ * Error thrown when WAL epoch mismatch detected (stale writer).
80
+ */
81
+ export declare class EpochMismatchError extends LockError {
82
+ readonly expected: number;
83
+ readonly actual: number;
84
+ constructor(expected: number, actual: number);
85
+ }
86
+ /**
87
+ * Error thrown when split-brain condition detected (multiple writers).
88
+ */
89
+ export declare class SplitBrainError extends LockError {
90
+ constructor(message?: string);
91
+ }
36
92
  //# sourceMappingURL=errors.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"errors.d.ts","sourceRoot":"","sources":["../../src/errors.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAUH;;GAEG;AACH,qBAAa,WAAY,SAAQ,KAAK;gBACxB,OAAO,EAAE,MAAM;CAK5B;AAED;;GAEG;AACH,qBAAa,eAAgB,SAAQ,WAAW;gBAClC,OAAO,EAAE,MAAM;CAK5B;AAED;;GAEG;AACH,qBAAa,gBAAiB,SAAQ,WAAW;gBACnC,OAAO,EAAE,MAAM;CAK5B;AAED;;GAEG;AACH,qBAAa,aAAc,SAAQ,WAAW;gBAChC,OAAO,EAAE,MAAM;CAK5B;AAED;;GAEG;AACH,qBAAa,aAAc,SAAQ,WAAW;gBAChC,OAAO,EAAE,MAAM;CAK5B"}
1
+ {"version":3,"file":"errors.d.ts","sourceRoot":"","sources":["../../src/errors.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAUH;;GAEG;AACH,oBAAY,SAAS;IAEnB,iBAAiB,OAAO;IACxB,kBAAkB,OAAO;IACzB,iBAAiB,OAAO;IACxB,cAAc,OAAO;IAGrB,mBAAmB,OAAO;IAC1B,oBAAoB,OAAO;IAG3B,cAAc,OAAO;IACrB,aAAa,OAAO;IAGpB,eAAe,QAAQ;IACvB,YAAY,QAAQ;IACpB,cAAc,QAAQ;IACtB,WAAW,QAAQ;IACnB,UAAU,QAAQ;CACnB;AAED;;GAEG;AACH,qBAAa,WAAY,SAAQ,KAAK;IACpC,SAAgB,IAAI,EAAE,SAAS,CAAC;IAChC,SAAgB,WAAW,CAAC,EAAE,MAAM,CAAC;gBAEzB,OAAO,EAAE,MAAM,EAAE,IAAI,GAAE,SAAoC,EAAE,WAAW,CAAC,EAAE,MAAM;CAO9F;AAED;;GAEG;AACH,qBAAa,eAAgB,SAAQ,WAAW;gBAClC,OAAO,EAAE,MAAM;CAK5B;AAED;;GAEG;AACH,qBAAa,gBAAiB,SAAQ,WAAW;gBACnC,OAAO,EAAE,MAAM;CAK5B;AAED;;GAEG;AACH,qBAAa,aAAc,SAAQ,WAAW;gBAChC,OAAO,EAAE,MAAM;CAK5B;AAED;;GAEG;AACH,qBAAa,aAAc,SAAQ,WAAW;gBAChC,OAAO,EAAE,MAAM;CAK5B;AAMD;;GAEG;AACH,qBAAa,SAAU,SAAQ,WAAW;gBAC5B,OAAO,EAAE,MAAM,EAAE,IAAI,GAAE,SAAqC,EAAE,WAAW,CAAC,EAAE,MAAM;CAK/F;AAED;;GAEG;AACH,qBAAa,mBAAoB,SAAQ,SAAS;IAChD,SAAgB,IAAI,EAAE,MAAM,CAAC;IAC7B,SAAgB,SAAS,CAAC,EAAE,MAAM,CAAC;gBAEvB,IAAI,EAAE,MAAM,EAAE,SAAS,CAAC,EAAE,MAAM;CAU7C;AAED;;GAEG;AACH,qBAAa,gBAAiB,SAAQ,SAAS;IAC7C,SAAgB,IAAI,EAAE,MAAM,CAAC;IAC7B,SAAgB,WAAW,EAAE,MAAM,CAAC;gBAExB,IAAI,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM;CAW9C;AAED;;GAEG;AACH,qBAAa,kBAAmB,SAAQ,SAAS;IAC/C,SAAgB,QAAQ,EAAE,MAAM,CAAC;IACjC,SAAgB,MAAM,EAAE,MAAM,CAAC;gBAEnB,QAAQ,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM;CAW7C;AAED;;GAEG;AACH,qBAAa,eAAgB,SAAQ,SAAS;gBAChC,OAAO,GAAE,MAAwD;CAS9E"}
@@ -35,16 +35,26 @@
35
35
  * await client.putKv('key', Buffer.from('value'));
36
36
  * ```
37
37
  */
38
- export declare const VERSION = "0.4.0";
38
+ export declare const VERSION = "0.4.1";
39
39
  export { EmbeddedDatabase, EmbeddedDatabaseConfig } from './embedded';
40
40
  export { EmbeddedTransaction } from './embedded';
41
41
  export { EmbeddedDatabase as Database } from './embedded';
42
+ export { Namespace, Collection, DistanceMetric, NamespaceNotFoundError, NamespaceExistsError, CollectionNotFoundError, CollectionExistsError, } from './namespace';
43
+ export type { NamespaceConfig, CollectionConfig, SearchRequest, SearchResult as NamespaceSearchResult, } from './namespace';
44
+ export { PriorityQueue, TaskState, createQueue, } from './queue';
45
+ export type { QueueConfig, QueueKey, Task, QueueStats, } from './queue';
46
+ export { SemanticCache, } from './semantic-cache';
47
+ export type { CacheEntry, CacheHit, CacheStats, } from './semantic-cache';
48
+ export { ContextQueryBuilder, ContextOutputFormat, TruncationStrategy, createContextBuilder, } from './context-builder';
49
+ export type { ContextResult, } from './context-builder';
50
+ export { ExtractionPipeline, Consolidator, HybridRetriever, AllowedSet, NamespacePolicy, } from './memory';
51
+ export type { Entity, Relation, Assertion, RawAssertion, CanonicalFact, ExtractionResult, ExtractionSchema, ConsolidationConfig, RetrievalConfig, RetrievalResult, RetrievalResponse, NamespaceGrant, } from './memory';
42
52
  export { SochDBClient } from './grpc-client';
43
53
  export type { SearchResult, Document, GraphNode, GraphEdge, } from './grpc-client';
44
54
  export { IpcClient } from './ipc-client';
45
55
  export { WireFormat, ContextFormat, CanonicalFormat, FormatCapabilities, FormatConversionError, } from './format';
46
56
  export { Query } from './query';
47
57
  export type { QueryResult } from './query';
48
- export { SochDBError, ConnectionError, TransactionError, ProtocolError, DatabaseError, } from './errors';
58
+ export { SochDBError, ConnectionError, TransactionError, ProtocolError, DatabaseError, ErrorCode, LockError, DatabaseLockedError, LockTimeoutError, EpochMismatchError, SplitBrainError, } from './errors';
49
59
  export { SochDBClient as GrpcClient } from './grpc-client';
50
60
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAoCG;AAGH,eAAO,MAAM,OAAO,UAAU,CAAC;AAG/B,OAAO,EAAE,gBAAgB,EAAE,sBAAsB,EAAE,MAAM,YAAY,CAAC;AACtE,OAAO,EAAE,mBAAmB,EAAE,MAAM,YAAY,CAAC;AAGjD,OAAO,EAAE,gBAAgB,IAAI,QAAQ,EAAE,MAAM,YAAY,CAAC;AAG1D,OAAO,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC;AAC7C,YAAY,EACV,YAAY,EACZ,QAAQ,EACR,SAAS,EACT,SAAS,GACV,MAAM,eAAe,CAAC;AAEvB,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAGzC,OAAO,EACL,UAAU,EACV,aAAa,EACb,eAAe,EACf,kBAAkB,EAClB,qBAAqB,GACtB,MAAM,UAAU,CAAC;AAGlB,OAAO,EAAE,KAAK,EAAE,MAAM,SAAS,CAAC;AAChC,YAAY,EAAE,WAAW,EAAE,MAAM,SAAS,CAAC;AAE3C,OAAO,EACL,WAAW,EACX,eAAe,EACf,gBAAgB,EAChB,aAAa,EACb,aAAa,GACd,MAAM,UAAU,CAAC;AAGlB,OAAO,EAAE,YAAY,IAAI,UAAU,EAAE,MAAM,eAAe,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAoCG;AAGH,eAAO,MAAM,OAAO,UAAU,CAAC;AAG/B,OAAO,EAAE,gBAAgB,EAAE,sBAAsB,EAAE,MAAM,YAAY,CAAC;AACtE,OAAO,EAAE,mBAAmB,EAAE,MAAM,YAAY,CAAC;AAGjD,OAAO,EAAE,gBAAgB,IAAI,QAAQ,EAAE,MAAM,YAAY,CAAC;AAG1D,OAAO,EACL,SAAS,EACT,UAAU,EACV,cAAc,EACd,sBAAsB,EACtB,oBAAoB,EACpB,uBAAuB,EACvB,qBAAqB,GACtB,MAAM,aAAa,CAAC;AACrB,YAAY,EACV,eAAe,EACf,gBAAgB,EAChB,aAAa,EACb,YAAY,IAAI,qBAAqB,GACtC,MAAM,aAAa,CAAC;AAGrB,OAAO,EACL,aAAa,EACb,SAAS,EACT,WAAW,GACZ,MAAM,SAAS,CAAC;AACjB,YAAY,EACV,WAAW,EACX,QAAQ,EACR,IAAI,EACJ,UAAU,GACX,MAAM,SAAS,CAAC;AAGjB,OAAO,EACL,aAAa,GACd,MAAM,kBAAkB,CAAC;AAC1B,YAAY,EACV,UAAU,EACV,QAAQ,EACR,UAAU,GACX,MAAM,kBAAkB,CAAC;AAG1B,OAAO,EACL,mBAAmB,EACnB,mBAAmB,EACnB,kBAAkB,EAClB,oBAAoB,GACrB,MAAM,mBAAmB,CAAC;AAC3B,YAAY,EACV,aAAa,GACd,MAAM,mBAAmB,CAAC;AAG3B,OAAO,EACL,kBAAkB,EAClB,YAAY,EACZ,eAAe,EACf,UAAU,EACV,eAAe,GAChB,MAAM,UAAU,CAAC;AAClB,YAAY,EACV,MAAM,EACN,QAAQ,EACR,SAAS,EACT,YAAY,EACZ,aAAa,EACb,gBAAgB,EAChB,gBAAgB,EAChB,mBAAmB,EACnB,eAAe,EACf,eAAe,EACf,iBAAiB,EACjB,cAAc,GACf,MAAM,UAAU,CAAC;AAGlB,OAAO,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC;AAC7C,YAAY,EACV,YAAY,EACZ,QAAQ,EACR,SAAS,EACT,SAAS,GACV,MAAM,eAAe,CAAC;AAEvB,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAGzC,OAAO,EACL,UAAU,EACV,aAAa,EACb,eAAe,EACf,kBAAkB,EAClB,qBAAqB,GACtB,MAAM,UAAU,CAAC;AAGlB,OAAO,EAAE,KAAK,EAAE,MAAM,SAAS,CAAC;AAChC,YAAY,EAAE,WAAW,EAAE,MAAM,SAAS,CAAC;AAE3C,OAAO,EACL,WAAW,EACX,eAAe,EACf,gBAAgB,EAChB,aAAa,EACb,aAAa,EAEb,SAAS,EACT,SAAS,EACT,mBAAmB,EACnB,gBAAgB,EAChB,kBAAkB,EAClB,eAAe,GAChB,MAAM,UAAU,CAAC;AAGlB,OAAO,EAAE,YAAY,IAAI,UAAU,EAAE,MAAM,eAAe,CAAC"}
@@ -51,7 +51,7 @@ export interface IpcClientConfig {
51
51
  *
52
52
  * @example
53
53
  * ```typescript
54
- * import { IpcClient } from '@sushanth/sochdb';
54
+ * import { IpcClient } from '@sochdb/sochdb';
55
55
  *
56
56
  * const client = await IpcClient.connect('/tmp/sochdb.sock');
57
57
  *
@@ -0,0 +1,66 @@
1
+ /**
2
+ * Consolidator for Memory System
3
+ *
4
+ * Event-sourced consolidation with append-only events and derived canonical facts.
5
+ */
6
+ import { EmbeddedDatabase } from '../embedded';
7
+ import { RawAssertion, CanonicalFact, ConsolidationConfig } from './types';
8
+ /**
9
+ * Consolidator for managing facts
10
+ */
11
+ export declare class Consolidator {
12
+ private db;
13
+ private namespace;
14
+ private config;
15
+ private prefix;
16
+ constructor(db: EmbeddedDatabase, namespace: string, config?: ConsolidationConfig);
17
+ /**
18
+ * Create consolidator from database
19
+ */
20
+ static fromDatabase(db: EmbeddedDatabase, namespace: string, config?: ConsolidationConfig): Consolidator;
21
+ /**
22
+ * Add a raw assertion (immutable event)
23
+ */
24
+ add(assertion: RawAssertion): Promise<string>;
25
+ /**
26
+ * Add assertion with contradiction handling
27
+ */
28
+ addWithContradiction(newAssertion: RawAssertion, contradicts: string[]): Promise<string>;
29
+ /**
30
+ * Run consolidation to update canonical view
31
+ */
32
+ consolidate(): Promise<number>;
33
+ /**
34
+ * Get canonical facts
35
+ */
36
+ getCanonicalFacts(): Promise<CanonicalFact[]>;
37
+ /**
38
+ * Explain provenance of a fact
39
+ */
40
+ explain(factId: string): Promise<{
41
+ evidenceCount: number;
42
+ sources: string[];
43
+ confidence: number;
44
+ }>;
45
+ /**
46
+ * Get all raw assertions
47
+ */
48
+ private getAllAssertions;
49
+ /**
50
+ * Get all contradictions
51
+ */
52
+ private getContradictions;
53
+ /**
54
+ * Merge confidence from multiple assertions
55
+ */
56
+ private mergeConfidence;
57
+ /**
58
+ * Generate deterministic assertion ID
59
+ */
60
+ private generateAssertionId;
61
+ /**
62
+ * Generate deterministic canonical fact ID
63
+ */
64
+ private generateCanonicalId;
65
+ }
66
+ //# sourceMappingURL=consolidation.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"consolidation.d.ts","sourceRoot":"","sources":["../../../src/memory/consolidation.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,EAAE,gBAAgB,EAAE,MAAM,aAAa,CAAC;AAC/C,OAAO,EACL,YAAY,EACZ,aAAa,EACb,mBAAmB,EACpB,MAAM,SAAS,CAAC;AAGjB;;GAEG;AACH,qBAAa,YAAY;IACvB,OAAO,CAAC,EAAE,CAAmB;IAC7B,OAAO,CAAC,SAAS,CAAS;IAC1B,OAAO,CAAC,MAAM,CAAsB;IACpC,OAAO,CAAC,MAAM,CAAS;gBAEX,EAAE,EAAE,gBAAgB,EAAE,SAAS,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,mBAAmB;IAWjF;;OAEG;IACH,MAAM,CAAC,YAAY,CAAC,EAAE,EAAE,gBAAgB,EAAE,SAAS,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,mBAAmB,GAAG,YAAY;IAIxG;;OAEG;IACG,GAAG,CAAC,SAAS,EAAE,YAAY,GAAG,OAAO,CAAC,MAAM,CAAC;IAgBnD;;OAEG;IACG,oBAAoB,CAAC,YAAY,EAAE,YAAY,EAAE,WAAW,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,MAAM,CAAC;IAmB9F;;OAEG;IACG,WAAW,IAAI,OAAO,CAAC,MAAM,CAAC;IA0DpC;;OAEG;IACG,iBAAiB,IAAI,OAAO,CAAC,aAAa,EAAE,CAAC;IAWnD;;OAEG;IACG,OAAO,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC;QAAE,aAAa,EAAE,MAAM,CAAC;QAAC,OAAO,EAAE,MAAM,EAAE,CAAC;QAAC,UAAU,EAAE,MAAM,CAAA;KAAE,CAAC;IAgBxG;;OAEG;YACW,gBAAgB;IAW9B;;OAEG;YACW,iBAAiB;IAW/B;;OAEG;IACH,OAAO,CAAC,eAAe;IAcvB;;OAEG;IACH,OAAO,CAAC,mBAAmB;IAO3B;;OAEG;IACH,OAAO,CAAC,mBAAmB;CAM5B"}
@@ -0,0 +1,82 @@
1
+ /**
2
+ * Extraction Pipeline for Memory System
3
+ *
4
+ * Compiles LLM outputs into typed, validated facts (Entity, Relation, Assertion).
5
+ */
6
+ import { EmbeddedDatabase } from '../embedded';
7
+ import { Entity, Relation, Assertion, ExtractionResult, ExtractionSchema } from './types';
8
+ /**
9
+ * Extractor function type - user provides this to call their LLM
10
+ */
11
+ export type ExtractorFunction = (text: string) => Promise<{
12
+ entities?: Array<{
13
+ name: string;
14
+ entity_type: string;
15
+ properties?: Record<string, any>;
16
+ confidence?: number;
17
+ }>;
18
+ relations?: Array<{
19
+ from_entity: string;
20
+ relation_type: string;
21
+ to_entity: string;
22
+ properties?: Record<string, any>;
23
+ confidence?: number;
24
+ }>;
25
+ assertions?: Array<{
26
+ subject: string;
27
+ predicate: string;
28
+ object: string;
29
+ confidence?: number;
30
+ }>;
31
+ }>;
32
+ /**
33
+ * Extraction Pipeline
34
+ */
35
+ export declare class ExtractionPipeline {
36
+ private db;
37
+ private namespace;
38
+ private schema?;
39
+ private prefix;
40
+ constructor(db: EmbeddedDatabase, namespace: string, schema?: ExtractionSchema);
41
+ /**
42
+ * Create pipeline from database
43
+ */
44
+ static fromDatabase(db: EmbeddedDatabase, namespace: string, schema?: ExtractionSchema): ExtractionPipeline;
45
+ /**
46
+ * Extract entities and relations from text
47
+ */
48
+ extract(text: string, extractor: ExtractorFunction): Promise<ExtractionResult>;
49
+ /**
50
+ * Extract and immediately commit to database
51
+ */
52
+ extractAndCommit(text: string, extractor: ExtractorFunction): Promise<ExtractionResult>;
53
+ /**
54
+ * Commit extraction result to database
55
+ */
56
+ commit(result: ExtractionResult): Promise<void>;
57
+ /**
58
+ * Get all entities
59
+ */
60
+ getEntities(): Promise<Entity[]>;
61
+ /**
62
+ * Get all relations
63
+ */
64
+ getRelations(): Promise<Relation[]>;
65
+ /**
66
+ * Get all assertions
67
+ */
68
+ getAssertions(): Promise<Assertion[]>;
69
+ /**
70
+ * Generate deterministic entity ID
71
+ */
72
+ private generateEntityId;
73
+ /**
74
+ * Generate deterministic relation ID
75
+ */
76
+ private generateRelationId;
77
+ /**
78
+ * Generate deterministic assertion ID
79
+ */
80
+ private generateAssertionId;
81
+ }
82
+ //# sourceMappingURL=extraction.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"extraction.d.ts","sourceRoot":"","sources":["../../../src/memory/extraction.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,EAAE,gBAAgB,EAAE,MAAM,aAAa,CAAC;AAC/C,OAAO,EACL,MAAM,EACN,QAAQ,EACR,SAAS,EACT,gBAAgB,EAChB,gBAAgB,EACjB,MAAM,SAAS,CAAC;AAGjB;;GAEG;AACH,MAAM,MAAM,iBAAiB,GAAG,CAAC,IAAI,EAAE,MAAM,KAAK,OAAO,CAAC;IACxD,QAAQ,CAAC,EAAE,KAAK,CAAC;QAAE,IAAI,EAAE,MAAM,CAAC;QAAC,WAAW,EAAE,MAAM,CAAC;QAAC,UAAU,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;QAAC,UAAU,CAAC,EAAE,MAAM,CAAA;KAAE,CAAC,CAAC;IAC/G,SAAS,CAAC,EAAE,KAAK,CAAC;QAAE,WAAW,EAAE,MAAM,CAAC;QAAC,aAAa,EAAE,MAAM,CAAC;QAAC,SAAS,EAAE,MAAM,CAAC;QAAC,UAAU,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;QAAC,UAAU,CAAC,EAAE,MAAM,CAAA;KAAE,CAAC,CAAC;IAC5I,UAAU,CAAC,EAAE,KAAK,CAAC;QAAE,OAAO,EAAE,MAAM,CAAC;QAAC,SAAS,EAAE,MAAM,CAAC;QAAC,MAAM,EAAE,MAAM,CAAC;QAAC,UAAU,CAAC,EAAE,MAAM,CAAA;KAAE,CAAC,CAAC;CACjG,CAAC,CAAC;AAEH;;GAEG;AACH,qBAAa,kBAAkB;IAC7B,OAAO,CAAC,EAAE,CAAmB;IAC7B,OAAO,CAAC,SAAS,CAAS;IAC1B,OAAO,CAAC,MAAM,CAAC,CAAmB;IAClC,OAAO,CAAC,MAAM,CAAS;gBAEX,EAAE,EAAE,gBAAgB,EAAE,SAAS,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,gBAAgB;IAO9E;;OAEG;IACH,MAAM,CAAC,YAAY,CAAC,EAAE,EAAE,gBAAgB,EAAE,SAAS,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,gBAAgB,GAAG,kBAAkB;IAI3G;;OAEG;IACG,OAAO,CAAC,IAAI,EAAE,MAAM,EAAE,SAAS,EAAE,iBAAiB,GAAG,OAAO,CAAC,gBAAgB,CAAC;IAwEpF;;OAEG;IACG,gBAAgB,CAAC,IAAI,EAAE,MAAM,EAAE,SAAS,EAAE,iBAAiB,GAAG,OAAO,CAAC,gBAAgB,CAAC;IAM7F;;OAEG;IACG,MAAM,CAAC,MAAM,EAAE,gBAAgB,GAAG,OAAO,CAAC,IAAI,CAAC;IAoBrD;;OAEG;IACG,WAAW,IAAI,OAAO,CAAC,MAAM,EAAE,CAAC;IAWtC;;OAEG;IACG,YAAY,IAAI,OAAO,CAAC,QAAQ,EAAE,CAAC;IAWzC;;OAEG;IACG,aAAa,IAAI,OAAO,CAAC,SAAS,EAAE,CAAC;IAW3C;;OAEG;IACH,OAAO,CAAC,gBAAgB;IAOxB;;OAEG;IACH,OAAO,CAAC,kBAAkB;IAO1B;;OAEG;IACH,OAAO,CAAC,mBAAmB;CAM5B"}