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