@jsonstudio/llms 0.4.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (538) hide show
  1. package/README.md +265 -0
  2. package/dist/api/index.d.ts +10 -0
  3. package/dist/api/index.js +11 -0
  4. package/dist/api/llmswitch-config.d.ts +15 -0
  5. package/dist/api/llmswitch-config.js +415 -0
  6. package/dist/api/llmswitch-types.d.ts +412 -0
  7. package/dist/api/llmswitch-types.js +60 -0
  8. package/dist/bridge/routecodex-adapter.d.ts +74 -0
  9. package/dist/bridge/routecodex-adapter.js +226 -0
  10. package/dist/config/index.d.ts +3 -0
  11. package/dist/config/index.js +5 -0
  12. package/dist/config-unified/enhanced-path-resolver.d.ts +5 -0
  13. package/dist/config-unified/enhanced-path-resolver.js +38 -0
  14. package/dist/config-unified/unified-config.d.ts +26 -0
  15. package/dist/config-unified/unified-config.js +187 -0
  16. package/dist/conversion/codec-registry.d.ts +10 -0
  17. package/dist/conversion/codec-registry.js +25 -0
  18. package/dist/conversion/codecs/anthropic-openai-codec.d.ts +23 -0
  19. package/dist/conversion/codecs/anthropic-openai-codec.js +546 -0
  20. package/dist/conversion/codecs/gemini-openai-codec.d.ts +16 -0
  21. package/dist/conversion/codecs/gemini-openai-codec.js +437 -0
  22. package/dist/conversion/codecs/openai-openai-codec.d.ts +12 -0
  23. package/dist/conversion/codecs/openai-openai-codec.js +125 -0
  24. package/dist/conversion/codecs/responses-openai-codec.d.ts +12 -0
  25. package/dist/conversion/codecs/responses-openai-codec.js +154 -0
  26. package/dist/conversion/config/config-manager.d.ts +212 -0
  27. package/dist/conversion/config/config-manager.js +310 -0
  28. package/dist/conversion/conversion-v3/adapters/index.d.ts +2 -0
  29. package/dist/conversion/conversion-v3/adapters/index.js +1 -0
  30. package/dist/conversion/conversion-v3/adapters/v3-to-standard-adapter.d.ts +38 -0
  31. package/dist/conversion/conversion-v3/adapters/v3-to-standard-adapter.js +55 -0
  32. package/dist/conversion/conversion-v3/compatibility/compatibility-profiles.d.ts +22 -0
  33. package/dist/conversion/conversion-v3/compatibility/compatibility-profiles.js +84 -0
  34. package/dist/conversion/conversion-v3/compatibility/compatibility-stages.d.ts +4 -0
  35. package/dist/conversion/conversion-v3/compatibility/compatibility-stages.js +285 -0
  36. package/dist/conversion/conversion-v3/compatibility/index.d.ts +3 -0
  37. package/dist/conversion/conversion-v3/compatibility/index.js +2 -0
  38. package/dist/conversion/conversion-v3/config/default-configs.d.ts +48 -0
  39. package/dist/conversion/conversion-v3/config/default-configs.js +1083 -0
  40. package/dist/conversion/conversion-v3/config/index.d.ts +5 -0
  41. package/dist/conversion/conversion-v3/config/index.js +5 -0
  42. package/dist/conversion/conversion-v3/config/pipeline-config-manager.d.ts +49 -0
  43. package/dist/conversion/conversion-v3/config/pipeline-config-manager.js +65 -0
  44. package/dist/conversion/conversion-v3/index.d.ts +11 -0
  45. package/dist/conversion/conversion-v3/index.js +17 -0
  46. package/dist/conversion/conversion-v3/nodes/index.d.ts +56 -0
  47. package/dist/conversion/conversion-v3/nodes/index.js +149 -0
  48. package/dist/conversion/conversion-v3/nodes/input/anthropic-input-node.d.ts +25 -0
  49. package/dist/conversion/conversion-v3/nodes/input/anthropic-input-node.js +56 -0
  50. package/dist/conversion/conversion-v3/nodes/input/base-input-node.d.ts +75 -0
  51. package/dist/conversion/conversion-v3/nodes/input/base-input-node.js +237 -0
  52. package/dist/conversion/conversion-v3/nodes/input/chat-input-node.d.ts +25 -0
  53. package/dist/conversion/conversion-v3/nodes/input/chat-input-node.js +56 -0
  54. package/dist/conversion/conversion-v3/nodes/input/chat-shape-helpers.d.ts +4 -0
  55. package/dist/conversion/conversion-v3/nodes/input/chat-shape-helpers.js +197 -0
  56. package/dist/conversion/conversion-v3/nodes/input/gemini-input-node.d.ts +16 -0
  57. package/dist/conversion/conversion-v3/nodes/input/gemini-input-node.js +125 -0
  58. package/dist/conversion/conversion-v3/nodes/input/index.d.ts +8 -0
  59. package/dist/conversion/conversion-v3/nodes/input/index.js +8 -0
  60. package/dist/conversion/conversion-v3/nodes/input/input-decision.d.ts +46 -0
  61. package/dist/conversion/conversion-v3/nodes/input/input-decision.js +125 -0
  62. package/dist/conversion/conversion-v3/nodes/input/responses-input-node.d.ts +20 -0
  63. package/dist/conversion/conversion-v3/nodes/input/responses-input-node.js +51 -0
  64. package/dist/conversion/conversion-v3/nodes/output/anthropic-output-node.d.ts +71 -0
  65. package/dist/conversion/conversion-v3/nodes/output/anthropic-output-node.js +320 -0
  66. package/dist/conversion/conversion-v3/nodes/output/base-output-node.d.ts +116 -0
  67. package/dist/conversion/conversion-v3/nodes/output/base-output-node.js +512 -0
  68. package/dist/conversion/conversion-v3/nodes/output/index.d.ts +7 -0
  69. package/dist/conversion/conversion-v3/nodes/output/index.js +7 -0
  70. package/dist/conversion/conversion-v3/nodes/output/openai-output-node.d.ts +71 -0
  71. package/dist/conversion/conversion-v3/nodes/output/openai-output-node.js +293 -0
  72. package/dist/conversion/conversion-v3/nodes/output/output-decision.d.ts +68 -0
  73. package/dist/conversion/conversion-v3/nodes/output/output-decision.js +161 -0
  74. package/dist/conversion/conversion-v3/nodes/output/responses-output-node.d.ts +64 -0
  75. package/dist/conversion/conversion-v3/nodes/output/responses-output-node.js +323 -0
  76. package/dist/conversion/conversion-v3/nodes/process/base-process-node.d.ts +72 -0
  77. package/dist/conversion/conversion-v3/nodes/process/base-process-node.js +246 -0
  78. package/dist/conversion/conversion-v3/nodes/process/chat-process-node.d.ts +135 -0
  79. package/dist/conversion/conversion-v3/nodes/process/chat-process-node.js +854 -0
  80. package/dist/conversion/conversion-v3/nodes/process/compatibility-process-node.d.ts +29 -0
  81. package/dist/conversion/conversion-v3/nodes/process/compatibility-process-node.js +181 -0
  82. package/dist/conversion/conversion-v3/nodes/process/index.d.ts +10 -0
  83. package/dist/conversion/conversion-v3/nodes/process/index.js +10 -0
  84. package/dist/conversion/conversion-v3/nodes/process/passthrough-process-node.d.ts +59 -0
  85. package/dist/conversion/conversion-v3/nodes/process/passthrough-process-node.js +243 -0
  86. package/dist/conversion/conversion-v3/nodes/process/response-process-node.d.ts +17 -0
  87. package/dist/conversion/conversion-v3/nodes/process/response-process-node.js +213 -0
  88. package/dist/conversion/conversion-v3/nodes/process/tool-process-node.d.ts +26 -0
  89. package/dist/conversion/conversion-v3/nodes/process/tool-process-node.js +299 -0
  90. package/dist/conversion/conversion-v3/nodes/process/virtual-router-process-node.d.ts +40 -0
  91. package/dist/conversion/conversion-v3/nodes/process/virtual-router-process-node.js +430 -0
  92. package/dist/conversion/conversion-v3/nodes/response/anthropic-response-input-node.d.ts +12 -0
  93. package/dist/conversion/conversion-v3/nodes/response/anthropic-response-input-node.js +129 -0
  94. package/dist/conversion/conversion-v3/nodes/response/chat-to-responses-response-node.d.ts +15 -0
  95. package/dist/conversion/conversion-v3/nodes/response/chat-to-responses-response-node.js +57 -0
  96. package/dist/conversion/conversion-v3/nodes/response/index.d.ts +4 -0
  97. package/dist/conversion/conversion-v3/nodes/response/index.js +4 -0
  98. package/dist/conversion/conversion-v3/nodes/response/openai-response-input-node.d.ts +15 -0
  99. package/dist/conversion/conversion-v3/nodes/response/openai-response-input-node.js +87 -0
  100. package/dist/conversion/conversion-v3/nodes/response/response-utils.d.ts +1 -0
  101. package/dist/conversion/conversion-v3/nodes/response/response-utils.js +1 -0
  102. package/dist/conversion/conversion-v3/nodes/response/responses-response-input-node.d.ts +12 -0
  103. package/dist/conversion/conversion-v3/nodes/response/responses-response-input-node.js +67 -0
  104. package/dist/conversion/conversion-v3/nodes/sse/index.d.ts +3 -0
  105. package/dist/conversion/conversion-v3/nodes/sse/index.js +3 -0
  106. package/dist/conversion/conversion-v3/nodes/sse/sse-input-node.d.ts +27 -0
  107. package/dist/conversion/conversion-v3/nodes/sse/sse-input-node.js +165 -0
  108. package/dist/conversion/conversion-v3/nodes/sse/sse-output-node.d.ts +19 -0
  109. package/dist/conversion/conversion-v3/nodes/sse/sse-output-node.js +267 -0
  110. package/dist/conversion/conversion-v3/nodes/sse/sse-passthrough-node.d.ts +18 -0
  111. package/dist/conversion/conversion-v3/nodes/sse/sse-passthrough-node.js +48 -0
  112. package/dist/conversion/conversion-v3/pipelines/index.d.ts +6 -0
  113. package/dist/conversion/conversion-v3/pipelines/index.js +6 -0
  114. package/dist/conversion/conversion-v3/pipelines/super-pipeline.d.ts +112 -0
  115. package/dist/conversion/conversion-v3/pipelines/super-pipeline.js +566 -0
  116. package/dist/conversion/conversion-v3/response/provider-response-converter.d.ts +28 -0
  117. package/dist/conversion/conversion-v3/response/provider-response-converter.js +249 -0
  118. package/dist/conversion/conversion-v3/sse/index.d.ts +140 -0
  119. package/dist/conversion/conversion-v3/sse/index.js +115 -0
  120. package/dist/conversion/conversion-v3/sse/json-to-sse/anthropic-json-to-sse-converter.d.ts +11 -0
  121. package/dist/conversion/conversion-v3/sse/json-to-sse/anthropic-json-to-sse-converter.js +79 -0
  122. package/dist/conversion/conversion-v3/sse/json-to-sse/chat-json-to-sse-converter.d.ts +79 -0
  123. package/dist/conversion/conversion-v3/sse/json-to-sse/chat-json-to-sse-converter.js +296 -0
  124. package/dist/conversion/conversion-v3/sse/json-to-sse/event-generators/chat.d.ts +55 -0
  125. package/dist/conversion/conversion-v3/sse/json-to-sse/event-generators/chat.js +233 -0
  126. package/dist/conversion/conversion-v3/sse/json-to-sse/event-generators/responses.d.ts +99 -0
  127. package/dist/conversion/conversion-v3/sse/json-to-sse/event-generators/responses.js +599 -0
  128. package/dist/conversion/conversion-v3/sse/json-to-sse/index.d.ts +6 -0
  129. package/dist/conversion/conversion-v3/sse/json-to-sse/index.js +7 -0
  130. package/dist/conversion/conversion-v3/sse/json-to-sse/responses-json-to-sse-converter.d.ts +79 -0
  131. package/dist/conversion/conversion-v3/sse/json-to-sse/responses-json-to-sse-converter.js +322 -0
  132. package/dist/conversion/conversion-v3/sse/json-to-sse/sequencers/chat-sequencer.d.ts +37 -0
  133. package/dist/conversion/conversion-v3/sse/json-to-sse/sequencers/chat-sequencer.js +218 -0
  134. package/dist/conversion/conversion-v3/sse/json-to-sse/sequencers/responses-sequencer.d.ts +40 -0
  135. package/dist/conversion/conversion-v3/sse/json-to-sse/sequencers/responses-sequencer.js +263 -0
  136. package/dist/conversion/conversion-v3/sse/registry/sse-codec-registry.d.ts +32 -0
  137. package/dist/conversion/conversion-v3/sse/registry/sse-codec-registry.js +106 -0
  138. package/dist/conversion/conversion-v3/sse/shared/chat-serializer.d.ts +4 -0
  139. package/dist/conversion/conversion-v3/sse/shared/chat-serializer.js +40 -0
  140. package/dist/conversion/conversion-v3/sse/shared/constants.d.ts +272 -0
  141. package/dist/conversion/conversion-v3/sse/shared/constants.js +321 -0
  142. package/dist/conversion/conversion-v3/sse/shared/serializers/base-serializer.d.ts +158 -0
  143. package/dist/conversion/conversion-v3/sse/shared/serializers/base-serializer.js +210 -0
  144. package/dist/conversion/conversion-v3/sse/shared/serializers/chat-event-serializer.d.ts +82 -0
  145. package/dist/conversion/conversion-v3/sse/shared/serializers/chat-event-serializer.js +275 -0
  146. package/dist/conversion/conversion-v3/sse/shared/serializers/index.d.ts +39 -0
  147. package/dist/conversion/conversion-v3/sse/shared/serializers/index.js +54 -0
  148. package/dist/conversion/conversion-v3/sse/shared/serializers/responses-event-serializer.d.ts +123 -0
  149. package/dist/conversion/conversion-v3/sse/shared/serializers/responses-event-serializer.js +356 -0
  150. package/dist/conversion/conversion-v3/sse/shared/serializers/types.d.ts +51 -0
  151. package/dist/conversion/conversion-v3/sse/shared/serializers/types.js +4 -0
  152. package/dist/conversion/conversion-v3/sse/shared/utils.d.ts +254 -0
  153. package/dist/conversion/conversion-v3/sse/shared/utils.js +543 -0
  154. package/dist/conversion/conversion-v3/sse/shared/writer.d.ts +111 -0
  155. package/dist/conversion/conversion-v3/sse/shared/writer.js +268 -0
  156. package/dist/conversion/conversion-v3/sse/sse-to-json/anthropic-sse-to-json-converter.d.ts +13 -0
  157. package/dist/conversion/conversion-v3/sse/sse-to-json/anthropic-sse-to-json-converter.js +139 -0
  158. package/dist/conversion/conversion-v3/sse/sse-to-json/builders/response-builder.d.ts +165 -0
  159. package/dist/conversion/conversion-v3/sse/sse-to-json/builders/response-builder.js +776 -0
  160. package/dist/conversion/conversion-v3/sse/sse-to-json/chat-sse-to-json-converter.d.ts +106 -0
  161. package/dist/conversion/conversion-v3/sse/sse-to-json/chat-sse-to-json-converter.js +540 -0
  162. package/dist/conversion/conversion-v3/sse/sse-to-json/index.d.ts +6 -0
  163. package/dist/conversion/conversion-v3/sse/sse-to-json/index.js +7 -0
  164. package/dist/conversion/conversion-v3/sse/sse-to-json/parsers/sse-parser.d.ts +73 -0
  165. package/dist/conversion/conversion-v3/sse/sse-to-json/parsers/sse-parser.js +332 -0
  166. package/dist/conversion/conversion-v3/sse/sse-to-json/responses-sse-to-json-converter.d.ts +59 -0
  167. package/dist/conversion/conversion-v3/sse/sse-to-json/responses-sse-to-json-converter.js +270 -0
  168. package/dist/conversion/conversion-v3/sse/types/anthropic-types.d.ts +87 -0
  169. package/dist/conversion/conversion-v3/sse/types/anthropic-types.js +5 -0
  170. package/dist/conversion/conversion-v3/sse/types/chat-types.d.ts +308 -0
  171. package/dist/conversion/conversion-v3/sse/types/chat-types.js +32 -0
  172. package/dist/conversion/conversion-v3/sse/types/conversion-context.d.ts +211 -0
  173. package/dist/conversion/conversion-v3/sse/types/conversion-context.js +20 -0
  174. package/dist/conversion/conversion-v3/sse/types/core-interfaces.d.ts +90 -0
  175. package/dist/conversion/conversion-v3/sse/types/core-interfaces.js +5 -0
  176. package/dist/conversion/conversion-v3/sse/types/index.d.ts +14 -0
  177. package/dist/conversion/conversion-v3/sse/types/index.js +7 -0
  178. package/dist/conversion/conversion-v3/sse/types/responses-types.d.ts +328 -0
  179. package/dist/conversion/conversion-v3/sse/types/responses-types.js +38 -0
  180. package/dist/conversion/conversion-v3/sse/types/sse-events.d.ts +180 -0
  181. package/dist/conversion/conversion-v3/sse/types/sse-events.js +150 -0
  182. package/dist/conversion/conversion-v3/sse/types/stream-state.d.ts +204 -0
  183. package/dist/conversion/conversion-v3/sse/types/stream-state.js +44 -0
  184. package/dist/conversion/conversion-v3/sse/types/utility-types.d.ts +230 -0
  185. package/dist/conversion/conversion-v3/sse/types/utility-types.js +49 -0
  186. package/dist/conversion/conversion-v3/standards/context-adapter.d.ts +146 -0
  187. package/dist/conversion/conversion-v3/standards/context-adapter.js +438 -0
  188. package/dist/conversion/conversion-v3/standards/errors.d.ts +38 -0
  189. package/dist/conversion/conversion-v3/standards/errors.js +27 -0
  190. package/dist/conversion/conversion-v3/standards/index.d.ts +15 -0
  191. package/dist/conversion/conversion-v3/standards/index.js +11 -0
  192. package/dist/conversion/conversion-v3/standards/node-capabilities.d.ts +123 -0
  193. package/dist/conversion/conversion-v3/standards/node-capabilities.js +330 -0
  194. package/dist/conversion/conversion-v3/standards/pipeline-context.d.ts +237 -0
  195. package/dist/conversion/conversion-v3/standards/pipeline-context.js +84 -0
  196. package/dist/conversion/conversion-v3/standards/pipeline-node.d.ts +196 -0
  197. package/dist/conversion/conversion-v3/standards/pipeline-node.js +316 -0
  198. package/dist/conversion/conversion-v3/standards/snapshot-handles.d.ts +24 -0
  199. package/dist/conversion/conversion-v3/standards/snapshot-handles.js +49 -0
  200. package/dist/conversion/conversion-v3/types/config-types.d.ts +242 -0
  201. package/dist/conversion/conversion-v3/types/config-types.js +13 -0
  202. package/dist/conversion/conversion-v3/types/index.d.ts +8 -0
  203. package/dist/conversion/conversion-v3/types/index.js +11 -0
  204. package/dist/conversion/conversion-v3/types/node-types.d.ts +211 -0
  205. package/dist/conversion/conversion-v3/types/node-types.js +20 -0
  206. package/dist/conversion/conversion-v3/types/pipeline-types.d.ts +246 -0
  207. package/dist/conversion/conversion-v3/types/pipeline-types.js +26 -0
  208. package/dist/conversion/conversion-v3/types/request-types.d.ts +293 -0
  209. package/dist/conversion/conversion-v3/types/request-types.js +26 -0
  210. package/dist/conversion/conversion-v3/utils/provider-payload-sanitizer.d.ts +10 -0
  211. package/dist/conversion/conversion-v3/utils/provider-payload-sanitizer.js +103 -0
  212. package/dist/conversion/conversion-v3/validations/index.d.ts +8 -0
  213. package/dist/conversion/conversion-v3/validations/index.js +7 -0
  214. package/dist/conversion/conversion-v3/validations/node-graph-validator.d.ts +116 -0
  215. package/dist/conversion/conversion-v3/validations/node-graph-validator.js +505 -0
  216. package/dist/conversion/conversion-v3/validations/tool-governance-enforcer.d.ts +139 -0
  217. package/dist/conversion/conversion-v3/validations/tool-governance-enforcer.js +338 -0
  218. package/dist/conversion/hub/config/types.d.ts +26 -0
  219. package/dist/conversion/hub/config/types.js +1 -0
  220. package/dist/conversion/hub/core/detour-registry.d.ts +9 -0
  221. package/dist/conversion/hub/core/detour-registry.js +23 -0
  222. package/dist/conversion/hub/core/hub-context.d.ts +21 -0
  223. package/dist/conversion/hub/core/hub-context.js +1 -0
  224. package/dist/conversion/hub/core/index.d.ts +3 -0
  225. package/dist/conversion/hub/core/index.js +3 -0
  226. package/dist/conversion/hub/core/stage-driver.d.ts +30 -0
  227. package/dist/conversion/hub/core/stage-driver.js +31 -0
  228. package/dist/conversion/hub/format-adapters/anthropic-format-adapter.d.ts +16 -0
  229. package/dist/conversion/hub/format-adapters/anthropic-format-adapter.js +23 -0
  230. package/dist/conversion/hub/format-adapters/chat-format-adapter.d.ts +17 -0
  231. package/dist/conversion/hub/format-adapters/chat-format-adapter.js +23 -0
  232. package/dist/conversion/hub/format-adapters/gemini-format-adapter.d.ts +16 -0
  233. package/dist/conversion/hub/format-adapters/gemini-format-adapter.js +23 -0
  234. package/dist/conversion/hub/format-adapters/index.d.ts +21 -0
  235. package/dist/conversion/hub/format-adapters/index.js +4 -0
  236. package/dist/conversion/hub/format-adapters/responses-format-adapter.d.ts +17 -0
  237. package/dist/conversion/hub/format-adapters/responses-format-adapter.js +23 -0
  238. package/dist/conversion/hub/hub-feature.d.ts +1 -0
  239. package/dist/conversion/hub/hub-feature.js +25 -0
  240. package/dist/conversion/hub/node-support.d.ts +19 -0
  241. package/dist/conversion/hub/node-support.js +115 -0
  242. package/dist/conversion/hub/pipeline/hub-pipeline.d.ts +68 -0
  243. package/dist/conversion/hub/pipeline/hub-pipeline.js +421 -0
  244. package/dist/conversion/hub/pipelines/inbound.d.ts +22 -0
  245. package/dist/conversion/hub/pipelines/inbound.js +64 -0
  246. package/dist/conversion/hub/pipelines/outbound.d.ts +22 -0
  247. package/dist/conversion/hub/pipelines/outbound.js +57 -0
  248. package/dist/conversion/hub/process/chat-process.d.ts +13 -0
  249. package/dist/conversion/hub/process/chat-process.js +50 -0
  250. package/dist/conversion/hub/registry.d.ts +28 -0
  251. package/dist/conversion/hub/registry.js +98 -0
  252. package/dist/conversion/hub/response/chat-response-utils.d.ts +6 -0
  253. package/dist/conversion/hub/response/chat-response-utils.js +89 -0
  254. package/dist/conversion/hub/response/provider-response.d.ts +20 -0
  255. package/dist/conversion/hub/response/provider-response.js +196 -0
  256. package/dist/conversion/hub/response/response-mappers.d.ts +19 -0
  257. package/dist/conversion/hub/response/response-mappers.js +23 -0
  258. package/dist/conversion/hub/response/response-runtime.d.ts +3 -0
  259. package/dist/conversion/hub/response/response-runtime.js +206 -0
  260. package/dist/conversion/hub/semantic-mappers/anthropic-mapper.d.ts +7 -0
  261. package/dist/conversion/hub/semantic-mappers/anthropic-mapper.js +308 -0
  262. package/dist/conversion/hub/semantic-mappers/chat-mapper.d.ts +7 -0
  263. package/dist/conversion/hub/semantic-mappers/chat-mapper.js +304 -0
  264. package/dist/conversion/hub/semantic-mappers/gemini-mapper.d.ts +7 -0
  265. package/dist/conversion/hub/semantic-mappers/gemini-mapper.js +477 -0
  266. package/dist/conversion/hub/semantic-mappers/index.d.ts +4 -0
  267. package/dist/conversion/hub/semantic-mappers/index.js +4 -0
  268. package/dist/conversion/hub/semantic-mappers/responses-mapper.d.ts +21 -0
  269. package/dist/conversion/hub/semantic-mappers/responses-mapper.js +379 -0
  270. package/dist/conversion/hub/snapshot-recorder.d.ts +12 -0
  271. package/dist/conversion/hub/snapshot-recorder.js +69 -0
  272. package/dist/conversion/hub/standardized-bridge.d.ts +12 -0
  273. package/dist/conversion/hub/standardized-bridge.js +248 -0
  274. package/dist/conversion/hub/types/chat-envelope.d.ts +67 -0
  275. package/dist/conversion/hub/types/chat-envelope.js +1 -0
  276. package/dist/conversion/hub/types/chat-schema.d.ts +112 -0
  277. package/dist/conversion/hub/types/chat-schema.js +1 -0
  278. package/dist/conversion/hub/types/errors.d.ts +5 -0
  279. package/dist/conversion/hub/types/errors.js +13 -0
  280. package/dist/conversion/hub/types/format-envelope.d.ts +7 -0
  281. package/dist/conversion/hub/types/format-envelope.js +1 -0
  282. package/dist/conversion/hub/types/index.d.ts +6 -0
  283. package/dist/conversion/hub/types/index.js +6 -0
  284. package/dist/conversion/hub/types/json.d.ts +9 -0
  285. package/dist/conversion/hub/types/json.js +9 -0
  286. package/dist/conversion/hub/types/node.d.ts +31 -0
  287. package/dist/conversion/hub/types/node.js +1 -0
  288. package/dist/conversion/hub/types/standardized.d.ts +94 -0
  289. package/dist/conversion/hub/types/standardized.js +1 -0
  290. package/dist/conversion/index.d.ts +28 -0
  291. package/dist/conversion/index.js +28 -0
  292. package/dist/conversion/responses/responses-openai-bridge.d.ts +95 -0
  293. package/dist/conversion/responses/responses-openai-bridge.js +1330 -0
  294. package/dist/conversion/schema-validator.d.ts +7 -0
  295. package/dist/conversion/schema-validator.js +67 -0
  296. package/dist/conversion/shared/args-mapping.d.ts +18 -0
  297. package/dist/conversion/shared/args-mapping.js +213 -0
  298. package/dist/conversion/shared/chat-request-filters.d.ts +9 -0
  299. package/dist/conversion/shared/chat-request-filters.js +74 -0
  300. package/dist/conversion/shared/jsonish.d.ts +3 -0
  301. package/dist/conversion/shared/jsonish.js +177 -0
  302. package/dist/conversion/shared/mcp-injection.d.ts +2 -0
  303. package/dist/conversion/shared/mcp-injection.js +89 -0
  304. package/dist/conversion/shared/media.d.ts +1 -0
  305. package/dist/conversion/shared/media.js +9 -0
  306. package/dist/conversion/shared/openai-finalizer.d.ts +9 -0
  307. package/dist/conversion/shared/openai-finalizer.js +104 -0
  308. package/dist/conversion/shared/openai-message-normalize.d.ts +1 -0
  309. package/dist/conversion/shared/openai-message-normalize.js +442 -0
  310. package/dist/conversion/shared/payload-budget.d.ts +13 -0
  311. package/dist/conversion/shared/payload-budget.js +248 -0
  312. package/dist/conversion/shared/reasoning-mapping.d.ts +5 -0
  313. package/dist/conversion/shared/reasoning-mapping.js +8 -0
  314. package/dist/conversion/shared/responses-conversation-store.d.ts +41 -0
  315. package/dist/conversion/shared/responses-conversation-store.js +285 -0
  316. package/dist/conversion/shared/responses-id-utils.d.ts +7 -0
  317. package/dist/conversion/shared/responses-id-utils.js +29 -0
  318. package/dist/conversion/shared/responses-instructions.d.ts +1 -0
  319. package/dist/conversion/shared/responses-instructions.js +113 -0
  320. package/dist/conversion/shared/responses-metadata.d.ts +1 -0
  321. package/dist/conversion/shared/responses-metadata.js +1 -0
  322. package/dist/conversion/shared/responses-request-adapter.d.ts +66 -0
  323. package/dist/conversion/shared/responses-request-adapter.js +461 -0
  324. package/dist/conversion/shared/snapshot-hooks.d.ts +12 -0
  325. package/dist/conversion/shared/snapshot-hooks.js +7 -0
  326. package/dist/conversion/shared/streaming-text-extractor.d.ts +26 -0
  327. package/dist/conversion/shared/streaming-text-extractor.js +145 -0
  328. package/dist/conversion/shared/text-markup-normalizer.d.ts +9 -0
  329. package/dist/conversion/shared/text-markup-normalizer.js +319 -0
  330. package/dist/conversion/shared/tool-canonicalizer.d.ts +2 -0
  331. package/dist/conversion/shared/tool-canonicalizer.js +50 -0
  332. package/dist/conversion/shared/tool-filter-pipeline.d.ts +17 -0
  333. package/dist/conversion/shared/tool-filter-pipeline.js +79 -0
  334. package/dist/conversion/shared/tool-governor.d.ts +27 -0
  335. package/dist/conversion/shared/tool-governor.js +269 -0
  336. package/dist/conversion/shared/tool-harvester.d.ts +31 -0
  337. package/dist/conversion/shared/tool-harvester.js +321 -0
  338. package/dist/conversion/shared/tool-mapping.d.ts +10 -0
  339. package/dist/conversion/shared/tool-mapping.js +10 -0
  340. package/dist/conversion/shared/tooling.d.ts +26 -0
  341. package/dist/conversion/shared/tooling.js +143 -0
  342. package/dist/conversion/types.d.ts +33 -0
  343. package/dist/conversion/types.js +1 -0
  344. package/dist/core/index.d.ts +6 -0
  345. package/dist/core/index.js +9 -0
  346. package/dist/core/llmswitch-engine-v2.d.ts +132 -0
  347. package/dist/core/llmswitch-engine-v2.js +649 -0
  348. package/dist/core/llmswitch-factory-v2.d.ts +123 -0
  349. package/dist/core/llmswitch-factory-v2.js +521 -0
  350. package/dist/endpoints/base-endpoint-handler.d.ts +128 -0
  351. package/dist/endpoints/base-endpoint-handler.js +545 -0
  352. package/dist/endpoints/chat-endpoint-handler.d.ts +115 -0
  353. package/dist/endpoints/chat-endpoint-handler.js +218 -0
  354. package/dist/endpoints/endpoint-router.d.ts +127 -0
  355. package/dist/endpoints/endpoint-router.js +438 -0
  356. package/dist/endpoints/index.d.ts +13 -0
  357. package/dist/endpoints/index.js +11 -0
  358. package/dist/endpoints/messages-endpoint-handler.d.ts +171 -0
  359. package/dist/endpoints/messages-endpoint-handler.js +238 -0
  360. package/dist/endpoints/responses-endpoint-handler.d.ts +147 -0
  361. package/dist/endpoints/responses-endpoint-handler.js +233 -0
  362. package/dist/filters/builtin/add-fields-filter.d.ts +8 -0
  363. package/dist/filters/builtin/add-fields-filter.js +16 -0
  364. package/dist/filters/builtin/blacklist-filter.d.ts +8 -0
  365. package/dist/filters/builtin/blacklist-filter.js +19 -0
  366. package/dist/filters/builtin/whitelist-filter.d.ts +8 -0
  367. package/dist/filters/builtin/whitelist-filter.js +19 -0
  368. package/dist/filters/engine.d.ts +16 -0
  369. package/dist/filters/engine.js +167 -0
  370. package/dist/filters/index.d.ts +19 -0
  371. package/dist/filters/index.js +24 -0
  372. package/dist/filters/special/request-streaming-to-nonstreaming.d.ts +12 -0
  373. package/dist/filters/special/request-streaming-to-nonstreaming.js +27 -0
  374. package/dist/filters/special/request-tool-choice-policy.d.ts +11 -0
  375. package/dist/filters/special/request-tool-choice-policy.js +27 -0
  376. package/dist/filters/special/request-tool-list-filter.d.ts +11 -0
  377. package/dist/filters/special/request-tool-list-filter.js +167 -0
  378. package/dist/filters/special/request-toolcalls-stringify.d.ts +10 -0
  379. package/dist/filters/special/request-toolcalls-stringify.js +44 -0
  380. package/dist/filters/special/request-tools-normalize.d.ts +12 -0
  381. package/dist/filters/special/request-tools-normalize.js +140 -0
  382. package/dist/filters/special/response-finish-invariants.d.ts +11 -0
  383. package/dist/filters/special/response-finish-invariants.js +30 -0
  384. package/dist/filters/special/response-openai-to-responses-bridge.d.ts +13 -0
  385. package/dist/filters/special/response-openai-to-responses-bridge.js +24 -0
  386. package/dist/filters/special/response-tool-arguments-blacklist.d.ts +12 -0
  387. package/dist/filters/special/response-tool-arguments-blacklist.js +63 -0
  388. package/dist/filters/special/response-tool-arguments-schema-converge.d.ts +13 -0
  389. package/dist/filters/special/response-tool-arguments-schema-converge.js +63 -0
  390. package/dist/filters/special/response-tool-arguments-stringify.d.ts +9 -0
  391. package/dist/filters/special/response-tool-arguments-stringify.js +134 -0
  392. package/dist/filters/special/response-tool-arguments-toon-decode.d.ts +10 -0
  393. package/dist/filters/special/response-tool-arguments-toon-decode.js +94 -0
  394. package/dist/filters/special/response-tool-arguments-whitelist.d.ts +11 -0
  395. package/dist/filters/special/response-tool-arguments-whitelist.js +56 -0
  396. package/dist/filters/special/response-tool-text-canonicalize.d.ts +10 -0
  397. package/dist/filters/special/response-tool-text-canonicalize.js +20 -0
  398. package/dist/filters/special/tool-filter-hooks.d.ts +19 -0
  399. package/dist/filters/special/tool-filter-hooks.js +341 -0
  400. package/dist/filters/special/tool-post-constraints.d.ts +31 -0
  401. package/dist/filters/special/tool-post-constraints.js +120 -0
  402. package/dist/filters/types.d.ts +68 -0
  403. package/dist/filters/types.js +3 -0
  404. package/dist/filters/utils/fieldmap-loader.d.ts +2 -0
  405. package/dist/filters/utils/fieldmap-loader.js +16 -0
  406. package/dist/filters/utils/snapshot-writer.d.ts +10 -0
  407. package/dist/filters/utils/snapshot-writer.js +47 -0
  408. package/dist/guidance/index.d.ts +3 -0
  409. package/dist/guidance/index.js +228 -0
  410. package/dist/hooks/hooks-integration.d.ts +161 -0
  411. package/dist/hooks/hooks-integration.js +519 -0
  412. package/dist/hooks/index.d.ts +10 -0
  413. package/dist/hooks/index.js +13 -0
  414. package/dist/html-to-markdown.d.ts +5 -0
  415. package/dist/html-to-markdown.js +66 -0
  416. package/dist/http/sse-response.d.ts +22 -0
  417. package/dist/http/sse-response.js +103 -0
  418. package/dist/index.d.ts +10 -0
  419. package/dist/index.js +10 -0
  420. package/dist/router/virtual-router/bootstrap.d.ts +6 -0
  421. package/dist/router/virtual-router/bootstrap.js +620 -0
  422. package/dist/router/virtual-router/classifier.d.ts +10 -0
  423. package/dist/router/virtual-router/classifier.js +99 -0
  424. package/dist/router/virtual-router/engine.d.ts +35 -0
  425. package/dist/router/virtual-router/engine.js +260 -0
  426. package/dist/router/virtual-router/error-center.d.ts +10 -0
  427. package/dist/router/virtual-router/error-center.js +39 -0
  428. package/dist/router/virtual-router/features.d.ts +3 -0
  429. package/dist/router/virtual-router/features.js +162 -0
  430. package/dist/router/virtual-router/health-manager.d.ts +18 -0
  431. package/dist/router/virtual-router/health-manager.js +98 -0
  432. package/dist/router/virtual-router/load-balancer.d.ts +18 -0
  433. package/dist/router/virtual-router/load-balancer.js +67 -0
  434. package/dist/router/virtual-router/provider-registry.d.ts +11 -0
  435. package/dist/router/virtual-router/provider-registry.js +74 -0
  436. package/dist/router/virtual-router/types.d.ts +206 -0
  437. package/dist/router/virtual-router/types.js +31 -0
  438. package/dist/sse/index.d.ts +140 -0
  439. package/dist/sse/index.js +115 -0
  440. package/dist/sse/json-to-sse/anthropic-json-to-sse-converter.d.ts +11 -0
  441. package/dist/sse/json-to-sse/anthropic-json-to-sse-converter.js +79 -0
  442. package/dist/sse/json-to-sse/chat-json-to-sse-converter.d.ts +79 -0
  443. package/dist/sse/json-to-sse/chat-json-to-sse-converter.js +296 -0
  444. package/dist/sse/json-to-sse/event-generators/chat.d.ts +55 -0
  445. package/dist/sse/json-to-sse/event-generators/chat.js +233 -0
  446. package/dist/sse/json-to-sse/event-generators/responses.d.ts +99 -0
  447. package/dist/sse/json-to-sse/event-generators/responses.js +599 -0
  448. package/dist/sse/json-to-sse/index.d.ts +6 -0
  449. package/dist/sse/json-to-sse/index.js +7 -0
  450. package/dist/sse/json-to-sse/responses-json-to-sse-converter.d.ts +79 -0
  451. package/dist/sse/json-to-sse/responses-json-to-sse-converter.js +322 -0
  452. package/dist/sse/json-to-sse/sequencers/chat-sequencer.d.ts +37 -0
  453. package/dist/sse/json-to-sse/sequencers/chat-sequencer.js +218 -0
  454. package/dist/sse/json-to-sse/sequencers/responses-sequencer.d.ts +40 -0
  455. package/dist/sse/json-to-sse/sequencers/responses-sequencer.js +263 -0
  456. package/dist/sse/registry/sse-codec-registry.d.ts +32 -0
  457. package/dist/sse/registry/sse-codec-registry.js +106 -0
  458. package/dist/sse/shared/chat-serializer.d.ts +4 -0
  459. package/dist/sse/shared/chat-serializer.js +40 -0
  460. package/dist/sse/shared/constants.d.ts +272 -0
  461. package/dist/sse/shared/constants.js +321 -0
  462. package/dist/sse/shared/serializers/base-serializer.d.ts +158 -0
  463. package/dist/sse/shared/serializers/base-serializer.js +210 -0
  464. package/dist/sse/shared/serializers/chat-event-serializer.d.ts +82 -0
  465. package/dist/sse/shared/serializers/chat-event-serializer.js +275 -0
  466. package/dist/sse/shared/serializers/index.d.ts +39 -0
  467. package/dist/sse/shared/serializers/index.js +54 -0
  468. package/dist/sse/shared/serializers/responses-event-serializer.d.ts +123 -0
  469. package/dist/sse/shared/serializers/responses-event-serializer.js +356 -0
  470. package/dist/sse/shared/serializers/types.d.ts +51 -0
  471. package/dist/sse/shared/serializers/types.js +4 -0
  472. package/dist/sse/shared/utils.d.ts +254 -0
  473. package/dist/sse/shared/utils.js +543 -0
  474. package/dist/sse/shared/writer.d.ts +111 -0
  475. package/dist/sse/shared/writer.js +268 -0
  476. package/dist/sse/sse-to-json/anthropic-sse-to-json-converter.d.ts +13 -0
  477. package/dist/sse/sse-to-json/anthropic-sse-to-json-converter.js +139 -0
  478. package/dist/sse/sse-to-json/builders/response-builder.d.ts +165 -0
  479. package/dist/sse/sse-to-json/builders/response-builder.js +776 -0
  480. package/dist/sse/sse-to-json/chat-sse-to-json-converter.d.ts +106 -0
  481. package/dist/sse/sse-to-json/chat-sse-to-json-converter.js +540 -0
  482. package/dist/sse/sse-to-json/index.d.ts +6 -0
  483. package/dist/sse/sse-to-json/index.js +7 -0
  484. package/dist/sse/sse-to-json/parsers/sse-parser.d.ts +73 -0
  485. package/dist/sse/sse-to-json/parsers/sse-parser.js +340 -0
  486. package/dist/sse/sse-to-json/responses-sse-to-json-converter.d.ts +59 -0
  487. package/dist/sse/sse-to-json/responses-sse-to-json-converter.js +270 -0
  488. package/dist/sse/types/anthropic-types.d.ts +87 -0
  489. package/dist/sse/types/anthropic-types.js +5 -0
  490. package/dist/sse/types/chat-types.d.ts +308 -0
  491. package/dist/sse/types/chat-types.js +32 -0
  492. package/dist/sse/types/conversion-context.d.ts +211 -0
  493. package/dist/sse/types/conversion-context.js +20 -0
  494. package/dist/sse/types/core-interfaces.d.ts +90 -0
  495. package/dist/sse/types/core-interfaces.js +5 -0
  496. package/dist/sse/types/index.d.ts +14 -0
  497. package/dist/sse/types/index.js +7 -0
  498. package/dist/sse/types/responses-types.d.ts +328 -0
  499. package/dist/sse/types/responses-types.js +38 -0
  500. package/dist/sse/types/sse-events.d.ts +180 -0
  501. package/dist/sse/types/sse-events.js +150 -0
  502. package/dist/sse/types/stream-state.d.ts +204 -0
  503. package/dist/sse/types/stream-state.js +44 -0
  504. package/dist/sse/types/utility-types.d.ts +230 -0
  505. package/dist/sse/types/utility-types.js +49 -0
  506. package/dist/tools/proxy/anthropic-tool-proxy.d.ts +19 -0
  507. package/dist/tools/proxy/anthropic-tool-proxy.js +57 -0
  508. package/dist/tools/proxy/executors/web-fetch.d.ts +6 -0
  509. package/dist/tools/proxy/executors/web-fetch.js +39 -0
  510. package/dist/tools/proxy/registry.d.ts +8 -0
  511. package/dist/tools/proxy/registry.js +14 -0
  512. package/dist/tools/proxy/types.d.ts +29 -0
  513. package/dist/tools/proxy/types.js +1 -0
  514. package/dist/tools/tool-registry.d.ts +8 -0
  515. package/dist/tools/tool-registry.js +154 -0
  516. package/dist/tools/web-fetch-html.d.ts +15 -0
  517. package/dist/tools/web-fetch-html.js +83 -0
  518. package/dist/utils/conversion-adapter.d.ts +65 -0
  519. package/dist/utils/conversion-adapter.js +183 -0
  520. package/dist/utils/error-factory.d.ts +88 -0
  521. package/dist/utils/error-factory.js +138 -0
  522. package/dist/utils/error-utils.d.ts +334 -0
  523. package/dist/utils/error-utils.js +782 -0
  524. package/dist/utils/index.d.ts +8 -0
  525. package/dist/utils/index.js +13 -0
  526. package/dist/utils/performance-utils.d.ts +205 -0
  527. package/dist/utils/performance-utils.js +440 -0
  528. package/dist/utils/profile-mapper.d.ts +32 -0
  529. package/dist/utils/profile-mapper.js +269 -0
  530. package/dist/utils/request-processor.d.ts +52 -0
  531. package/dist/utils/request-processor.js +210 -0
  532. package/dist/utils/request-utils.d.ts +117 -0
  533. package/dist/utils/request-utils.js +333 -0
  534. package/dist/utils/response-utils.d.ts +127 -0
  535. package/dist/utils/response-utils.js +516 -0
  536. package/dist/utils/token-counter.d.ts +89 -0
  537. package/dist/utils/token-counter.js +541 -0
  538. package/package.json +65 -0
@@ -0,0 +1,541 @@
1
+ /**
2
+ * Token计数工具
3
+ *
4
+ * 基于OpenAI的标准token计算方法
5
+ * 参考: https://github.com/openai/tiktoken
6
+ */
7
+ /**
8
+ * 简化的Token计数器
9
+ *
10
+ * 注意:这是一个简化实现,准确的token计算需要使用tiktoken库
11
+ * 这里提供基本的估算功能,在生产环境中应该集成实际的tiktoken
12
+ */
13
+ const ENABLE_TIKTOKEN = true; // 临时禁用 tiktoken,统一走估算路径
14
+ export class TokenCounter {
15
+ /**
16
+ * 估算文本的token数量
17
+ *
18
+ * 基于OpenAI的经验法则:
19
+ * - 英文:1 token ≈ 4 characters
20
+ * - 中文:1 token ≈ 1.5-2 characters
21
+ * - 代码:1 token ≈ 3-4 characters
22
+ *
23
+ * @param text 要计算的文本
24
+ * @param language 语言类型 (optional)
25
+ * @returns 估算的token数量
26
+ */
27
+ static estimateTokens(text, language = 'auto') {
28
+ if (!text || typeof text !== 'string') {
29
+ return 0;
30
+ }
31
+ // 自动检测语言类型
32
+ if (language === 'auto') {
33
+ language = this.detectLanguage(text);
34
+ }
35
+ // 根据语言类型使用不同的计算比率
36
+ switch (language) {
37
+ case 'en':
38
+ return Math.ceil(text.length / 4); // 英文:约4个字符 = 1个token
39
+ case 'zh':
40
+ return Math.ceil(text.length / 1.5); // 中文:约1.5个字符 = 1个token
41
+ case 'code':
42
+ return Math.ceil(text.length / 3.5); // 代码:约3.5个字符 = 1个token
43
+ default:
44
+ return Math.ceil(text.length / 4); // 默认使用英文比率
45
+ }
46
+ }
47
+ /**
48
+ * 检测文本的主要语言类型
49
+ */
50
+ static detectLanguage(text) {
51
+ // 计算中文字符比例
52
+ const chineseChars = (text.match(/[\u4e00-\u9fff]/g) || []).length;
53
+ const chineseRatio = chineseChars / text.length;
54
+ // 计算代码特征比例(括号、分号、等号等)
55
+ const codeChars = (text.match(/[{}();=<>[\]]/g) || []).length;
56
+ const codeRatio = codeChars / text.length;
57
+ // 根据比例判断语言类型
58
+ if (chineseRatio > 0.3) {
59
+ return 'zh';
60
+ }
61
+ else if (codeRatio > 0.1) {
62
+ return 'code';
63
+ }
64
+ else {
65
+ return 'en';
66
+ }
67
+ }
68
+ /**
69
+ * 计算消息的token数量
70
+ */
71
+ static estimateMessageTokens(message, language = 'auto') {
72
+ if (!message) {
73
+ return 0;
74
+ }
75
+ let totalTokens = 0;
76
+ // 计算role的token数量(通常是1-2个token)
77
+ if (message.role) {
78
+ totalTokens += this.estimateTokens(message.role, language);
79
+ }
80
+ // 计算content的token数量
81
+ if (message.content) {
82
+ if (typeof message.content === 'string') {
83
+ totalTokens += this.estimateTokens(message.content, language);
84
+ }
85
+ else if (Array.isArray(message.content)) {
86
+ // 处理多模态内容(如图片 + 文本)
87
+ for (const contentItem of message.content) {
88
+ if (contentItem.type === 'text' && contentItem.text) {
89
+ totalTokens += this.estimateTokens(contentItem.text, language);
90
+ }
91
+ else if (contentItem.type === 'image') {
92
+ // 图片通常需要额外的token,这里使用一个估算值
93
+ // 具体数值取决于图片大小和模型,这里使用一个保守估计
94
+ totalTokens += 85; // OpenAI的典型图片token成本
95
+ }
96
+ }
97
+ }
98
+ }
99
+ // 计算tool_calls的token数量
100
+ if (message.tool_calls && Array.isArray(message.tool_calls)) {
101
+ for (const toolCall of message.tool_calls) {
102
+ // tool name: 约1-3个token
103
+ totalTokens += this.estimateTokens(toolCall.function?.name || '', language);
104
+ // arguments: 根据参数长度计算
105
+ totalTokens += this.estimateTokens(toolCall.function?.arguments || '{}', language);
106
+ // tool调用本身的一些固定开销
107
+ totalTokens += 5;
108
+ }
109
+ }
110
+ // 每个消息格式的一些固定开销
111
+ totalTokens += 3;
112
+ return totalTokens;
113
+ }
114
+ /**
115
+ * 计算工具定义的token数量
116
+ */
117
+ static estimateToolTokens(tool) {
118
+ if (!tool || !tool.function) {
119
+ return 0;
120
+ }
121
+ let tokens = 0;
122
+ // function name
123
+ tokens += this.estimateTokens(tool.function.name || '', 'en');
124
+ // function description
125
+ tokens += this.estimateTokens(tool.function.description || '', 'en');
126
+ // function parameters (JSON schema)
127
+ if (tool.function.parameters) {
128
+ const paramStr = JSON.stringify(tool.function.parameters);
129
+ tokens += this.estimateTokens(paramStr, 'code');
130
+ }
131
+ // 工具定义的一些固定开销
132
+ tokens += 10;
133
+ return tokens;
134
+ }
135
+ /**
136
+ * 计算完整请求的token数量
137
+ */
138
+ static estimateRequestTokens(request) {
139
+ if (!request) {
140
+ return { inputTokens: 0 };
141
+ }
142
+ let inputTokens = 0;
143
+ let toolTokens = 0;
144
+ // 计算model的token数量
145
+ if (request.model) {
146
+ inputTokens += this.estimateTokens(request.model, 'en');
147
+ }
148
+ // 计算系统指令的token数量
149
+ if (request.system || request.messages?.[0]?.role === 'system') {
150
+ const systemContent = request.system || request.messages[0].content;
151
+ inputTokens += this.estimateTokens(systemContent, 'auto');
152
+ }
153
+ // 计算消息的token数量
154
+ if (request.messages && Array.isArray(request.messages)) {
155
+ for (const message of request.messages) {
156
+ if (message.role !== 'system') { // 系统消息已经计算过了
157
+ inputTokens += this.estimateMessageTokens(message, 'auto');
158
+ }
159
+ }
160
+ }
161
+ // 计算工具定义的token数量
162
+ if (request.tools && Array.isArray(request.tools)) {
163
+ for (const tool of request.tools) {
164
+ toolTokens += this.estimateToolTokens(tool);
165
+ }
166
+ }
167
+ // 请求格式的固定开销
168
+ inputTokens += 10;
169
+ return {
170
+ inputTokens,
171
+ ...(toolTokens > 0 && { toolTokens })
172
+ };
173
+ }
174
+ /**
175
+ * 计算响应的token数量
176
+ */
177
+ static estimateResponseTokens(response) {
178
+ if (!response) {
179
+ return 0;
180
+ }
181
+ let tokens = 0;
182
+ // 计算response content的token数量
183
+ if (response.choices && response.choices[0]) {
184
+ const choice = response.choices[0];
185
+ if (choice.message) {
186
+ // 计算文本内容
187
+ if (choice.message.content) {
188
+ tokens += this.estimateTokens(choice.message.content, 'auto');
189
+ }
190
+ // 计算工具调用的token数量
191
+ if (choice.message.tool_calls && Array.isArray(choice.message.tool_calls)) {
192
+ for (const toolCall of choice.message.tool_calls) {
193
+ tokens += this.estimateTokens(toolCall.function?.name || '', 'en');
194
+ tokens += this.estimateTokens(toolCall.function?.arguments || '{}', 'code');
195
+ tokens += 5; // 工具调用固定开销
196
+ }
197
+ }
198
+ }
199
+ // 响应格式的固定开销
200
+ tokens += 5;
201
+ }
202
+ else if (response.content && Array.isArray(response.content)) {
203
+ // Anthropic Messages格式
204
+ for (const contentItem of response.content) {
205
+ if (contentItem.type === 'text' && contentItem.text) {
206
+ tokens += this.estimateTokens(contentItem.text, 'auto');
207
+ }
208
+ else if (contentItem.type === 'tool_use') {
209
+ tokens += this.estimateTokens(contentItem.name || '', 'en');
210
+ tokens += this.estimateTokens(JSON.stringify(contentItem.input || {}), 'code');
211
+ tokens += 5; // 工具使用固定开销
212
+ }
213
+ }
214
+ }
215
+ return tokens;
216
+ }
217
+ /**
218
+ * 精确计算token数量(使用tiktoken库)
219
+ *
220
+ * 使用tiktoken库进行精确的token计算
221
+ */
222
+ static async calculateTokensExact(text, model = 'gpt-3.5-turbo') {
223
+ if (!ENABLE_TIKTOKEN) {
224
+ return this.estimateTokens(text);
225
+ }
226
+ try {
227
+ // 动态导入tiktoken
228
+ const { encoding_for_model } = await import('tiktoken');
229
+ // 获取模型对应的编码器
230
+ const encoding = encoding_for_model(model);
231
+ // 计算token数量
232
+ const tokens = encoding.encode(text);
233
+ const tokenCount = tokens.length;
234
+ // 释放编码器资源
235
+ encoding.free();
236
+ return tokenCount;
237
+ }
238
+ catch (error) {
239
+ // 如果tiktoken计算失败,回退到估算方法
240
+ console.warn('tiktoken calculation failed, using estimation:', error);
241
+ return this.estimateTokens(text);
242
+ }
243
+ }
244
+ /**
245
+ * 检查tiktoken库是否可用
246
+ */
247
+ static async isTiktokenAvailable() {
248
+ if (!ENABLE_TIKTOKEN)
249
+ return false;
250
+ try {
251
+ // 尝试导入tiktoken来检查可用性
252
+ await import('tiktoken');
253
+ return true;
254
+ }
255
+ catch {
256
+ return false;
257
+ }
258
+ }
259
+ /**
260
+ * 智能token计算(优先使用tiktoken,回退到估算)
261
+ */
262
+ static async calculateTokens(text, model = 'gpt-3.5-turbo') {
263
+ // 如果tiktoken可用,使用精确计算
264
+ if (await this.isTiktokenAvailable()) {
265
+ return await this.calculateTokensExact(text, model);
266
+ }
267
+ // 否则使用估算方法
268
+ return this.estimateTokens(text);
269
+ }
270
+ /**
271
+ * 计算消息的精确token数量(使用tiktoken)
272
+ */
273
+ static async calculateMessageTokensExact(message, model = 'gpt-3.5-turbo') {
274
+ if (!ENABLE_TIKTOKEN) {
275
+ return this.estimateMessageTokens(message);
276
+ }
277
+ try {
278
+ const { encoding_for_model } = await import('tiktoken');
279
+ const encoding = encoding_for_model(model);
280
+ let totalTokens = 0;
281
+ // 计算role的token数量
282
+ if (message.role) {
283
+ totalTokens += encoding.encode(message.role).length;
284
+ }
285
+ // 计算content的token数量
286
+ if (message.content) {
287
+ if (typeof message.content === 'string') {
288
+ totalTokens += encoding.encode(message.content).length;
289
+ }
290
+ else if (Array.isArray(message.content)) {
291
+ for (const contentItem of message.content) {
292
+ if (contentItem.type === 'text' && contentItem.text) {
293
+ totalTokens += encoding.encode(contentItem.text).length;
294
+ }
295
+ else if (contentItem.type === 'image') {
296
+ // 图片token成本(使用OpenAI的典型值)
297
+ totalTokens += 85;
298
+ }
299
+ }
300
+ }
301
+ }
302
+ // 计算tool_calls的token数量
303
+ if (message.tool_calls && Array.isArray(message.tool_calls)) {
304
+ for (const toolCall of message.tool_calls) {
305
+ // tool name
306
+ if (toolCall.function?.name) {
307
+ totalTokens += encoding.encode(toolCall.function.name).length;
308
+ }
309
+ // arguments
310
+ const args = toolCall.function?.arguments || '{}';
311
+ totalTokens += encoding.encode(args).length;
312
+ // tool调用固定开销
313
+ totalTokens += 5;
314
+ }
315
+ }
316
+ // 每个消息的固定开销
317
+ totalTokens += 3;
318
+ encoding.free();
319
+ return totalTokens;
320
+ }
321
+ catch (error) {
322
+ console.warn('tiktoken message calculation failed, using estimation:', error);
323
+ return this.estimateMessageTokens(message);
324
+ }
325
+ }
326
+ /**
327
+ * 计算工具定义的精确token数量(使用tiktoken)
328
+ */
329
+ static async calculateToolTokensExact(tool, model = 'gpt-3.5-turbo') {
330
+ if (!ENABLE_TIKTOKEN) {
331
+ return this.estimateToolTokens(tool);
332
+ }
333
+ try {
334
+ const { encoding_for_model } = await import('tiktoken');
335
+ const encoding = encoding_for_model(model);
336
+ let tokens = 0;
337
+ if (tool?.function) {
338
+ // function name
339
+ if (tool.function.name) {
340
+ tokens += encoding.encode(tool.function.name).length;
341
+ }
342
+ // function description
343
+ if (tool.function.description) {
344
+ tokens += encoding.encode(tool.function.description).length;
345
+ }
346
+ // function parameters (JSON schema)
347
+ if (tool.function.parameters) {
348
+ const paramStr = JSON.stringify(tool.function.parameters);
349
+ tokens += encoding.encode(paramStr).length;
350
+ }
351
+ }
352
+ // 工具定义固定开销
353
+ tokens += 10;
354
+ encoding.free();
355
+ return tokens;
356
+ }
357
+ catch (error) {
358
+ console.warn('tiktoken tool calculation failed, using estimation:', error);
359
+ return this.estimateToolTokens(tool);
360
+ }
361
+ }
362
+ /**
363
+ * 计算请求的精确token数量(使用tiktoken)
364
+ *
365
+ * 非严格版本:若tiktoken不可用或出错,则回退到估算方法。
366
+ * 注意:路由/长上下文判断应优先使用 calculateRequestTokensStrict,禁止静默回退。
367
+ */
368
+ static async calculateRequestTokensExact(request, model = 'gpt-3.5-turbo') {
369
+ if (!ENABLE_TIKTOKEN) {
370
+ return this.estimateRequestTokens(request);
371
+ }
372
+ try {
373
+ return await this.calculateRequestTokensStrict(request, model);
374
+ }
375
+ catch (error) {
376
+ console.warn('tiktoken request calculation failed, using estimation:', error);
377
+ return this.estimateRequestTokens(request);
378
+ }
379
+ }
380
+ /**
381
+ * 计算请求的精确token数量(使用tiktoken,严格模式:禁止回退)
382
+ *
383
+ * 任何错误直接抛出,由调用方决定是否Fail Fast。
384
+ */
385
+ static async calculateRequestTokensStrict(request, model = 'gpt-3.5-turbo') {
386
+ const { get_encoding } = await import('tiktoken');
387
+ let inputTokens = 0;
388
+ let toolTokens = 0;
389
+ // 使用统一的cl100k_base编码,避免对非OpenAI模型抛出Invalid model错误
390
+ const encoding = get_encoding('cl100k_base');
391
+ const encodeText = (text) => {
392
+ if (!text || typeof text !== 'string')
393
+ return 0;
394
+ return encoding.encode(text).length;
395
+ };
396
+ try {
397
+ // 计算model的token数量
398
+ if (request.model) {
399
+ inputTokens += encodeText(request.model);
400
+ }
401
+ // 计算系统指令的token数量
402
+ if (request.system || request.messages?.[0]?.role === 'system') {
403
+ const systemContent = request.system || request.messages?.[0]?.content || '';
404
+ inputTokens += encodeText(systemContent);
405
+ }
406
+ // 计算消息的token数量
407
+ if (request.messages && Array.isArray(request.messages)) {
408
+ for (const message of request.messages) {
409
+ if (!message || typeof message !== 'object')
410
+ continue;
411
+ if (message.role === 'system')
412
+ continue; // 系统消息已单独计算
413
+ // role
414
+ if (message.role) {
415
+ inputTokens += encodeText(message.role);
416
+ }
417
+ // content
418
+ const content = message.content;
419
+ if (typeof content === 'string') {
420
+ inputTokens += encodeText(content);
421
+ }
422
+ else if (Array.isArray(content)) {
423
+ for (const part of content) {
424
+ if (part && typeof part === 'object') {
425
+ if (part.type === 'text' && typeof part.text === 'string') {
426
+ inputTokens += encodeText(part.text);
427
+ }
428
+ else if (part.type === 'image_url') {
429
+ // 使用与 estimateMessageTokens 相同的图片成本基准
430
+ inputTokens += 85;
431
+ }
432
+ }
433
+ }
434
+ }
435
+ // tool_calls
436
+ if (Array.isArray(message.tool_calls)) {
437
+ for (const tc of message.tool_calls) {
438
+ const fn = tc?.function;
439
+ if (fn?.name) {
440
+ inputTokens += encodeText(fn.name);
441
+ }
442
+ const args = typeof fn?.arguments === 'string' ? fn.arguments : JSON.stringify(fn?.arguments ?? {});
443
+ inputTokens += encodeText(args);
444
+ inputTokens += 5; // 固定开销
445
+ }
446
+ }
447
+ // 每个消息的固定开销
448
+ inputTokens += 3;
449
+ }
450
+ }
451
+ // 计算工具定义的token数量
452
+ if (request.tools && Array.isArray(request.tools)) {
453
+ for (const tool of request.tools) {
454
+ if (!tool || typeof tool !== 'object')
455
+ continue;
456
+ const fn = tool.function || {};
457
+ if (fn.name) {
458
+ toolTokens += encodeText(fn.name);
459
+ }
460
+ if (fn.description) {
461
+ toolTokens += encodeText(fn.description);
462
+ }
463
+ if (fn.parameters) {
464
+ toolTokens += encodeText(JSON.stringify(fn.parameters));
465
+ }
466
+ // 工具定义固定开销
467
+ toolTokens += 10;
468
+ }
469
+ }
470
+ // 请求格式的固定开销
471
+ inputTokens += 10;
472
+ return {
473
+ inputTokens,
474
+ ...(toolTokens > 0 && { toolTokens })
475
+ };
476
+ }
477
+ finally {
478
+ try {
479
+ encoding.free();
480
+ }
481
+ catch {
482
+ // ignore
483
+ }
484
+ }
485
+ }
486
+ /**
487
+ * 计算响应的精确token数量(使用tiktoken)
488
+ */
489
+ static async calculateResponseTokensExact(response, model = 'gpt-3.5-turbo') {
490
+ if (!ENABLE_TIKTOKEN) {
491
+ return this.estimateResponseTokens(response);
492
+ }
493
+ try {
494
+ let tokens = 0;
495
+ // 计算response content的token数量
496
+ if (response.choices && response.choices[0]) {
497
+ const choice = response.choices[0];
498
+ if (choice.message) {
499
+ // 计算文本内容
500
+ if (choice.message.content) {
501
+ tokens += await this.calculateTokensExact(choice.message.content, model);
502
+ }
503
+ // 计算工具调用的token数量
504
+ if (choice.message.tool_calls && Array.isArray(choice.message.tool_calls)) {
505
+ for (const toolCall of choice.message.tool_calls) {
506
+ if (toolCall.function?.name) {
507
+ tokens += await this.calculateTokensExact(toolCall.function.name, model);
508
+ }
509
+ const args = toolCall.function?.arguments || '{}';
510
+ tokens += await this.calculateTokensExact(args, model);
511
+ tokens += 5; // 工具调用固定开销
512
+ }
513
+ }
514
+ }
515
+ // 响应格式的固定开销
516
+ tokens += 5;
517
+ }
518
+ else if (response.content && Array.isArray(response.content)) {
519
+ // Anthropic Messages格式
520
+ for (const contentItem of response.content) {
521
+ if (contentItem.type === 'text' && contentItem.text) {
522
+ tokens += await this.calculateTokensExact(contentItem.text, model);
523
+ }
524
+ else if (contentItem.type === 'tool_use') {
525
+ if (contentItem.name) {
526
+ tokens += await this.calculateTokensExact(contentItem.name, model);
527
+ }
528
+ const input = JSON.stringify(contentItem.input || {});
529
+ tokens += await this.calculateTokensExact(input, model);
530
+ tokens += 5; // 工具使用固定开销
531
+ }
532
+ }
533
+ }
534
+ return tokens;
535
+ }
536
+ catch (error) {
537
+ console.warn('tiktoken response calculation failed, using estimation:', error);
538
+ return this.estimateResponseTokens(response);
539
+ }
540
+ }
541
+ }
package/package.json ADDED
@@ -0,0 +1,65 @@
1
+ {
2
+ "name": "@jsonstudio/llms",
3
+ "version": "0.4.2",
4
+ "type": "module",
5
+ "main": "dist/index.js",
6
+ "module": "dist/index.js",
7
+ "types": "dist/index.d.ts",
8
+ "scripts": {
9
+ "build": "tsc -p tsconfig.json",
10
+ "build:dev": "tsc -p tsconfig.json",
11
+ "postbuild": "node scripts/tests/run-matrix-ci.mjs",
12
+ "verif": "node scripts/tests/run-matrix-ci.mjs",
13
+ "verif:bridge": "node scripts/tests/run-cross-bridge-ci.mjs",
14
+ "test:looprt:chat": "npm run build && node scripts/tests/loop-rt-chat.mjs",
15
+ "test:looprt:responses": "npm run build && node scripts/tests/loop-rt-responses.mjs",
16
+ "test:looprt:anthropic": "npm run build && node scripts/tests/loop-rt-anthropic.mjs",
17
+ "test:looprt:all": "npm run build:dev && node scripts/tests/loop-rt-all.mjs",
18
+ "capture:chat:lmstudio": "node scripts/tools/capture-chat-golden-lmstudio.mjs",
19
+ "capture:chat:modelscope": "node scripts/tools/capture-chat-golden-modelscope.mjs",
20
+ "test:matrix": "npm run build:dev && node scripts/tests/run-matrix-ci.mjs",
21
+ "test:phase2": "npm run build && node scripts/tests/run-phase2a.mjs",
22
+ "test:phase3-sse": "npm run build && node scripts/tests/sse-node-roundtrip.mjs",
23
+ "test:anthropic-sse": "npm run build && node scripts/tests/anthropic-sse-node-roundtrip.mjs",
24
+ "test:anthropic-node": "npm run build && node scripts/tests/anthropic-node-roundtrip.mjs",
25
+ "capture:anthropic:golden": "node scripts/tools/capture-anthropic-golden.mjs --config $HOME/.routecodex/provider/glm-anthropic/config.json --prompt 'Say hi in one sentence'",
26
+ "test:anthropic-golden": "npm run build && node scripts/tests/anthropic-golden-roundtrip.mjs",
27
+ "test:looprt:gemini": "npm run build && node scripts/tests/loop-rt-gemini.mjs",
28
+ "replay:responses:chat-sse": "node scripts/exp3-responses-sse-to-chat-sse.mjs",
29
+ "replay:responses:loop": "node scripts/exp4-responses-sse-loop.mjs",
30
+ "replay:chat:bridge": "node scripts/exp5-chat-direct-bridge.mjs",
31
+ "test:virtual-router": "npm run build:dev && node scripts/tests/virtual-router-dry-run.mjs",
32
+ "test:virtual-router-health": "npm run build:dev && node scripts/tests/virtual-router-health.mjs"
33
+ },
34
+ "dependencies": {
35
+ "ajv": "^8.17.1",
36
+ "openai": "^6.9.1",
37
+ "tiktoken": "^1.0.22"
38
+ },
39
+ "exports": {
40
+ ".": {
41
+ "import": "./dist/index.js",
42
+ "types": "./dist/index.d.ts"
43
+ },
44
+ "./sse": {
45
+ "import": "./dist/sse/index.js",
46
+ "types": "./dist/sse/index.d.ts"
47
+ },
48
+ "./conversion": {
49
+ "import": "./dist/conversion/index.js",
50
+ "types": "./dist/conversion/index.d.ts"
51
+ },
52
+ "./guidance": {
53
+ "import": "./dist/guidance/index.js",
54
+ "types": "./dist/guidance/index.d.ts"
55
+ }
56
+ },
57
+ "devDependencies": {
58
+ "@types/node": "^20.11.25",
59
+ "typescript": "^5.4.0"
60
+ },
61
+ "files": [
62
+ "dist",
63
+ "README.md"
64
+ ]
65
+ }