@jsonstudio/llms 0.4.2 → 0.4.4

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 (417) hide show
  1. package/README.md +3 -1
  2. package/dist/bridge/routecodex-adapter.js +6 -3
  3. package/dist/config-unified/enhanced-path-resolver.js +14 -6
  4. package/dist/config-unified/unified-config.js +103 -59
  5. package/dist/conversion/codec-registry.js +4 -2
  6. package/dist/conversion/hub/pipeline/hub-pipeline.js +4 -5
  7. package/dist/conversion/hub/process/chat-process.js +258 -41
  8. package/dist/conversion/hub/response/provider-response.js +8 -2
  9. package/dist/conversion/hub/tool-governance/engine.d.ts +16 -0
  10. package/dist/conversion/hub/tool-governance/engine.js +266 -0
  11. package/dist/conversion/hub/tool-governance/index.d.ts +3 -0
  12. package/dist/conversion/hub/tool-governance/index.js +2 -0
  13. package/dist/conversion/hub/tool-governance/rules.d.ts +2 -0
  14. package/dist/conversion/hub/tool-governance/rules.js +76 -0
  15. package/dist/conversion/hub/tool-governance/types.d.ts +38 -0
  16. package/dist/conversion/index.d.ts +1 -0
  17. package/dist/conversion/index.js +1 -0
  18. package/dist/conversion/responses/responses-openai-bridge.js +5 -3
  19. package/dist/conversion/shared/responses-id-utils.js +18 -5
  20. package/dist/sse/sse-to-json/builders/response-builder.js +2 -1
  21. package/dist/sse/sse-to-json/chat-sse-to-json-converter.js +37 -23
  22. package/dist/sse/sse-to-json/parsers/sse-parser.js +20 -12
  23. package/dist/sse/sse-to-json/responses-sse-to-json-converter.d.ts +1 -0
  24. package/dist/sse/sse-to-json/responses-sse-to-json-converter.js +10 -8
  25. package/dist/sse/types/chat-types.d.ts +9 -6
  26. package/dist/sse/types/conversion-context.d.ts +14 -11
  27. package/dist/sse/types/core-interfaces.d.ts +6 -2
  28. package/dist/sse/types/index.d.ts +1 -1
  29. package/dist/sse/types/responses-types.d.ts +20 -20
  30. package/dist/sse/types/sse-events.d.ts +4 -3
  31. package/dist/sse/types/stream-state.d.ts +34 -39
  32. package/dist/sse/types/utility-types.d.ts +47 -43
  33. package/dist/sse/types/utility-types.js +10 -13
  34. package/dist/tools/tool-registry.js +156 -98
  35. package/package.json +6 -6
  36. package/dist/api/index.d.ts +0 -10
  37. package/dist/api/index.js +0 -11
  38. package/dist/api/llmswitch-config.d.ts +0 -15
  39. package/dist/api/llmswitch-config.js +0 -415
  40. package/dist/api/llmswitch-types.d.ts +0 -412
  41. package/dist/api/llmswitch-types.js +0 -60
  42. package/dist/bridge/routecodex-adapter.d.ts +0 -74
  43. package/dist/config/index.d.ts +0 -3
  44. package/dist/config/index.js +0 -5
  45. package/dist/config-unified/enhanced-path-resolver.d.ts +0 -5
  46. package/dist/config-unified/unified-config.d.ts +0 -26
  47. package/dist/conversion/codec-registry.d.ts +0 -10
  48. package/dist/conversion/codecs/anthropic-openai-codec.d.ts +0 -23
  49. package/dist/conversion/codecs/gemini-openai-codec.d.ts +0 -16
  50. package/dist/conversion/codecs/openai-openai-codec.d.ts +0 -12
  51. package/dist/conversion/codecs/responses-openai-codec.d.ts +0 -12
  52. package/dist/conversion/config/config-manager.d.ts +0 -212
  53. package/dist/conversion/conversion-v3/adapters/index.d.ts +0 -2
  54. package/dist/conversion/conversion-v3/adapters/index.js +0 -1
  55. package/dist/conversion/conversion-v3/adapters/v3-to-standard-adapter.d.ts +0 -38
  56. package/dist/conversion/conversion-v3/adapters/v3-to-standard-adapter.js +0 -55
  57. package/dist/conversion/conversion-v3/compatibility/compatibility-profiles.d.ts +0 -22
  58. package/dist/conversion/conversion-v3/compatibility/compatibility-profiles.js +0 -84
  59. package/dist/conversion/conversion-v3/compatibility/compatibility-stages.d.ts +0 -4
  60. package/dist/conversion/conversion-v3/compatibility/compatibility-stages.js +0 -285
  61. package/dist/conversion/conversion-v3/compatibility/index.d.ts +0 -3
  62. package/dist/conversion/conversion-v3/compatibility/index.js +0 -2
  63. package/dist/conversion/conversion-v3/config/default-configs.d.ts +0 -48
  64. package/dist/conversion/conversion-v3/config/default-configs.js +0 -1083
  65. package/dist/conversion/conversion-v3/config/index.d.ts +0 -5
  66. package/dist/conversion/conversion-v3/config/index.js +0 -5
  67. package/dist/conversion/conversion-v3/config/pipeline-config-manager.d.ts +0 -49
  68. package/dist/conversion/conversion-v3/config/pipeline-config-manager.js +0 -65
  69. package/dist/conversion/conversion-v3/index.d.ts +0 -11
  70. package/dist/conversion/conversion-v3/index.js +0 -17
  71. package/dist/conversion/conversion-v3/nodes/index.d.ts +0 -56
  72. package/dist/conversion/conversion-v3/nodes/index.js +0 -149
  73. package/dist/conversion/conversion-v3/nodes/input/anthropic-input-node.d.ts +0 -25
  74. package/dist/conversion/conversion-v3/nodes/input/anthropic-input-node.js +0 -56
  75. package/dist/conversion/conversion-v3/nodes/input/base-input-node.d.ts +0 -75
  76. package/dist/conversion/conversion-v3/nodes/input/base-input-node.js +0 -237
  77. package/dist/conversion/conversion-v3/nodes/input/chat-input-node.d.ts +0 -25
  78. package/dist/conversion/conversion-v3/nodes/input/chat-input-node.js +0 -56
  79. package/dist/conversion/conversion-v3/nodes/input/chat-shape-helpers.d.ts +0 -4
  80. package/dist/conversion/conversion-v3/nodes/input/chat-shape-helpers.js +0 -197
  81. package/dist/conversion/conversion-v3/nodes/input/gemini-input-node.d.ts +0 -16
  82. package/dist/conversion/conversion-v3/nodes/input/gemini-input-node.js +0 -125
  83. package/dist/conversion/conversion-v3/nodes/input/index.d.ts +0 -8
  84. package/dist/conversion/conversion-v3/nodes/input/index.js +0 -8
  85. package/dist/conversion/conversion-v3/nodes/input/input-decision.d.ts +0 -46
  86. package/dist/conversion/conversion-v3/nodes/input/input-decision.js +0 -125
  87. package/dist/conversion/conversion-v3/nodes/input/responses-input-node.d.ts +0 -20
  88. package/dist/conversion/conversion-v3/nodes/input/responses-input-node.js +0 -51
  89. package/dist/conversion/conversion-v3/nodes/output/anthropic-output-node.d.ts +0 -71
  90. package/dist/conversion/conversion-v3/nodes/output/anthropic-output-node.js +0 -320
  91. package/dist/conversion/conversion-v3/nodes/output/base-output-node.d.ts +0 -116
  92. package/dist/conversion/conversion-v3/nodes/output/base-output-node.js +0 -512
  93. package/dist/conversion/conversion-v3/nodes/output/index.d.ts +0 -7
  94. package/dist/conversion/conversion-v3/nodes/output/index.js +0 -7
  95. package/dist/conversion/conversion-v3/nodes/output/openai-output-node.d.ts +0 -71
  96. package/dist/conversion/conversion-v3/nodes/output/openai-output-node.js +0 -293
  97. package/dist/conversion/conversion-v3/nodes/output/output-decision.d.ts +0 -68
  98. package/dist/conversion/conversion-v3/nodes/output/output-decision.js +0 -161
  99. package/dist/conversion/conversion-v3/nodes/output/responses-output-node.d.ts +0 -64
  100. package/dist/conversion/conversion-v3/nodes/output/responses-output-node.js +0 -323
  101. package/dist/conversion/conversion-v3/nodes/process/base-process-node.d.ts +0 -72
  102. package/dist/conversion/conversion-v3/nodes/process/base-process-node.js +0 -246
  103. package/dist/conversion/conversion-v3/nodes/process/chat-process-node.d.ts +0 -135
  104. package/dist/conversion/conversion-v3/nodes/process/chat-process-node.js +0 -854
  105. package/dist/conversion/conversion-v3/nodes/process/compatibility-process-node.d.ts +0 -29
  106. package/dist/conversion/conversion-v3/nodes/process/compatibility-process-node.js +0 -181
  107. package/dist/conversion/conversion-v3/nodes/process/index.d.ts +0 -10
  108. package/dist/conversion/conversion-v3/nodes/process/index.js +0 -10
  109. package/dist/conversion/conversion-v3/nodes/process/passthrough-process-node.d.ts +0 -59
  110. package/dist/conversion/conversion-v3/nodes/process/passthrough-process-node.js +0 -243
  111. package/dist/conversion/conversion-v3/nodes/process/response-process-node.d.ts +0 -17
  112. package/dist/conversion/conversion-v3/nodes/process/response-process-node.js +0 -213
  113. package/dist/conversion/conversion-v3/nodes/process/tool-process-node.d.ts +0 -26
  114. package/dist/conversion/conversion-v3/nodes/process/tool-process-node.js +0 -299
  115. package/dist/conversion/conversion-v3/nodes/process/virtual-router-process-node.d.ts +0 -40
  116. package/dist/conversion/conversion-v3/nodes/process/virtual-router-process-node.js +0 -430
  117. package/dist/conversion/conversion-v3/nodes/response/anthropic-response-input-node.d.ts +0 -12
  118. package/dist/conversion/conversion-v3/nodes/response/anthropic-response-input-node.js +0 -129
  119. package/dist/conversion/conversion-v3/nodes/response/chat-to-responses-response-node.d.ts +0 -15
  120. package/dist/conversion/conversion-v3/nodes/response/chat-to-responses-response-node.js +0 -57
  121. package/dist/conversion/conversion-v3/nodes/response/index.d.ts +0 -4
  122. package/dist/conversion/conversion-v3/nodes/response/index.js +0 -4
  123. package/dist/conversion/conversion-v3/nodes/response/openai-response-input-node.d.ts +0 -15
  124. package/dist/conversion/conversion-v3/nodes/response/openai-response-input-node.js +0 -87
  125. package/dist/conversion/conversion-v3/nodes/response/response-utils.d.ts +0 -1
  126. package/dist/conversion/conversion-v3/nodes/response/response-utils.js +0 -1
  127. package/dist/conversion/conversion-v3/nodes/response/responses-response-input-node.d.ts +0 -12
  128. package/dist/conversion/conversion-v3/nodes/response/responses-response-input-node.js +0 -67
  129. package/dist/conversion/conversion-v3/nodes/sse/index.d.ts +0 -3
  130. package/dist/conversion/conversion-v3/nodes/sse/index.js +0 -3
  131. package/dist/conversion/conversion-v3/nodes/sse/sse-input-node.d.ts +0 -27
  132. package/dist/conversion/conversion-v3/nodes/sse/sse-input-node.js +0 -165
  133. package/dist/conversion/conversion-v3/nodes/sse/sse-output-node.d.ts +0 -19
  134. package/dist/conversion/conversion-v3/nodes/sse/sse-output-node.js +0 -267
  135. package/dist/conversion/conversion-v3/nodes/sse/sse-passthrough-node.d.ts +0 -18
  136. package/dist/conversion/conversion-v3/nodes/sse/sse-passthrough-node.js +0 -48
  137. package/dist/conversion/conversion-v3/pipelines/index.d.ts +0 -6
  138. package/dist/conversion/conversion-v3/pipelines/index.js +0 -6
  139. package/dist/conversion/conversion-v3/pipelines/super-pipeline.d.ts +0 -112
  140. package/dist/conversion/conversion-v3/pipelines/super-pipeline.js +0 -566
  141. package/dist/conversion/conversion-v3/response/provider-response-converter.d.ts +0 -28
  142. package/dist/conversion/conversion-v3/response/provider-response-converter.js +0 -249
  143. package/dist/conversion/conversion-v3/sse/index.d.ts +0 -140
  144. package/dist/conversion/conversion-v3/sse/index.js +0 -115
  145. package/dist/conversion/conversion-v3/sse/json-to-sse/anthropic-json-to-sse-converter.d.ts +0 -11
  146. package/dist/conversion/conversion-v3/sse/json-to-sse/anthropic-json-to-sse-converter.js +0 -79
  147. package/dist/conversion/conversion-v3/sse/json-to-sse/chat-json-to-sse-converter.d.ts +0 -79
  148. package/dist/conversion/conversion-v3/sse/json-to-sse/chat-json-to-sse-converter.js +0 -296
  149. package/dist/conversion/conversion-v3/sse/json-to-sse/event-generators/chat.d.ts +0 -55
  150. package/dist/conversion/conversion-v3/sse/json-to-sse/event-generators/chat.js +0 -233
  151. package/dist/conversion/conversion-v3/sse/json-to-sse/event-generators/responses.d.ts +0 -99
  152. package/dist/conversion/conversion-v3/sse/json-to-sse/event-generators/responses.js +0 -599
  153. package/dist/conversion/conversion-v3/sse/json-to-sse/index.d.ts +0 -6
  154. package/dist/conversion/conversion-v3/sse/json-to-sse/index.js +0 -7
  155. package/dist/conversion/conversion-v3/sse/json-to-sse/responses-json-to-sse-converter.d.ts +0 -79
  156. package/dist/conversion/conversion-v3/sse/json-to-sse/responses-json-to-sse-converter.js +0 -322
  157. package/dist/conversion/conversion-v3/sse/json-to-sse/sequencers/chat-sequencer.d.ts +0 -37
  158. package/dist/conversion/conversion-v3/sse/json-to-sse/sequencers/chat-sequencer.js +0 -218
  159. package/dist/conversion/conversion-v3/sse/json-to-sse/sequencers/responses-sequencer.d.ts +0 -40
  160. package/dist/conversion/conversion-v3/sse/json-to-sse/sequencers/responses-sequencer.js +0 -263
  161. package/dist/conversion/conversion-v3/sse/registry/sse-codec-registry.d.ts +0 -32
  162. package/dist/conversion/conversion-v3/sse/registry/sse-codec-registry.js +0 -106
  163. package/dist/conversion/conversion-v3/sse/shared/chat-serializer.d.ts +0 -4
  164. package/dist/conversion/conversion-v3/sse/shared/chat-serializer.js +0 -40
  165. package/dist/conversion/conversion-v3/sse/shared/constants.d.ts +0 -272
  166. package/dist/conversion/conversion-v3/sse/shared/constants.js +0 -321
  167. package/dist/conversion/conversion-v3/sse/shared/serializers/base-serializer.d.ts +0 -158
  168. package/dist/conversion/conversion-v3/sse/shared/serializers/base-serializer.js +0 -210
  169. package/dist/conversion/conversion-v3/sse/shared/serializers/chat-event-serializer.d.ts +0 -82
  170. package/dist/conversion/conversion-v3/sse/shared/serializers/chat-event-serializer.js +0 -275
  171. package/dist/conversion/conversion-v3/sse/shared/serializers/index.d.ts +0 -39
  172. package/dist/conversion/conversion-v3/sse/shared/serializers/index.js +0 -54
  173. package/dist/conversion/conversion-v3/sse/shared/serializers/responses-event-serializer.d.ts +0 -123
  174. package/dist/conversion/conversion-v3/sse/shared/serializers/responses-event-serializer.js +0 -356
  175. package/dist/conversion/conversion-v3/sse/shared/serializers/types.d.ts +0 -51
  176. package/dist/conversion/conversion-v3/sse/shared/serializers/types.js +0 -4
  177. package/dist/conversion/conversion-v3/sse/shared/utils.d.ts +0 -254
  178. package/dist/conversion/conversion-v3/sse/shared/utils.js +0 -543
  179. package/dist/conversion/conversion-v3/sse/shared/writer.d.ts +0 -111
  180. package/dist/conversion/conversion-v3/sse/shared/writer.js +0 -268
  181. package/dist/conversion/conversion-v3/sse/sse-to-json/anthropic-sse-to-json-converter.d.ts +0 -13
  182. package/dist/conversion/conversion-v3/sse/sse-to-json/anthropic-sse-to-json-converter.js +0 -139
  183. package/dist/conversion/conversion-v3/sse/sse-to-json/builders/response-builder.d.ts +0 -165
  184. package/dist/conversion/conversion-v3/sse/sse-to-json/builders/response-builder.js +0 -776
  185. package/dist/conversion/conversion-v3/sse/sse-to-json/chat-sse-to-json-converter.d.ts +0 -106
  186. package/dist/conversion/conversion-v3/sse/sse-to-json/chat-sse-to-json-converter.js +0 -540
  187. package/dist/conversion/conversion-v3/sse/sse-to-json/index.d.ts +0 -6
  188. package/dist/conversion/conversion-v3/sse/sse-to-json/index.js +0 -7
  189. package/dist/conversion/conversion-v3/sse/sse-to-json/parsers/sse-parser.d.ts +0 -73
  190. package/dist/conversion/conversion-v3/sse/sse-to-json/parsers/sse-parser.js +0 -332
  191. package/dist/conversion/conversion-v3/sse/sse-to-json/responses-sse-to-json-converter.d.ts +0 -59
  192. package/dist/conversion/conversion-v3/sse/sse-to-json/responses-sse-to-json-converter.js +0 -270
  193. package/dist/conversion/conversion-v3/sse/types/anthropic-types.d.ts +0 -87
  194. package/dist/conversion/conversion-v3/sse/types/anthropic-types.js +0 -5
  195. package/dist/conversion/conversion-v3/sse/types/chat-types.d.ts +0 -308
  196. package/dist/conversion/conversion-v3/sse/types/chat-types.js +0 -32
  197. package/dist/conversion/conversion-v3/sse/types/conversion-context.d.ts +0 -211
  198. package/dist/conversion/conversion-v3/sse/types/conversion-context.js +0 -20
  199. package/dist/conversion/conversion-v3/sse/types/core-interfaces.d.ts +0 -90
  200. package/dist/conversion/conversion-v3/sse/types/core-interfaces.js +0 -5
  201. package/dist/conversion/conversion-v3/sse/types/index.d.ts +0 -14
  202. package/dist/conversion/conversion-v3/sse/types/index.js +0 -7
  203. package/dist/conversion/conversion-v3/sse/types/responses-types.d.ts +0 -328
  204. package/dist/conversion/conversion-v3/sse/types/responses-types.js +0 -38
  205. package/dist/conversion/conversion-v3/sse/types/sse-events.d.ts +0 -180
  206. package/dist/conversion/conversion-v3/sse/types/sse-events.js +0 -150
  207. package/dist/conversion/conversion-v3/sse/types/stream-state.d.ts +0 -204
  208. package/dist/conversion/conversion-v3/sse/types/stream-state.js +0 -44
  209. package/dist/conversion/conversion-v3/sse/types/utility-types.d.ts +0 -230
  210. package/dist/conversion/conversion-v3/sse/types/utility-types.js +0 -49
  211. package/dist/conversion/conversion-v3/standards/context-adapter.d.ts +0 -146
  212. package/dist/conversion/conversion-v3/standards/context-adapter.js +0 -438
  213. package/dist/conversion/conversion-v3/standards/errors.d.ts +0 -38
  214. package/dist/conversion/conversion-v3/standards/errors.js +0 -27
  215. package/dist/conversion/conversion-v3/standards/index.d.ts +0 -15
  216. package/dist/conversion/conversion-v3/standards/index.js +0 -11
  217. package/dist/conversion/conversion-v3/standards/node-capabilities.d.ts +0 -123
  218. package/dist/conversion/conversion-v3/standards/node-capabilities.js +0 -330
  219. package/dist/conversion/conversion-v3/standards/pipeline-context.d.ts +0 -237
  220. package/dist/conversion/conversion-v3/standards/pipeline-context.js +0 -84
  221. package/dist/conversion/conversion-v3/standards/pipeline-node.d.ts +0 -196
  222. package/dist/conversion/conversion-v3/standards/pipeline-node.js +0 -316
  223. package/dist/conversion/conversion-v3/standards/snapshot-handles.d.ts +0 -24
  224. package/dist/conversion/conversion-v3/standards/snapshot-handles.js +0 -49
  225. package/dist/conversion/conversion-v3/types/config-types.d.ts +0 -242
  226. package/dist/conversion/conversion-v3/types/config-types.js +0 -13
  227. package/dist/conversion/conversion-v3/types/index.d.ts +0 -8
  228. package/dist/conversion/conversion-v3/types/index.js +0 -11
  229. package/dist/conversion/conversion-v3/types/node-types.d.ts +0 -211
  230. package/dist/conversion/conversion-v3/types/node-types.js +0 -20
  231. package/dist/conversion/conversion-v3/types/pipeline-types.d.ts +0 -246
  232. package/dist/conversion/conversion-v3/types/pipeline-types.js +0 -26
  233. package/dist/conversion/conversion-v3/types/request-types.d.ts +0 -293
  234. package/dist/conversion/conversion-v3/types/request-types.js +0 -26
  235. package/dist/conversion/conversion-v3/utils/provider-payload-sanitizer.d.ts +0 -10
  236. package/dist/conversion/conversion-v3/utils/provider-payload-sanitizer.js +0 -103
  237. package/dist/conversion/conversion-v3/validations/index.d.ts +0 -8
  238. package/dist/conversion/conversion-v3/validations/index.js +0 -7
  239. package/dist/conversion/conversion-v3/validations/node-graph-validator.d.ts +0 -116
  240. package/dist/conversion/conversion-v3/validations/node-graph-validator.js +0 -505
  241. package/dist/conversion/conversion-v3/validations/tool-governance-enforcer.d.ts +0 -139
  242. package/dist/conversion/conversion-v3/validations/tool-governance-enforcer.js +0 -338
  243. package/dist/conversion/hub/config/types.d.ts +0 -26
  244. package/dist/conversion/hub/core/detour-registry.d.ts +0 -9
  245. package/dist/conversion/hub/core/hub-context.d.ts +0 -21
  246. package/dist/conversion/hub/core/index.d.ts +0 -3
  247. package/dist/conversion/hub/core/stage-driver.d.ts +0 -30
  248. package/dist/conversion/hub/format-adapters/anthropic-format-adapter.d.ts +0 -16
  249. package/dist/conversion/hub/format-adapters/chat-format-adapter.d.ts +0 -17
  250. package/dist/conversion/hub/format-adapters/gemini-format-adapter.d.ts +0 -16
  251. package/dist/conversion/hub/format-adapters/index.d.ts +0 -21
  252. package/dist/conversion/hub/format-adapters/responses-format-adapter.d.ts +0 -17
  253. package/dist/conversion/hub/hub-feature.d.ts +0 -1
  254. package/dist/conversion/hub/node-support.d.ts +0 -19
  255. package/dist/conversion/hub/pipeline/hub-pipeline.d.ts +0 -68
  256. package/dist/conversion/hub/pipelines/inbound.d.ts +0 -22
  257. package/dist/conversion/hub/pipelines/outbound.d.ts +0 -22
  258. package/dist/conversion/hub/process/chat-process.d.ts +0 -13
  259. package/dist/conversion/hub/registry.d.ts +0 -28
  260. package/dist/conversion/hub/response/chat-response-utils.d.ts +0 -6
  261. package/dist/conversion/hub/response/provider-response.d.ts +0 -20
  262. package/dist/conversion/hub/response/response-mappers.d.ts +0 -19
  263. package/dist/conversion/hub/response/response-runtime.d.ts +0 -3
  264. package/dist/conversion/hub/semantic-mappers/anthropic-mapper.d.ts +0 -7
  265. package/dist/conversion/hub/semantic-mappers/chat-mapper.d.ts +0 -7
  266. package/dist/conversion/hub/semantic-mappers/gemini-mapper.d.ts +0 -7
  267. package/dist/conversion/hub/semantic-mappers/index.d.ts +0 -4
  268. package/dist/conversion/hub/semantic-mappers/responses-mapper.d.ts +0 -21
  269. package/dist/conversion/hub/snapshot-recorder.d.ts +0 -12
  270. package/dist/conversion/hub/standardized-bridge.d.ts +0 -12
  271. package/dist/conversion/hub/types/chat-envelope.d.ts +0 -67
  272. package/dist/conversion/hub/types/chat-schema.d.ts +0 -112
  273. package/dist/conversion/hub/types/errors.d.ts +0 -5
  274. package/dist/conversion/hub/types/format-envelope.d.ts +0 -7
  275. package/dist/conversion/hub/types/index.d.ts +0 -6
  276. package/dist/conversion/hub/types/json.d.ts +0 -9
  277. package/dist/conversion/hub/types/node.d.ts +0 -31
  278. package/dist/conversion/hub/types/standardized.d.ts +0 -94
  279. package/dist/conversion/responses/responses-openai-bridge.d.ts +0 -95
  280. package/dist/conversion/schema-validator.d.ts +0 -7
  281. package/dist/conversion/shared/args-mapping.d.ts +0 -18
  282. package/dist/conversion/shared/chat-request-filters.d.ts +0 -9
  283. package/dist/conversion/shared/jsonish.d.ts +0 -3
  284. package/dist/conversion/shared/mcp-injection.d.ts +0 -2
  285. package/dist/conversion/shared/media.d.ts +0 -1
  286. package/dist/conversion/shared/openai-finalizer.d.ts +0 -9
  287. package/dist/conversion/shared/openai-message-normalize.d.ts +0 -1
  288. package/dist/conversion/shared/payload-budget.d.ts +0 -13
  289. package/dist/conversion/shared/reasoning-mapping.d.ts +0 -5
  290. package/dist/conversion/shared/responses-conversation-store.d.ts +0 -41
  291. package/dist/conversion/shared/responses-id-utils.d.ts +0 -7
  292. package/dist/conversion/shared/responses-instructions.d.ts +0 -1
  293. package/dist/conversion/shared/responses-metadata.d.ts +0 -1
  294. package/dist/conversion/shared/responses-request-adapter.d.ts +0 -66
  295. package/dist/conversion/shared/snapshot-hooks.d.ts +0 -12
  296. package/dist/conversion/shared/streaming-text-extractor.d.ts +0 -26
  297. package/dist/conversion/shared/text-markup-normalizer.d.ts +0 -9
  298. package/dist/conversion/shared/tool-canonicalizer.d.ts +0 -2
  299. package/dist/conversion/shared/tool-filter-pipeline.d.ts +0 -17
  300. package/dist/conversion/shared/tool-governor.d.ts +0 -27
  301. package/dist/conversion/shared/tool-harvester.d.ts +0 -31
  302. package/dist/conversion/shared/tool-mapping.d.ts +0 -10
  303. package/dist/conversion/shared/tooling.d.ts +0 -26
  304. package/dist/conversion/types.d.ts +0 -33
  305. package/dist/core/index.d.ts +0 -6
  306. package/dist/core/index.js +0 -9
  307. package/dist/core/llmswitch-engine-v2.d.ts +0 -132
  308. package/dist/core/llmswitch-engine-v2.js +0 -649
  309. package/dist/core/llmswitch-factory-v2.d.ts +0 -123
  310. package/dist/core/llmswitch-factory-v2.js +0 -521
  311. package/dist/endpoints/base-endpoint-handler.d.ts +0 -128
  312. package/dist/endpoints/base-endpoint-handler.js +0 -545
  313. package/dist/endpoints/chat-endpoint-handler.d.ts +0 -115
  314. package/dist/endpoints/chat-endpoint-handler.js +0 -218
  315. package/dist/endpoints/endpoint-router.d.ts +0 -127
  316. package/dist/endpoints/endpoint-router.js +0 -438
  317. package/dist/endpoints/index.d.ts +0 -13
  318. package/dist/endpoints/index.js +0 -11
  319. package/dist/endpoints/messages-endpoint-handler.d.ts +0 -171
  320. package/dist/endpoints/messages-endpoint-handler.js +0 -238
  321. package/dist/endpoints/responses-endpoint-handler.d.ts +0 -147
  322. package/dist/endpoints/responses-endpoint-handler.js +0 -233
  323. package/dist/filters/builtin/add-fields-filter.d.ts +0 -8
  324. package/dist/filters/builtin/blacklist-filter.d.ts +0 -8
  325. package/dist/filters/builtin/whitelist-filter.d.ts +0 -8
  326. package/dist/filters/engine.d.ts +0 -16
  327. package/dist/filters/index.d.ts +0 -19
  328. package/dist/filters/special/request-streaming-to-nonstreaming.d.ts +0 -12
  329. package/dist/filters/special/request-tool-choice-policy.d.ts +0 -11
  330. package/dist/filters/special/request-tool-list-filter.d.ts +0 -11
  331. package/dist/filters/special/request-toolcalls-stringify.d.ts +0 -10
  332. package/dist/filters/special/request-tools-normalize.d.ts +0 -12
  333. package/dist/filters/special/response-finish-invariants.d.ts +0 -11
  334. package/dist/filters/special/response-openai-to-responses-bridge.d.ts +0 -13
  335. package/dist/filters/special/response-tool-arguments-blacklist.d.ts +0 -12
  336. package/dist/filters/special/response-tool-arguments-schema-converge.d.ts +0 -13
  337. package/dist/filters/special/response-tool-arguments-stringify.d.ts +0 -9
  338. package/dist/filters/special/response-tool-arguments-toon-decode.d.ts +0 -10
  339. package/dist/filters/special/response-tool-arguments-whitelist.d.ts +0 -11
  340. package/dist/filters/special/response-tool-text-canonicalize.d.ts +0 -10
  341. package/dist/filters/special/tool-filter-hooks.d.ts +0 -19
  342. package/dist/filters/special/tool-post-constraints.d.ts +0 -31
  343. package/dist/filters/types.d.ts +0 -68
  344. package/dist/filters/utils/fieldmap-loader.d.ts +0 -2
  345. package/dist/filters/utils/snapshot-writer.d.ts +0 -10
  346. package/dist/guidance/index.d.ts +0 -3
  347. package/dist/hooks/hooks-integration.d.ts +0 -161
  348. package/dist/hooks/hooks-integration.js +0 -519
  349. package/dist/hooks/index.d.ts +0 -10
  350. package/dist/hooks/index.js +0 -13
  351. package/dist/html-to-markdown.d.ts +0 -5
  352. package/dist/html-to-markdown.js +0 -66
  353. package/dist/http/sse-response.d.ts +0 -22
  354. package/dist/router/virtual-router/bootstrap.d.ts +0 -6
  355. package/dist/router/virtual-router/classifier.d.ts +0 -10
  356. package/dist/router/virtual-router/engine.d.ts +0 -35
  357. package/dist/router/virtual-router/error-center.d.ts +0 -10
  358. package/dist/router/virtual-router/features.d.ts +0 -3
  359. package/dist/router/virtual-router/health-manager.d.ts +0 -18
  360. package/dist/router/virtual-router/load-balancer.d.ts +0 -18
  361. package/dist/router/virtual-router/provider-registry.d.ts +0 -11
  362. package/dist/router/virtual-router/types.d.ts +0 -206
  363. package/dist/sse/json-to-sse/anthropic-json-to-sse-converter.d.ts +0 -11
  364. package/dist/sse/json-to-sse/chat-json-to-sse-converter.d.ts +0 -79
  365. package/dist/sse/json-to-sse/event-generators/chat.d.ts +0 -55
  366. package/dist/sse/json-to-sse/event-generators/responses.d.ts +0 -99
  367. package/dist/sse/json-to-sse/index.d.ts +0 -6
  368. package/dist/sse/json-to-sse/responses-json-to-sse-converter.d.ts +0 -79
  369. package/dist/sse/json-to-sse/sequencers/chat-sequencer.d.ts +0 -37
  370. package/dist/sse/json-to-sse/sequencers/responses-sequencer.d.ts +0 -40
  371. package/dist/sse/registry/sse-codec-registry.d.ts +0 -32
  372. package/dist/sse/shared/chat-serializer.d.ts +0 -4
  373. package/dist/sse/shared/constants.d.ts +0 -272
  374. package/dist/sse/shared/serializers/base-serializer.d.ts +0 -158
  375. package/dist/sse/shared/serializers/chat-event-serializer.d.ts +0 -82
  376. package/dist/sse/shared/serializers/index.d.ts +0 -39
  377. package/dist/sse/shared/serializers/responses-event-serializer.d.ts +0 -123
  378. package/dist/sse/shared/serializers/types.d.ts +0 -51
  379. package/dist/sse/shared/utils.d.ts +0 -254
  380. package/dist/sse/shared/writer.d.ts +0 -111
  381. package/dist/sse/sse-to-json/anthropic-sse-to-json-converter.d.ts +0 -13
  382. package/dist/sse/sse-to-json/builders/response-builder.d.ts +0 -165
  383. package/dist/sse/sse-to-json/chat-sse-to-json-converter.d.ts +0 -106
  384. package/dist/sse/sse-to-json/index.d.ts +0 -6
  385. package/dist/sse/sse-to-json/parsers/sse-parser.d.ts +0 -73
  386. package/dist/sse/types/anthropic-types.d.ts +0 -87
  387. package/dist/tools/proxy/anthropic-tool-proxy.d.ts +0 -19
  388. package/dist/tools/proxy/anthropic-tool-proxy.js +0 -57
  389. package/dist/tools/proxy/executors/web-fetch.d.ts +0 -6
  390. package/dist/tools/proxy/executors/web-fetch.js +0 -39
  391. package/dist/tools/proxy/registry.d.ts +0 -8
  392. package/dist/tools/proxy/registry.js +0 -14
  393. package/dist/tools/proxy/types.d.ts +0 -29
  394. package/dist/tools/tool-registry.d.ts +0 -8
  395. package/dist/tools/web-fetch-html.d.ts +0 -15
  396. package/dist/tools/web-fetch-html.js +0 -83
  397. package/dist/utils/conversion-adapter.d.ts +0 -65
  398. package/dist/utils/conversion-adapter.js +0 -183
  399. package/dist/utils/error-factory.d.ts +0 -88
  400. package/dist/utils/error-factory.js +0 -138
  401. package/dist/utils/error-utils.d.ts +0 -334
  402. package/dist/utils/error-utils.js +0 -782
  403. package/dist/utils/index.d.ts +0 -8
  404. package/dist/utils/index.js +0 -13
  405. package/dist/utils/performance-utils.d.ts +0 -205
  406. package/dist/utils/performance-utils.js +0 -440
  407. package/dist/utils/profile-mapper.d.ts +0 -32
  408. package/dist/utils/profile-mapper.js +0 -269
  409. package/dist/utils/request-processor.d.ts +0 -52
  410. package/dist/utils/request-processor.js +0 -210
  411. package/dist/utils/request-utils.d.ts +0 -117
  412. package/dist/utils/request-utils.js +0 -333
  413. package/dist/utils/response-utils.d.ts +0 -127
  414. package/dist/utils/response-utils.js +0 -516
  415. package/dist/utils/token-counter.d.ts +0 -89
  416. package/dist/utils/token-counter.js +0 -541
  417. /package/dist/{tools/proxy → conversion/hub/tool-governance}/types.js +0 -0
@@ -1,541 +0,0 @@
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
- }