@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.
Files changed (326) hide show
  1. package/README.md +240 -0
  2. package/dist/agent/Agent.d.ts +34 -0
  3. package/dist/agent/Agent.d.ts.map +1 -0
  4. package/dist/agent/Agent.js +168 -0
  5. package/dist/agent/Agent.js.map +1 -0
  6. package/dist/agent/createAgent.d.ts +4 -0
  7. package/dist/agent/createAgent.d.ts.map +1 -0
  8. package/dist/agent/createAgent.js +8 -0
  9. package/dist/agent/createAgent.js.map +1 -0
  10. package/dist/agent/index.d.ts +4 -0
  11. package/dist/agent/index.d.ts.map +1 -0
  12. package/dist/agent/index.js +8 -0
  13. package/dist/agent/index.js.map +1 -0
  14. package/dist/agent/types.d.ts +23 -0
  15. package/dist/agent/types.d.ts.map +1 -0
  16. package/dist/agent/types.js +3 -0
  17. package/dist/agent/types.js.map +1 -0
  18. package/dist/config/config.d.ts +35 -0
  19. package/dist/config/config.d.ts.map +1 -0
  20. package/dist/config/config.js +123 -0
  21. package/dist/config/config.js.map +1 -0
  22. package/dist/config/index.d.ts +3 -0
  23. package/dist/config/index.d.ts.map +1 -0
  24. package/dist/config/index.js +6 -0
  25. package/dist/config/index.js.map +1 -0
  26. package/dist/executors/base.d.ts +44 -0
  27. package/dist/executors/base.d.ts.map +1 -0
  28. package/dist/executors/base.js +3 -0
  29. package/dist/executors/base.js.map +1 -0
  30. package/dist/executors/index.d.ts +7 -0
  31. package/dist/executors/index.d.ts.map +1 -0
  32. package/dist/executors/index.js +10 -0
  33. package/dist/executors/index.js.map +1 -0
  34. package/dist/executors/rag-executor.d.ts +16 -0
  35. package/dist/executors/rag-executor.d.ts.map +1 -0
  36. package/dist/executors/rag-executor.js +120 -0
  37. package/dist/executors/rag-executor.js.map +1 -0
  38. package/dist/executors/simple-chat-executor.d.ts +5 -0
  39. package/dist/executors/simple-chat-executor.d.ts.map +1 -0
  40. package/dist/executors/simple-chat-executor.js +77 -0
  41. package/dist/executors/simple-chat-executor.js.map +1 -0
  42. package/dist/executors/tool-calling-executor.d.ts +10 -0
  43. package/dist/executors/tool-calling-executor.d.ts.map +1 -0
  44. package/dist/executors/tool-calling-executor.js +151 -0
  45. package/dist/executors/tool-calling-executor.js.map +1 -0
  46. package/dist/history/base.d.ts +16 -0
  47. package/dist/history/base.d.ts.map +1 -0
  48. package/dist/history/base.js +10 -0
  49. package/dist/history/base.js.map +1 -0
  50. package/dist/history/in-memory.d.ts +26 -0
  51. package/dist/history/in-memory.d.ts.map +1 -0
  52. package/dist/history/in-memory.js +88 -0
  53. package/dist/history/in-memory.js.map +1 -0
  54. package/dist/history/index.d.ts +5 -0
  55. package/dist/history/index.d.ts.map +1 -0
  56. package/dist/history/index.js +10 -0
  57. package/dist/history/index.js.map +1 -0
  58. package/dist/index.d.ts +10 -0
  59. package/dist/index.d.ts.map +1 -0
  60. package/dist/index.js +26 -0
  61. package/dist/index.js.map +1 -0
  62. package/dist/llm/LLM.d.ts +23 -0
  63. package/dist/llm/LLM.d.ts.map +1 -0
  64. package/dist/llm/LLM.js +404 -0
  65. package/dist/llm/LLM.js.map +1 -0
  66. package/dist/llm/errors.d.ts +43 -0
  67. package/dist/llm/errors.d.ts.map +1 -0
  68. package/dist/llm/errors.js +128 -0
  69. package/dist/llm/errors.js.map +1 -0
  70. package/dist/llm/factory.d.ts +9 -0
  71. package/dist/llm/factory.d.ts.map +1 -0
  72. package/dist/llm/factory.js +28 -0
  73. package/dist/llm/factory.js.map +1 -0
  74. package/dist/llm/index.d.ts +6 -0
  75. package/dist/llm/index.d.ts.map +1 -0
  76. package/dist/llm/index.js +18 -0
  77. package/dist/llm/index.js.map +1 -0
  78. package/dist/llm/providers/base.d.ts +3 -0
  79. package/dist/llm/providers/base.d.ts.map +1 -0
  80. package/dist/llm/providers/base.js +3 -0
  81. package/dist/llm/providers/base.js.map +1 -0
  82. package/dist/llm/providers/local.d.ts +6 -0
  83. package/dist/llm/providers/local.d.ts.map +1 -0
  84. package/dist/llm/providers/local.js +19 -0
  85. package/dist/llm/providers/local.js.map +1 -0
  86. package/dist/llm/providers/openai-compatible.d.ts +13 -0
  87. package/dist/llm/providers/openai-compatible.d.ts.map +1 -0
  88. package/dist/llm/providers/openai-compatible.js +176 -0
  89. package/dist/llm/providers/openai-compatible.js.map +1 -0
  90. package/dist/llm/providers/openai.d.ts +6 -0
  91. package/dist/llm/providers/openai.d.ts.map +1 -0
  92. package/dist/llm/providers/openai.js +23 -0
  93. package/dist/llm/providers/openai.js.map +1 -0
  94. package/dist/llm/types.d.ts +116 -0
  95. package/dist/llm/types.d.ts.map +1 -0
  96. package/dist/llm/types.js +3 -0
  97. package/dist/llm/types.js.map +1 -0
  98. package/dist/messages/index.d.ts +3 -0
  99. package/dist/messages/index.d.ts.map +1 -0
  100. package/dist/messages/index.js +6 -0
  101. package/dist/messages/index.js.map +1 -0
  102. package/dist/messages/message.d.ts +25 -0
  103. package/dist/messages/message.d.ts.map +1 -0
  104. package/dist/messages/message.js +110 -0
  105. package/dist/messages/message.js.map +1 -0
  106. package/dist/messages/types.d.ts +20 -0
  107. package/dist/messages/types.d.ts.map +1 -0
  108. package/dist/messages/types.js +3 -0
  109. package/dist/messages/types.js.map +1 -0
  110. package/dist/observability/console-observer.d.ts +10 -0
  111. package/dist/observability/console-observer.d.ts.map +1 -0
  112. package/dist/observability/console-observer.js +28 -0
  113. package/dist/observability/console-observer.js.map +1 -0
  114. package/dist/observability/index.d.ts +5 -0
  115. package/dist/observability/index.d.ts.map +1 -0
  116. package/dist/observability/index.js +11 -0
  117. package/dist/observability/index.js.map +1 -0
  118. package/dist/observability/observer.d.ts +8 -0
  119. package/dist/observability/observer.d.ts.map +1 -0
  120. package/dist/observability/observer.js +46 -0
  121. package/dist/observability/observer.js.map +1 -0
  122. package/dist/observability/types.d.ts +34 -0
  123. package/dist/observability/types.d.ts.map +1 -0
  124. package/dist/observability/types.js +3 -0
  125. package/dist/observability/types.js.map +1 -0
  126. package/dist/rag/chunking/auto-chunker.d.ts +25 -0
  127. package/dist/rag/chunking/auto-chunker.d.ts.map +1 -0
  128. package/dist/rag/chunking/auto-chunker.js +101 -0
  129. package/dist/rag/chunking/auto-chunker.js.map +1 -0
  130. package/dist/rag/chunking/chunker.d.ts +44 -0
  131. package/dist/rag/chunking/chunker.d.ts.map +1 -0
  132. package/dist/rag/chunking/chunker.js +162 -0
  133. package/dist/rag/chunking/chunker.js.map +1 -0
  134. package/dist/rag/chunking/index.d.ts +6 -0
  135. package/dist/rag/chunking/index.d.ts.map +1 -0
  136. package/dist/rag/chunking/index.js +22 -0
  137. package/dist/rag/chunking/index.js.map +1 -0
  138. package/dist/rag/chunking/markdown-chunker.d.ts +13 -0
  139. package/dist/rag/chunking/markdown-chunker.d.ts.map +1 -0
  140. package/dist/rag/chunking/markdown-chunker.js +144 -0
  141. package/dist/rag/chunking/markdown-chunker.js.map +1 -0
  142. package/dist/rag/chunking/parent-child.d.ts +16 -0
  143. package/dist/rag/chunking/parent-child.d.ts.map +1 -0
  144. package/dist/rag/chunking/parent-child.js +76 -0
  145. package/dist/rag/chunking/parent-child.js.map +1 -0
  146. package/dist/rag/chunking/recursive-chunker.d.ts +11 -0
  147. package/dist/rag/chunking/recursive-chunker.d.ts.map +1 -0
  148. package/dist/rag/chunking/recursive-chunker.js +27 -0
  149. package/dist/rag/chunking/recursive-chunker.js.map +1 -0
  150. package/dist/rag/embeddings/embedder.d.ts +24 -0
  151. package/dist/rag/embeddings/embedder.d.ts.map +1 -0
  152. package/dist/rag/embeddings/embedder.js +73 -0
  153. package/dist/rag/embeddings/embedder.js.map +1 -0
  154. package/dist/rag/embeddings/embedding-cache.d.ts +40 -0
  155. package/dist/rag/embeddings/embedding-cache.d.ts.map +1 -0
  156. package/dist/rag/embeddings/embedding-cache.js +118 -0
  157. package/dist/rag/embeddings/embedding-cache.js.map +1 -0
  158. package/dist/rag/embeddings/fake-embedder.d.ts +20 -0
  159. package/dist/rag/embeddings/fake-embedder.d.ts.map +1 -0
  160. package/dist/rag/embeddings/fake-embedder.js +55 -0
  161. package/dist/rag/embeddings/fake-embedder.js.map +1 -0
  162. package/dist/rag/embeddings/index.d.ts +5 -0
  163. package/dist/rag/embeddings/index.d.ts.map +1 -0
  164. package/dist/rag/embeddings/index.js +21 -0
  165. package/dist/rag/embeddings/index.js.map +1 -0
  166. package/dist/rag/embeddings/openai-compatible-embedder.d.ts +46 -0
  167. package/dist/rag/embeddings/openai-compatible-embedder.d.ts.map +1 -0
  168. package/dist/rag/embeddings/openai-compatible-embedder.js +145 -0
  169. package/dist/rag/embeddings/openai-compatible-embedder.js.map +1 -0
  170. package/dist/rag/generation/context-builder.d.ts +22 -0
  171. package/dist/rag/generation/context-builder.d.ts.map +1 -0
  172. package/dist/rag/generation/context-builder.js +166 -0
  173. package/dist/rag/generation/context-builder.js.map +1 -0
  174. package/dist/rag/generation/generator.d.ts +25 -0
  175. package/dist/rag/generation/generator.d.ts.map +1 -0
  176. package/dist/rag/generation/generator.js +185 -0
  177. package/dist/rag/generation/generator.js.map +1 -0
  178. package/dist/rag/generation/index.d.ts +4 -0
  179. package/dist/rag/generation/index.d.ts.map +1 -0
  180. package/dist/rag/generation/index.js +20 -0
  181. package/dist/rag/generation/index.js.map +1 -0
  182. package/dist/rag/generation/verifier.d.ts +13 -0
  183. package/dist/rag/generation/verifier.d.ts.map +1 -0
  184. package/dist/rag/generation/verifier.js +43 -0
  185. package/dist/rag/generation/verifier.js.map +1 -0
  186. package/dist/rag/index.d.ts +9 -0
  187. package/dist/rag/index.d.ts.map +1 -0
  188. package/dist/rag/index.js +25 -0
  189. package/dist/rag/index.js.map +1 -0
  190. package/dist/rag/ingestion/index.d.ts +4 -0
  191. package/dist/rag/ingestion/index.d.ts.map +1 -0
  192. package/dist/rag/ingestion/index.js +20 -0
  193. package/dist/rag/ingestion/index.js.map +1 -0
  194. package/dist/rag/ingestion/loaders.d.ts +69 -0
  195. package/dist/rag/ingestion/loaders.d.ts.map +1 -0
  196. package/dist/rag/ingestion/loaders.js +653 -0
  197. package/dist/rag/ingestion/loaders.js.map +1 -0
  198. package/dist/rag/ingestion/metadata.d.ts +31 -0
  199. package/dist/rag/ingestion/metadata.d.ts.map +1 -0
  200. package/dist/rag/ingestion/metadata.js +81 -0
  201. package/dist/rag/ingestion/metadata.js.map +1 -0
  202. package/dist/rag/ingestion/normalizer.d.ts +20 -0
  203. package/dist/rag/ingestion/normalizer.d.ts.map +1 -0
  204. package/dist/rag/ingestion/normalizer.js +161 -0
  205. package/dist/rag/ingestion/normalizer.js.map +1 -0
  206. package/dist/rag/pipeline.d.ts +62 -0
  207. package/dist/rag/pipeline.d.ts.map +1 -0
  208. package/dist/rag/pipeline.js +75 -0
  209. package/dist/rag/pipeline.js.map +1 -0
  210. package/dist/rag/retrieval/dense-retriever.d.ts +17 -0
  211. package/dist/rag/retrieval/dense-retriever.d.ts.map +1 -0
  212. package/dist/rag/retrieval/dense-retriever.js +21 -0
  213. package/dist/rag/retrieval/dense-retriever.js.map +1 -0
  214. package/dist/rag/retrieval/fusion.d.ts +12 -0
  215. package/dist/rag/retrieval/fusion.d.ts.map +1 -0
  216. package/dist/rag/retrieval/fusion.js +54 -0
  217. package/dist/rag/retrieval/fusion.js.map +1 -0
  218. package/dist/rag/retrieval/http-rerank-model-client.d.ts +41 -0
  219. package/dist/rag/retrieval/http-rerank-model-client.d.ts.map +1 -0
  220. package/dist/rag/retrieval/http-rerank-model-client.js +130 -0
  221. package/dist/rag/retrieval/http-rerank-model-client.js.map +1 -0
  222. package/dist/rag/retrieval/hybrid-retriever.d.ts +22 -0
  223. package/dist/rag/retrieval/hybrid-retriever.d.ts.map +1 -0
  224. package/dist/rag/retrieval/hybrid-retriever.js +49 -0
  225. package/dist/rag/retrieval/hybrid-retriever.js.map +1 -0
  226. package/dist/rag/retrieval/index.d.ts +8 -0
  227. package/dist/rag/retrieval/index.d.ts.map +1 -0
  228. package/dist/rag/retrieval/index.js +24 -0
  229. package/dist/rag/retrieval/index.js.map +1 -0
  230. package/dist/rag/retrieval/reranker.d.ts +30 -0
  231. package/dist/rag/retrieval/reranker.d.ts.map +1 -0
  232. package/dist/rag/retrieval/reranker.js +85 -0
  233. package/dist/rag/retrieval/reranker.js.map +1 -0
  234. package/dist/rag/retrieval/sparse-retriever.d.ts +14 -0
  235. package/dist/rag/retrieval/sparse-retriever.d.ts.map +1 -0
  236. package/dist/rag/retrieval/sparse-retriever.js +18 -0
  237. package/dist/rag/retrieval/sparse-retriever.js.map +1 -0
  238. package/dist/rag/retrieval/types.d.ts +11 -0
  239. package/dist/rag/retrieval/types.d.ts.map +1 -0
  240. package/dist/rag/retrieval/types.js +10 -0
  241. package/dist/rag/retrieval/types.js.map +1 -0
  242. package/dist/rag/retrieval/utils.d.ts +8 -0
  243. package/dist/rag/retrieval/utils.d.ts.map +1 -0
  244. package/dist/rag/retrieval/utils.js +114 -0
  245. package/dist/rag/retrieval/utils.js.map +1 -0
  246. package/dist/rag/stores/in-memory-document-store.d.ts +14 -0
  247. package/dist/rag/stores/in-memory-document-store.d.ts.map +1 -0
  248. package/dist/rag/stores/in-memory-document-store.js +64 -0
  249. package/dist/rag/stores/in-memory-document-store.js.map +1 -0
  250. package/dist/rag/stores/in-memory-keyword-store.d.ts +10 -0
  251. package/dist/rag/stores/in-memory-keyword-store.d.ts.map +1 -0
  252. package/dist/rag/stores/in-memory-keyword-store.js +99 -0
  253. package/dist/rag/stores/in-memory-keyword-store.js.map +1 -0
  254. package/dist/rag/stores/in-memory-vector-store.d.ts +14 -0
  255. package/dist/rag/stores/in-memory-vector-store.d.ts.map +1 -0
  256. package/dist/rag/stores/in-memory-vector-store.js +61 -0
  257. package/dist/rag/stores/in-memory-vector-store.js.map +1 -0
  258. package/dist/rag/stores/index.d.ts +6 -0
  259. package/dist/rag/stores/index.d.ts.map +1 -0
  260. package/dist/rag/stores/index.js +22 -0
  261. package/dist/rag/stores/index.js.map +1 -0
  262. package/dist/rag/stores/postgres/index.d.ts +6 -0
  263. package/dist/rag/stores/postgres/index.d.ts.map +1 -0
  264. package/dist/rag/stores/postgres/index.js +22 -0
  265. package/dist/rag/stores/postgres/index.js.map +1 -0
  266. package/dist/rag/stores/postgres/pg-vector-store.d.ts +16 -0
  267. package/dist/rag/stores/postgres/pg-vector-store.d.ts.map +1 -0
  268. package/dist/rag/stores/postgres/pg-vector-store.js +77 -0
  269. package/dist/rag/stores/postgres/pg-vector-store.js.map +1 -0
  270. package/dist/rag/stores/postgres/postgres-document-store.d.ts +15 -0
  271. package/dist/rag/stores/postgres/postgres-document-store.d.ts.map +1 -0
  272. package/dist/rag/stores/postgres/postgres-document-store.js +174 -0
  273. package/dist/rag/stores/postgres/postgres-document-store.js.map +1 -0
  274. package/dist/rag/stores/postgres/postgres-keyword-store.d.ts +15 -0
  275. package/dist/rag/stores/postgres/postgres-keyword-store.d.ts.map +1 -0
  276. package/dist/rag/stores/postgres/postgres-keyword-store.js +163 -0
  277. package/dist/rag/stores/postgres/postgres-keyword-store.js.map +1 -0
  278. package/dist/rag/stores/postgres/schema.d.ts +8 -0
  279. package/dist/rag/stores/postgres/schema.d.ts.map +1 -0
  280. package/dist/rag/stores/postgres/schema.js +91 -0
  281. package/dist/rag/stores/postgres/schema.js.map +1 -0
  282. package/dist/rag/stores/postgres/sql.d.ts +23 -0
  283. package/dist/rag/stores/postgres/sql.d.ts.map +1 -0
  284. package/dist/rag/stores/postgres/sql.js +177 -0
  285. package/dist/rag/stores/postgres/sql.js.map +1 -0
  286. package/dist/rag/stores/postgres/types.d.ts +17 -0
  287. package/dist/rag/stores/postgres/types.d.ts.map +1 -0
  288. package/dist/rag/stores/postgres/types.js +3 -0
  289. package/dist/rag/stores/postgres/types.js.map +1 -0
  290. package/dist/rag/stores/types.d.ts +36 -0
  291. package/dist/rag/stores/types.d.ts.map +1 -0
  292. package/dist/rag/stores/types.js +3 -0
  293. package/dist/rag/stores/types.js.map +1 -0
  294. package/dist/rag/stores/utils.d.ts +11 -0
  295. package/dist/rag/stores/utils.d.ts.map +1 -0
  296. package/dist/rag/stores/utils.js +200 -0
  297. package/dist/rag/stores/utils.js.map +1 -0
  298. package/dist/rag/types.d.ts +174 -0
  299. package/dist/rag/types.d.ts.map +1 -0
  300. package/dist/rag/types.js +3 -0
  301. package/dist/rag/types.js.map +1 -0
  302. package/dist/tools/base.d.ts +28 -0
  303. package/dist/tools/base.d.ts.map +1 -0
  304. package/dist/tools/base.js +68 -0
  305. package/dist/tools/base.js.map +1 -0
  306. package/dist/tools/builtin/advancedSearchTool.d.ts +24 -0
  307. package/dist/tools/builtin/advancedSearchTool.d.ts.map +1 -0
  308. package/dist/tools/builtin/advancedSearchTool.js +134 -0
  309. package/dist/tools/builtin/advancedSearchTool.js.map +1 -0
  310. package/dist/tools/builtin/ragSearchTool.d.ts +29 -0
  311. package/dist/tools/builtin/ragSearchTool.d.ts.map +1 -0
  312. package/dist/tools/builtin/ragSearchTool.js +91 -0
  313. package/dist/tools/builtin/ragSearchTool.js.map +1 -0
  314. package/dist/tools/executor.d.ts +10 -0
  315. package/dist/tools/executor.d.ts.map +1 -0
  316. package/dist/tools/executor.js +86 -0
  317. package/dist/tools/executor.js.map +1 -0
  318. package/dist/tools/index.d.ts +9 -0
  319. package/dist/tools/index.d.ts.map +1 -0
  320. package/dist/tools/index.js +16 -0
  321. package/dist/tools/index.js.map +1 -0
  322. package/dist/tools/registry.d.ts +16 -0
  323. package/dist/tools/registry.d.ts.map +1 -0
  324. package/dist/tools/registry.js +35 -0
  325. package/dist/tools/registry.js.map +1 -0
  326. 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,5 @@
1
+ export * from './embedder';
2
+ export * from './embedding-cache';
3
+ export * from './fake-embedder';
4
+ export * from './openai-compatible-embedder';
5
+ //# sourceMappingURL=index.d.ts.map
@@ -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"}