@sochdb/sochdb 0.4.0 → 0.4.2
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/README.md +416 -34
- package/_bin/aarch64-apple-darwin/libsochdb_storage.dylib +0 -0
- package/_bin/aarch64-apple-darwin/sochdb-bulk +0 -0
- package/_bin/aarch64-apple-darwin/sochdb-grpc-server +0 -0
- package/_bin/aarch64-apple-darwin/sochdb-server +0 -0
- package/_bin/x86_64-pc-windows-msvc/sochdb-bulk.exe +0 -0
- package/_bin/x86_64-pc-windows-msvc/sochdb-grpc-server.exe +0 -0
- package/_bin/x86_64-pc-windows-msvc/sochdb_storage.dll +0 -0
- package/_bin/x86_64-unknown-linux-gnu/libsochdb_storage.so +0 -0
- package/_bin/x86_64-unknown-linux-gnu/sochdb-bulk +0 -0
- package/_bin/x86_64-unknown-linux-gnu/sochdb-grpc-server +0 -0
- package/_bin/x86_64-unknown-linux-gnu/sochdb-server +0 -0
- package/bin/sochdb-bulk.js +1 -1
- package/bin/sochdb-grpc-server.js +1 -1
- package/bin/sochdb-server.js +1 -1
- package/dist/cjs/context-builder.js +280 -0
- package/dist/cjs/database.js +2 -2
- package/dist/cjs/embedded/database.js +2 -2
- package/dist/cjs/embedded/ffi/hnsw-bindings.js +295 -0
- package/dist/cjs/embedded/ffi/library-finder.js +10 -3
- package/dist/cjs/embedded/index.js +5 -2
- package/dist/cjs/errors.js +99 -7
- package/dist/cjs/index.js +46 -6
- package/dist/cjs/ipc-client.js +2 -2
- package/dist/cjs/memory/consolidation.js +202 -0
- package/dist/cjs/memory/extraction.js +181 -0
- package/dist/cjs/memory/index.js +26 -0
- package/dist/cjs/memory/retrieval.js +232 -0
- package/dist/cjs/memory/types.js +69 -0
- package/dist/cjs/namespace.js +255 -0
- package/dist/cjs/queue.js +289 -0
- package/dist/cjs/semantic-cache.js +220 -0
- package/dist/esm/context-builder.js +280 -0
- package/dist/esm/database.js +2 -2
- package/dist/esm/embedded/database.js +2 -2
- package/dist/esm/embedded/ffi/hnsw-bindings.js +316 -0
- package/dist/esm/embedded/ffi/library-finder.js +10 -3
- package/dist/esm/embedded/index.js +5 -2
- package/dist/esm/errors.js +107 -7
- package/dist/esm/index.js +46 -6
- package/dist/esm/ipc-client.js +2 -2
- package/dist/esm/memory/consolidation.js +206 -0
- package/dist/esm/memory/extraction.js +185 -0
- package/dist/esm/memory/index.js +26 -0
- package/dist/esm/memory/retrieval.js +243 -0
- package/dist/esm/memory/types.js +72 -0
- package/dist/esm/namespace.js +262 -0
- package/dist/esm/queue.js +291 -0
- package/dist/esm/semantic-cache.js +223 -0
- package/dist/types/context-builder.d.ts +97 -0
- package/dist/types/context-builder.d.ts.map +1 -0
- package/dist/types/database.d.ts +1 -1
- package/dist/types/embedded/database.d.ts +1 -1
- package/dist/types/embedded/ffi/hnsw-bindings.d.ts +90 -0
- package/dist/types/embedded/ffi/hnsw-bindings.d.ts.map +1 -0
- package/dist/types/embedded/ffi/library-finder.d.ts.map +1 -1
- package/dist/types/embedded/index.d.ts +1 -0
- package/dist/types/embedded/index.d.ts.map +1 -1
- package/dist/types/errors.d.ts +57 -1
- package/dist/types/errors.d.ts.map +1 -1
- package/dist/types/index.d.ts +15 -3
- package/dist/types/index.d.ts.map +1 -1
- package/dist/types/ipc-client.d.ts +1 -1
- package/dist/types/memory/consolidation.d.ts +66 -0
- package/dist/types/memory/consolidation.d.ts.map +1 -0
- package/dist/types/memory/extraction.d.ts +82 -0
- package/dist/types/memory/extraction.d.ts.map +1 -0
- package/dist/types/memory/index.d.ts +10 -0
- package/dist/types/memory/index.d.ts.map +1 -0
- package/dist/types/memory/retrieval.d.ts +46 -0
- package/dist/types/memory/retrieval.d.ts.map +1 -0
- package/dist/types/memory/types.d.ts +147 -0
- package/dist/types/memory/types.d.ts.map +1 -0
- package/dist/types/namespace.d.ts +129 -0
- package/dist/types/namespace.d.ts.map +1 -0
- package/dist/types/queue.d.ts +120 -0
- package/dist/types/queue.d.ts.map +1 -0
- package/dist/types/semantic-cache.d.ts +84 -0
- package/dist/types/semantic-cache.d.ts.map +1 -0
- 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"}
|
package/dist/types/database.d.ts
CHANGED
|
@@ -99,7 +99,7 @@ export declare class Transaction {
|
|
|
99
99
|
*
|
|
100
100
|
* @example
|
|
101
101
|
* ```typescript
|
|
102
|
-
* import { Database } from '@
|
|
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 '@
|
|
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'));
|
|
@@ -0,0 +1,90 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* HNSW Vector Index FFI Bindings
|
|
3
|
+
*
|
|
4
|
+
* Native vector search using HNSW (Hierarchical Navigable Small World) algorithm.
|
|
5
|
+
*
|
|
6
|
+
* @see sochdb-index/src/ffi.rs
|
|
7
|
+
*/
|
|
8
|
+
export interface SearchResult {
|
|
9
|
+
id: string;
|
|
10
|
+
distance: number;
|
|
11
|
+
}
|
|
12
|
+
export interface HnswConfig {
|
|
13
|
+
dimension: number;
|
|
14
|
+
maxConnections?: number;
|
|
15
|
+
efConstruction?: number;
|
|
16
|
+
efSearch?: number;
|
|
17
|
+
}
|
|
18
|
+
export declare class HnswBindings {
|
|
19
|
+
private static instance;
|
|
20
|
+
private lib;
|
|
21
|
+
hnsw_new: any;
|
|
22
|
+
hnsw_free: any;
|
|
23
|
+
hnsw_insert: any;
|
|
24
|
+
hnsw_insert_batch: any;
|
|
25
|
+
hnsw_insert_flat: any;
|
|
26
|
+
hnsw_insert_batch_flat: any;
|
|
27
|
+
hnsw_search: any;
|
|
28
|
+
hnsw_search_fast: any;
|
|
29
|
+
hnsw_search_ultra: any;
|
|
30
|
+
hnsw_len: any;
|
|
31
|
+
hnsw_dimension: any;
|
|
32
|
+
hnsw_set_ef_search: any;
|
|
33
|
+
hnsw_get_ef_search: any;
|
|
34
|
+
hnsw_build_flat_cache: any;
|
|
35
|
+
private constructor();
|
|
36
|
+
static getInstance(): HnswBindings;
|
|
37
|
+
}
|
|
38
|
+
/**
|
|
39
|
+
* High-level HNSW Index wrapper
|
|
40
|
+
*/
|
|
41
|
+
export declare class HnswIndex {
|
|
42
|
+
private ptr;
|
|
43
|
+
private bindings;
|
|
44
|
+
private _dimension;
|
|
45
|
+
private _efSearch;
|
|
46
|
+
constructor(config: HnswConfig);
|
|
47
|
+
/**
|
|
48
|
+
* Insert a single vector
|
|
49
|
+
*/
|
|
50
|
+
insert(id: string, vector: number[]): void;
|
|
51
|
+
/**
|
|
52
|
+
* Insert multiple vectors in batch (faster)
|
|
53
|
+
*/
|
|
54
|
+
insertBatch(ids: string[], vectors: number[][]): void;
|
|
55
|
+
/**
|
|
56
|
+
* Search for k nearest neighbors
|
|
57
|
+
*/
|
|
58
|
+
search(queryVector: number[], k: number, fast?: boolean): SearchResult[];
|
|
59
|
+
/**
|
|
60
|
+
* Ultra-fast search with minimal ef_search
|
|
61
|
+
*/
|
|
62
|
+
searchUltra(queryVector: number[], k: number): SearchResult[];
|
|
63
|
+
/**
|
|
64
|
+
* Get number of vectors in index
|
|
65
|
+
*/
|
|
66
|
+
get length(): number;
|
|
67
|
+
/**
|
|
68
|
+
* Get vector dimension
|
|
69
|
+
*/
|
|
70
|
+
get dimension(): number;
|
|
71
|
+
/**
|
|
72
|
+
* Set ef_search parameter (controls search quality vs speed)
|
|
73
|
+
*/
|
|
74
|
+
set efSearch(value: number);
|
|
75
|
+
/**
|
|
76
|
+
* Get ef_search parameter
|
|
77
|
+
*/
|
|
78
|
+
get efSearch(): number;
|
|
79
|
+
/**
|
|
80
|
+
* Build flat cache for faster searches
|
|
81
|
+
*/
|
|
82
|
+
buildFlatCache(): void;
|
|
83
|
+
/**
|
|
84
|
+
* Free native resources
|
|
85
|
+
*/
|
|
86
|
+
close(): void;
|
|
87
|
+
private stringToId;
|
|
88
|
+
private idToString;
|
|
89
|
+
}
|
|
90
|
+
//# sourceMappingURL=hnsw-bindings.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"hnsw-bindings.d.ts","sourceRoot":"","sources":["../../../../src/embedded/ffi/hnsw-bindings.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAeH,MAAM,WAAW,YAAY;IACzB,EAAE,EAAE,MAAM,CAAC;IACX,QAAQ,EAAE,MAAM,CAAC;CACpB;AAED,MAAM,WAAW,UAAU;IACvB,SAAS,EAAE,MAAM,CAAC;IAClB,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,QAAQ,CAAC,EAAE,MAAM,CAAC;CACrB;AAED,qBAAa,YAAY;IACrB,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAe;IACtC,OAAO,CAAC,GAAG,CAAM;IAGV,QAAQ,EAAE,GAAG,CAAC;IACd,SAAS,EAAE,GAAG,CAAC;IACf,WAAW,EAAE,GAAG,CAAC;IACjB,iBAAiB,EAAE,GAAG,CAAC;IACvB,gBAAgB,EAAE,GAAG,CAAC;IACtB,sBAAsB,EAAE,GAAG,CAAC;IAC5B,WAAW,EAAE,GAAG,CAAC;IACjB,gBAAgB,EAAE,GAAG,CAAC;IACtB,iBAAiB,EAAE,GAAG,CAAC;IACvB,QAAQ,EAAE,GAAG,CAAC;IACd,cAAc,EAAE,GAAG,CAAC;IACpB,kBAAkB,EAAE,GAAG,CAAC;IACxB,kBAAkB,EAAE,GAAG,CAAC;IACxB,qBAAqB,EAAE,GAAG,CAAC;IAElC,OAAO;WAuFO,WAAW,IAAI,YAAY;CAM5C;AAED;;GAEG;AACH,qBAAa,SAAS;IAClB,OAAO,CAAC,GAAG,CAAM;IACjB,OAAO,CAAC,QAAQ,CAAe;IAC/B,OAAO,CAAC,UAAU,CAAS;IAC3B,OAAO,CAAC,SAAS,CAAS;gBAEd,MAAM,EAAE,UAAU;IAmB9B;;OAEG;IACH,MAAM,CAAC,EAAE,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,GAAG,IAAI;IAgB1C;;OAEG;IACH,WAAW,CAAC,GAAG,EAAE,MAAM,EAAE,EAAE,OAAO,EAAE,MAAM,EAAE,EAAE,GAAG,IAAI;IAmCrD;;OAEG;IACH,MAAM,CAAC,WAAW,EAAE,MAAM,EAAE,EAAE,CAAC,EAAE,MAAM,EAAE,IAAI,GAAE,OAAe,GAAG,YAAY,EAAE;IAgC/E;;OAEG;IACH,WAAW,CAAC,WAAW,EAAE,MAAM,EAAE,EAAE,CAAC,EAAE,MAAM,GAAG,YAAY,EAAE;IA6B7D;;OAEG;IACH,IAAI,MAAM,IAAI,MAAM,CAEnB;IAED;;OAEG;IACH,IAAI,SAAS,IAAI,MAAM,CAEtB;IAED;;OAEG;IACH,IAAI,QAAQ,CAAC,KAAK,EAAE,MAAM,EAGzB;IAED;;OAEG;IACH,IAAI,QAAQ,IAAI,MAAM,CAErB;IAED;;OAEG;IACH,cAAc,IAAI,IAAI;IAOtB;;OAEG;IACH,KAAK,IAAI,IAAI;IAQb,OAAO,CAAC,UAAU;IAUlB,OAAO,CAAC,UAAU;CAIrB"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"library-finder.d.ts","sourceRoot":"","sources":["../../../../src/embedded/ffi/library-finder.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAyCH;;;;;;;;GAQG;AACH,wBAAgB,WAAW,IAAI,MAAM,
|
|
1
|
+
{"version":3,"file":"library-finder.d.ts","sourceRoot":"","sources":["../../../../src/embedded/ffi/library-finder.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAyCH;;;;;;;;GAQG;AACH,wBAAgB,WAAW,IAAI,MAAM,CAiEpC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/embedded/index.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,EAAE,gBAAgB,EAAE,sBAAsB,EAAE,MAAM,YAAY,CAAC;AACtE,OAAO,EAAE,mBAAmB,EAAE,MAAM,eAAe,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/embedded/index.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,EAAE,gBAAgB,EAAE,sBAAsB,EAAE,MAAM,YAAY,CAAC;AACtE,OAAO,EAAE,mBAAmB,EAAE,MAAM,eAAe,CAAC;AACpD,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,YAAY,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC"}
|
package/dist/types/errors.d.ts
CHANGED
|
@@ -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
|
-
|
|
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;
|
|
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"}
|
package/dist/types/index.d.ts
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
/**
|
|
2
|
-
* SochDB Node.js SDK v0.4.
|
|
2
|
+
* SochDB Node.js SDK v0.4.2
|
|
3
3
|
*
|
|
4
4
|
* Dual-mode architecture: Embedded (FFI) + Server (gRPC/IPC)
|
|
5
5
|
*
|
|
@@ -35,16 +35,28 @@
|
|
|
35
35
|
* await client.putKv('key', Buffer.from('value'));
|
|
36
36
|
* ```
|
|
37
37
|
*/
|
|
38
|
-
export declare const VERSION = "0.4.
|
|
38
|
+
export declare const VERSION = "0.4.2";
|
|
39
39
|
export { EmbeddedDatabase, EmbeddedDatabaseConfig } from './embedded';
|
|
40
40
|
export { EmbeddedTransaction } from './embedded';
|
|
41
|
+
export { HnswIndex, HnswConfig, HnswBindings } from './embedded';
|
|
42
|
+
export { SearchResult as HnswSearchResult } from './embedded';
|
|
41
43
|
export { EmbeddedDatabase as Database } from './embedded';
|
|
44
|
+
export { Namespace, Collection, DistanceMetric, NamespaceNotFoundError, NamespaceExistsError, CollectionNotFoundError, CollectionExistsError, } from './namespace';
|
|
45
|
+
export type { NamespaceConfig, CollectionConfig, SearchRequest, SearchResult as NamespaceSearchResult, } from './namespace';
|
|
46
|
+
export { PriorityQueue, TaskState, createQueue, } from './queue';
|
|
47
|
+
export type { QueueConfig, QueueKey, Task, QueueStats, } from './queue';
|
|
48
|
+
export { SemanticCache, } from './semantic-cache';
|
|
49
|
+
export type { CacheEntry, CacheHit, CacheStats, } from './semantic-cache';
|
|
50
|
+
export { ContextQueryBuilder, ContextOutputFormat, TruncationStrategy, createContextBuilder, } from './context-builder';
|
|
51
|
+
export type { ContextResult, } from './context-builder';
|
|
52
|
+
export { ExtractionPipeline, Consolidator, HybridRetriever, AllowedSet, NamespacePolicy, } from './memory';
|
|
53
|
+
export type { Entity, Relation, Assertion, RawAssertion, CanonicalFact, ExtractionResult, ExtractionSchema, ConsolidationConfig, RetrievalConfig, RetrievalResult, RetrievalResponse, NamespaceGrant, } from './memory';
|
|
42
54
|
export { SochDBClient } from './grpc-client';
|
|
43
55
|
export type { SearchResult, Document, GraphNode, GraphEdge, } from './grpc-client';
|
|
44
56
|
export { IpcClient } from './ipc-client';
|
|
45
57
|
export { WireFormat, ContextFormat, CanonicalFormat, FormatCapabilities, FormatConversionError, } from './format';
|
|
46
58
|
export { Query } from './query';
|
|
47
59
|
export type { QueryResult } from './query';
|
|
48
|
-
export { SochDBError, ConnectionError, TransactionError, ProtocolError, DatabaseError, } from './errors';
|
|
60
|
+
export { SochDBError, ConnectionError, TransactionError, ProtocolError, DatabaseError, ErrorCode, LockError, DatabaseLockedError, LockTimeoutError, EpochMismatchError, SplitBrainError, } from './errors';
|
|
49
61
|
export { SochDBClient as GrpcClient } from './grpc-client';
|
|
50
62
|
//# 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;
|
|
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;AACjD,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,YAAY,EAAE,MAAM,YAAY,CAAC;AACjE,OAAO,EAAE,YAAY,IAAI,gBAAgB,EAAE,MAAM,YAAY,CAAC;AAG9D,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"}
|