@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.
- package/README.md +220 -33
- 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/errors.js +99 -7
- package/dist/cjs/index.js +40 -3
- 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/errors.js +107 -7
- package/dist/esm/index.js +40 -3
- 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/errors.d.ts +57 -1
- package/dist/types/errors.d.ts.map +1 -1
- package/dist/types/index.d.ts +12 -2
- 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,185 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Extraction Pipeline for Memory System
|
|
4
|
+
*
|
|
5
|
+
* Compiles LLM outputs into typed, validated facts (Entity, Relation, Assertion).
|
|
6
|
+
*/
|
|
7
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
8
|
+
exports.ExtractionPipeline = void 0;
|
|
9
|
+
const crypto_1 = require("crypto");
|
|
10
|
+
/**
|
|
11
|
+
* Extraction Pipeline
|
|
12
|
+
*/
|
|
13
|
+
class ExtractionPipeline {
|
|
14
|
+
db;
|
|
15
|
+
namespace;
|
|
16
|
+
schema;
|
|
17
|
+
prefix;
|
|
18
|
+
constructor(db, namespace, schema) {
|
|
19
|
+
this.db = db;
|
|
20
|
+
this.namespace = namespace;
|
|
21
|
+
this.schema = schema;
|
|
22
|
+
this.prefix = Buffer.from(`memory:${namespace}:`);
|
|
23
|
+
}
|
|
24
|
+
/**
|
|
25
|
+
* Create pipeline from database
|
|
26
|
+
*/
|
|
27
|
+
static fromDatabase(db, namespace, schema) {
|
|
28
|
+
return new ExtractionPipeline(db, namespace, schema);
|
|
29
|
+
}
|
|
30
|
+
/**
|
|
31
|
+
* Extract entities and relations from text
|
|
32
|
+
*/
|
|
33
|
+
async extract(text, extractor) {
|
|
34
|
+
const rawResult = await extractor(text);
|
|
35
|
+
const timestamp = Date.now();
|
|
36
|
+
// Normalize entities
|
|
37
|
+
const entities = (rawResult.entities || []).map(e => ({
|
|
38
|
+
id: this.generateEntityId(e.name, e.entity_type),
|
|
39
|
+
name: e.name,
|
|
40
|
+
entityType: e.entity_type,
|
|
41
|
+
properties: e.properties,
|
|
42
|
+
confidence: e.confidence || 1.0,
|
|
43
|
+
provenance: text.substring(0, 100),
|
|
44
|
+
timestamp,
|
|
45
|
+
}));
|
|
46
|
+
// Validate entities
|
|
47
|
+
if (this.schema?.entityTypes) {
|
|
48
|
+
const validTypes = new Set(this.schema.entityTypes);
|
|
49
|
+
const filteredEntities = entities.filter(e => validTypes.has(e.entityType));
|
|
50
|
+
if (filteredEntities.length < entities.length) {
|
|
51
|
+
console.warn(`Filtered ${entities.length - filteredEntities.length} entities with invalid types`);
|
|
52
|
+
}
|
|
53
|
+
entities.splice(0, entities.length, ...filteredEntities);
|
|
54
|
+
}
|
|
55
|
+
// Normalize relations
|
|
56
|
+
const relations = (rawResult.relations || []).map(r => ({
|
|
57
|
+
id: this.generateRelationId(r.from_entity, r.relation_type, r.to_entity),
|
|
58
|
+
fromEntity: r.from_entity,
|
|
59
|
+
relationType: r.relation_type,
|
|
60
|
+
toEntity: r.to_entity,
|
|
61
|
+
properties: r.properties,
|
|
62
|
+
confidence: r.confidence || 1.0,
|
|
63
|
+
provenance: text.substring(0, 100),
|
|
64
|
+
timestamp,
|
|
65
|
+
}));
|
|
66
|
+
// Validate relations
|
|
67
|
+
if (this.schema?.relationTypes) {
|
|
68
|
+
const validTypes = new Set(this.schema.relationTypes);
|
|
69
|
+
const filteredRelations = relations.filter(r => validTypes.has(r.relationType));
|
|
70
|
+
if (filteredRelations.length < relations.length) {
|
|
71
|
+
console.warn(`Filtered ${relations.length - filteredRelations.length} relations with invalid types`);
|
|
72
|
+
}
|
|
73
|
+
relations.splice(0, relations.length, ...filteredRelations);
|
|
74
|
+
}
|
|
75
|
+
// Normalize assertions
|
|
76
|
+
const assertions = (rawResult.assertions || []).map(a => ({
|
|
77
|
+
id: this.generateAssertionId(a.subject, a.predicate, a.object),
|
|
78
|
+
subject: a.subject,
|
|
79
|
+
predicate: a.predicate,
|
|
80
|
+
object: a.object,
|
|
81
|
+
confidence: a.confidence || 1.0,
|
|
82
|
+
provenance: text.substring(0, 100),
|
|
83
|
+
timestamp,
|
|
84
|
+
}));
|
|
85
|
+
// Apply min confidence filter
|
|
86
|
+
if (this.schema?.minConfidence) {
|
|
87
|
+
const minConf = this.schema.minConfidence;
|
|
88
|
+
const filterByConfidence = (items) => items.filter(item => (item.confidence || 0) >= minConf);
|
|
89
|
+
entities.splice(0, entities.length, ...filterByConfidence(entities));
|
|
90
|
+
relations.splice(0, relations.length, ...filterByConfidence(relations));
|
|
91
|
+
assertions.splice(0, assertions.length, ...filterByConfidence(assertions));
|
|
92
|
+
}
|
|
93
|
+
return { entities, relations, assertions };
|
|
94
|
+
}
|
|
95
|
+
/**
|
|
96
|
+
* Extract and immediately commit to database
|
|
97
|
+
*/
|
|
98
|
+
async extractAndCommit(text, extractor) {
|
|
99
|
+
const result = await this.extract(text, extractor);
|
|
100
|
+
await this.commit(result);
|
|
101
|
+
return result;
|
|
102
|
+
}
|
|
103
|
+
/**
|
|
104
|
+
* Commit extraction result to database
|
|
105
|
+
*/
|
|
106
|
+
async commit(result) {
|
|
107
|
+
// Store entities
|
|
108
|
+
for (const entity of result.entities) {
|
|
109
|
+
const key = Buffer.concat([this.prefix, Buffer.from(`entity:${entity.id}`)]);
|
|
110
|
+
await this.db.put(key, Buffer.from(JSON.stringify(entity)));
|
|
111
|
+
}
|
|
112
|
+
// Store relations
|
|
113
|
+
for (const relation of result.relations) {
|
|
114
|
+
const key = Buffer.concat([this.prefix, Buffer.from(`relation:${relation.id}`)]);
|
|
115
|
+
await this.db.put(key, Buffer.from(JSON.stringify(relation)));
|
|
116
|
+
}
|
|
117
|
+
// Store assertions
|
|
118
|
+
for (const assertion of result.assertions) {
|
|
119
|
+
const key = Buffer.concat([this.prefix, Buffer.from(`assertion:${assertion.id}`)]);
|
|
120
|
+
await this.db.put(key, Buffer.from(JSON.stringify(assertion)));
|
|
121
|
+
}
|
|
122
|
+
}
|
|
123
|
+
/**
|
|
124
|
+
* Get all entities
|
|
125
|
+
*/
|
|
126
|
+
async getEntities() {
|
|
127
|
+
const entities = [];
|
|
128
|
+
const entityPrefix = Buffer.concat([this.prefix, Buffer.from('entity:')]);
|
|
129
|
+
for await (const [_, value] of this.db.scanPrefix(entityPrefix)) {
|
|
130
|
+
entities.push(JSON.parse(value.toString()));
|
|
131
|
+
}
|
|
132
|
+
return entities;
|
|
133
|
+
}
|
|
134
|
+
/**
|
|
135
|
+
* Get all relations
|
|
136
|
+
*/
|
|
137
|
+
async getRelations() {
|
|
138
|
+
const relations = [];
|
|
139
|
+
const relationPrefix = Buffer.concat([this.prefix, Buffer.from('relation:')]);
|
|
140
|
+
for await (const [_, value] of this.db.scanPrefix(relationPrefix)) {
|
|
141
|
+
relations.push(JSON.parse(value.toString()));
|
|
142
|
+
}
|
|
143
|
+
return relations;
|
|
144
|
+
}
|
|
145
|
+
/**
|
|
146
|
+
* Get all assertions
|
|
147
|
+
*/
|
|
148
|
+
async getAssertions() {
|
|
149
|
+
const assertions = [];
|
|
150
|
+
const assertionPrefix = Buffer.concat([this.prefix, Buffer.from('assertion:')]);
|
|
151
|
+
for await (const [_, value] of this.db.scanPrefix(assertionPrefix)) {
|
|
152
|
+
assertions.push(JSON.parse(value.toString()));
|
|
153
|
+
}
|
|
154
|
+
return assertions;
|
|
155
|
+
}
|
|
156
|
+
/**
|
|
157
|
+
* Generate deterministic entity ID
|
|
158
|
+
*/
|
|
159
|
+
generateEntityId(name, entityType) {
|
|
160
|
+
return (0, crypto_1.createHash)('sha256')
|
|
161
|
+
.update(`${name}:${entityType}`)
|
|
162
|
+
.digest('hex')
|
|
163
|
+
.substring(0, 16);
|
|
164
|
+
}
|
|
165
|
+
/**
|
|
166
|
+
* Generate deterministic relation ID
|
|
167
|
+
*/
|
|
168
|
+
generateRelationId(from, relationType, to) {
|
|
169
|
+
return (0, crypto_1.createHash)('sha256')
|
|
170
|
+
.update(`${from}:${relationType}:${to}`)
|
|
171
|
+
.digest('hex')
|
|
172
|
+
.substring(0, 16);
|
|
173
|
+
}
|
|
174
|
+
/**
|
|
175
|
+
* Generate deterministic assertion ID
|
|
176
|
+
*/
|
|
177
|
+
generateAssertionId(subject, predicate, object) {
|
|
178
|
+
return (0, crypto_1.createHash)('sha256')
|
|
179
|
+
.update(`${subject}:${predicate}:${object}`)
|
|
180
|
+
.digest('hex')
|
|
181
|
+
.substring(0, 16);
|
|
182
|
+
}
|
|
183
|
+
}
|
|
184
|
+
exports.ExtractionPipeline = ExtractionPipeline;
|
|
185
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXh0cmFjdGlvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9tZW1vcnkvZXh0cmFjdGlvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUE7Ozs7R0FJRzs7O0FBVUgsbUNBQW9DO0FBV3BDOztHQUVHO0FBQ0gsTUFBYSxrQkFBa0I7SUFDckIsRUFBRSxDQUFtQjtJQUNyQixTQUFTLENBQVM7SUFDbEIsTUFBTSxDQUFvQjtJQUMxQixNQUFNLENBQVM7SUFFdkIsWUFBWSxFQUFvQixFQUFFLFNBQWlCLEVBQUUsTUFBeUI7UUFDNUUsSUFBSSxDQUFDLEVBQUUsR0FBRyxFQUFFLENBQUM7UUFDYixJQUFJLENBQUMsU0FBUyxHQUFHLFNBQVMsQ0FBQztRQUMzQixJQUFJLENBQUMsTUFBTSxHQUFHLE1BQU0sQ0FBQztRQUNyQixJQUFJLENBQUMsTUFBTSxHQUFHLE1BQU0sQ0FBQyxJQUFJLENBQUMsVUFBVSxTQUFTLEdBQUcsQ0FBQyxDQUFDO0lBQ3BELENBQUM7SUFFRDs7T0FFRztJQUNILE1BQU0sQ0FBQyxZQUFZLENBQUMsRUFBb0IsRUFBRSxTQUFpQixFQUFFLE1BQXlCO1FBQ3BGLE9BQU8sSUFBSSxrQkFBa0IsQ0FBQyxFQUFFLEVBQUUsU0FBUyxFQUFFLE1BQU0sQ0FBQyxDQUFDO0lBQ3ZELENBQUM7SUFFRDs7T0FFRztJQUNILEtBQUssQ0FBQyxPQUFPLENBQUMsSUFBWSxFQUFFLFNBQTRCO1FBQ3RELE1BQU0sU0FBUyxHQUFHLE1BQU0sU0FBUyxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQ3hDLE1BQU0sU0FBUyxHQUFHLElBQUksQ0FBQyxHQUFHLEVBQUUsQ0FBQztRQUU3QixxQkFBcUI7UUFDckIsTUFBTSxRQUFRLEdBQWEsQ0FBQyxTQUFTLENBQUMsUUFBUSxJQUFJLEVBQUUsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUM7WUFDOUQsRUFBRSxFQUFFLElBQUksQ0FBQyxnQkFB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QixFQUFFLEVBQVU7UUFDdkUsT0FBTyxJQUFBLG1CQUFVLEVBQUMsUUFBUSxDQUFDO2FBQ3hCLE1BQU0sQ0FBQyxHQUFHLElBQUksSUFBSSxZQUFZLElBQUksRUFBRSxFQUFFLENBQUM7YUFDdkMsTUFBTSxDQUFDLEtBQUssQ0FBQzthQUNiLFNBQVMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUM7SUFDdEIsQ0FBQztJQUVEOztPQUVHO0lBQ0ssbUJBQW1CLENBQUMsT0FBZSxFQUFFLFNBQWlCLEVBQUUsTUFBYztRQUM1RSxPQUFPLElBQUEsbUJBQVUsRUFBQyxRQUFRLENBQUM7YUFDeEIsTUFBTSxDQUFDLEdBQUcsT0FBTyxJQUFJLFNBQVMsSUFBSSxNQUFNLEVBQUUsQ0FBQzthQUMzQyxNQUFNLENBQUMsS0FBSyxDQUFDO2FBQ2IsU0FBUyxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQztJQUN0QixDQUFDO0NBQ0Y7QUF0TUQsZ0RBc01DIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRyYWN0aW9uIFBpcGVsaW5lIGZvciBNZW1vcnkgU3lzdGVtXG4gKiBcbiAqIENvbXBpbGVzIExMTSBvdXRwdXRzIGludG8gdHlwZWQsIHZhbGlkYXRlZCBmYWN0cyAoRW50aXR5LCBSZWxhdGlvbiwgQXNzZXJ0aW9uKS5cbiAqL1xuXG5pbXBvcnQgeyBFbWJlZGRlZERhdGFiYXNlIH0gZnJvbSAnLi4vZW1iZWRkZWQnO1xuaW1wb3J0IHtcbiAgRW50aXR5LFxuICBSZWxhdGlvbixcbiAgQXNzZXJ0aW9uLFxuICBFeHRyYWN0aW9uUmVzdWx0LFxuICBFeHRyYWN0aW9uU2NoZW1hLFxufSBmcm9tICcuL3R5cGVzJztcbmltcG9ydCB7IGNyZWF0ZUhhc2ggfSBmcm9tICdjcnlwdG8nO1xuXG4vKipcbiAqIEV4dHJhY3RvciBmdW5jdGlvbiB0eXBlIC0gdXNlciBwcm92aWRlcyB0aGlzIHRvIGNhbGwgdGhlaXIgTExNXG4gKi9cbmV4cG9ydCB0eXBlIEV4dHJhY3RvckZ1bmN0aW9uID0gKHRleHQ6IHN0cmluZykgPT4gUHJvbWlzZTx7XG4gIGVudGl0aWVzPzogQXJyYXk8eyBuYW1lOiBzdHJpbmc7IGVudGl0eV90eXBlOiBzdHJpbmc7IHByb3BlcnRpZXM/OiBSZWNvcmQ8c3RyaW5nLCBhbnk+OyBjb25maWRlbmNlPzogbnVtYmVyIH0+O1xuICByZWxhdGlvbnM/OiBBcnJheTx7IGZyb21fZW50aXR5OiBzdHJpbmc7IHJlbGF0aW9uX3R5cGU6IHN0cmluZzsgdG9fZW50aXR5OiBzdHJpbmc7IHByb3BlcnRpZXM/OiBSZWNvcmQ8c3RyaW5nLCBhbnk+OyBjb25maWRlbmNlPzogbnVtYmVyIH0+O1xuICBhc3NlcnRpb25zPzogQXJyYXk8eyBzdWJqZWN0OiBzdHJpbmc7IHByZWRpY2F0ZTogc3RyaW5nOyBvYmplY3Q6IHN0cmluZzsgY29uZmlkZW5jZT86IG51bWJlciB9Pjtcbn0+O1xuXG4vKipcbiAqIEV4dHJhY3Rpb24gUGlwZWxpbmVcbiAqL1xuZXhwb3J0IGNsYXNzIEV4dHJhY3Rpb25QaXBlbGluZSB7XG4gIHByaXZhdGUgZGI6IEVtYmVkZGVkRGF0YWJhc2U7XG4gIHByaXZhdGUgbmFtZXNwYWNlOiBzdHJpbmc7XG4gIHByaXZhdGUgc2NoZW1hPzogRXh0cmFjdGlvblNjaGVtYTtcbiAgcHJpdmF0ZSBwcmVmaXg6IEJ1ZmZlcjtcblxuICBjb25zdHJ1Y3RvcihkYjogRW1iZWRkZWREYXRhYmFzZSwgbmFtZXNwYWNlOiBzdHJpbmcsIHNjaGVtYT86IEV4dHJhY3Rpb25TY2hlbWEpIHtcbiAgICB0aGlzLmRiID0gZGI7XG4gICAgdGhpcy5uYW1lc3BhY2UgPSBuYW1lc3BhY2U7XG4gICAgdGhpcy5zY2hlbWEgPSBzY2hlbWE7XG4gICAgdGhpcy5wcmVmaXggPSBCdWZmZXIuZnJvbShgbWVtb3J5OiR7bmFtZXNwYWNlfTpgKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBDcmVhdGUgcGlwZWxpbmUgZnJvbSBkYXRhYmFzZVxuICAgKi9cbiAgc3RhdGljIGZyb21EYXRhYmFzZShkYjogRW1iZWRkZWREYXRhYmFzZSwgbmFtZXNwYWNlOiBzdHJpbmcsIHNjaGVtYT86IEV4dHJhY3Rpb25TY2hlbWEpOiBFeHRyYWN0aW9uUGlwZWxpbmUge1xuICAgIHJldHVybiBuZXcgRXh0cmFjdGlvblBpcGVsaW5lKGRiLCBuYW1lc3BhY2UsIHNjaGVtYSk7XG4gIH1cblxuICAvKipcbiAgICogRXh0cmFjdCBlbnRpdGllcyBhbmQgcmVsYXRpb25zIGZyb20gdGV4dFxuICAgKi9cbiAgYXN5bmMgZXh0cmFjdCh0ZXh0OiBzdHJpbmcsIGV4dHJhY3RvcjogRXh0cmFjdG9yRnVuY3Rpb24pOiBQcm9taXNlPEV4dHJhY3Rpb25SZXN1bHQ+IHtcbiAgICBjb25zdCByYXdSZXN1bHQgPSBhd2FpdCBleHRyYWN0b3IodGV4dCk7XG4gICAgY29uc3QgdGltZXN0YW1wID0gRGF0ZS5ub3coKTtcblxuICAgIC8vIE5vcm1hbGl6ZSBlbnRpdGllc1xuICAgIGNvbnN0IGVudGl0aWVzOiBFbnRpdHlbXSA9IChyYXdSZXN1bHQuZW50aXRpZXMgfHwgW10pLm1hcChlID0+ICh7XG4gICAgICBpZDogdGhpcy5nZW5lcmF0ZUVudGl0eUlkKGUubmFtZSwgZS5lbnRpdHlfdHlwZSksXG4gICAgICBuYW1lOiBlLm5hbWUsXG4gICAgICBlbnRpdHlUeXBlOiBlLmVudGl0eV90eXBlLFxuICAgICAgcHJvcGVydGllczogZS5wcm9wZXJ0aWVzLFxuICAgICAgY29uZmlkZW5jZTogZS5jb25maWRlbmNlIHx8IDEuMCxcbiAgICAgIHByb3ZlbmFuY2U6IHRleHQuc3Vic3RyaW5nKDAsIDEwMCksXG4gICAgICB0aW1lc3RhbXAsXG4gICAgfSkpO1xuXG4gICAgLy8gVmFsaWRhdGUgZW50aXRpZXNcbiAgICBpZiAodGhpcy5zY2hlbWE/LmVudGl0eVR5cGVzKSB7XG4gICAgICBjb25zdCB2YWxpZFR5cGVzID0gbmV3IFNldCh0aGlzLnNjaGVtYS5lbnRpdHlUeXBlcyk7XG4gICAgICBjb25zdCBmaWx0ZXJlZEVudGl0aWVzID0gZW50aXRpZXMuZmlsdGVyKGUgPT4gdmFsaWRUeXBlcy5oYXMoZS5lbnRpdHlUeXBlKSk7XG4gICAgICBpZiAoZmlsdGVyZWRFbnRpdGllcy5sZW5ndGggPCBlbnRpdGllcy5sZW5ndGgpIHtcbiAgICAgICAgY29uc29sZS53YXJuKGBGaWx0ZXJlZCAke2VudGl0aWVzLmxlbmd0aCAtIGZpbHRlcmVkRW50aXRpZXMubGVuZ3RofSBlbnRpdGllcyB3aXRoIGludmFsaWQgdHlwZXNgKTtcbiAgICAgIH1cbiAgICAgIGVudGl0aWVzLnNwbGljZSgwLCBlbnRpdGllcy5sZW5ndGgsIC4uLmZpbHRlcmVkRW50aXRpZXMpO1xuICAgIH1cblxuICAgIC8vIE5vcm1hbGl6ZSByZWxhdGlvbnNcbiAgICBjb25zdCByZWxhdGlvbnM6IFJlbGF0aW9uW10gPSAocmF3UmVzdWx0LnJlbGF0aW9ucyB8fCBbXSkubWFwKHIgPT4gKHtcbiAgICAgIGlkOiB0aGlzLmdlbmVyYXRlUmVsYXRpb25JZChyLmZyb21fZW50aXR5LCByLnJlbGF0aW9uX3R5cGUsIHIudG9fZW50aXR5KSxcbiAgICAgIGZyb21FbnRpdHk6IHIuZnJvbV9lbnRpdHksXG4gICAgICByZWxhdGlvblR5cGU6IHIucmVsYXRpb25fdHlwZSxcbiAgICAgIHRvRW50aXR5OiByLnRvX2VudGl0eSxcbiAgICAgIHByb3BlcnRpZXM6IHIucHJvcGVydGllcyxcbiAgICAgIGNvbmZpZGVuY2U6IHIuY29uZmlkZW5jZSB8fCAxLjAsXG4gICAgICBwcm92ZW5hbmNlOiB0ZXh0LnN1YnN0cmluZygwLCAxMDApLFxuICAgICAgdGltZXN0YW1wLFxuICAgIH0pKTtcblxuICAgIC8vIFZhbGlkYXRlIHJlbGF0aW9uc1xuICAgIGlmICh0aGlzLnNjaGVtYT8ucmVsYXRpb25UeXBlcykge1xuICAgICAgY29uc3QgdmFsaWRUeXBlcyA9IG5ldyBTZXQodGhpcy5zY2hlbWEucmVsYXRpb25UeXBlcyk7XG4gICAgICBjb25zdCBmaWx0ZXJlZFJlbGF0aW9ucyA9IHJlbGF0aW9ucy5maWx0ZXIociA9PiB2YWxpZFR5cGVzLmhhcyhyLnJlbGF0aW9uVHlwZSkpO1xuICAgICAgaWYgKGZpbHRlcmVkUmVsYXRpb25zLmxlbmd0aCA8IHJlbGF0aW9ucy5sZW5ndGgpIHtcbiAgICAgICAgY29uc29sZS53YXJuKGBGaWx0ZXJlZCAke3JlbGF0aW9ucy5sZW5ndGggLSBmaWx0ZXJlZFJlbGF0aW9ucy5sZW5ndGh9IHJlbGF0aW9ucyB3aXRoIGludmFsaWQgdHlwZXNgKTtcbiAgICAgIH1cbiAgICAgIHJlbGF0aW9ucy5zcGxpY2UoMCwgcmVsYXRpb25zLmxlbmd0aCwgLi4uZmlsdGVyZWRSZWxhdGlvbnMpO1xuICAgIH1cblxuICAgIC8vIE5vcm1hbGl6ZSBhc3NlcnRpb25zXG4gICAgY29uc3QgYXNzZXJ0aW9uczogQXNzZXJ0aW9uW10gPSAocmF3UmVzdWx0LmFzc2VydGlvbnMgfHwgW10pLm1hcChhID0+ICh7XG4gICAgICBpZDogdGhpcy5nZW5lcmF0ZUFzc2VydGlvbklkKGEuc3ViamVjdCwgYS5wcmVkaWNhdGUsIGEub2JqZWN0KSxcbiAgICAgIHN1YmplY3Q6IGEuc3ViamVjdCxcbiAgICAgIHByZWRpY2F0ZTogYS5wcmVkaWNhdGUsXG4gICAgICBvYmplY3Q6IGEub2JqZWN0LFxuICAgICAgY29uZmlkZW5jZTogYS5jb25maWRlbmNlIHx8IDEuMCxcbiAgICAgIHByb3ZlbmFuY2U6IHRleHQuc3Vic3RyaW5nKDAsIDEwMCksXG4gICAgICB0aW1lc3RhbXAsXG4gICAgfSkpO1xuXG4gICAgLy8gQXBwbHkgbWluIGNvbmZpZGVuY2UgZmlsdGVyXG4gICAgaWYgKHRoaXMuc2NoZW1hPy5taW5Db25maWRlbmNlKSB7XG4gICAgICBjb25zdCBtaW5Db25mID0gdGhpcy5zY2hlbWEubWluQ29uZmlkZW5jZTtcbiAgICAgIGNvbnN0IGZpbHRlckJ5Q29uZmlkZW5jZSA9IDxUIGV4dGVuZHMgeyBjb25maWRlbmNlPzogbnVtYmVyIH0+KGl0ZW1zOiBUW10pOiBUW10gPT5cbiAgICAgICAgaXRlbXMuZmlsdGVyKGl0ZW0gPT4gKGl0ZW0uY29uZmlkZW5jZSB8fCAwKSA+PSBtaW5Db25mKTtcblxuICAgICAgZW50aXRpZXMuc3BsaWNlKDAsIGVudGl0aWVzLmxlbmd0aCwgLi4uZmlsdGVyQnlDb25maWRlbmNlKGVudGl0aWVzKSk7XG4gICAgICByZWxhdGlvbnMuc3BsaWNlKDAsIHJlbGF0aW9ucy5sZW5ndGgsIC4uLmZpbHRlckJ5Q29uZmlkZW5jZShyZWxhdGlvbnMpKTtcbiAgICAgIGFzc2VydGlvbnMuc3BsaWNlKDAsIGFzc2VydGlvbnMubGVuZ3RoLCAuLi5maWx0ZXJCeUNvbmZpZGVuY2UoYXNzZXJ0aW9ucykpO1xuICAgIH1cblxuICAgIHJldHVybiB7IGVudGl0aWVzLCByZWxhdGlvbnMsIGFzc2VydGlvbnMgfTtcbiAgfVxuXG4gIC8qKlxuICAgKiBFeHRyYWN0IGFuZCBpbW1lZGlhdGVseSBjb21taXQgdG8gZGF0YWJhc2VcbiAgICovXG4gIGFzeW5jIGV4dHJhY3RBbmRDb21taXQodGV4dDogc3RyaW5nLCBleHRyYWN0b3I6IEV4dHJhY3RvckZ1bmN0aW9uKTogUHJvbWlzZTxFeHRyYWN0aW9uUmVzdWx0PiB7XG4gICAgY29uc3QgcmVzdWx0ID0gYXdhaXQgdGhpcy5leHRyYWN0KHRleHQsIGV4dHJhY3Rvcik7XG4gICAgYXdhaXQgdGhpcy5jb21taXQocmVzdWx0KTtcbiAgICByZXR1cm4gcmVzdWx0O1xuICB9XG5cbiAgLyoqXG4gICAqIENvbW1pdCBleHRyYWN0aW9uIHJlc3VsdCB0byBkYXRhYmFzZVxuICAgKi9cbiAgYXN5bmMgY29tbWl0KHJlc3VsdDogRXh0cmFjdGlvblJlc3VsdCk6IFByb21pc2U8dm9pZD4ge1xuICAgIC8vIFN0b3JlIGVudGl0aWVzXG4gICAgZm9yIChjb25zdCBlbnRpdHkgb2YgcmVzdWx0LmVudGl0aWVzKSB7XG4gICAgICBjb25zdCBrZXkgPSBCdWZmZXIuY29uY2F0KFt0aGlzLnByZWZpeCwgQnVmZmVyLmZyb20oYGVudGl0eToke2VudGl0eS5pZH1gKV0pO1xuICAgICAgYXdhaXQgdGhpcy5kYi5wdXQoa2V5LCBCdWZmZXIuZnJvbShKU09OLnN0cmluZ2lmeShlbnRpdHkpKSk7XG4gICAgfVxuXG4gICAgLy8gU3RvcmUgcmVsYXRpb25zXG4gICAgZm9yIChjb25zdCByZWxhdGlvbiBvZiByZXN1bHQucmVsYXRpb25zKSB7XG4gICAgICBjb25zdCBrZXkgPSBCdWZmZXIuY29uY2F0KFt0aGlzLnByZWZpeCwgQnVmZmVyLmZyb20oYHJlbGF0aW9uOiR7cmVsYXRpb24uaWR9YCldKTtcbiAgICAgIGF3YWl0IHRoaXMuZGIucHV0KGtleSwgQnVmZmVyLmZyb20oSlNPTi5zdHJpbmdpZnkocmVsYXRpb24pKSk7XG4gICAgfVxuXG4gICAgLy8gU3RvcmUgYXNzZXJ0aW9uc1xuICAgIGZvciAoY29uc3QgYXNzZXJ0aW9uIG9mIHJlc3VsdC5hc3NlcnRpb25zKSB7XG4gICAgICBjb25zdCBrZXkgPSBCdWZmZXIuY29uY2F0KFt0aGlzLnByZWZpeCwgQnVmZmVyLmZyb20oYGFzc2VydGlvbjoke2Fzc2VydGlvbi5pZH1gKV0pO1xuICAgICAgYXdhaXQgdGhpcy5kYi5wdXQoa2V5LCBCdWZmZXIuZnJvbShKU09OLnN0cmluZ2lmeShhc3NlcnRpb24pKSk7XG4gICAgfVxuICB9XG5cbiAgLyoqXG4gICAqIEdldCBhbGwgZW50aXRpZXNcbiAgICovXG4gIGFzeW5jIGdldEVudGl0aWVzKCk6IFByb21pc2U8RW50aXR5W10+IHtcbiAgICBjb25zdCBlbnRpdGllczogRW50aXR5W10gPSBbXTtcbiAgICBjb25zdCBlbnRpdHlQcmVmaXggPSBCdWZmZXIuY29uY2F0KFt0aGlzLnByZWZpeCwgQnVmZmVyLmZyb20oJ2VudGl0eTonKV0pO1xuXG4gICAgZm9yIGF3YWl0IChjb25zdCBbXywgdmFsdWVdIG9mIHRoaXMuZGIuc2NhblByZWZpeChlbnRpdHlQcmVmaXgpKSB7XG4gICAgICBlbnRpdGllcy5wdXNoKEpTT04ucGFyc2UodmFsdWUudG9TdHJpbmcoKSkpO1xuICAgIH1cblxuICAgIHJldHVybiBlbnRpdGllcztcbiAgfVxuXG4gIC8qKlxuICAgKiBHZXQgYWxsIHJlbGF0aW9uc1xuICAgKi9cbiAgYXN5bmMgZ2V0UmVsYXRpb25zKCk6IFByb21pc2U8UmVsYXRpb25bXT4ge1xuICAgIGNvbnN0IHJlbGF0aW9uczogUmVsYXRpb25bXSA9IFtdO1xuICAgIGNvbnN0IHJlbGF0aW9uUHJlZml4ID0gQnVmZmVyLmNvbmNhdChbdGhpcy5wcmVmaXgsIEJ1ZmZlci5mcm9tKCdyZWxhdGlvbjonKV0pO1xuXG4gICAgZm9yIGF3YWl0IChjb25zdCBbXywgdmFsdWVdIG9mIHRoaXMuZGIuc2NhblByZWZpeChyZWxhdGlvblByZWZpeCkpIHtcbiAgICAgIHJlbGF0aW9ucy5wdXNoKEpTT04ucGFyc2UodmFsdWUudG9TdHJpbmcoKSkpO1xuICAgIH1cblxuICAgIHJldHVybiByZWxhdGlvbnM7XG4gIH1cblxuICAvKipcbiAgICogR2V0IGFsbCBhc3NlcnRpb25zXG4gICAqL1xuICBhc3luYyBnZXRBc3NlcnRpb25zKCk6IFByb21pc2U8QXNzZXJ0aW9uW10+IHtcbiAgICBjb25zdCBhc3NlcnRpb25zOiBBc3NlcnRpb25bXSA9IFtdO1xuICAgIGNvbnN0IGFzc2VydGlvblByZWZpeCA9IEJ1ZmZlci5jb25jYXQoW3RoaXMucHJlZml4LCBCdWZmZXIuZnJvbSgnYXNzZXJ0aW9uOicpXSk7XG5cbiAgICBmb3IgYXdhaXQgKGNvbnN0IFtfLCB2YWx1ZV0gb2YgdGhpcy5kYi5zY2FuUHJlZml4KGFzc2VydGlvblByZWZpeCkpIHtcbiAgICAgIGFzc2VydGlvbnMucHVzaChKU09OLnBhcnNlKHZhbHVlLnRvU3RyaW5nKCkpKTtcbiAgICB9XG5cbiAgICByZXR1cm4gYXNzZXJ0aW9ucztcbiAgfVxuXG4gIC8qKlxuICAgKiBHZW5lcmF0ZSBkZXRlcm1pbmlzdGljIGVudGl0eSBJRFxuICAgKi9cbiAgcHJpdmF0ZSBnZW5lcmF0ZUVudGl0eUlkKG5hbWU6IHN0cmluZywgZW50aXR5VHlwZTogc3RyaW5nKTogc3RyaW5nIHtcbiAgICByZXR1cm4gY3JlYXRlSGFzaCgnc2hhMjU2JylcbiAgICAgIC51cGRhdGUoYCR7bmFtZX06JHtlbnRpdHlUeXBlfWApXG4gICAgICAuZGlnZXN0KCdoZXgnKVxuICAgICAgLnN1YnN0cmluZygwLCAxNik7XG4gIH1cblxuICAvKipcbiAgICogR2VuZXJhdGUgZGV0ZXJtaW5pc3RpYyByZWxhdGlvbiBJRFxuICAgKi9cbiAgcHJpdmF0ZSBnZW5lcmF0ZVJlbGF0aW9uSWQoZnJvbTogc3RyaW5nLCByZWxhdGlvblR5cGU6IHN0cmluZywgdG86IHN0cmluZyk6IHN0cmluZyB7XG4gICAgcmV0dXJuIGNyZWF0ZUhhc2goJ3NoYTI1NicpXG4gICAgICAudXBkYXRlKGAke2Zyb219OiR7cmVsYXRpb25UeXBlfToke3RvfWApXG4gICAgICAuZGlnZXN0KCdoZXgnKVxuICAgICAgLnN1YnN0cmluZygwLCAxNik7XG4gIH1cblxuICAvKipcbiAgICogR2VuZXJhdGUgZGV0ZXJtaW5pc3RpYyBhc3NlcnRpb24gSURcbiAgICovXG4gIHByaXZhdGUgZ2VuZXJhdGVBc3NlcnRpb25JZChzdWJqZWN0OiBzdHJpbmcsIHByZWRpY2F0ZTogc3RyaW5nLCBvYmplY3Q6IHN0cmluZyk6IHN0cmluZyB7XG4gICAgcmV0dXJuIGNyZWF0ZUhhc2goJ3NoYTI1NicpXG4gICAgICAudXBkYXRlKGAke3N1YmplY3R9OiR7cHJlZGljYXRlfToke29iamVjdH1gKVxuICAgICAgLmRpZ2VzdCgnaGV4JylcbiAgICAgIC5zdWJzdHJpbmcoMCwgMTYpO1xuICB9XG59XG4iXX0=
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Memory System - Main Export
|
|
4
|
+
*
|
|
5
|
+
* LLM-native memory system with extraction, consolidation, and retrieval.
|
|
6
|
+
*/
|
|
7
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
8
|
+
if (k2 === undefined) k2 = k;
|
|
9
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
10
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
11
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
12
|
+
}
|
|
13
|
+
Object.defineProperty(o, k2, desc);
|
|
14
|
+
}) : (function(o, m, k, k2) {
|
|
15
|
+
if (k2 === undefined) k2 = k;
|
|
16
|
+
o[k2] = m[k];
|
|
17
|
+
}));
|
|
18
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
19
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
20
|
+
};
|
|
21
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
22
|
+
__exportStar(require("./types"), exports);
|
|
23
|
+
__exportStar(require("./extraction"), exports);
|
|
24
|
+
__exportStar(require("./consolidation"), exports);
|
|
25
|
+
__exportStar(require("./retrieval"), exports);
|
|
26
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvbWVtb3J5L2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQTs7OztHQUlHOzs7Ozs7Ozs7Ozs7Ozs7O0FBRUgsMENBQXdCO0FBQ3hCLCtDQUE2QjtBQUM3QixrREFBZ0M7QUFDaEMsOENBQTRCIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBNZW1vcnkgU3lzdGVtIC0gTWFpbiBFeHBvcnRcbiAqIFxuICogTExNLW5hdGl2ZSBtZW1vcnkgc3lzdGVtIHdpdGggZXh0cmFjdGlvbiwgY29uc29saWRhdGlvbiwgYW5kIHJldHJpZXZhbC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL3R5cGVzJztcbmV4cG9ydCAqIGZyb20gJy4vZXh0cmFjdGlvbic7XG5leHBvcnQgKiBmcm9tICcuL2NvbnNvbGlkYXRpb24nO1xuZXhwb3J0ICogZnJvbSAnLi9yZXRyaWV2YWwnO1xuIl19
|
|
@@ -0,0 +1,243 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Hybrid Retriever for Memory System
|
|
4
|
+
*
|
|
5
|
+
* Combines vector and keyword search with RRF (Reciprocal Rank Fusion).
|
|
6
|
+
*/
|
|
7
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
8
|
+
exports.HybridRetriever = void 0;
|
|
9
|
+
/**
|
|
10
|
+
* Simple BM25 scorer for keyword matching
|
|
11
|
+
*/
|
|
12
|
+
class BM25Scorer {
|
|
13
|
+
k1 = 1.5;
|
|
14
|
+
b = 0.75;
|
|
15
|
+
avgDocLength;
|
|
16
|
+
docLengths;
|
|
17
|
+
termFreqs;
|
|
18
|
+
docFreqs;
|
|
19
|
+
numDocs;
|
|
20
|
+
constructor() {
|
|
21
|
+
this.avgDocLength = 0;
|
|
22
|
+
this.docLengths = new Map();
|
|
23
|
+
this.termFreqs = new Map();
|
|
24
|
+
this.docFreqs = new Map();
|
|
25
|
+
this.numDocs = 0;
|
|
26
|
+
}
|
|
27
|
+
/**
|
|
28
|
+
* Index a document
|
|
29
|
+
*/
|
|
30
|
+
indexDocument(docId, text) {
|
|
31
|
+
const terms = this.tokenize(text);
|
|
32
|
+
const termCounts = new Map();
|
|
33
|
+
for (const term of terms) {
|
|
34
|
+
termCounts.set(term, (termCounts.get(term) || 0) + 1);
|
|
35
|
+
}
|
|
36
|
+
this.docLengths.set(docId, terms.length);
|
|
37
|
+
this.termFreqs.set(docId, termCounts);
|
|
38
|
+
for (const term of termCounts.keys()) {
|
|
39
|
+
this.docFreqs.set(term, (this.docFreqs.get(term) || 0) + 1);
|
|
40
|
+
}
|
|
41
|
+
this.numDocs++;
|
|
42
|
+
this.updateAvgDocLength();
|
|
43
|
+
}
|
|
44
|
+
/**
|
|
45
|
+
* Score a query against a document
|
|
46
|
+
*/
|
|
47
|
+
score(docId, queryTerms) {
|
|
48
|
+
const termCounts = this.termFreqs.get(docId);
|
|
49
|
+
if (!termCounts)
|
|
50
|
+
return 0;
|
|
51
|
+
const docLength = this.docLengths.get(docId) || 0;
|
|
52
|
+
let score = 0;
|
|
53
|
+
for (const term of queryTerms) {
|
|
54
|
+
const tf = termCounts.get(term) || 0;
|
|
55
|
+
const df = this.docFreqs.get(term) || 0;
|
|
56
|
+
if (tf === 0)
|
|
57
|
+
continue;
|
|
58
|
+
const idf = Math.log((this.numDocs - df + 0.5) / (df + 0.5) + 1);
|
|
59
|
+
const norm = tf / (tf + this.k1 * (1 - this.b + this.b * (docLength / this.avgDocLength)));
|
|
60
|
+
score += idf * norm;
|
|
61
|
+
}
|
|
62
|
+
return score;
|
|
63
|
+
}
|
|
64
|
+
/**
|
|
65
|
+
* Tokenize text into terms
|
|
66
|
+
*/
|
|
67
|
+
tokenize(text) {
|
|
68
|
+
return text
|
|
69
|
+
.toLowerCase()
|
|
70
|
+
.replace(/[^\w\s]/g, ' ')
|
|
71
|
+
.split(/\s+/)
|
|
72
|
+
.filter(t => t.length > 0);
|
|
73
|
+
}
|
|
74
|
+
/**
|
|
75
|
+
* Update average document length
|
|
76
|
+
*/
|
|
77
|
+
updateAvgDocLength() {
|
|
78
|
+
const totalLength = Array.from(this.docLengths.values()).reduce((a, b) => a + b, 0);
|
|
79
|
+
this.avgDocLength = totalLength / this.numDocs;
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
/**
|
|
83
|
+
* Cosine similarity for vector search
|
|
84
|
+
*/
|
|
85
|
+
function cosineSimilarity(a, b) {
|
|
86
|
+
if (a.length !== b.length)
|
|
87
|
+
return 0;
|
|
88
|
+
let dotProduct = 0;
|
|
89
|
+
let normA = 0;
|
|
90
|
+
let normB = 0;
|
|
91
|
+
for (let i = 0; i < a.length; i++) {
|
|
92
|
+
dotProduct += a[i] * b[i];
|
|
93
|
+
normA += a[i] * a[i];
|
|
94
|
+
normB += b[i] * b[i];
|
|
95
|
+
}
|
|
96
|
+
if (normA === 0 || normB === 0)
|
|
97
|
+
return 0;
|
|
98
|
+
return dotProduct / (Math.sqrt(normA) * Math.sqrt(normB));
|
|
99
|
+
}
|
|
100
|
+
/**
|
|
101
|
+
* Hybrid Retriever with RRF fusion
|
|
102
|
+
*/
|
|
103
|
+
class HybridRetriever {
|
|
104
|
+
db;
|
|
105
|
+
namespace;
|
|
106
|
+
collection;
|
|
107
|
+
config;
|
|
108
|
+
prefix;
|
|
109
|
+
bm25;
|
|
110
|
+
indexed = false;
|
|
111
|
+
constructor(db, namespace, collection, config) {
|
|
112
|
+
this.db = db;
|
|
113
|
+
this.namespace = namespace;
|
|
114
|
+
this.collection = collection;
|
|
115
|
+
this.config = {
|
|
116
|
+
k: config?.k || 10,
|
|
117
|
+
alpha: config?.alpha !== undefined ? config.alpha : 0.5,
|
|
118
|
+
enableRerank: config?.enableRerank || false,
|
|
119
|
+
rerankK: config?.rerankK || 100,
|
|
120
|
+
};
|
|
121
|
+
this.prefix = Buffer.from(`retrieval:${namespace}:${collection}:`);
|
|
122
|
+
this.bm25 = new BM25Scorer();
|
|
123
|
+
}
|
|
124
|
+
/**
|
|
125
|
+
* Create retriever from database
|
|
126
|
+
*/
|
|
127
|
+
static fromDatabase(db, namespace, collection, config) {
|
|
128
|
+
return new HybridRetriever(db, namespace, collection, config);
|
|
129
|
+
}
|
|
130
|
+
/**
|
|
131
|
+
* Index documents for retrieval
|
|
132
|
+
*/
|
|
133
|
+
async indexDocuments(documents) {
|
|
134
|
+
for (const doc of documents) {
|
|
135
|
+
const key = Buffer.concat([this.prefix, Buffer.from(doc.id)]);
|
|
136
|
+
await this.db.put(key, Buffer.from(JSON.stringify({
|
|
137
|
+
id: doc.id,
|
|
138
|
+
content: doc.content,
|
|
139
|
+
embedding: doc.embedding,
|
|
140
|
+
metadata: doc.metadata,
|
|
141
|
+
})));
|
|
142
|
+
// Index for BM25
|
|
143
|
+
this.bm25.indexDocument(doc.id, doc.content);
|
|
144
|
+
}
|
|
145
|
+
this.indexed = true;
|
|
146
|
+
}
|
|
147
|
+
/**
|
|
148
|
+
* Retrieve documents with hybrid search
|
|
149
|
+
*/
|
|
150
|
+
async retrieve(queryText, queryVector, allowed, k) {
|
|
151
|
+
const startTime = Date.now();
|
|
152
|
+
const targetK = k || this.config.k;
|
|
153
|
+
// Get all documents
|
|
154
|
+
const documents = [];
|
|
155
|
+
for await (const [_, value] of this.db.scanPrefix(this.prefix)) {
|
|
156
|
+
const doc = JSON.parse(value.toString());
|
|
157
|
+
// Apply pre-filtering with AllowedSet
|
|
158
|
+
if (allowed.contains(doc.id, doc.metadata)) {
|
|
159
|
+
documents.push(doc);
|
|
160
|
+
}
|
|
161
|
+
}
|
|
162
|
+
// Vector search scores
|
|
163
|
+
const vectorScores = new Map();
|
|
164
|
+
documents
|
|
165
|
+
.map(doc => ({
|
|
166
|
+
id: doc.id,
|
|
167
|
+
score: cosineSimilarity(queryVector, doc.embedding),
|
|
168
|
+
}))
|
|
169
|
+
.sort((a, b) => b.score - a.score)
|
|
170
|
+
.forEach((item, rank) => {
|
|
171
|
+
vectorScores.set(item.id, { score: item.score, rank });
|
|
172
|
+
});
|
|
173
|
+
// Keyword search scores (BM25)
|
|
174
|
+
const queryTerms = queryText
|
|
175
|
+
.toLowerCase()
|
|
176
|
+
.replace(/[^\w\s]/g, ' ')
|
|
177
|
+
.split(/\s+/)
|
|
178
|
+
.filter(t => t.length > 0);
|
|
179
|
+
const keywordScores = new Map();
|
|
180
|
+
documents
|
|
181
|
+
.map(doc => ({
|
|
182
|
+
id: doc.id,
|
|
183
|
+
score: this.bm25.score(doc.id, queryTerms),
|
|
184
|
+
}))
|
|
185
|
+
.sort((a, b) => b.score - a.score)
|
|
186
|
+
.forEach((item, rank) => {
|
|
187
|
+
keywordScores.set(item.id, { score: item.score, rank });
|
|
188
|
+
});
|
|
189
|
+
// RRF (Reciprocal Rank Fusion)
|
|
190
|
+
const k_rrf = 60; // RRF constant
|
|
191
|
+
const alpha = this.config.alpha;
|
|
192
|
+
const fusedScores = documents.map(doc => {
|
|
193
|
+
const vectorData = vectorScores.get(doc.id);
|
|
194
|
+
const keywordData = keywordScores.get(doc.id);
|
|
195
|
+
const vectorScore = vectorData ? 1 / (k_rrf + vectorData.rank) : 0;
|
|
196
|
+
const keywordScore = keywordData ? 1 / (k_rrf + keywordData.rank) : 0;
|
|
197
|
+
// Weighted combination
|
|
198
|
+
const finalScore = alpha * vectorScore + (1 - alpha) * keywordScore;
|
|
199
|
+
return {
|
|
200
|
+
id: doc.id,
|
|
201
|
+
score: finalScore,
|
|
202
|
+
content: doc.content,
|
|
203
|
+
metadata: doc.metadata,
|
|
204
|
+
vectorRank: vectorData?.rank,
|
|
205
|
+
keywordRank: keywordData?.rank,
|
|
206
|
+
};
|
|
207
|
+
});
|
|
208
|
+
// Sort by fused score and take top k
|
|
209
|
+
fusedScores.sort((a, b) => b.score - a.score);
|
|
210
|
+
const results = fusedScores.slice(0, targetK);
|
|
211
|
+
return {
|
|
212
|
+
results,
|
|
213
|
+
queryTime: Date.now() - startTime,
|
|
214
|
+
totalResults: documents.length,
|
|
215
|
+
};
|
|
216
|
+
}
|
|
217
|
+
/**
|
|
218
|
+
* Explain ranking for a specific document
|
|
219
|
+
*/
|
|
220
|
+
async explain(queryText, queryVector, docId) {
|
|
221
|
+
// Simplified version - full implementation would require re-running retrieval
|
|
222
|
+
const key = Buffer.concat([this.prefix, Buffer.from(docId)]);
|
|
223
|
+
const value = await this.db.get(key);
|
|
224
|
+
if (!value) {
|
|
225
|
+
return {};
|
|
226
|
+
}
|
|
227
|
+
const doc = JSON.parse(value.toString());
|
|
228
|
+
const vectorScore = cosineSimilarity(queryVector, doc.embedding);
|
|
229
|
+
const queryTerms = queryText
|
|
230
|
+
.toLowerCase()
|
|
231
|
+
.replace(/[^\w\s]/g, ' ')
|
|
232
|
+
.split(/\s+/)
|
|
233
|
+
.filter(t => t.length > 0);
|
|
234
|
+
const keywordScore = this.bm25.score(docId, queryTerms);
|
|
235
|
+
return {
|
|
236
|
+
vectorRank: undefined, // Would need full ranking
|
|
237
|
+
keywordRank: undefined,
|
|
238
|
+
expectedRrfScore: vectorScore + keywordScore, // Simplified
|
|
239
|
+
};
|
|
240
|
+
}
|
|
241
|
+
}
|
|
242
|
+
exports.HybridRetriever = HybridRetriever;
|
|
243
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmV0cmlldmFsLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL21lbW9yeS9yZXRyaWV2YWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBOzs7O0dBSUc7OztBQVVIOztHQUVHO0FBQ0gsTUFBTSxVQUFVO0lBQ04sRUFBRSxHQUFHLEdBQUcsQ0FBQztJQUNULENBQUMsR0FBRyxJQUFJLENBQUM7SUFDVCxZQUFZLENBQVM7SUFDckIsVUFBVSxDQUFzQjtJQUNoQyxTQUFTLENBQW1DO0lBQzVDLFFBQVEsQ0FBc0I7SUFDOUIsT0FBTyxDQUFTO0lBRXhCO1FBQ0UsSUFBSSxDQUFDLFlBQVksR0FBRyxDQUFDLENBQUM7UUFDdEIsSUFBSSxDQUFDLFVBQVUsR0FBRyxJQUFJLEdBQUcsRUFBRSxDQUFDO1FBQzVCLElBQUksQ0FBQyxTQUFTLEdBQUcsSUFBSSxHQUFHLEVBQUUsQ0FBQztRQUMzQixJQUFJLENBQUMsUUFBUSxHQUFHLElBQUksR0FBRyxFQUFFLENBQUM7UUFDMUIsSUFBSSxDQUFDLE9BQU8sR0FBRyxDQUFDLENBQUM7SUFDbkIsQ0FBQztJQUVEOztPQUVHO0lBQ0gsYUFBYSxDQUFDLEtBQWEsRUFBRSxJQUFZO1FBQ3ZDLE1BQU0sS0FBSyxHQUFHLElBQUksQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDbEMsTUFBTSxVQUFVLEdBQUcsSUFBSSxHQUFHLEVBQWtCLENBQUM7UUFFN0MsS0FBSyxNQUFNLElBQUksSUFBSSxLQUFLLEVBQUUsQ0FBQztZQUN6QixVQUFVLENBQUMsR0FBRyxDQUFDLElBQUksRUFBRSxDQUFDLFVBQVUsQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUM7UUFDeEQsQ0FBQztRQUVELElBQUksQ0FBQyxVQUFVLENBQUMsR0FBRyxDQUFDLEtBQUssRUFBRSxLQUFLLENBQUMsTUFBTSxDQUFDLENBQUM7UUFDekMsSUFBSSxD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TSxHQUFHLENBQUMsQ0FBQyxDQUFDO1FBQzdCLE1BQU0sWUFBWSxHQUFHLElBQUksQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLEtBQUssRUFBRSxVQUFVLENBQUMsQ0FBQztRQUV4RCxPQUFPO1lBQ0wsVUFBVSxFQUFFLFNBQVMsRUFBRSwwQkFBMEI7WUFDakQsV0FBVyxFQUFFLFNBQVM7WUFDdEIsZ0JBQWdCLEVBQUUsV0FBVyxHQUFHLFlBQVksRUFBRSxhQUFhO1NBQzVELENBQUM7SUFDSixDQUFDO0NBQ0Y7QUExTEQsMENBMExDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBIeWJyaWQgUmV0cmlldmVyIGZvciBNZW1vcnkgU3lzdGVtXG4gKiBcbiAqIENvbWJpbmVzIHZlY3RvciBhbmQga2V5d29yZCBzZWFyY2ggd2l0aCBSUkYgKFJlY2lwcm9jYWwgUmFuayBGdXNpb24pLlxuICovXG5cbmltcG9ydCB7IEVtYmVkZGVkRGF0YWJhc2UgfSBmcm9tICcuLi9lbWJlZGRlZCc7XG5pbXBvcnQge1xuICBBbGxvd2VkU2V0LFxuICBSZXRyaWV2YWxDb25maWcsXG4gIFJldHJpZXZhbFJlc3BvbnNlLFxuICBSZXRyaWV2YWxSZXN1bHQsXG59IGZyb20gJy4vdHlwZXMnO1xuXG4vKipcbiAqIFNpbXBsZSBCTTI1IHNjb3JlciBmb3Iga2V5d29yZCBtYXRjaGluZ1xuICovXG5jbGFzcyBCTTI1U2NvcmVyIHtcbiAgcHJpdmF0ZSBrMSA9IDEuNTtcbiAgcHJpdmF0ZSBiID0gMC43NTtcbiAgcHJpdmF0ZSBhdmdEb2NMZW5ndGg6IG51bWJlcjtcbiAgcHJpdmF0ZSBkb2NMZW5ndGhzOiBNYXA8c3RyaW5nLCBudW1iZXI+O1xuICBwcml2YXRlIHRlcm1GcmVxczogTWFwPHN0cmluZywgTWFwPHN0cmluZywgbnVtYmVyPj47XG4gIHByaXZhdGUgZG9jRnJlcXM6IE1hcDxzdHJpbmcsIG51bWJlcj47XG4gIHByaXZhdGUgbnVtRG9jczogbnVtYmVyO1xuXG4gIGNvbnN0cnVjdG9yKCkge1xuICAgIHRoaXMuYXZnRG9jTGVuZ3RoID0gMDtcbiAgICB0aGlzLmRvY0xlbmd0aHMgPSBuZXcgTWFwKCk7XG4gICAgdGhpcy50ZXJtRnJlcXMgPSBuZXcgTWFwKCk7XG4gICAgdGhpcy5kb2NGcmVxcyA9IG5ldyBNYXAoKTtcbiAgICB0aGlzLm51bURvY3MgPSAwO1xuICB9XG5cbiAgLyoqXG4gICAqIEluZGV4IGEgZG9jdW1lbnRcbiAgICovXG4gIGluZGV4RG9jdW1lbnQoZG9jSWQ6IHN0cmluZywgdGV4dDogc3RyaW5nKTogdm9pZCB7XG4gICAgY29uc3QgdGVybXMgPSB0aGlzLnRva2VuaXplKHRleHQpO1xuICAgIGNvbnN0IHRlcm1Db3VudHMgPSBuZXcgTWFwPHN0cmluZywgbnVtYmVyPigpO1xuXG4gICAgZm9yIChjb25zdCB0ZXJtIG9mIHRlcm1zKSB7XG4gICAgICB0ZXJtQ291bnRzLnNldCh0ZXJtLCAodGVybUNvdW50cy5nZXQodGVybSkgfHwgMCkgKyAxKTtcbiAgICB9XG5cbiAgICB0aGlzLmRvY0xlbmd0aHMuc2V0KGRvY0lkLCB0ZXJtcy5sZW5ndGgpO1xuICAgIHRoaXMudGVybUZyZXFzLnNldChkb2NJZCwgdGVybUNvdW50cyk7XG5cbiAgICBmb3IgKGNvbnN0IHRlcm0gb2YgdGVybUNvdW50cy5rZXlzKCkpIHtcbiAgICAgIHRoaXMuZG9jRnJlcXMuc2V0KHRlcm0sICh0aGlzLmRvY0ZyZXFzLmdldCh0ZXJtKSB8fCAwKSArIDEpO1xuICAgIH1cblxuICAgIHRoaXMubnVtRG9jcysrO1xuICAgIHRoaXMudXBkYXRlQXZnRG9jTGVuZ3RoKCk7XG4gIH1cblxuICAvKipcbiAgICogU2NvcmUgYSBxdWVyeSBhZ2FpbnN0IGEgZG9jdW1lbnRcbiAgICovXG4gIHNjb3JlKGRvY0lkOiBzdHJpbmcsIHF1ZXJ5VGVybXM6IHN0cmluZ1tdKTogbnVtYmVyIHtcbiAgICBjb25zdCB0ZXJtQ291bnRzID0gdGhpcy50ZXJtRnJlcXMuZ2V0KGRvY0lkKTtcbiAgICBpZiAoIXRlcm1Db3VudHMpIHJldHVybiAwO1xuXG4gICAgY29uc3QgZG9jTGVuZ3RoID0gdGhpcy5kb2NMZW5ndGhzLmdldChkb2NJZCkgfHwgMDtcbiAgICBsZXQgc2NvcmUgPSAwO1xuXG4gICAgZm9yIChjb25zdCB0ZXJtIG9mIHF1ZXJ5VGVybXMpIHtcbiAgICAgIGNvbnN0IHRmID0gdGVybUNvdW50cy5nZXQodGVybSkgfHwgMDtcbiAgICAgIGNvbnN0IGRmID0gdGhpcy5kb2NGcmVxcy5nZXQodGVybSkgfHwgMDtcbiAgICAgIFxuICAgICAgaWYgKHRmID09PSAwKSBjb250aW51ZTtcblxuICAgICAgY29uc3QgaWRmID0gTWF0aC5sb2coKHRoaXMubnVtRG9jcyAtIGRmICsgMC41KSAvIChkZiArIDAuNSkgKyAxKTtcbiAgICAgIGNvbnN0IG5vcm0gPSB0ZiAvICh0ZiArIHRoaXMuazEgKiAoMSAtIHRoaXMuYiArIHRoaXMuYiAqIChkb2NMZW5ndGggLyB0aGlzLmF2Z0RvY0xlbmd0aCkpKTtcbiAgICAgIFxuICAgICAgc2NvcmUgKz0gaWRmICogbm9ybTtcbiAgICB9XG5cbiAgICByZXR1cm4gc2NvcmU7XG4gIH1cblxuICAvKipcbiAgICogVG9rZW5pemUgdGV4dCBpbnRvIHRlcm1zXG4gICAqL1xuICBwcml2YXRlIHRva2VuaXplKHRleHQ6IHN0cmluZyk6IHN0cmluZ1tdIHtcbiAgICByZXR1cm4gdGV4dFxuICAgICAgLnRvTG93ZXJDYXNlKClcbiAgICAgIC5yZXBsYWNlKC9bXlxcd1xcc10vZywgJyAnKVxuICAgICAgLnNwbGl0KC9cXHMrLylcbiAgICAgIC5maWx0ZXIodCA9PiB0Lmxlbmd0aCA+IDApO1xuICB9XG5cbiAgLyoqXG4gICAqIFVwZGF0ZSBhdmVyYWdlIGRvY3VtZW50IGxlbmd0aFxuICAgKi9cbiAgcHJpdmF0ZSB1cGRhdGVBdmdEb2NMZW5ndGgoKTogdm9pZCB7XG4gICAgY29uc3QgdG90YWxMZW5ndGggPSBBcnJheS5mcm9tKHRoaXMuZG9jTGVuZ3Rocy52YWx1ZXMoKSkucmVkdWNlKChhLCBiKSA9PiBhICsgYiwgMCk7XG4gICAgdGhpcy5hdmdEb2NMZW5ndGggPSB0b3RhbExlbmd0aCAvIHRoaXMubnVtRG9jcztcbiAgfVxufVxuXG4vKipcbiAqIENvc2luZSBzaW1pbGFyaXR5IGZvciB2ZWN0b3Igc2VhcmNoXG4gKi9cbmZ1bmN0aW9uIGNvc2luZVNpbWlsYXJpdHkoYTogbnVtYmVyW10sIGI6IG51bWJlcltdKTogbnVtYmVyIHtcbiAgaWYgKGEubGVuZ3RoICE9PSBiLmxlbmd0aCkgcmV0dXJuIDA7XG5cbiAgbGV0IGRvdFByb2R1Y3QgPSAwO1xuICBsZXQgbm9ybUEgPSAwO1xuICBsZXQgbm9ybUIgPSAwO1xuXG4gIGZvciAobGV0IGkgPSAwOyBpIDwgYS5sZW5ndGg7IGkrKykge1xuICAgIGRvdFByb2R1Y3QgKz0gYVtpXSAqIGJbaV07XG4gICAgbm9ybUEgKz0gYVtpXSAqIGFbaV07XG4gICAgbm9ybUIgKz0gYltpXSAqIGJbaV07XG4gIH1cblxuICBpZiAobm9ybUEgPT09IDAgfHwgbm9ybUIgPT09IDApIHJldHVybiAwO1xuICByZXR1cm4gZG90UHJvZHVjdCAvIChNYXRoLnNxcnQobm9ybUEpICogTWF0aC5zcXJ0KG5vcm1CKSk7XG59XG5cbi8qKlxuICogSHlicmlkIFJldHJpZXZlciB3aXRoIFJSRiBmdXNpb25cbiAqL1xuZXhwb3J0IGNsYXNzIEh5YnJpZFJldHJpZXZlciB7XG4gIHByaXZhdGUgZGI6IEVtYmVkZGVkRGF0YWJhc2U7XG4gIHByaXZhdGUgbmFtZXNwYWNlOiBzdHJpbmc7XG4gIHByaXZhdGUgY29sbGVjdGlvbjogc3RyaW5nO1xuICBwcml2YXRlIGNvbmZpZzogUmV0cmlldmFsQ29uZmlnO1xuICBwcml2YXRlIHByZWZpeDogQnVmZmVyO1xuICBwcml2YXRlIGJtMjU6IEJNMjVTY29yZXI7XG4gIHByaXZhdGUgaW5kZXhlZDogYm9vbGVhbiA9IGZhbHNlO1xuXG4gIGNvbnN0cnVjdG9yKFxuICAgIGRiOiBFbWJlZGRlZERhdGFiYXNlLFxuICAgIG5hbWVzcGFjZTogc3RyaW5nLFxuICAgIGNvbGxlY3Rpb246IHN0cmluZyxcbiAgICBjb25maWc/OiBSZXRyaWV2YWxDb25maWdcbiAgKSB7XG4gICAgdGhpcy5kYiA9IGRiO1xuICAgIHRoaXMubmFtZXNwYWNlID0gbmFtZXNwYWNlO1xuICAgIHRoaXMuY29sbGVjdGlvbiA9IGNvbGxlY3Rpb247XG4gICAgdGhpcy5jb25maWcgPSB7XG4gICAgICBrOiBjb25maWc/LmsgfHwgMTAsXG4gICAgICBhbHBoYTogY29uZmlnPy5hbHBoYSAhPT0gdW5kZWZpbmVkID8gY29uZmlnLmFscGhhIDogMC41LFxuICAgICAgZW5hYmxlUmVyYW5rOiBjb25maWc/LmVuYWJsZVJlcmFuayB8fCBmYWxzZSxcbiAgICAgIHJlcmFua0s6IGNvbmZpZz8ucmVyYW5rSyB8fCAxMDAsXG4gICAgfTtcbiAgICB0aGlzLnByZWZpeCA9IEJ1ZmZlci5mcm9tKGByZXRyaWV2YWw6JHtuYW1lc3BhY2V9OiR7Y29sbGVjdGlvbn06YCk7XG4gICAgdGhpcy5ibTI1ID0gbmV3IEJNMjVTY29yZXIoKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBDcmVhdGUgcmV0cmlldmVyIGZyb20gZGF0YWJhc2VcbiAgICovXG4gIHN0YXRpYyBmcm9tRGF0YWJhc2UoXG4gICAgZGI6IEVtYmVkZGVkRGF0YWJhc2UsXG4gICAgbmFtZXNwYWNlOiBzdHJpbmcsXG4gICAgY29sbGVjdGlvbjogc3RyaW5nLFxuICAgIGNvbmZpZz86IFJldHJpZXZhbENvbmZpZ1xuICApOiBIeWJyaWRSZXRyaWV2ZXIge1xuICAgIHJldHVybiBuZXcgSHlicmlkUmV0cmlldmVyKGRiLCBuYW1lc3BhY2UsIGNvbGxlY3Rpb24sIGNvbmZpZyk7XG4gIH1cblxuICAvKipcbiAgICogSW5kZXggZG9jdW1lbnRzIGZvciByZXRyaWV2YWxcbiAgICovXG4gIGFzeW5jIGluZGV4RG9jdW1lbnRzKGRvY3VtZW50czogQXJyYXk8eyBpZDogc3RyaW5nOyBjb250ZW50OiBzdHJpbmc7IGVtYmVkZGluZzogbnVtYmVyW107IG1ldGFkYXRhPzogUmVjb3JkPHN0cmluZywgYW55PiB9Pik6IFByb21pc2U8dm9pZD4ge1xuICAgIGZvciAoY29uc3QgZG9jIG9mIGRvY3VtZW50cykge1xuICAgICAgY29uc3Qga2V5ID0gQnVmZmVyLmNvbmNhdChbdGhpcy5wcmVmaXgsIEJ1ZmZlci5mcm9tKGRvYy5pZCldKTtcbiAgICAgIGF3YWl0IHRoaXMuZGIucHV0KGtleSwgQnVmZmVyLmZyb20oSlNPTi5zdHJpbmdpZnkoe1xuICAgICAgICBpZDogZG9jLmlkLFxuICAgICAgICBjb250ZW50OiBkb2MuY29udGVudCxcbiAgICAgICAgZW1iZWRkaW5nOiBkb2MuZW1iZWRkaW5nLFxuICAgICAgICBtZXRhZGF0YTogZG9jLm1ldGFkYXRhLFxuICAgICAgfSkpKTtcblxuICAgICAgLy8gSW5kZXggZm9yIEJNMjVcbiAgICAgIHRoaXMuYm0yNS5pbmRleERvY3VtZW50KGRvYy5pZCwgZG9jLmNvbnRlbnQpO1xuICAgIH1cblxuICAgIHRoaXMuaW5kZXhlZCA9IHRydWU7XG4gIH1cblxuICAvKipcbiAgICogUmV0cmlldmUgZG9jdW1lbnRzIHdpdGggaHlicmlkIHNlYXJjaFxuICAgKi9cbiAgYXN5bmMgcmV0cmlldmUoXG4gICAgcXVlcnlUZXh0OiBzdHJpbmcsXG4gICAgcXVlcnlWZWN0b3I6IG51bWJlcltdLFxuICAgIGFsbG93ZWQ6IEFsbG93ZWRTZXQsXG4gICAgaz86IG51bWJlclxuICApOiBQcm9taXNlPFJldHJpZXZhbFJlc3BvbnNlPiB7XG4gICAgY29uc3Qgc3RhcnRUaW1lID0gRGF0ZS5ub3coKTtcbiAgICBjb25zdCB0YXJnZXRLID0gayB8fCB0aGlzLmNvbmZpZy5rITtcblxuICAgIC8vIEdldCBhbGwgZG9jdW1lbnRzXG4gICAgY29uc3QgZG9jdW1lbnRzOiBBcnJheTx7XG4gICAgICBpZDogc3RyaW5nO1xuICAgICAgY29udGVudDogc3RyaW5nO1xuICAgICAgZW1iZWRkaW5nOiBudW1iZXJbXTtcbiAgICAgIG1ldGFkYXRhPzogUmVjb3JkPHN0cmluZywgYW55PjtcbiAgICB9PiA9IFtdO1xuXG4gICAgZm9yIGF3YWl0IChjb25zdCBbXywgdmFsdWVdIG9mIHRoaXMuZGIuc2NhblByZWZpeCh0aGlzLnByZWZpeCkpIHtcbiAgICAgIGNvbnN0IGRvYyA9IEpTT04ucGFyc2UodmFsdWUudG9TdHJpbmcoKSk7XG4gICAgICBcbiAgICAgIC8vIEFwcGx5IHByZS1maWx0ZXJpbmcgd2l0aCBBbGxvd2VkU2V0XG4gICAgICBpZiAoYWxsb3dlZC5jb250YWlucyhkb2MuaWQsIGRvYy5tZXRhZGF0YSkpIHtcbiAgICAgICAgZG9jdW1lbnRzLnB1c2goZG9jKTtcbiAgICAgIH1cbiAgICB9XG5cbiAgICAvLyBWZWN0b3Igc2VhcmNoIHNjb3Jlc1xuICAgIGNvbnN0IHZlY3RvclNjb3JlcyA9IG5ldyBNYXA8c3RyaW5nLCB7IHNjb3JlOiBudW1iZXI7IHJhbms6IG51bWJlciB9PigpO1xuICAgIGRvY3VtZW50c1xuICAgICAgLm1hcChkb2MgPT4gKHtcbiAgICAgICAgaWQ6IGRvYy5pZCxcbiAgICAgICAgc2NvcmU6IGNvc2luZVNpbWlsYXJpdHkocXVlcnlWZWN0b3IsIGRvYy5lbWJlZGRpbmcpLFxuICAgICAgfSkpXG4gICAgICAuc29ydCgoYSwgYikgPT4gYi5zY29yZSAtIGEuc2NvcmUpXG4gICAgICAuZm9yRWFjaCgoaXRlbSwgcmFuaykgPT4ge1xuICAgICAgICB2ZWN0b3JTY29yZXMuc2V0KGl0ZW0uaWQsIHsgc2NvcmU6IGl0ZW0uc2NvcmUsIHJhbmsgfSk7XG4gICAgICB9KTtcblxuICAgIC8vIEtleXdvcmQgc2VhcmNoIHNjb3JlcyAoQk0yNSlcbiAgICBjb25zdCBxdWVyeVRlcm1zID0gcXVlcnlUZXh0XG4gICAgICAudG9Mb3dlckNhc2UoKVxuICAgICAgLnJlcGxhY2UoL1teXFx3XFxzXS9nLCAnICcpXG4gICAgICAuc3BsaXQoL1xccysvKVxuICAgICAgLmZpbHRlcih0ID0+IHQubGVuZ3RoID4gMCk7XG5cbiAgICBjb25zdCBrZXl3b3JkU2NvcmVzID0gbmV3IE1hcDxzdHJpbmcsIHsgc2NvcmU6IG51bWJlcjsgcmFuazogbnVtYmVyIH0+KCk7XG4gICAgZG9jdW1lbnRzXG4gICAgICAubWFwKGRvYyA9PiAoe1xuICAgICAgICBpZDogZG9jLmlkLFxuICAgICAgICBzY29yZTogdGhpcy5ibTI1LnNjb3JlKGRvYy5pZCwgcXVlcnlUZXJtcyksXG4gICAgICB9KSlcbiAgICAgIC5zb3J0KChhLCBiKSA9PiBiLnNjb3JlIC0gYS5zY29yZSlcbiAgICAgIC5mb3JFYWNoKChpdGVtLCByYW5rKSA9PiB7XG4gICAgICAgIGtleXdvcmRTY29yZXMuc2V0KGl0ZW0uaWQsIHsgc2NvcmU6IGl0ZW0uc2NvcmUsIHJhbmsgfSk7XG4gICAgICB9KTtcblxuICAgIC8vIFJSRiAoUmVjaXByb2NhbCBSYW5rIEZ1c2lvbilcbiAgICBjb25zdCBrX3JyZiA9IDYwOyAvLyBSUkYgY29uc3RhbnRcbiAgICBjb25zdCBhbHBoYSA9IHRoaXMuY29uZmlnLmFscGhhITtcbiAgICBcbiAgICBjb25zdCBmdXNlZFNjb3JlcyA9IGRvY3VtZW50cy5tYXAoZG9jID0+IHtcbiAgICAgIGNvbnN0IHZlY3RvckRhdGEgPSB2ZWN0b3JTY29yZXMuZ2V0KGRvYy5pZCk7XG4gICAgICBjb25zdCBrZXl3b3JkRGF0YSA9IGtleXdvcmRTY29yZXMuZ2V0KGRvYy5pZCk7XG4gICAgICBcbiAgICAgIGNvbnN0IHZlY3RvclNjb3JlID0gdmVjdG9yRGF0YSA/IDEgLyAoa19ycmYgKyB2ZWN0b3JEYXRhLnJhbmspIDogMDtcbiAgICAgIGNvbnN0IGtleXdvcmRTY29yZSA9IGtleXdvcmREYXRhID8gMSAvIChrX3JyZiArIGtleXdvcmREYXRhLnJhbmspIDogMDtcbiAgICAgIFxuICAgICAgLy8gV2VpZ2h0ZWQgY29tYmluYXRpb25cbiAgICAgIGNvbnN0IGZpbmFsU2NvcmUgPSBhbHBoYSAqIHZlY3RvclNjb3JlICsgKDEgLSBhbHBoYSkgKiBrZXl3b3JkU2NvcmU7XG5cbiAgICAgIHJldHVybiB7XG4gICAgICAgIGlkOiBkb2MuaWQsXG4gICAgICAgIHNjb3JlOiBmaW5hbFNjb3JlLFxuICAgICAgICBjb250ZW50OiBkb2MuY29udGVudCxcbiAgICAgICAgbWV0YWRhdGE6IGRvYy5tZXRhZGF0YSxcbiAgICAgICAgdmVjdG9yUmFuazogdmVjdG9yRGF0YT8ucmFuayxcbiAgICAgICAga2V5d29yZFJhbms6IGtleXdvcmREYXRhPy5yYW5rLFxuICAgICAgfTtcbiAgICB9KTtcblxuICAgIC8vIFNvcnQgYnkgZnVzZWQgc2NvcmUgYW5kIHRha2UgdG9wIGtcbiAgICBmdXNlZFNjb3Jlcy5zb3J0KChhLCBiKSA9PiBiLnNjb3JlIC0gYS5zY29yZSk7XG4gICAgY29uc3QgcmVzdWx0cyA9IGZ1c2VkU2NvcmVzLnNsaWNlKDAsIHRhcmdldEspO1xuXG4gICAgcmV0dXJuIHtcbiAgICAgIHJlc3VsdHMsXG4gICAgICBxdWVyeVRpbWU6IERhdGUubm93KCkgLSBzdGFydFRpbWUsXG4gICAgICB0b3RhbFJlc3VsdHM6IGRvY3VtZW50cy5sZW5ndGgsXG4gICAgfTtcbiAgfVxuXG4gIC8qKlxuICAgKiBFeHBsYWluIHJhbmtpbmcgZm9yIGEgc3BlY2lmaWMgZG9jdW1lbnRcbiAgICovXG4gIGFzeW5jIGV4cGxhaW4oXG4gICAgcXVlcnlUZXh0OiBzdHJpbmcsXG4gICAgcXVlcnlWZWN0b3I6IG51bWJlcltdLFxuICAgIGRvY0lkOiBzdHJpbmdcbiAgKTogUHJvbWlzZTx7IHZlY3RvclJhbms/OiBudW1iZXI7IGtleXdvcmRSYW5rPzogbnVtYmVyOyBleHBlY3RlZFJyZlNjb3JlPzogbnVtYmVyIH0+IHtcbiAgICAvLyBTaW1wbGlmaWVkIHZlcnNpb24gLSBmdWxsIGltcGxlbWVudGF0aW9uIHdvdWxkIHJlcXVpcmUgcmUtcnVubmluZyByZXRyaWV2YWxcbiAgICBjb25zdCBrZXkgPSBCdWZmZXIuY29uY2F0KFt0aGlzLnByZWZpeCwgQnVmZmVyLmZyb20oZG9jSWQpXSk7XG4gICAgY29uc3QgdmFsdWUgPSBhd2FpdCB0aGlzLmRiLmdldChrZXkpO1xuICAgIFxuICAgIGlmICghdmFsdWUpIHtcbiAgICAgIHJldHVybiB7fTtcbiAgICB9XG5cbiAgICBjb25zdCBkb2MgPSBKU09OLnBhcnNlKHZhbHVlLnRvU3RyaW5nKCkpO1xuICAgIFxuICAgIGNvbnN0IHZlY3RvclNjb3JlID0gY29zaW5lU2ltaWxhcml0eShxdWVyeVZlY3RvciwgZG9jLmVtYmVkZGluZyk7XG4gICAgY29uc3QgcXVlcnlUZXJtcyA9IHF1ZXJ5VGV4dFxuICAgICAgLnRvTG93ZXJDYXNlKClcbiAgICAgIC5yZXBsYWNlKC9bXlxcd1xcc10vZywgJyAnKVxuICAgICAgLnNwbGl0KC9cXHMrLylcbiAgICAgIC5maWx0ZXIodCA9PiB0Lmxlbmd0aCA+IDApO1xuICAgIGNvbnN0IGtleXdvcmRTY29yZSA9IHRoaXMuYm0yNS5zY29yZShkb2NJZCwgcXVlcnlUZXJtcyk7XG5cbiAgICByZXR1cm4ge1xuICAgICAgdmVjdG9yUmFuazogdW5kZWZpbmVkLCAvLyBXb3VsZCBuZWVkIGZ1bGwgcmFua2luZ1xuICAgICAga2V5d29yZFJhbms6IHVuZGVmaW5lZCxcbiAgICAgIGV4cGVjdGVkUnJmU2NvcmU6IHZlY3RvclNjb3JlICsga2V5d29yZFNjb3JlLCAvLyBTaW1wbGlmaWVkXG4gICAgfTtcbiAgfVxufVxuIl19
|
|
@@ -0,0 +1,72 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Memory System Core Types
|
|
4
|
+
*
|
|
5
|
+
* Type definitions for LLM-native memory system with extraction,
|
|
6
|
+
* consolidation, and retrieval capabilities.
|
|
7
|
+
*/
|
|
8
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
9
|
+
exports.NamespacePolicy = exports.AllowedSet = void 0;
|
|
10
|
+
/**
|
|
11
|
+
* AllowedSet for pre-filtering
|
|
12
|
+
*/
|
|
13
|
+
class AllowedSet {
|
|
14
|
+
static fromIds(ids) {
|
|
15
|
+
return new IdsAllowedSet(new Set(ids));
|
|
16
|
+
}
|
|
17
|
+
static fromNamespace(namespace) {
|
|
18
|
+
return new NamespaceAllowedSet(namespace);
|
|
19
|
+
}
|
|
20
|
+
static fromFilter(filterFn) {
|
|
21
|
+
return new FilterAllowedSet(filterFn);
|
|
22
|
+
}
|
|
23
|
+
static allowAll() {
|
|
24
|
+
return new AllAllowedSet();
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
exports.AllowedSet = AllowedSet;
|
|
28
|
+
class IdsAllowedSet extends AllowedSet {
|
|
29
|
+
ids;
|
|
30
|
+
constructor(ids) {
|
|
31
|
+
super();
|
|
32
|
+
this.ids = ids;
|
|
33
|
+
}
|
|
34
|
+
contains(id) {
|
|
35
|
+
return this.ids.has(id);
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
class NamespaceAllowedSet extends AllowedSet {
|
|
39
|
+
namespace;
|
|
40
|
+
constructor(namespace) {
|
|
41
|
+
super();
|
|
42
|
+
this.namespace = namespace;
|
|
43
|
+
}
|
|
44
|
+
contains(id) {
|
|
45
|
+
return id.startsWith(`${this.namespace}_`) || id.startsWith(`${this.namespace}:`);
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
class FilterAllowedSet extends AllowedSet {
|
|
49
|
+
filterFn;
|
|
50
|
+
constructor(filterFn) {
|
|
51
|
+
super();
|
|
52
|
+
this.filterFn = filterFn;
|
|
53
|
+
}
|
|
54
|
+
contains(id, metadata) {
|
|
55
|
+
return this.filterFn(id, metadata);
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
class AllAllowedSet extends AllowedSet {
|
|
59
|
+
contains() {
|
|
60
|
+
return true;
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
/**
|
|
64
|
+
* Namespace policy
|
|
65
|
+
*/
|
|
66
|
+
var NamespacePolicy;
|
|
67
|
+
(function (NamespacePolicy) {
|
|
68
|
+
NamespacePolicy["STRICT"] = "strict";
|
|
69
|
+
NamespacePolicy["EXPLICIT"] = "explicit";
|
|
70
|
+
NamespacePolicy["PERMISSIVE"] = "permissive";
|
|
71
|
+
})(NamespacePolicy || (exports.NamespacePolicy = NamespacePolicy = {}));
|
|
72
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvbWVtb3J5L3R5cGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQTs7Ozs7R0FLRzs7O0FBNEhIOztHQUVHO0FBQ0gsTUFBc0IsVUFBVTtJQUc5QixNQUFNLENBQUMsT0FBTyxDQUFDLEdBQWE7UUFDMUIsT0FBTyxJQUFJLGFBQWEsQ0FBQyxJQUFJLEdBQUcsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDO0lBQ3pDLENBQUM7SUFFRCxNQUFNLENBQUMsYUFBYSxDQUFDLFNBQWlCO1FBQ3BDLE9BQU8sSUFBSSxtQkFBbUIsQ0FBQyxTQUFTLENBQUMsQ0FBQztJQUM1QyxDQUFDO0lBRUQsTUFBTSxDQUFDLFVBQVUsQ0FBQyxRQUFpRTtRQUNqRixPQUFPLElBQUksZ0JBQWdCLENBQUMsUUFBUSxDQUFDLENBQUM7SUFDeEMsQ0FBQztJQUVELE1BQU0sQ0FBQyxRQUFRO1FBQ2IsT0FBTyxJQUFJLGFBQWEsRUFBRSxDQUFDO0lBQzdCLENBQUM7Q0FDRjtBQWxCRCxnQ0FrQkM7QUFFRCxNQUFNLGFBQWMsU0FBUSxVQUFVO0lBQ2hCO0lBQXBCLFlBQW9CLEdBQWdCO1FBQ2xDLEtBQUssRUFBRSxDQUFDO1FBRFUsUUFBRyxHQUFILEdBQUcsQ0FBYTtJQUVwQyxDQUFDO0lBRUQsUUFBUSxDQUFDLEVBQVU7UUFDakIsT0FBTyxJQUFJLENBQUMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsQ0FBQztJQUMxQixDQUFDO0NBQ0Y7QUFFRCxNQUFNLG1CQUFvQixTQUFRLFVBQVU7SUFDdEI7SUFBcEIsWUFBb0IsU0FBaUI7UUFDbkMsS0FBSyxFQUFFLENBQUM7UUFEVSxjQUFTLEdBQVQsU0FBUyxDQUFRO0lBRXJDLENBQUM7SUFFRCxRQUFRLENBQUMsRUFBVTtRQUNqQixPQUFPLEVBQUUsQ0FBQyxVQUFVLENBQUMsR0FBRyxJQUFJLENBQUMsU0FBUyxHQUFHLENBQUMsSUFBSSxFQUFFLENBQUMsVUFBVSxDQUFDLEdBQUcsSUFBSSxDQUFDLFNBQVMsR0FBRyxDQUFDLENBQUM7SUFDcEYsQ0FBQztDQUNGO0FBRUQsTUFBTSxnQkFBaUIsU0FBUSxVQUFVO0lBQ25CO0lBQXBCLFlBQW9CLFFBQWlFO1FBQ25GLEtBQUssRUFBRSxDQUFDO1FBRFUsYUFBUSxHQUFSLFFBQVEsQ0FBeUQ7SUFFckYsQ0FBQztJQUVELFFBQVEsQ0FBQyxFQUFVLEVBQUUsUUFBOEI7UUFDakQsT0FBTyxJQUFJLENBQUMsUUFBUSxDQUFDLEVBQUUsRUFBRSxRQUFRLENBQUMsQ0FBQztJQUNyQyxDQUFDO0NBQ0Y7QUFFRCxNQUFNLGFBQWMsU0FBUSxVQUFVO0lBQ3BDLFFBQVE7UUFDTixPQUFPLElBQUksQ0FBQztJQUNkLENBQUM7Q0FDRjtBQUVEOztHQUVHO0FBQ0gsSUFBWSxlQUlYO0FBSkQsV0FBWSxlQUFlO0lBQ3pCLG9DQUFpQixDQUFBO0lBQ2pCLHdDQUFxQixDQUFBO0lBQ3JCLDRDQUF5QixDQUFBO0FBQzNCLENBQUMsRUFKVyxlQUFlLCtCQUFmLGVBQWUsUUFJMUIiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIE1lbW9yeSBTeXN0ZW0gQ29yZSBUeXBlc1xuICogXG4gKiBUeXBlIGRlZmluaXRpb25zIGZvciBMTE0tbmF0aXZlIG1lbW9yeSBzeXN0ZW0gd2l0aCBleHRyYWN0aW9uLFxuICogY29uc29saWRhdGlvbiwgYW5kIHJldHJpZXZhbCBjYXBhYmlsaXRpZXMuXG4gKi9cblxuLyoqXG4gKiBFbnRpdHkgZXh0cmFjdGVkIGZyb20gdGV4dFxuICovXG5leHBvcnQgaW50ZXJmYWNlIEVudGl0eSB7XG4gIGlkPzogc3RyaW5nO1xuICBuYW1lOiBzdHJpbmc7XG4gIGVudGl0eVR5cGU6IHN0cmluZztcbiAgcHJvcGVydGllcz86IFJlY29yZDxzdHJpbmcsIGFueT47XG4gIGNvbmZpZGVuY2U/OiBudW1iZXI7XG4gIHByb3ZlbmFuY2U/OiBzdHJpbmc7XG4gIHRpbWVzdGFtcD86IG51bWJlcjtcbn1cblxuLyoqXG4gKiBSZWxhdGlvbiBiZXR3ZWVuIHR3byBlbnRpdGllc1xuICovXG5leHBvcnQgaW50ZXJmYWNlIFJlbGF0aW9uIHtcbiAgaWQ/OiBzdHJpbmc7XG4gIGZyb21FbnRpdHk6IHN0cmluZztcbiAgcmVsYXRpb25UeXBlOiBzdHJpbmc7XG4gIHRvRW50aXR5OiBzdHJpbmc7XG4gIHByb3BlcnRpZXM/OiBSZWNvcmQ8c3RyaW5nLCBhbnk+O1xuICBjb25maWRlbmNlPzogbnVtYmVyO1xuICBwcm92ZW5hbmNlPzogc3RyaW5nO1xuICB0aW1lc3RhbXA/OiBudW1iZXI7XG59XG5cbi8qKlxuICogQXNzZXJ0aW9uIChzdWJqZWN0LXByZWRpY2F0ZS1vYmplY3QgdHJpcGxlKVxuICovXG5leHBvcnQgaW50ZXJmYWNlIEFzc2VydGlvbiB7XG4gIGlkPzogc3RyaW5nO1xuICBzdWJqZWN0OiBzdHJpbmc7XG4gIHByZWRpY2F0ZTogc3RyaW5nO1xuICBvYmplY3Q6IHN0cmluZztcbiAgY29uZmlkZW5jZT86IG51bWJlcjtcbiAgcHJvdmVuYW5jZT86IHN0cmluZztcbiAgdGltZXN0YW1wPzogbnVtYmVyO1xufVxuXG4vKipcbiAqIFJhdyBhc3NlcnRpb24gZm9yIGNvbnNvbGlkYXRpb25cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBSYXdBc3NlcnRpb24ge1xuICBpZD86IHN0cmluZztcbiAgZmFjdDogUmVjb3JkPHN0cmluZywgYW55PjtcbiAgc291cmNlOiBzdHJpbmc7XG4gIGNvbmZpZGVuY2U6IG51bWJlcjtcbiAgdGltZXN0YW1wPzogbnVtYmVyO1xufVxuXG4vKipcbiAqIENhbm9uaWNhbCBmYWN0IGFmdGVyIGNvbnNvbGlkYXRpb25cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBDYW5vbmljYWxGYWN0IHtcbiAgaWQ6IHN0cmluZztcbiAgbWVyZ2VkRmFjdDogUmVjb3JkPHN0cmluZywgYW55PjtcbiAgY29uZmlkZW5jZTogbnVtYmVyO1xuICBzb3VyY2VzOiBzdHJpbmdbXTtcbiAgdmFsaWRGcm9tOiBudW1iZXI7XG4gIHZhbGlkVW50aWw/OiBudW1iZXI7XG59XG5cbi8qKlxuICogRXh0cmFjdGlvbiByZXN1bHQgZnJvbSBMTE1cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBFeHRyYWN0aW9uUmVzdWx0IHtcbiAgZW50aXRpZXM6IEVudGl0eVtdO1xuICByZWxhdGlvbnM6IFJlbGF0aW9uW107XG4gIGFzc2VydGlvbnM6IEFzc2VydGlvbltdO1xufVxuXG4vKipcbiAqIEV4dHJhY3Rpb24gc2NoZW1hIGZvciB2YWxpZGF0aW9uXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgRXh0cmFjdGlvblNjaGVtYSB7XG4gIGVudGl0eVR5cGVzPzogc3RyaW5nW107XG4gIHJlbGF0aW9uVHlwZXM/OiBzdHJpbmdbXTtcbiAgbWluQ29uZmlkZW5jZT86IG51bWJlcjtcbiAgcmVxdWlyZVByb3ZlbmFuY2U/OiBib29sZWFuO1xufVxuXG4vKipcbiAqIENvbnNvbGlkYXRpb24gY29uZmlndXJhdGlvblxuICovXG5leHBvcnQgaW50ZXJmYWNlIENvbnNvbGlkYXRpb25Db25maWcge1xuICBzaW1pbGFyaXR5VGhyZXNob2xkPzogbnVtYmVyO1xuICB1c2VUZW1wb3JhbFVwZGF0ZXM/OiBib29sZWFuO1xuICBtYXhDb25mbGljdEFnZT86IG51bWJlcjsgLy8gc2Vjb25kc1xufVxuXG4vKipcbiAqIFJldHJpZXZhbCBjb25maWd1cmF0aW9uXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgUmV0cmlldmFsQ29uZmlnIHtcbiAgaz86IG51bWJlcjtcbiAgYWxwaGE/OiBudW1iZXI7IC8vIDA9a2V5d29yZCBvbmx5LCAxPXZlY3RvciBvbmx5LCAwLjU9YmFsYW5jZWRcbiAgZW5hYmxlUmVyYW5rPzogYm9vbGVhbjtcbiAgcmVyYW5rSz86IG51bWJlcjtcbn1cblxuLyoqXG4gKiBSZXRyaWV2YWwgcmVzdWx0XG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgUmV0cmlldmFsUmVzdWx0IHtcbiAgaWQ6IHN0cmluZztcbiAgc2NvcmU6IG51bWJlcjtcbiAgY29udGVudDogc3RyaW5nO1xuICBtZXRhZGF0YT86IFJlY29yZDxzdHJpbmcsIGFueT47XG4gIHZlY3RvclJhbms/OiBudW1iZXI7XG4gIGtleXdvcmRSYW5rPzogbnVtYmVyO1xufVxuXG4vKipcbiAqIFJldHJpZXZhbCByZXNwb25zZVxuICovXG5leHBvcnQgaW50ZXJmYWNlIFJldHJpZXZhbFJlc3BvbnNlIHtcbiAgcmVzdWx0czogUmV0cmlldmFsUmVzdWx0W107XG4gIHF1ZXJ5VGltZTogbnVtYmVyO1xuICB0b3RhbFJlc3VsdHM6IG51bWJlcjtcbn1cblxuLyoqXG4gKiBBbGxvd2VkU2V0IGZvciBwcmUtZmlsdGVyaW5nXG4gKi9cbmV4cG9ydCBhYnN0cmFjdCBjbGFzcyBBbGxvd2VkU2V0IHtcbiAgYWJzdHJhY3QgY29udGFpbnMoaWQ6IHN0cmluZywgbWV0YWRhdGE/OiBSZWNvcmQ8c3RyaW5nLCBhbnk+KTogYm9vbGVhbjtcblxuICBzdGF0aWMgZnJvbUlkcyhpZHM6IHN0cmluZ1tdKTogQWxsb3dlZFNldCB7XG4gICAgcmV0dXJuIG5ldyBJZHNBbGxvd2VkU2V0KG5ldyBTZXQoaWRzKSk7XG4gIH1cblxuICBzdGF0aWMgZnJvbU5hbWVzcGFjZShuYW1lc3BhY2U6IHN0cmluZyk6IEFsbG93ZWRTZXQge1xuICAgIHJldHVybiBuZXcgTmFtZXNwYWNlQWxsb3dlZFNldChuYW1lc3BhY2UpO1xuICB9XG5cbiAgc3RhdGljIGZyb21GaWx0ZXIoZmlsdGVyRm46IChpZDogc3RyaW5nLCBtZXRhZGF0YT86IFJlY29yZDxzdHJpbmcsIGFueT4pID0+IGJvb2xlYW4pOiBBbGxvd2VkU2V0IHtcbiAgICByZXR1cm4gbmV3IEZpbHRlckFsbG93ZWRTZXQoZmlsdGVyRm4pO1xuICB9XG5cbiAgc3RhdGljIGFsbG93QWxsKCk6IEFsbG93ZWRTZXQge1xuICAgIHJldHVybiBuZXcgQWxsQWxsb3dlZFNldCgpO1xuICB9XG59XG5cbmNsYXNzIElkc0FsbG93ZWRTZXQgZXh0ZW5kcyBBbGxvd2VkU2V0IHtcbiAgY29uc3RydWN0b3IocHJpdmF0ZSBpZHM6IFNldDxzdHJpbmc+KSB7XG4gICAgc3VwZXIoKTtcbiAgfVxuXG4gIGNvbnRhaW5zKGlkOiBzdHJpbmcpOiBib29sZWFuIHtcbiAgICByZXR1cm4gdGhpcy5pZHMuaGFzKGlkKTtcbiAgfVxufVxuXG5jbGFzcyBOYW1lc3BhY2VBbGxvd2VkU2V0IGV4dGVuZHMgQWxsb3dlZFNldCB7XG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgbmFtZXNwYWNlOiBzdHJpbmcpIHtcbiAgICBzdXBlcigpO1xuICB9XG5cbiAgY29udGFpbnMoaWQ6IHN0cmluZyk6IGJvb2xlYW4ge1xuICAgIHJldHVybiBpZC5zdGFydHNXaXRoKGAke3RoaXMubmFtZXNwYWNlfV9gKSB8fCBpZC5zdGFydHNXaXRoKGAke3RoaXMubmFtZXNwYWNlfTpgKTtcbiAgfVxufVxuXG5jbGFzcyBGaWx0ZXJBbGxvd2VkU2V0IGV4dGVuZHMgQWxsb3dlZFNldCB7XG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgZmlsdGVyRm46IChpZDogc3RyaW5nLCBtZXRhZGF0YT86IFJlY29yZDxzdHJpbmcsIGFueT4pID0+IGJvb2xlYW4pIHtcbiAgICBzdXBlcigpO1xuICB9XG5cbiAgY29udGFpbnMoaWQ6IHN0cmluZywgbWV0YWRhdGE/OiBSZWNvcmQ8c3RyaW5nLCBhbnk+KTogYm9vbGVhbiB7XG4gICAgcmV0dXJuIHRoaXMuZmlsdGVyRm4oaWQsIG1ldGFkYXRhKTtcbiAgfVxufVxuXG5jbGFzcyBBbGxBbGxvd2VkU2V0IGV4dGVuZHMgQWxsb3dlZFNldCB7XG4gIGNvbnRhaW5zKCk6IGJvb2xlYW4ge1xuICAgIHJldHVybiB0cnVlO1xuICB9XG59XG5cbi8qKlxuICogTmFtZXNwYWNlIHBvbGljeVxuICovXG5leHBvcnQgZW51bSBOYW1lc3BhY2VQb2xpY3kge1xuICBTVFJJQ1QgPSAnc3RyaWN0JyxcbiAgRVhQTElDSVQgPSAnZXhwbGljaXQnLFxuICBQRVJNSVNTSVZFID0gJ3Blcm1pc3NpdmUnLFxufVxuXG4vKipcbiAqIENyb3NzLW5hbWVzcGFjZSBncmFudFxuICovXG5leHBvcnQgaW50ZXJmYWNlIE5hbWVzcGFjZUdyYW50IHtcbiAgaWQ6IHN0cmluZztcbiAgZnJvbU5hbWVzcGFjZTogc3RyaW5nO1xuICB0b05hbWVzcGFjZTogc3RyaW5nO1xuICBvcGVyYXRpb25zOiBzdHJpbmdbXTtcbiAgZXhwaXJlc0F0PzogbnVtYmVyO1xuICByZWFzb24/OiBzdHJpbmc7XG59XG4iXX0=
|