@fllf/agent-sdk 0.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +240 -0
- package/dist/agent/Agent.d.ts +34 -0
- package/dist/agent/Agent.d.ts.map +1 -0
- package/dist/agent/Agent.js +168 -0
- package/dist/agent/Agent.js.map +1 -0
- package/dist/agent/createAgent.d.ts +4 -0
- package/dist/agent/createAgent.d.ts.map +1 -0
- package/dist/agent/createAgent.js +8 -0
- package/dist/agent/createAgent.js.map +1 -0
- package/dist/agent/index.d.ts +4 -0
- package/dist/agent/index.d.ts.map +1 -0
- package/dist/agent/index.js +8 -0
- package/dist/agent/index.js.map +1 -0
- package/dist/agent/types.d.ts +23 -0
- package/dist/agent/types.d.ts.map +1 -0
- package/dist/agent/types.js +3 -0
- package/dist/agent/types.js.map +1 -0
- package/dist/config/config.d.ts +35 -0
- package/dist/config/config.d.ts.map +1 -0
- package/dist/config/config.js +123 -0
- package/dist/config/config.js.map +1 -0
- package/dist/config/index.d.ts +3 -0
- package/dist/config/index.d.ts.map +1 -0
- package/dist/config/index.js +6 -0
- package/dist/config/index.js.map +1 -0
- package/dist/executors/base.d.ts +44 -0
- package/dist/executors/base.d.ts.map +1 -0
- package/dist/executors/base.js +3 -0
- package/dist/executors/base.js.map +1 -0
- package/dist/executors/index.d.ts +7 -0
- package/dist/executors/index.d.ts.map +1 -0
- package/dist/executors/index.js +10 -0
- package/dist/executors/index.js.map +1 -0
- package/dist/executors/rag-executor.d.ts +16 -0
- package/dist/executors/rag-executor.d.ts.map +1 -0
- package/dist/executors/rag-executor.js +120 -0
- package/dist/executors/rag-executor.js.map +1 -0
- package/dist/executors/simple-chat-executor.d.ts +5 -0
- package/dist/executors/simple-chat-executor.d.ts.map +1 -0
- package/dist/executors/simple-chat-executor.js +77 -0
- package/dist/executors/simple-chat-executor.js.map +1 -0
- package/dist/executors/tool-calling-executor.d.ts +10 -0
- package/dist/executors/tool-calling-executor.d.ts.map +1 -0
- package/dist/executors/tool-calling-executor.js +151 -0
- package/dist/executors/tool-calling-executor.js.map +1 -0
- package/dist/history/base.d.ts +16 -0
- package/dist/history/base.d.ts.map +1 -0
- package/dist/history/base.js +10 -0
- package/dist/history/base.js.map +1 -0
- package/dist/history/in-memory.d.ts +26 -0
- package/dist/history/in-memory.d.ts.map +1 -0
- package/dist/history/in-memory.js +88 -0
- package/dist/history/in-memory.js.map +1 -0
- package/dist/history/index.d.ts +5 -0
- package/dist/history/index.d.ts.map +1 -0
- package/dist/history/index.js +10 -0
- package/dist/history/index.js.map +1 -0
- package/dist/index.d.ts +10 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +26 -0
- package/dist/index.js.map +1 -0
- package/dist/llm/LLM.d.ts +23 -0
- package/dist/llm/LLM.d.ts.map +1 -0
- package/dist/llm/LLM.js +404 -0
- package/dist/llm/LLM.js.map +1 -0
- package/dist/llm/errors.d.ts +43 -0
- package/dist/llm/errors.d.ts.map +1 -0
- package/dist/llm/errors.js +128 -0
- package/dist/llm/errors.js.map +1 -0
- package/dist/llm/factory.d.ts +9 -0
- package/dist/llm/factory.d.ts.map +1 -0
- package/dist/llm/factory.js +28 -0
- package/dist/llm/factory.js.map +1 -0
- package/dist/llm/index.d.ts +6 -0
- package/dist/llm/index.d.ts.map +1 -0
- package/dist/llm/index.js +18 -0
- package/dist/llm/index.js.map +1 -0
- package/dist/llm/providers/base.d.ts +3 -0
- package/dist/llm/providers/base.d.ts.map +1 -0
- package/dist/llm/providers/base.js +3 -0
- package/dist/llm/providers/base.js.map +1 -0
- package/dist/llm/providers/local.d.ts +6 -0
- package/dist/llm/providers/local.d.ts.map +1 -0
- package/dist/llm/providers/local.js +19 -0
- package/dist/llm/providers/local.js.map +1 -0
- package/dist/llm/providers/openai-compatible.d.ts +13 -0
- package/dist/llm/providers/openai-compatible.d.ts.map +1 -0
- package/dist/llm/providers/openai-compatible.js +176 -0
- package/dist/llm/providers/openai-compatible.js.map +1 -0
- package/dist/llm/providers/openai.d.ts +6 -0
- package/dist/llm/providers/openai.d.ts.map +1 -0
- package/dist/llm/providers/openai.js +23 -0
- package/dist/llm/providers/openai.js.map +1 -0
- package/dist/llm/types.d.ts +116 -0
- package/dist/llm/types.d.ts.map +1 -0
- package/dist/llm/types.js +3 -0
- package/dist/llm/types.js.map +1 -0
- package/dist/messages/index.d.ts +3 -0
- package/dist/messages/index.d.ts.map +1 -0
- package/dist/messages/index.js +6 -0
- package/dist/messages/index.js.map +1 -0
- package/dist/messages/message.d.ts +25 -0
- package/dist/messages/message.d.ts.map +1 -0
- package/dist/messages/message.js +110 -0
- package/dist/messages/message.js.map +1 -0
- package/dist/messages/types.d.ts +20 -0
- package/dist/messages/types.d.ts.map +1 -0
- package/dist/messages/types.js +3 -0
- package/dist/messages/types.js.map +1 -0
- package/dist/observability/console-observer.d.ts +10 -0
- package/dist/observability/console-observer.d.ts.map +1 -0
- package/dist/observability/console-observer.js +28 -0
- package/dist/observability/console-observer.js.map +1 -0
- package/dist/observability/index.d.ts +5 -0
- package/dist/observability/index.d.ts.map +1 -0
- package/dist/observability/index.js +11 -0
- package/dist/observability/index.js.map +1 -0
- package/dist/observability/observer.d.ts +8 -0
- package/dist/observability/observer.d.ts.map +1 -0
- package/dist/observability/observer.js +46 -0
- package/dist/observability/observer.js.map +1 -0
- package/dist/observability/types.d.ts +34 -0
- package/dist/observability/types.d.ts.map +1 -0
- package/dist/observability/types.js +3 -0
- package/dist/observability/types.js.map +1 -0
- package/dist/rag/chunking/auto-chunker.d.ts +25 -0
- package/dist/rag/chunking/auto-chunker.d.ts.map +1 -0
- package/dist/rag/chunking/auto-chunker.js +101 -0
- package/dist/rag/chunking/auto-chunker.js.map +1 -0
- package/dist/rag/chunking/chunker.d.ts +44 -0
- package/dist/rag/chunking/chunker.d.ts.map +1 -0
- package/dist/rag/chunking/chunker.js +162 -0
- package/dist/rag/chunking/chunker.js.map +1 -0
- package/dist/rag/chunking/index.d.ts +6 -0
- package/dist/rag/chunking/index.d.ts.map +1 -0
- package/dist/rag/chunking/index.js +22 -0
- package/dist/rag/chunking/index.js.map +1 -0
- package/dist/rag/chunking/markdown-chunker.d.ts +13 -0
- package/dist/rag/chunking/markdown-chunker.d.ts.map +1 -0
- package/dist/rag/chunking/markdown-chunker.js +144 -0
- package/dist/rag/chunking/markdown-chunker.js.map +1 -0
- package/dist/rag/chunking/parent-child.d.ts +16 -0
- package/dist/rag/chunking/parent-child.d.ts.map +1 -0
- package/dist/rag/chunking/parent-child.js +76 -0
- package/dist/rag/chunking/parent-child.js.map +1 -0
- package/dist/rag/chunking/recursive-chunker.d.ts +11 -0
- package/dist/rag/chunking/recursive-chunker.d.ts.map +1 -0
- package/dist/rag/chunking/recursive-chunker.js +27 -0
- package/dist/rag/chunking/recursive-chunker.js.map +1 -0
- package/dist/rag/embeddings/embedder.d.ts +24 -0
- package/dist/rag/embeddings/embedder.d.ts.map +1 -0
- package/dist/rag/embeddings/embedder.js +73 -0
- package/dist/rag/embeddings/embedder.js.map +1 -0
- package/dist/rag/embeddings/embedding-cache.d.ts +40 -0
- package/dist/rag/embeddings/embedding-cache.d.ts.map +1 -0
- package/dist/rag/embeddings/embedding-cache.js +118 -0
- package/dist/rag/embeddings/embedding-cache.js.map +1 -0
- package/dist/rag/embeddings/fake-embedder.d.ts +20 -0
- package/dist/rag/embeddings/fake-embedder.d.ts.map +1 -0
- package/dist/rag/embeddings/fake-embedder.js +55 -0
- package/dist/rag/embeddings/fake-embedder.js.map +1 -0
- package/dist/rag/embeddings/index.d.ts +5 -0
- package/dist/rag/embeddings/index.d.ts.map +1 -0
- package/dist/rag/embeddings/index.js +21 -0
- package/dist/rag/embeddings/index.js.map +1 -0
- package/dist/rag/embeddings/openai-compatible-embedder.d.ts +46 -0
- package/dist/rag/embeddings/openai-compatible-embedder.d.ts.map +1 -0
- package/dist/rag/embeddings/openai-compatible-embedder.js +145 -0
- package/dist/rag/embeddings/openai-compatible-embedder.js.map +1 -0
- package/dist/rag/generation/context-builder.d.ts +22 -0
- package/dist/rag/generation/context-builder.d.ts.map +1 -0
- package/dist/rag/generation/context-builder.js +166 -0
- package/dist/rag/generation/context-builder.js.map +1 -0
- package/dist/rag/generation/generator.d.ts +25 -0
- package/dist/rag/generation/generator.d.ts.map +1 -0
- package/dist/rag/generation/generator.js +185 -0
- package/dist/rag/generation/generator.js.map +1 -0
- package/dist/rag/generation/index.d.ts +4 -0
- package/dist/rag/generation/index.d.ts.map +1 -0
- package/dist/rag/generation/index.js +20 -0
- package/dist/rag/generation/index.js.map +1 -0
- package/dist/rag/generation/verifier.d.ts +13 -0
- package/dist/rag/generation/verifier.d.ts.map +1 -0
- package/dist/rag/generation/verifier.js +43 -0
- package/dist/rag/generation/verifier.js.map +1 -0
- package/dist/rag/index.d.ts +9 -0
- package/dist/rag/index.d.ts.map +1 -0
- package/dist/rag/index.js +25 -0
- package/dist/rag/index.js.map +1 -0
- package/dist/rag/ingestion/index.d.ts +4 -0
- package/dist/rag/ingestion/index.d.ts.map +1 -0
- package/dist/rag/ingestion/index.js +20 -0
- package/dist/rag/ingestion/index.js.map +1 -0
- package/dist/rag/ingestion/loaders.d.ts +69 -0
- package/dist/rag/ingestion/loaders.d.ts.map +1 -0
- package/dist/rag/ingestion/loaders.js +653 -0
- package/dist/rag/ingestion/loaders.js.map +1 -0
- package/dist/rag/ingestion/metadata.d.ts +31 -0
- package/dist/rag/ingestion/metadata.d.ts.map +1 -0
- package/dist/rag/ingestion/metadata.js +81 -0
- package/dist/rag/ingestion/metadata.js.map +1 -0
- package/dist/rag/ingestion/normalizer.d.ts +20 -0
- package/dist/rag/ingestion/normalizer.d.ts.map +1 -0
- package/dist/rag/ingestion/normalizer.js +161 -0
- package/dist/rag/ingestion/normalizer.js.map +1 -0
- package/dist/rag/pipeline.d.ts +62 -0
- package/dist/rag/pipeline.d.ts.map +1 -0
- package/dist/rag/pipeline.js +75 -0
- package/dist/rag/pipeline.js.map +1 -0
- package/dist/rag/retrieval/dense-retriever.d.ts +17 -0
- package/dist/rag/retrieval/dense-retriever.d.ts.map +1 -0
- package/dist/rag/retrieval/dense-retriever.js +21 -0
- package/dist/rag/retrieval/dense-retriever.js.map +1 -0
- package/dist/rag/retrieval/fusion.d.ts +12 -0
- package/dist/rag/retrieval/fusion.d.ts.map +1 -0
- package/dist/rag/retrieval/fusion.js +54 -0
- package/dist/rag/retrieval/fusion.js.map +1 -0
- package/dist/rag/retrieval/http-rerank-model-client.d.ts +41 -0
- package/dist/rag/retrieval/http-rerank-model-client.d.ts.map +1 -0
- package/dist/rag/retrieval/http-rerank-model-client.js +130 -0
- package/dist/rag/retrieval/http-rerank-model-client.js.map +1 -0
- package/dist/rag/retrieval/hybrid-retriever.d.ts +22 -0
- package/dist/rag/retrieval/hybrid-retriever.d.ts.map +1 -0
- package/dist/rag/retrieval/hybrid-retriever.js +49 -0
- package/dist/rag/retrieval/hybrid-retriever.js.map +1 -0
- package/dist/rag/retrieval/index.d.ts +8 -0
- package/dist/rag/retrieval/index.d.ts.map +1 -0
- package/dist/rag/retrieval/index.js +24 -0
- package/dist/rag/retrieval/index.js.map +1 -0
- package/dist/rag/retrieval/reranker.d.ts +30 -0
- package/dist/rag/retrieval/reranker.d.ts.map +1 -0
- package/dist/rag/retrieval/reranker.js +85 -0
- package/dist/rag/retrieval/reranker.js.map +1 -0
- package/dist/rag/retrieval/sparse-retriever.d.ts +14 -0
- package/dist/rag/retrieval/sparse-retriever.d.ts.map +1 -0
- package/dist/rag/retrieval/sparse-retriever.js +18 -0
- package/dist/rag/retrieval/sparse-retriever.js.map +1 -0
- package/dist/rag/retrieval/types.d.ts +11 -0
- package/dist/rag/retrieval/types.d.ts.map +1 -0
- package/dist/rag/retrieval/types.js +10 -0
- package/dist/rag/retrieval/types.js.map +1 -0
- package/dist/rag/retrieval/utils.d.ts +8 -0
- package/dist/rag/retrieval/utils.d.ts.map +1 -0
- package/dist/rag/retrieval/utils.js +114 -0
- package/dist/rag/retrieval/utils.js.map +1 -0
- package/dist/rag/stores/in-memory-document-store.d.ts +14 -0
- package/dist/rag/stores/in-memory-document-store.d.ts.map +1 -0
- package/dist/rag/stores/in-memory-document-store.js +64 -0
- package/dist/rag/stores/in-memory-document-store.js.map +1 -0
- package/dist/rag/stores/in-memory-keyword-store.d.ts +10 -0
- package/dist/rag/stores/in-memory-keyword-store.d.ts.map +1 -0
- package/dist/rag/stores/in-memory-keyword-store.js +99 -0
- package/dist/rag/stores/in-memory-keyword-store.js.map +1 -0
- package/dist/rag/stores/in-memory-vector-store.d.ts +14 -0
- package/dist/rag/stores/in-memory-vector-store.d.ts.map +1 -0
- package/dist/rag/stores/in-memory-vector-store.js +61 -0
- package/dist/rag/stores/in-memory-vector-store.js.map +1 -0
- package/dist/rag/stores/index.d.ts +6 -0
- package/dist/rag/stores/index.d.ts.map +1 -0
- package/dist/rag/stores/index.js +22 -0
- package/dist/rag/stores/index.js.map +1 -0
- package/dist/rag/stores/postgres/index.d.ts +6 -0
- package/dist/rag/stores/postgres/index.d.ts.map +1 -0
- package/dist/rag/stores/postgres/index.js +22 -0
- package/dist/rag/stores/postgres/index.js.map +1 -0
- package/dist/rag/stores/postgres/pg-vector-store.d.ts +16 -0
- package/dist/rag/stores/postgres/pg-vector-store.d.ts.map +1 -0
- package/dist/rag/stores/postgres/pg-vector-store.js +77 -0
- package/dist/rag/stores/postgres/pg-vector-store.js.map +1 -0
- package/dist/rag/stores/postgres/postgres-document-store.d.ts +15 -0
- package/dist/rag/stores/postgres/postgres-document-store.d.ts.map +1 -0
- package/dist/rag/stores/postgres/postgres-document-store.js +174 -0
- package/dist/rag/stores/postgres/postgres-document-store.js.map +1 -0
- package/dist/rag/stores/postgres/postgres-keyword-store.d.ts +15 -0
- package/dist/rag/stores/postgres/postgres-keyword-store.d.ts.map +1 -0
- package/dist/rag/stores/postgres/postgres-keyword-store.js +163 -0
- package/dist/rag/stores/postgres/postgres-keyword-store.js.map +1 -0
- package/dist/rag/stores/postgres/schema.d.ts +8 -0
- package/dist/rag/stores/postgres/schema.d.ts.map +1 -0
- package/dist/rag/stores/postgres/schema.js +91 -0
- package/dist/rag/stores/postgres/schema.js.map +1 -0
- package/dist/rag/stores/postgres/sql.d.ts +23 -0
- package/dist/rag/stores/postgres/sql.d.ts.map +1 -0
- package/dist/rag/stores/postgres/sql.js +177 -0
- package/dist/rag/stores/postgres/sql.js.map +1 -0
- package/dist/rag/stores/postgres/types.d.ts +17 -0
- package/dist/rag/stores/postgres/types.d.ts.map +1 -0
- package/dist/rag/stores/postgres/types.js +3 -0
- package/dist/rag/stores/postgres/types.js.map +1 -0
- package/dist/rag/stores/types.d.ts +36 -0
- package/dist/rag/stores/types.d.ts.map +1 -0
- package/dist/rag/stores/types.js +3 -0
- package/dist/rag/stores/types.js.map +1 -0
- package/dist/rag/stores/utils.d.ts +11 -0
- package/dist/rag/stores/utils.d.ts.map +1 -0
- package/dist/rag/stores/utils.js +200 -0
- package/dist/rag/stores/utils.js.map +1 -0
- package/dist/rag/types.d.ts +174 -0
- package/dist/rag/types.d.ts.map +1 -0
- package/dist/rag/types.js +3 -0
- package/dist/rag/types.js.map +1 -0
- package/dist/tools/base.d.ts +28 -0
- package/dist/tools/base.d.ts.map +1 -0
- package/dist/tools/base.js +68 -0
- package/dist/tools/base.js.map +1 -0
- package/dist/tools/builtin/advancedSearchTool.d.ts +24 -0
- package/dist/tools/builtin/advancedSearchTool.d.ts.map +1 -0
- package/dist/tools/builtin/advancedSearchTool.js +134 -0
- package/dist/tools/builtin/advancedSearchTool.js.map +1 -0
- package/dist/tools/builtin/ragSearchTool.d.ts +29 -0
- package/dist/tools/builtin/ragSearchTool.d.ts.map +1 -0
- package/dist/tools/builtin/ragSearchTool.js +91 -0
- package/dist/tools/builtin/ragSearchTool.js.map +1 -0
- package/dist/tools/executor.d.ts +10 -0
- package/dist/tools/executor.d.ts.map +1 -0
- package/dist/tools/executor.js +86 -0
- package/dist/tools/executor.js.map +1 -0
- package/dist/tools/index.d.ts +9 -0
- package/dist/tools/index.d.ts.map +1 -0
- package/dist/tools/index.js +16 -0
- package/dist/tools/index.js.map +1 -0
- package/dist/tools/registry.d.ts +16 -0
- package/dist/tools/registry.d.ts.map +1 -0
- package/dist/tools/registry.js +35 -0
- package/dist/tools/registry.js.map +1 -0
- package/package.json +43 -0
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.FakeEmbedder = void 0;
|
|
4
|
+
const node_crypto_1 = require("node:crypto");
|
|
5
|
+
const embedder_1 = require("./embedder");
|
|
6
|
+
/**
|
|
7
|
+
* FakeEmbedder 是测试用 embedding 实现,不调用外部服务。
|
|
8
|
+
* 它用 token 哈希填充固定维度向量,保证相同文本稳定得到相同向量。
|
|
9
|
+
*/
|
|
10
|
+
class FakeEmbedder {
|
|
11
|
+
model;
|
|
12
|
+
dimensions;
|
|
13
|
+
normalize;
|
|
14
|
+
constructor(options = {}) {
|
|
15
|
+
this.model = options.model ?? 'fake-embedding';
|
|
16
|
+
this.dimensions = (0, embedder_1.assertValidEmbeddingDimensions)(options.dimensions ?? 32);
|
|
17
|
+
this.normalize = options.normalize ?? true;
|
|
18
|
+
}
|
|
19
|
+
async embedDocuments(texts) {
|
|
20
|
+
return texts.map((text) => this.embed(text));
|
|
21
|
+
}
|
|
22
|
+
async embedQuery(text) {
|
|
23
|
+
return this.embed(text);
|
|
24
|
+
}
|
|
25
|
+
embed(text) {
|
|
26
|
+
const vector = Array.from({ length: this.dimensions }, () => 0);
|
|
27
|
+
const tokens = tokenize(text);
|
|
28
|
+
if (tokens.length === 0) {
|
|
29
|
+
return vector;
|
|
30
|
+
}
|
|
31
|
+
for (const token of tokens) {
|
|
32
|
+
const hash = hashToken(token, this.model);
|
|
33
|
+
const index = hash.readUInt32BE(0) % this.dimensions;
|
|
34
|
+
const sign = hash.readUInt8(4) % 2 === 0 ? 1 : -1;
|
|
35
|
+
const weight = 1 + Math.log(token.length + 1);
|
|
36
|
+
vector[index] = (vector[index] ?? 0) + sign * weight;
|
|
37
|
+
}
|
|
38
|
+
return this.normalize ? (0, embedder_1.normalizeEmbedding)(vector) : vector;
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
exports.FakeEmbedder = FakeEmbedder;
|
|
42
|
+
function tokenize(text) {
|
|
43
|
+
return text
|
|
44
|
+
.normalize('NFKC')
|
|
45
|
+
.toLowerCase()
|
|
46
|
+
.match(/[\p{L}\p{N}_-]+/gu) ?? [];
|
|
47
|
+
}
|
|
48
|
+
function hashToken(token, model) {
|
|
49
|
+
return (0, node_crypto_1.createHash)('sha256')
|
|
50
|
+
.update(model)
|
|
51
|
+
.update('\0')
|
|
52
|
+
.update(token)
|
|
53
|
+
.digest();
|
|
54
|
+
}
|
|
55
|
+
//# sourceMappingURL=fake-embedder.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"fake-embedder.js","sourceRoot":"","sources":["../../../src/rag/embeddings/fake-embedder.ts"],"names":[],"mappings":";;;AAAA,6CAAyC;AACzC,yCAGoB;AASpB;;;GAGG;AACH,MAAa,YAAY;IACZ,KAAK,CAAS;IACd,UAAU,CAAS;IACX,SAAS,CAAU;IAEpC,YAAY,UAA+B,EAAE;QACzC,IAAI,CAAC,KAAK,GAAG,OAAO,CAAC,KAAK,IAAI,gBAAgB,CAAC;QAC/C,IAAI,CAAC,UAAU,GAAG,IAAA,yCAA8B,EAAC,OAAO,CAAC,UAAU,IAAI,EAAE,CAAC,CAAC;QAC3E,IAAI,CAAC,SAAS,GAAG,OAAO,CAAC,SAAS,IAAI,IAAI,CAAC;IAC/C,CAAC;IAED,KAAK,CAAC,cAAc,CAAC,KAAe;QAChC,OAAO,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC;IACjD,CAAC;IAED,KAAK,CAAC,UAAU,CAAC,IAAY;QACzB,OAAO,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;IAC5B,CAAC;IAEO,KAAK,CAAC,IAAY;QACtB,MAAM,MAAM,GAAG,KAAK,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,IAAI,CAAC,UAAU,EAAE,EAAE,GAAG,EAAE,CAAC,CAAC,CAAC,CAAC;QAChE,MAAM,MAAM,GAAG,QAAQ,CAAC,IAAI,CAAC,CAAC;QAE9B,IAAI,MAAM,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YACtB,OAAO,MAAM,CAAC;QAClB,CAAC;QAED,KAAK,MAAM,KAAK,IAAI,MAAM,EAAE,CAAC;YACzB,MAAM,IAAI,GAAG,SAAS,CAAC,KAAK,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC;YAC1C,MAAM,KAAK,GAAG,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,UAAU,CAAC;YACrD,MAAM,IAAI,GAAG,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YAClD,MAAM,MAAM,GAAG,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;YAC9C,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,GAAG,IAAI,GAAG,MAAM,CAAC;QACzD,CAAC;QAED,OAAO,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,IAAA,6BAAkB,EAAC,MAAM,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC;IAChE,CAAC;CACJ;AArCD,oCAqCC;AAED,SAAS,QAAQ,CAAC,IAAY;IAC1B,OAAO,IAAI;SACN,SAAS,CAAC,MAAM,CAAC;SACjB,WAAW,EAAE;SACb,KAAK,CAAC,mBAAmB,CAAC,IAAI,EAAE,CAAC;AAC1C,CAAC;AAED,SAAS,SAAS,CAAC,KAAa,EAAE,KAAa;IAC3C,OAAO,IAAA,wBAAU,EAAC,QAAQ,CAAC;SACtB,MAAM,CAAC,KAAK,CAAC;SACb,MAAM,CAAC,IAAI,CAAC;SACZ,MAAM,CAAC,KAAK,CAAC;SACb,MAAM,EAAE,CAAC;AAClB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/rag/embeddings/index.ts"],"names":[],"mappings":"AAAA,cAAc,YAAY,CAAC;AAC3B,cAAc,mBAAmB,CAAC;AAClC,cAAc,iBAAiB,CAAC;AAChC,cAAc,8BAA8B,CAAC"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./embedder"), exports);
|
|
18
|
+
__exportStar(require("./embedding-cache"), exports);
|
|
19
|
+
__exportStar(require("./fake-embedder"), exports);
|
|
20
|
+
__exportStar(require("./openai-compatible-embedder"), exports);
|
|
21
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/rag/embeddings/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,6CAA2B;AAC3B,oDAAkC;AAClC,kDAAgC;AAChC,+DAA6C"}
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
import OpenAI from 'openai';
|
|
2
|
+
import type { Embedder } from './embedder';
|
|
3
|
+
type OpenAIEmbeddingBody = Parameters<OpenAI['embeddings']['create']>[0];
|
|
4
|
+
export interface OpenAIEmbeddingResponseLike {
|
|
5
|
+
data: Array<{
|
|
6
|
+
embedding: unknown;
|
|
7
|
+
index?: number;
|
|
8
|
+
}>;
|
|
9
|
+
}
|
|
10
|
+
export interface OpenAIEmbeddingsClientLike {
|
|
11
|
+
embeddings: {
|
|
12
|
+
create(body: OpenAIEmbeddingBody): Promise<OpenAIEmbeddingResponseLike>;
|
|
13
|
+
};
|
|
14
|
+
}
|
|
15
|
+
export interface OpenAICompatibleEmbedderOptions {
|
|
16
|
+
apiKey?: string;
|
|
17
|
+
model: string;
|
|
18
|
+
dimensions?: number;
|
|
19
|
+
baseURL?: string;
|
|
20
|
+
batchSize?: number;
|
|
21
|
+
sendDimensions?: boolean;
|
|
22
|
+
client?: OpenAIEmbeddingsClientLike;
|
|
23
|
+
}
|
|
24
|
+
export interface OpenAIEmbedderOptions extends Omit<OpenAICompatibleEmbedderOptions, 'model'> {
|
|
25
|
+
model?: string;
|
|
26
|
+
}
|
|
27
|
+
/**
|
|
28
|
+
* OpenAI-compatible embedding 实现,适配 OpenAI 官方 Embeddings API 以及兼容该协议的服务。
|
|
29
|
+
* 官方 OpenAI 只需要 apiKey/model;兼容网关、本地服务或代理服务通常还需要 baseURL。
|
|
30
|
+
*/
|
|
31
|
+
export declare class OpenAICompatibleEmbedder implements Embedder {
|
|
32
|
+
readonly model: string;
|
|
33
|
+
readonly dimensions: number;
|
|
34
|
+
private readonly client;
|
|
35
|
+
private readonly batchSize;
|
|
36
|
+
private readonly sendDimensions;
|
|
37
|
+
constructor(options: OpenAICompatibleEmbedderOptions);
|
|
38
|
+
embedDocuments(texts: string[]): Promise<number[][]>;
|
|
39
|
+
embedQuery(text: string): Promise<number[]>;
|
|
40
|
+
private createEmbeddings;
|
|
41
|
+
}
|
|
42
|
+
export declare class OpenAIEmbedder extends OpenAICompatibleEmbedder {
|
|
43
|
+
constructor(options?: OpenAIEmbedderOptions);
|
|
44
|
+
}
|
|
45
|
+
export {};
|
|
46
|
+
//# sourceMappingURL=openai-compatible-embedder.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"openai-compatible-embedder.d.ts","sourceRoot":"","sources":["../../../src/rag/embeddings/openai-compatible-embedder.ts"],"names":[],"mappings":"AAAA,OAAO,MAAM,MAAM,QAAQ,CAAC;AAO5B,OAAO,KAAK,EACR,QAAQ,EACX,MAAM,YAAY,CAAC;AAEpB,KAAK,mBAAmB,GAAG,UAAU,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;AAEzE,MAAM,WAAW,2BAA2B;IACxC,IAAI,EAAE,KAAK,CAAC;QACR,SAAS,EAAE,OAAO,CAAC;QACnB,KAAK,CAAC,EAAE,MAAM,CAAC;KAClB,CAAC,CAAC;CACN;AAED,MAAM,WAAW,0BAA0B;IACvC,UAAU,EAAE;QACR,MAAM,CAAC,IAAI,EAAE,mBAAmB,GAAG,OAAO,CAAC,2BAA2B,CAAC,CAAC;KAC3E,CAAC;CACL;AAED,MAAM,WAAW,+BAA+B;IAC5C,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,KAAK,EAAE,MAAM,CAAC;IACd,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,cAAc,CAAC,EAAE,OAAO,CAAC;IACzB,MAAM,CAAC,EAAE,0BAA0B,CAAC;CACvC;AAED,MAAM,WAAW,qBAAsB,SAAQ,IAAI,CAAC,+BAA+B,EAAE,OAAO,CAAC;IACzF,KAAK,CAAC,EAAE,MAAM,CAAC;CAClB;AAUD;;;GAGG;AACH,qBAAa,wBAAyB,YAAW,QAAQ;IACrD,QAAQ,CAAC,KAAK,EAAE,MAAM,CAAC;IACvB,QAAQ,CAAC,UAAU,EAAE,MAAM,CAAC;IAC5B,OAAO,CAAC,QAAQ,CAAC,MAAM,CAA6B;IACpD,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAS;IACnC,OAAO,CAAC,QAAQ,CAAC,cAAc,CAAU;gBAE7B,OAAO,EAAE,+BAA+B;IAS9C,cAAc,CAAC,KAAK,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,MAAM,EAAE,EAAE,CAAC;IAcpD,UAAU,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC;YAUnC,gBAAgB;CAiBjC;AAED,qBAAa,cAAe,SAAQ,wBAAwB;gBAC5C,OAAO,GAAE,qBAA0B;CAgBlD"}
|
|
@@ -0,0 +1,145 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.OpenAIEmbedder = exports.OpenAICompatibleEmbedder = void 0;
|
|
7
|
+
const openai_1 = __importDefault(require("openai"));
|
|
8
|
+
const embedder_1 = require("./embedder");
|
|
9
|
+
const DEFAULT_OPENAI_EMBEDDING_MODEL = 'text-embedding-3-small';
|
|
10
|
+
const DEFAULT_BATCH_SIZE = 100;
|
|
11
|
+
const DEFAULT_OPENAI_EMBEDDING_DIMENSIONS = {
|
|
12
|
+
'text-embedding-3-small': 1536,
|
|
13
|
+
'text-embedding-3-large': 3072,
|
|
14
|
+
'text-embedding-ada-002': 1536,
|
|
15
|
+
};
|
|
16
|
+
/**
|
|
17
|
+
* OpenAI-compatible embedding 实现,适配 OpenAI 官方 Embeddings API 以及兼容该协议的服务。
|
|
18
|
+
* 官方 OpenAI 只需要 apiKey/model;兼容网关、本地服务或代理服务通常还需要 baseURL。
|
|
19
|
+
*/
|
|
20
|
+
class OpenAICompatibleEmbedder {
|
|
21
|
+
model;
|
|
22
|
+
dimensions;
|
|
23
|
+
client;
|
|
24
|
+
batchSize;
|
|
25
|
+
sendDimensions;
|
|
26
|
+
constructor(options) {
|
|
27
|
+
this.model = options.model;
|
|
28
|
+
this.dimensions = resolveEmbeddingDimensions(options.model, options.dimensions);
|
|
29
|
+
this.batchSize = resolveBatchSize(options.batchSize);
|
|
30
|
+
this.sendDimensions = options.sendDimensions
|
|
31
|
+
?? (options.dimensions !== undefined && supportsDimensionsParam(options.model));
|
|
32
|
+
this.client = options.client ?? createOpenAIClient(options);
|
|
33
|
+
}
|
|
34
|
+
async embedDocuments(texts) {
|
|
35
|
+
const embeddings = [];
|
|
36
|
+
for (let start = 0; start < texts.length; start += this.batchSize) {
|
|
37
|
+
const batch = texts.slice(start, start + this.batchSize);
|
|
38
|
+
const batchEmbeddings = await this.createEmbeddings(batch);
|
|
39
|
+
embeddings.push(...batchEmbeddings);
|
|
40
|
+
}
|
|
41
|
+
(0, embedder_1.assertEmbeddingBatchSize)(embeddings, texts.length);
|
|
42
|
+
return embeddings.map((embedding) => (0, embedder_1.cloneEmbedding)(embedding));
|
|
43
|
+
}
|
|
44
|
+
async embedQuery(text) {
|
|
45
|
+
const embeddings = await this.embedDocuments([text]);
|
|
46
|
+
const embedding = embeddings[0];
|
|
47
|
+
if (embedding === undefined) {
|
|
48
|
+
throw new Error('OpenAI-compatible embedder failed to resolve query embedding.');
|
|
49
|
+
}
|
|
50
|
+
return (0, embedder_1.cloneEmbedding)(embedding);
|
|
51
|
+
}
|
|
52
|
+
async createEmbeddings(texts) {
|
|
53
|
+
if (texts.length === 0) {
|
|
54
|
+
return [];
|
|
55
|
+
}
|
|
56
|
+
const body = {
|
|
57
|
+
model: this.model,
|
|
58
|
+
input: texts,
|
|
59
|
+
};
|
|
60
|
+
if (this.sendDimensions) {
|
|
61
|
+
body.dimensions = this.dimensions;
|
|
62
|
+
}
|
|
63
|
+
const response = await this.client.embeddings.create(body);
|
|
64
|
+
return toOrderedEmbeddings(response, texts.length, this.dimensions);
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
exports.OpenAICompatibleEmbedder = OpenAICompatibleEmbedder;
|
|
68
|
+
class OpenAIEmbedder extends OpenAICompatibleEmbedder {
|
|
69
|
+
constructor(options = {}) {
|
|
70
|
+
const resolvedOptions = {
|
|
71
|
+
...options,
|
|
72
|
+
model: options.model ?? process.env.OPENAI_EMBEDDING_MODEL ?? DEFAULT_OPENAI_EMBEDDING_MODEL,
|
|
73
|
+
};
|
|
74
|
+
const apiKey = options.apiKey ?? process.env.OPENAI_API_KEY;
|
|
75
|
+
if (apiKey !== undefined) {
|
|
76
|
+
resolvedOptions.apiKey = apiKey;
|
|
77
|
+
}
|
|
78
|
+
const baseURL = options.baseURL ?? process.env.OPENAI_BASE_URL;
|
|
79
|
+
if (baseURL !== undefined) {
|
|
80
|
+
resolvedOptions.baseURL = baseURL;
|
|
81
|
+
}
|
|
82
|
+
super(resolvedOptions);
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
exports.OpenAIEmbedder = OpenAIEmbedder;
|
|
86
|
+
function createOpenAIClient(options) {
|
|
87
|
+
if (!options.apiKey) {
|
|
88
|
+
throw new Error('OpenAI-compatible embedder requires an apiKey.');
|
|
89
|
+
}
|
|
90
|
+
const clientOptions = {
|
|
91
|
+
apiKey: options.apiKey,
|
|
92
|
+
};
|
|
93
|
+
if (options.baseURL) {
|
|
94
|
+
clientOptions.baseURL = options.baseURL;
|
|
95
|
+
}
|
|
96
|
+
return new openai_1.default(clientOptions);
|
|
97
|
+
}
|
|
98
|
+
function resolveEmbeddingDimensions(model, dimensions) {
|
|
99
|
+
if (dimensions !== undefined) {
|
|
100
|
+
return (0, embedder_1.assertValidEmbeddingDimensions)(dimensions);
|
|
101
|
+
}
|
|
102
|
+
const knownDimensions = DEFAULT_OPENAI_EMBEDDING_DIMENSIONS[model];
|
|
103
|
+
if (knownDimensions !== undefined) {
|
|
104
|
+
return knownDimensions;
|
|
105
|
+
}
|
|
106
|
+
throw new Error(`OpenAI-compatible embedder requires dimensions for unknown embedding model "${model}".`);
|
|
107
|
+
}
|
|
108
|
+
function resolveBatchSize(batchSize) {
|
|
109
|
+
if (batchSize === undefined) {
|
|
110
|
+
return DEFAULT_BATCH_SIZE;
|
|
111
|
+
}
|
|
112
|
+
if (!Number.isInteger(batchSize) || batchSize <= 0) {
|
|
113
|
+
throw new RangeError('Embedding batchSize must be a positive integer.');
|
|
114
|
+
}
|
|
115
|
+
return batchSize;
|
|
116
|
+
}
|
|
117
|
+
function supportsDimensionsParam(model) {
|
|
118
|
+
return model === 'text-embedding-3-small' || model === 'text-embedding-3-large';
|
|
119
|
+
}
|
|
120
|
+
function toOrderedEmbeddings(response, expectedSize, expectedDimensions) {
|
|
121
|
+
(0, embedder_1.assertEmbeddingBatchSize)(response.data, expectedSize);
|
|
122
|
+
const ordered = new Array(expectedSize);
|
|
123
|
+
response.data.forEach((item, offset) => {
|
|
124
|
+
const index = item.index ?? offset;
|
|
125
|
+
if (!Number.isInteger(index) || index < 0 || index >= expectedSize) {
|
|
126
|
+
throw new RangeError(`Embedding response index out of range: ${String(index)}.`);
|
|
127
|
+
}
|
|
128
|
+
const embedding = readEmbedding(item.embedding);
|
|
129
|
+
(0, embedder_1.assertEmbeddingDimensions)(embedding, expectedDimensions, `embedding response item ${index}`);
|
|
130
|
+
ordered[index] = (0, embedder_1.cloneEmbedding)(embedding);
|
|
131
|
+
});
|
|
132
|
+
return ordered.map((embedding, index) => {
|
|
133
|
+
if (embedding === undefined) {
|
|
134
|
+
throw new Error(`Embedding response missing item at index ${index}.`);
|
|
135
|
+
}
|
|
136
|
+
return (0, embedder_1.cloneEmbedding)(embedding);
|
|
137
|
+
});
|
|
138
|
+
}
|
|
139
|
+
function readEmbedding(value) {
|
|
140
|
+
if (!Array.isArray(value) || !value.every((item) => typeof item === 'number')) {
|
|
141
|
+
throw new TypeError('Embedding response item must contain a numeric embedding array.');
|
|
142
|
+
}
|
|
143
|
+
return value;
|
|
144
|
+
}
|
|
145
|
+
//# sourceMappingURL=openai-compatible-embedder.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"openai-compatible-embedder.js","sourceRoot":"","sources":["../../../src/rag/embeddings/openai-compatible-embedder.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import type { AnswerOptions, RagContext, RetrievedChunk } from '../types';
|
|
2
|
+
export interface ContextBuilder {
|
|
3
|
+
build(query: string, retrieved: RetrievedChunk[], options?: AnswerOptions): Promise<RagContext>;
|
|
4
|
+
}
|
|
5
|
+
export interface DefaultContextBuilderOptions {
|
|
6
|
+
maxContextTokens?: number;
|
|
7
|
+
maxChunkCharacters?: number;
|
|
8
|
+
includeScores?: boolean;
|
|
9
|
+
}
|
|
10
|
+
export declare class DefaultContextBuilder implements ContextBuilder {
|
|
11
|
+
private readonly maxContextTokens;
|
|
12
|
+
private readonly maxChunkCharacters;
|
|
13
|
+
private readonly includeScores;
|
|
14
|
+
constructor(options?: DefaultContextBuilderOptions);
|
|
15
|
+
build(query: string, retrieved: RetrievedChunk[], options?: AnswerOptions): Promise<RagContext>;
|
|
16
|
+
}
|
|
17
|
+
/**
|
|
18
|
+
* 这里用轻量估算替代 tokenizer,避免当前基础包绑定具体模型。
|
|
19
|
+
* 真正按模型 token 预算裁剪时,可以替换这个函数而不影响 ContextBuilder 接口。
|
|
20
|
+
*/
|
|
21
|
+
export declare function estimateTokens(text: string): number;
|
|
22
|
+
//# sourceMappingURL=context-builder.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"context-builder.d.ts","sourceRoot":"","sources":["../../../src/rag/generation/context-builder.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACR,aAAa,EAEb,UAAU,EAEV,cAAc,EACjB,MAAM,UAAU,CAAC;AAElB,MAAM,WAAW,cAAc;IAC3B,KAAK,CACD,KAAK,EAAE,MAAM,EACb,SAAS,EAAE,cAAc,EAAE,EAC3B,OAAO,CAAC,EAAE,aAAa,GACxB,OAAO,CAAC,UAAU,CAAC,CAAC;CAC1B;AAED,MAAM,WAAW,4BAA4B;IACzC,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,kBAAkB,CAAC,EAAE,MAAM,CAAC;IAC5B,aAAa,CAAC,EAAE,OAAO,CAAC;CAC3B;AAED,qBAAa,qBAAsB,YAAW,cAAc;IACxD,OAAO,CAAC,QAAQ,CAAC,gBAAgB,CAAS;IAC1C,OAAO,CAAC,QAAQ,CAAC,kBAAkB,CAAqB;IACxD,OAAO,CAAC,QAAQ,CAAC,aAAa,CAAU;gBAE5B,OAAO,GAAE,4BAAiC;IAMhD,KAAK,CACP,KAAK,EAAE,MAAM,EACb,SAAS,EAAE,cAAc,EAAE,EAC3B,OAAO,GAAE,aAAkB,GAC5B,OAAO,CAAC,UAAU,CAAC;CAwDzB;AAqHD;;;GAGG;AACH,wBAAgB,cAAc,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM,CAKnD"}
|
|
@@ -0,0 +1,166 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.DefaultContextBuilder = void 0;
|
|
4
|
+
exports.estimateTokens = estimateTokens;
|
|
5
|
+
class DefaultContextBuilder {
|
|
6
|
+
maxContextTokens;
|
|
7
|
+
maxChunkCharacters;
|
|
8
|
+
includeScores;
|
|
9
|
+
constructor(options = {}) {
|
|
10
|
+
this.maxContextTokens = normalizePositiveInteger(options.maxContextTokens, 3000);
|
|
11
|
+
this.maxChunkCharacters = normalizeOptionalPositiveInteger(options.maxChunkCharacters);
|
|
12
|
+
this.includeScores = options.includeScores ?? false;
|
|
13
|
+
}
|
|
14
|
+
async build(query, retrieved, options = {}) {
|
|
15
|
+
const maxContextTokens = normalizePositiveInteger(options.maxContextTokens, this.maxContextTokens);
|
|
16
|
+
const candidates = dedupeRetrievedChunks(retrieved)
|
|
17
|
+
.filter((item) => options.minScore === undefined || item.score >= options.minScore);
|
|
18
|
+
const items = [];
|
|
19
|
+
let tokenTotal = 0;
|
|
20
|
+
let citationIndex = 1;
|
|
21
|
+
for (const item of candidates) {
|
|
22
|
+
const content = truncateChunkContent(item.chunk.content, this.maxChunkCharacters);
|
|
23
|
+
if (content.length === 0) {
|
|
24
|
+
continue;
|
|
25
|
+
}
|
|
26
|
+
const citation = createCitation(citationIndex, item, content);
|
|
27
|
+
const rendered = renderContextEntry(citation, content, createRenderOptions(this.includeScores, item.score));
|
|
28
|
+
const tokenEstimate = estimateTokens(rendered);
|
|
29
|
+
if (items.length > 0 && tokenTotal + tokenEstimate > maxContextTokens) {
|
|
30
|
+
break;
|
|
31
|
+
}
|
|
32
|
+
items.push({
|
|
33
|
+
citation,
|
|
34
|
+
chunk: item.chunk,
|
|
35
|
+
content,
|
|
36
|
+
score: item.score,
|
|
37
|
+
source: item.source,
|
|
38
|
+
tokenEstimate,
|
|
39
|
+
});
|
|
40
|
+
tokenTotal += tokenEstimate;
|
|
41
|
+
citationIndex += 1;
|
|
42
|
+
}
|
|
43
|
+
const text = items
|
|
44
|
+
.map((item) => renderContextEntry(item.citation, item.content, createRenderOptions(this.includeScores, item.score)))
|
|
45
|
+
.join('\n\n');
|
|
46
|
+
return {
|
|
47
|
+
query,
|
|
48
|
+
text,
|
|
49
|
+
items,
|
|
50
|
+
citations: items.map((item) => item.citation),
|
|
51
|
+
estimatedTokens: tokenTotal,
|
|
52
|
+
};
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
exports.DefaultContextBuilder = DefaultContextBuilder;
|
|
56
|
+
function dedupeRetrievedChunks(retrieved) {
|
|
57
|
+
const seenChunkIds = new Set();
|
|
58
|
+
const seenContentKeys = new Set();
|
|
59
|
+
const result = [];
|
|
60
|
+
for (const item of retrieved) {
|
|
61
|
+
const contentKey = normalizeContentKey(item.chunk.content);
|
|
62
|
+
if (seenChunkIds.has(item.chunk.id) || seenContentKeys.has(contentKey)) {
|
|
63
|
+
continue;
|
|
64
|
+
}
|
|
65
|
+
seenChunkIds.add(item.chunk.id);
|
|
66
|
+
seenContentKeys.add(contentKey);
|
|
67
|
+
result.push(item);
|
|
68
|
+
}
|
|
69
|
+
return result;
|
|
70
|
+
}
|
|
71
|
+
function createCitation(index, retrieved, content) {
|
|
72
|
+
const citation = {
|
|
73
|
+
index,
|
|
74
|
+
chunkId: retrieved.chunk.id,
|
|
75
|
+
documentId: retrieved.chunk.documentId,
|
|
76
|
+
source: retrieved.chunk.metadata.source,
|
|
77
|
+
};
|
|
78
|
+
assignIfDefined(citation, 'title', retrieved.chunk.metadata.title);
|
|
79
|
+
assignIfDefined(citation, 'page', retrieved.chunk.metadata.page);
|
|
80
|
+
if (retrieved.chunk.metadata.headingPath !== undefined) {
|
|
81
|
+
citation.headingPath = [...retrieved.chunk.metadata.headingPath];
|
|
82
|
+
}
|
|
83
|
+
citation.quote = createQuote(content);
|
|
84
|
+
const metadata = {
|
|
85
|
+
retrievalSource: retrieved.source,
|
|
86
|
+
score: retrieved.score,
|
|
87
|
+
...(retrieved.metadata ?? {}),
|
|
88
|
+
};
|
|
89
|
+
citation.metadata = metadata;
|
|
90
|
+
return citation;
|
|
91
|
+
}
|
|
92
|
+
function renderContextEntry(citation, content, options = {}) {
|
|
93
|
+
const attributes = [
|
|
94
|
+
`source=${formatAttribute(citation.source)}`,
|
|
95
|
+
];
|
|
96
|
+
if (citation.title !== undefined) {
|
|
97
|
+
attributes.push(`title=${formatAttribute(citation.title)}`);
|
|
98
|
+
}
|
|
99
|
+
if (citation.headingPath !== undefined && citation.headingPath.length > 0) {
|
|
100
|
+
attributes.push(`section=${formatAttribute(citation.headingPath.join(' > '))}`);
|
|
101
|
+
}
|
|
102
|
+
if (citation.page !== undefined) {
|
|
103
|
+
attributes.push(`page=${citation.page}`);
|
|
104
|
+
}
|
|
105
|
+
if (options.score !== undefined) {
|
|
106
|
+
attributes.push(`score=${formatScore(options.score)}`);
|
|
107
|
+
}
|
|
108
|
+
return `[${citation.index}] ${attributes.join(' ')}\n${content}`;
|
|
109
|
+
}
|
|
110
|
+
function createRenderOptions(includeScores, score) {
|
|
111
|
+
const options = {};
|
|
112
|
+
if (includeScores) {
|
|
113
|
+
options.score = score;
|
|
114
|
+
}
|
|
115
|
+
return options;
|
|
116
|
+
}
|
|
117
|
+
function formatAttribute(value) {
|
|
118
|
+
if (/^[A-Za-z0-9_./:-]+$/.test(value)) {
|
|
119
|
+
return value;
|
|
120
|
+
}
|
|
121
|
+
return JSON.stringify(value);
|
|
122
|
+
}
|
|
123
|
+
function formatScore(score) {
|
|
124
|
+
return Number.isFinite(score) ? score.toFixed(4) : String(score);
|
|
125
|
+
}
|
|
126
|
+
function truncateChunkContent(content, maxChunkCharacters) {
|
|
127
|
+
const normalized = content.trim();
|
|
128
|
+
if (maxChunkCharacters === undefined || normalized.length <= maxChunkCharacters) {
|
|
129
|
+
return normalized;
|
|
130
|
+
}
|
|
131
|
+
return normalized.slice(0, maxChunkCharacters).trimEnd();
|
|
132
|
+
}
|
|
133
|
+
function createQuote(content) {
|
|
134
|
+
const normalized = content.replace(/\s+/g, ' ').trim();
|
|
135
|
+
return normalized.length <= 200 ? normalized : `${normalized.slice(0, 197)}...`;
|
|
136
|
+
}
|
|
137
|
+
function normalizeContentKey(content) {
|
|
138
|
+
return content.replace(/\s+/g, ' ').trim().toLowerCase();
|
|
139
|
+
}
|
|
140
|
+
/**
|
|
141
|
+
* 这里用轻量估算替代 tokenizer,避免当前基础包绑定具体模型。
|
|
142
|
+
* 真正按模型 token 预算裁剪时,可以替换这个函数而不影响 ContextBuilder 接口。
|
|
143
|
+
*/
|
|
144
|
+
function estimateTokens(text) {
|
|
145
|
+
const cjkChars = text.match(/[\u4E00-\u9FFF]/g)?.length ?? 0;
|
|
146
|
+
const nonCjkChars = text.length - cjkChars;
|
|
147
|
+
return Math.max(1, Math.ceil(cjkChars + nonCjkChars / 4));
|
|
148
|
+
}
|
|
149
|
+
function normalizePositiveInteger(value, fallback) {
|
|
150
|
+
if (value === undefined || !Number.isFinite(value) || value <= 0) {
|
|
151
|
+
return fallback;
|
|
152
|
+
}
|
|
153
|
+
return Math.floor(value);
|
|
154
|
+
}
|
|
155
|
+
function normalizeOptionalPositiveInteger(value) {
|
|
156
|
+
if (value === undefined || !Number.isFinite(value) || value <= 0) {
|
|
157
|
+
return undefined;
|
|
158
|
+
}
|
|
159
|
+
return Math.floor(value);
|
|
160
|
+
}
|
|
161
|
+
function assignIfDefined(target, key, value) {
|
|
162
|
+
if (value !== undefined) {
|
|
163
|
+
target[key] = value;
|
|
164
|
+
}
|
|
165
|
+
}
|
|
166
|
+
//# sourceMappingURL=context-builder.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"context-builder.js","sourceRoot":"","sources":["../../../src/rag/generation/context-builder.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import type { AnswerOptions, Citation, RagAnswer, RagContext, RetrievedChunk } from '../types';
|
|
2
|
+
export declare const DEFAULT_RAG_REFUSAL_MESSAGE = "\u65E0\u6CD5\u4ECE\u63D0\u4F9B\u7684\u8D44\u6599\u4E2D\u786E\u8BA4\u3002";
|
|
3
|
+
export interface RagGenerator {
|
|
4
|
+
generate(query: string, context: RagContext, options?: AnswerOptions): Promise<RagAnswer>;
|
|
5
|
+
}
|
|
6
|
+
export interface DefaultRagGeneratorOptions {
|
|
7
|
+
systemPrompt?: string;
|
|
8
|
+
refusalMessage?: string;
|
|
9
|
+
}
|
|
10
|
+
export declare class MissingRagLlmError extends Error {
|
|
11
|
+
constructor();
|
|
12
|
+
}
|
|
13
|
+
export declare class DefaultRagGenerator implements RagGenerator {
|
|
14
|
+
private readonly systemPrompt;
|
|
15
|
+
private readonly refusalMessage;
|
|
16
|
+
constructor(options?: DefaultRagGeneratorOptions);
|
|
17
|
+
generate(query: string, context: RagContext, options?: AnswerOptions): Promise<RagAnswer>;
|
|
18
|
+
}
|
|
19
|
+
export declare function createRefusalAnswer(context: RagContext, refusalMessage?: string, reason?: string): RagAnswer;
|
|
20
|
+
export declare function extractCitationIndexes(text: string): number[];
|
|
21
|
+
export declare function resolveCitationsFromText(text: string, citations: Citation[]): Citation[];
|
|
22
|
+
export declare function retrievedFromContext(context: RagContext): RetrievedChunk[];
|
|
23
|
+
export declare function cloneCitation(citation: Citation): Citation;
|
|
24
|
+
export declare function cloneRagAnswer(answer: RagAnswer): RagAnswer;
|
|
25
|
+
//# sourceMappingURL=generator.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"generator.d.ts","sourceRoot":"","sources":["../../../src/rag/generation/generator.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EACR,aAAa,EACb,QAAQ,EACR,SAAS,EACT,UAAU,EACV,cAAc,EACjB,MAAM,UAAU,CAAC;AAElB,eAAO,MAAM,2BAA2B,6EAAiB,CAAC;AAU1D,MAAM,WAAW,YAAY;IACzB,QAAQ,CACJ,KAAK,EAAE,MAAM,EACb,OAAO,EAAE,UAAU,EACnB,OAAO,CAAC,EAAE,aAAa,GACxB,OAAO,CAAC,SAAS,CAAC,CAAC;CACzB;AAED,MAAM,WAAW,0BAA0B;IACvC,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,cAAc,CAAC,EAAE,MAAM,CAAC;CAC3B;AAED,qBAAa,kBAAmB,SAAQ,KAAK;;CAK5C;AAED,qBAAa,mBAAoB,YAAW,YAAY;IACpD,OAAO,CAAC,QAAQ,CAAC,YAAY,CAAS;IACtC,OAAO,CAAC,QAAQ,CAAC,cAAc,CAAS;gBAE5B,OAAO,GAAE,0BAA+B;IAK9C,QAAQ,CACV,KAAK,EAAE,MAAM,EACb,OAAO,EAAE,UAAU,EACnB,OAAO,GAAE,aAAkB,GAC5B,OAAO,CAAC,SAAS,CAAC;CAsCxB;AAkDD,wBAAgB,mBAAmB,CAC/B,OAAO,EAAE,UAAU,EACnB,cAAc,SAA8B,EAC5C,MAAM,SAAyB,GAChC,SAAS,CAUX;AAED,wBAAgB,sBAAsB,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM,EAAE,CAqB7D;AAED,wBAAgB,wBAAwB,CACpC,IAAI,EAAE,MAAM,EACZ,SAAS,EAAE,QAAQ,EAAE,GACtB,QAAQ,EAAE,CAOZ;AAED,wBAAgB,oBAAoB,CAAC,OAAO,EAAE,UAAU,GAAG,cAAc,EAAE,CAM1E;AAED,wBAAgB,aAAa,CAAC,QAAQ,EAAE,QAAQ,GAAG,QAAQ,CAoB1D;AAED,wBAAgB,cAAc,CAAC,MAAM,EAAE,SAAS,GAAG,SAAS,CAgB3D"}
|