ai 6.0.32 → 6.0.34

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 (353) hide show
  1. package/CHANGELOG.md +16 -0
  2. package/dist/index.js +12 -2
  3. package/dist/index.js.map +1 -1
  4. package/dist/index.mjs +12 -2
  5. package/dist/index.mjs.map +1 -1
  6. package/dist/internal/index.js +1 -1
  7. package/dist/internal/index.mjs +1 -1
  8. package/docs/02-foundations/03-prompts.mdx +2 -2
  9. package/docs/03-ai-sdk-core/15-tools-and-tool-calling.mdx +1 -1
  10. package/docs/07-reference/01-ai-sdk-core/28-output.mdx +1 -1
  11. package/package.json +6 -4
  12. package/src/agent/agent.ts +116 -0
  13. package/src/agent/create-agent-ui-stream-response.test.ts +258 -0
  14. package/src/agent/create-agent-ui-stream-response.ts +50 -0
  15. package/src/agent/create-agent-ui-stream.ts +73 -0
  16. package/src/agent/index.ts +33 -0
  17. package/src/agent/infer-agent-tools.ts +7 -0
  18. package/src/agent/infer-agent-ui-message.test-d.ts +54 -0
  19. package/src/agent/infer-agent-ui-message.ts +11 -0
  20. package/src/agent/pipe-agent-ui-stream-to-response.ts +52 -0
  21. package/src/agent/tool-loop-agent-on-finish-callback.ts +31 -0
  22. package/src/agent/tool-loop-agent-on-step-finish-callback.ts +11 -0
  23. package/src/agent/tool-loop-agent-settings.ts +182 -0
  24. package/src/agent/tool-loop-agent.test-d.ts +114 -0
  25. package/src/agent/tool-loop-agent.test.ts +442 -0
  26. package/src/agent/tool-loop-agent.ts +114 -0
  27. package/src/embed/__snapshots__/embed-many.test.ts.snap +191 -0
  28. package/src/embed/__snapshots__/embed.test.ts.snap +81 -0
  29. package/src/embed/embed-many-result.ts +53 -0
  30. package/src/embed/embed-many.test.ts +653 -0
  31. package/src/embed/embed-many.ts +378 -0
  32. package/src/embed/embed-result.ts +50 -0
  33. package/src/embed/embed.test.ts +298 -0
  34. package/src/embed/embed.ts +211 -0
  35. package/src/embed/index.ts +4 -0
  36. package/src/error/index.ts +34 -0
  37. package/src/error/invalid-argument-error.ts +34 -0
  38. package/src/error/invalid-stream-part-error.ts +28 -0
  39. package/src/error/invalid-tool-approval-error.ts +26 -0
  40. package/src/error/invalid-tool-input-error.ts +33 -0
  41. package/src/error/no-image-generated-error.ts +39 -0
  42. package/src/error/no-object-generated-error.ts +70 -0
  43. package/src/error/no-output-generated-error.ts +26 -0
  44. package/src/error/no-speech-generated-error.ts +18 -0
  45. package/src/error/no-such-tool-error.ts +35 -0
  46. package/src/error/no-transcript-generated-error.ts +20 -0
  47. package/src/error/tool-call-not-found-for-approval-error.ts +32 -0
  48. package/src/error/tool-call-repair-error.ts +30 -0
  49. package/src/error/unsupported-model-version-error.ts +23 -0
  50. package/src/error/verify-no-object-generated-error.ts +27 -0
  51. package/src/generate-image/generate-image-result.ts +42 -0
  52. package/src/generate-image/generate-image.test.ts +1420 -0
  53. package/src/generate-image/generate-image.ts +360 -0
  54. package/src/generate-image/index.ts +18 -0
  55. package/src/generate-object/__snapshots__/generate-object.test.ts.snap +133 -0
  56. package/src/generate-object/__snapshots__/stream-object.test.ts.snap +297 -0
  57. package/src/generate-object/generate-object-result.ts +67 -0
  58. package/src/generate-object/generate-object.test-d.ts +49 -0
  59. package/src/generate-object/generate-object.test.ts +1191 -0
  60. package/src/generate-object/generate-object.ts +518 -0
  61. package/src/generate-object/index.ts +9 -0
  62. package/src/generate-object/inject-json-instruction.test.ts +181 -0
  63. package/src/generate-object/inject-json-instruction.ts +30 -0
  64. package/src/generate-object/output-strategy.ts +415 -0
  65. package/src/generate-object/parse-and-validate-object-result.ts +111 -0
  66. package/src/generate-object/repair-text.ts +12 -0
  67. package/src/generate-object/stream-object-result.ts +120 -0
  68. package/src/generate-object/stream-object.test-d.ts +74 -0
  69. package/src/generate-object/stream-object.test.ts +1950 -0
  70. package/src/generate-object/stream-object.ts +986 -0
  71. package/src/generate-object/validate-object-generation-input.ts +144 -0
  72. package/src/generate-speech/generate-speech-result.ts +30 -0
  73. package/src/generate-speech/generate-speech.test.ts +300 -0
  74. package/src/generate-speech/generate-speech.ts +190 -0
  75. package/src/generate-speech/generated-audio-file.ts +65 -0
  76. package/src/generate-speech/index.ts +3 -0
  77. package/src/generate-text/__snapshots__/generate-text.test.ts.snap +1872 -0
  78. package/src/generate-text/__snapshots__/stream-text.test.ts.snap +1255 -0
  79. package/src/generate-text/collect-tool-approvals.test.ts +553 -0
  80. package/src/generate-text/collect-tool-approvals.ts +116 -0
  81. package/src/generate-text/content-part.ts +25 -0
  82. package/src/generate-text/execute-tool-call.ts +129 -0
  83. package/src/generate-text/extract-reasoning-content.ts +17 -0
  84. package/src/generate-text/extract-text-content.ts +15 -0
  85. package/src/generate-text/generate-text-result.ts +168 -0
  86. package/src/generate-text/generate-text.test-d.ts +68 -0
  87. package/src/generate-text/generate-text.test.ts +7011 -0
  88. package/src/generate-text/generate-text.ts +1223 -0
  89. package/src/generate-text/generated-file.ts +70 -0
  90. package/src/generate-text/index.ts +57 -0
  91. package/src/generate-text/is-approval-needed.ts +29 -0
  92. package/src/generate-text/output-utils.ts +23 -0
  93. package/src/generate-text/output.test.ts +698 -0
  94. package/src/generate-text/output.ts +590 -0
  95. package/src/generate-text/parse-tool-call.test.ts +570 -0
  96. package/src/generate-text/parse-tool-call.ts +188 -0
  97. package/src/generate-text/prepare-step.ts +103 -0
  98. package/src/generate-text/prune-messages.test.ts +720 -0
  99. package/src/generate-text/prune-messages.ts +167 -0
  100. package/src/generate-text/reasoning-output.ts +20 -0
  101. package/src/generate-text/reasoning.ts +8 -0
  102. package/src/generate-text/response-message.ts +10 -0
  103. package/src/generate-text/run-tools-transformation.test.ts +1143 -0
  104. package/src/generate-text/run-tools-transformation.ts +420 -0
  105. package/src/generate-text/smooth-stream.test.ts +2101 -0
  106. package/src/generate-text/smooth-stream.ts +162 -0
  107. package/src/generate-text/step-result.ts +238 -0
  108. package/src/generate-text/stop-condition.ts +29 -0
  109. package/src/generate-text/stream-text-result.ts +463 -0
  110. package/src/generate-text/stream-text.test-d.ts +200 -0
  111. package/src/generate-text/stream-text.test.ts +19979 -0
  112. package/src/generate-text/stream-text.ts +2505 -0
  113. package/src/generate-text/to-response-messages.test.ts +922 -0
  114. package/src/generate-text/to-response-messages.ts +163 -0
  115. package/src/generate-text/tool-approval-request-output.ts +21 -0
  116. package/src/generate-text/tool-call-repair-function.ts +27 -0
  117. package/src/generate-text/tool-call.ts +47 -0
  118. package/src/generate-text/tool-error.ts +34 -0
  119. package/src/generate-text/tool-output-denied.ts +21 -0
  120. package/src/generate-text/tool-output.ts +7 -0
  121. package/src/generate-text/tool-result.ts +36 -0
  122. package/src/generate-text/tool-set.ts +14 -0
  123. package/src/global.ts +24 -0
  124. package/src/index.ts +50 -0
  125. package/src/logger/index.ts +6 -0
  126. package/src/logger/log-warnings.test.ts +351 -0
  127. package/src/logger/log-warnings.ts +119 -0
  128. package/src/middleware/__snapshots__/simulate-streaming-middleware.test.ts.snap +64 -0
  129. package/src/middleware/add-tool-input-examples-middleware.test.ts +476 -0
  130. package/src/middleware/add-tool-input-examples-middleware.ts +90 -0
  131. package/src/middleware/default-embedding-settings-middleware.test.ts +126 -0
  132. package/src/middleware/default-embedding-settings-middleware.ts +22 -0
  133. package/src/middleware/default-settings-middleware.test.ts +388 -0
  134. package/src/middleware/default-settings-middleware.ts +33 -0
  135. package/src/middleware/extract-json-middleware.test.ts +827 -0
  136. package/src/middleware/extract-json-middleware.ts +197 -0
  137. package/src/middleware/extract-reasoning-middleware.test.ts +1028 -0
  138. package/src/middleware/extract-reasoning-middleware.ts +238 -0
  139. package/src/middleware/index.ts +10 -0
  140. package/src/middleware/simulate-streaming-middleware.test.ts +911 -0
  141. package/src/middleware/simulate-streaming-middleware.ts +79 -0
  142. package/src/middleware/wrap-embedding-model.test.ts +358 -0
  143. package/src/middleware/wrap-embedding-model.ts +86 -0
  144. package/src/middleware/wrap-image-model.test.ts +423 -0
  145. package/src/middleware/wrap-image-model.ts +85 -0
  146. package/src/middleware/wrap-language-model.test.ts +518 -0
  147. package/src/middleware/wrap-language-model.ts +104 -0
  148. package/src/middleware/wrap-provider.test.ts +120 -0
  149. package/src/middleware/wrap-provider.ts +51 -0
  150. package/src/model/as-embedding-model-v3.test.ts +319 -0
  151. package/src/model/as-embedding-model-v3.ts +24 -0
  152. package/src/model/as-image-model-v3.test.ts +409 -0
  153. package/src/model/as-image-model-v3.ts +24 -0
  154. package/src/model/as-language-model-v3.test.ts +508 -0
  155. package/src/model/as-language-model-v3.ts +103 -0
  156. package/src/model/as-provider-v3.ts +36 -0
  157. package/src/model/as-speech-model-v3.test.ts +356 -0
  158. package/src/model/as-speech-model-v3.ts +24 -0
  159. package/src/model/as-transcription-model-v3.test.ts +529 -0
  160. package/src/model/as-transcription-model-v3.ts +24 -0
  161. package/src/model/resolve-model.test.ts +244 -0
  162. package/src/model/resolve-model.ts +126 -0
  163. package/src/prompt/call-settings.ts +148 -0
  164. package/src/prompt/content-part.ts +209 -0
  165. package/src/prompt/convert-to-language-model-prompt.test.ts +2018 -0
  166. package/src/prompt/convert-to-language-model-prompt.ts +442 -0
  167. package/src/prompt/create-tool-model-output.test.ts +508 -0
  168. package/src/prompt/create-tool-model-output.ts +34 -0
  169. package/src/prompt/data-content.test.ts +15 -0
  170. package/src/prompt/data-content.ts +134 -0
  171. package/src/prompt/index.ts +27 -0
  172. package/src/prompt/invalid-data-content-error.ts +29 -0
  173. package/src/prompt/invalid-message-role-error.ts +27 -0
  174. package/src/prompt/message-conversion-error.ts +28 -0
  175. package/src/prompt/message.ts +68 -0
  176. package/src/prompt/prepare-call-settings.test.ts +159 -0
  177. package/src/prompt/prepare-call-settings.ts +108 -0
  178. package/src/prompt/prepare-tools-and-tool-choice.test.ts +461 -0
  179. package/src/prompt/prepare-tools-and-tool-choice.ts +86 -0
  180. package/src/prompt/prompt.ts +43 -0
  181. package/src/prompt/split-data-url.ts +17 -0
  182. package/src/prompt/standardize-prompt.test.ts +82 -0
  183. package/src/prompt/standardize-prompt.ts +99 -0
  184. package/src/prompt/wrap-gateway-error.ts +29 -0
  185. package/src/registry/custom-provider.test.ts +211 -0
  186. package/src/registry/custom-provider.ts +155 -0
  187. package/src/registry/index.ts +7 -0
  188. package/src/registry/no-such-provider-error.ts +41 -0
  189. package/src/registry/provider-registry.test.ts +691 -0
  190. package/src/registry/provider-registry.ts +328 -0
  191. package/src/rerank/index.ts +2 -0
  192. package/src/rerank/rerank-result.ts +70 -0
  193. package/src/rerank/rerank.test.ts +516 -0
  194. package/src/rerank/rerank.ts +237 -0
  195. package/src/telemetry/assemble-operation-name.ts +21 -0
  196. package/src/telemetry/get-base-telemetry-attributes.ts +53 -0
  197. package/src/telemetry/get-tracer.ts +20 -0
  198. package/src/telemetry/noop-tracer.ts +69 -0
  199. package/src/telemetry/record-span.ts +63 -0
  200. package/src/telemetry/select-telemetry-attributes.ts +78 -0
  201. package/src/telemetry/select-temetry-attributes.test.ts +114 -0
  202. package/src/telemetry/stringify-for-telemetry.test.ts +114 -0
  203. package/src/telemetry/stringify-for-telemetry.ts +33 -0
  204. package/src/telemetry/telemetry-settings.ts +44 -0
  205. package/src/test/mock-embedding-model-v2.ts +35 -0
  206. package/src/test/mock-embedding-model-v3.ts +48 -0
  207. package/src/test/mock-image-model-v2.ts +28 -0
  208. package/src/test/mock-image-model-v3.ts +28 -0
  209. package/src/test/mock-language-model-v2.ts +72 -0
  210. package/src/test/mock-language-model-v3.ts +77 -0
  211. package/src/test/mock-provider-v2.ts +68 -0
  212. package/src/test/mock-provider-v3.ts +80 -0
  213. package/src/test/mock-reranking-model-v3.ts +25 -0
  214. package/src/test/mock-server-response.ts +69 -0
  215. package/src/test/mock-speech-model-v2.ts +24 -0
  216. package/src/test/mock-speech-model-v3.ts +24 -0
  217. package/src/test/mock-tracer.ts +156 -0
  218. package/src/test/mock-transcription-model-v2.ts +24 -0
  219. package/src/test/mock-transcription-model-v3.ts +24 -0
  220. package/src/test/mock-values.ts +4 -0
  221. package/src/test/not-implemented.ts +3 -0
  222. package/src/text-stream/create-text-stream-response.test.ts +38 -0
  223. package/src/text-stream/create-text-stream-response.ts +18 -0
  224. package/src/text-stream/index.ts +2 -0
  225. package/src/text-stream/pipe-text-stream-to-response.test.ts +38 -0
  226. package/src/text-stream/pipe-text-stream-to-response.ts +26 -0
  227. package/src/transcribe/index.ts +2 -0
  228. package/src/transcribe/transcribe-result.ts +60 -0
  229. package/src/transcribe/transcribe.test.ts +313 -0
  230. package/src/transcribe/transcribe.ts +173 -0
  231. package/src/types/embedding-model-middleware.ts +3 -0
  232. package/src/types/embedding-model.ts +18 -0
  233. package/src/types/image-model-middleware.ts +3 -0
  234. package/src/types/image-model-response-metadata.ts +16 -0
  235. package/src/types/image-model.ts +19 -0
  236. package/src/types/index.ts +29 -0
  237. package/src/types/json-value.ts +15 -0
  238. package/src/types/language-model-middleware.ts +3 -0
  239. package/src/types/language-model-request-metadata.ts +6 -0
  240. package/src/types/language-model-response-metadata.ts +21 -0
  241. package/src/types/language-model.ts +104 -0
  242. package/src/types/provider-metadata.ts +16 -0
  243. package/src/types/provider.ts +55 -0
  244. package/src/types/reranking-model.ts +6 -0
  245. package/src/types/speech-model-response-metadata.ts +21 -0
  246. package/src/types/speech-model.ts +6 -0
  247. package/src/types/transcription-model-response-metadata.ts +16 -0
  248. package/src/types/transcription-model.ts +9 -0
  249. package/src/types/usage.ts +200 -0
  250. package/src/types/warning.ts +7 -0
  251. package/src/ui/__snapshots__/append-response-messages.test.ts.snap +416 -0
  252. package/src/ui/__snapshots__/convert-to-model-messages.test.ts.snap +419 -0
  253. package/src/ui/__snapshots__/process-chat-text-response.test.ts.snap +142 -0
  254. package/src/ui/call-completion-api.ts +157 -0
  255. package/src/ui/chat-transport.ts +83 -0
  256. package/src/ui/chat.test-d.ts +233 -0
  257. package/src/ui/chat.test.ts +2695 -0
  258. package/src/ui/chat.ts +716 -0
  259. package/src/ui/convert-file-list-to-file-ui-parts.ts +36 -0
  260. package/src/ui/convert-to-model-messages.test.ts +2775 -0
  261. package/src/ui/convert-to-model-messages.ts +373 -0
  262. package/src/ui/default-chat-transport.ts +36 -0
  263. package/src/ui/direct-chat-transport.test.ts +446 -0
  264. package/src/ui/direct-chat-transport.ts +118 -0
  265. package/src/ui/http-chat-transport.test.ts +185 -0
  266. package/src/ui/http-chat-transport.ts +292 -0
  267. package/src/ui/index.ts +71 -0
  268. package/src/ui/last-assistant-message-is-complete-with-approval-responses.ts +44 -0
  269. package/src/ui/last-assistant-message-is-complete-with-tool-calls.test.ts +371 -0
  270. package/src/ui/last-assistant-message-is-complete-with-tool-calls.ts +39 -0
  271. package/src/ui/process-text-stream.test.ts +38 -0
  272. package/src/ui/process-text-stream.ts +16 -0
  273. package/src/ui/process-ui-message-stream.test.ts +8052 -0
  274. package/src/ui/process-ui-message-stream.ts +713 -0
  275. package/src/ui/text-stream-chat-transport.ts +23 -0
  276. package/src/ui/transform-text-to-ui-message-stream.test.ts +124 -0
  277. package/src/ui/transform-text-to-ui-message-stream.ts +27 -0
  278. package/src/ui/ui-messages.test.ts +48 -0
  279. package/src/ui/ui-messages.ts +534 -0
  280. package/src/ui/use-completion.ts +84 -0
  281. package/src/ui/validate-ui-messages.test.ts +1428 -0
  282. package/src/ui/validate-ui-messages.ts +476 -0
  283. package/src/ui-message-stream/create-ui-message-stream-response.test.ts +266 -0
  284. package/src/ui-message-stream/create-ui-message-stream-response.ts +32 -0
  285. package/src/ui-message-stream/create-ui-message-stream.test.ts +639 -0
  286. package/src/ui-message-stream/create-ui-message-stream.ts +124 -0
  287. package/src/ui-message-stream/get-response-ui-message-id.test.ts +55 -0
  288. package/src/ui-message-stream/get-response-ui-message-id.ts +24 -0
  289. package/src/ui-message-stream/handle-ui-message-stream-finish.test.ts +429 -0
  290. package/src/ui-message-stream/handle-ui-message-stream-finish.ts +135 -0
  291. package/src/ui-message-stream/index.ts +13 -0
  292. package/src/ui-message-stream/json-to-sse-transform-stream.ts +12 -0
  293. package/src/ui-message-stream/pipe-ui-message-stream-to-response.test.ts +90 -0
  294. package/src/ui-message-stream/pipe-ui-message-stream-to-response.ts +40 -0
  295. package/src/ui-message-stream/read-ui-message-stream.test.ts +122 -0
  296. package/src/ui-message-stream/read-ui-message-stream.ts +87 -0
  297. package/src/ui-message-stream/ui-message-chunks.test-d.ts +18 -0
  298. package/src/ui-message-stream/ui-message-chunks.ts +344 -0
  299. package/src/ui-message-stream/ui-message-stream-headers.ts +7 -0
  300. package/src/ui-message-stream/ui-message-stream-on-finish-callback.ts +32 -0
  301. package/src/ui-message-stream/ui-message-stream-response-init.ts +5 -0
  302. package/src/ui-message-stream/ui-message-stream-writer.ts +24 -0
  303. package/src/util/as-array.ts +3 -0
  304. package/src/util/async-iterable-stream.test.ts +241 -0
  305. package/src/util/async-iterable-stream.ts +94 -0
  306. package/src/util/consume-stream.ts +29 -0
  307. package/src/util/cosine-similarity.test.ts +57 -0
  308. package/src/util/cosine-similarity.ts +47 -0
  309. package/src/util/create-resolvable-promise.ts +30 -0
  310. package/src/util/create-stitchable-stream.test.ts +239 -0
  311. package/src/util/create-stitchable-stream.ts +112 -0
  312. package/src/util/data-url.ts +17 -0
  313. package/src/util/deep-partial.ts +84 -0
  314. package/src/util/detect-media-type.test.ts +670 -0
  315. package/src/util/detect-media-type.ts +184 -0
  316. package/src/util/download/download-function.ts +45 -0
  317. package/src/util/download/download.test.ts +69 -0
  318. package/src/util/download/download.ts +46 -0
  319. package/src/util/error-handler.ts +1 -0
  320. package/src/util/fix-json.test.ts +279 -0
  321. package/src/util/fix-json.ts +401 -0
  322. package/src/util/get-potential-start-index.test.ts +34 -0
  323. package/src/util/get-potential-start-index.ts +30 -0
  324. package/src/util/index.ts +11 -0
  325. package/src/util/is-deep-equal-data.test.ts +119 -0
  326. package/src/util/is-deep-equal-data.ts +48 -0
  327. package/src/util/is-non-empty-object.ts +5 -0
  328. package/src/util/job.ts +1 -0
  329. package/src/util/log-v2-compatibility-warning.ts +21 -0
  330. package/src/util/merge-abort-signals.test.ts +155 -0
  331. package/src/util/merge-abort-signals.ts +43 -0
  332. package/src/util/merge-objects.test.ts +118 -0
  333. package/src/util/merge-objects.ts +79 -0
  334. package/src/util/now.ts +4 -0
  335. package/src/util/parse-partial-json.test.ts +80 -0
  336. package/src/util/parse-partial-json.ts +30 -0
  337. package/src/util/prepare-headers.test.ts +51 -0
  338. package/src/util/prepare-headers.ts +14 -0
  339. package/src/util/prepare-retries.test.ts +10 -0
  340. package/src/util/prepare-retries.ts +47 -0
  341. package/src/util/retry-error.ts +41 -0
  342. package/src/util/retry-with-exponential-backoff.test.ts +446 -0
  343. package/src/util/retry-with-exponential-backoff.ts +154 -0
  344. package/src/util/serial-job-executor.test.ts +162 -0
  345. package/src/util/serial-job-executor.ts +36 -0
  346. package/src/util/simulate-readable-stream.test.ts +98 -0
  347. package/src/util/simulate-readable-stream.ts +39 -0
  348. package/src/util/split-array.test.ts +60 -0
  349. package/src/util/split-array.ts +20 -0
  350. package/src/util/value-of.ts +65 -0
  351. package/src/util/write-to-server-response.test.ts +266 -0
  352. package/src/util/write-to-server-response.ts +49 -0
  353. package/src/version.ts +5 -0
@@ -0,0 +1,518 @@
1
+ import { JSONValue } from '@ai-sdk/provider';
2
+ import {
3
+ createIdGenerator,
4
+ FlexibleSchema,
5
+ InferSchema,
6
+ ProviderOptions,
7
+ withUserAgentSuffix,
8
+ } from '@ai-sdk/provider-utils';
9
+ import { NoObjectGeneratedError } from '../error/no-object-generated-error';
10
+ import { extractReasoningContent } from '../generate-text/extract-reasoning-content';
11
+ import { extractTextContent } from '../generate-text/extract-text-content';
12
+ import { logWarnings } from '../logger/log-warnings';
13
+ import { resolveLanguageModel } from '../model/resolve-model';
14
+ import { CallSettings } from '../prompt/call-settings';
15
+ import { convertToLanguageModelPrompt } from '../prompt/convert-to-language-model-prompt';
16
+ import { prepareCallSettings } from '../prompt/prepare-call-settings';
17
+ import { Prompt } from '../prompt/prompt';
18
+ import { standardizePrompt } from '../prompt/standardize-prompt';
19
+ import { wrapGatewayError } from '../prompt/wrap-gateway-error';
20
+ import { assembleOperationName } from '../telemetry/assemble-operation-name';
21
+ import { getBaseTelemetryAttributes } from '../telemetry/get-base-telemetry-attributes';
22
+ import { getTracer } from '../telemetry/get-tracer';
23
+ import { recordSpan } from '../telemetry/record-span';
24
+ import { selectTelemetryAttributes } from '../telemetry/select-telemetry-attributes';
25
+ import { stringifyForTelemetry } from '../telemetry/stringify-for-telemetry';
26
+ import { TelemetrySettings } from '../telemetry/telemetry-settings';
27
+ import {
28
+ CallWarning,
29
+ FinishReason,
30
+ LanguageModel,
31
+ } from '../types/language-model';
32
+ import { LanguageModelRequestMetadata } from '../types/language-model-request-metadata';
33
+ import { LanguageModelResponseMetadata } from '../types/language-model-response-metadata';
34
+ import { ProviderMetadata } from '../types/provider-metadata';
35
+ import { asLanguageModelUsage, LanguageModelUsage } from '../types/usage';
36
+ import { DownloadFunction } from '../util/download/download-function';
37
+ import { prepareHeaders } from '../util/prepare-headers';
38
+ import { prepareRetries } from '../util/prepare-retries';
39
+ import { VERSION } from '../version';
40
+ import { GenerateObjectResult } from './generate-object-result';
41
+ import { getOutputStrategy } from './output-strategy';
42
+ import { parseAndValidateObjectResultWithRepair } from './parse-and-validate-object-result';
43
+ import { RepairTextFunction } from './repair-text';
44
+ import { validateObjectGenerationInput } from './validate-object-generation-input';
45
+
46
+ const originalGenerateId = createIdGenerator({ prefix: 'aiobj', size: 24 });
47
+
48
+ /**
49
+ Generate a structured, typed object for a given prompt and schema using a language model.
50
+
51
+ This function does not stream the output. If you want to stream the output, use `streamObject` instead.
52
+
53
+ @param model - The language model to use.
54
+ @param tools - Tools that are accessible to and can be called by the model. The model needs to support calling tools.
55
+
56
+ @param system - A system message that will be part of the prompt.
57
+ @param prompt - A simple text prompt. You can either use `prompt` or `messages` but not both.
58
+ @param messages - A list of messages. You can either use `prompt` or `messages` but not both.
59
+
60
+ @param maxOutputTokens - Maximum number of tokens to generate.
61
+ @param temperature - Temperature setting.
62
+ The value is passed through to the provider. The range depends on the provider and model.
63
+ It is recommended to set either `temperature` or `topP`, but not both.
64
+ @param topP - Nucleus sampling.
65
+ The value is passed through to the provider. The range depends on the provider and model.
66
+ It is recommended to set either `temperature` or `topP`, but not both.
67
+ @param topK - Only sample from the top K options for each subsequent token.
68
+ Used to remove "long tail" low probability responses.
69
+ Recommended for advanced use cases only. You usually only need to use temperature.
70
+ @param presencePenalty - Presence penalty setting.
71
+ It affects the likelihood of the model to repeat information that is already in the prompt.
72
+ The value is passed through to the provider. The range depends on the provider and model.
73
+ @param frequencyPenalty - Frequency penalty setting.
74
+ It affects the likelihood of the model to repeatedly use the same words or phrases.
75
+ The value is passed through to the provider. The range depends on the provider and model.
76
+ @param stopSequences - Stop sequences.
77
+ If set, the model will stop generating text when one of the stop sequences is generated.
78
+ @param seed - The seed (integer) to use for random sampling.
79
+ If set and supported by the model, calls will generate deterministic results.
80
+
81
+ @param maxRetries - Maximum number of retries. Set to 0 to disable retries. Default: 2.
82
+ @param abortSignal - An optional abort signal that can be used to cancel the call.
83
+ @param headers - Additional HTTP headers to be sent with the request. Only applicable for HTTP-based providers.
84
+
85
+ @param schema - The schema of the object that the model should generate.
86
+ @param schemaName - Optional name of the output that should be generated.
87
+ Used by some providers for additional LLM guidance, e.g.
88
+ via tool or schema name.
89
+ @param schemaDescription - Optional description of the output that should be generated.
90
+ Used by some providers for additional LLM guidance, e.g.
91
+ via tool or schema description.
92
+
93
+ @param output - The type of the output.
94
+
95
+ - 'object': The output is an object.
96
+ - 'array': The output is an array.
97
+ - 'enum': The output is an enum.
98
+ - 'no-schema': The output is not a schema.
99
+
100
+ @param experimental_repairText - A function that attempts to repair the raw output of the model
101
+ to enable JSON parsing.
102
+
103
+ @param experimental_telemetry - Optional telemetry configuration (experimental).
104
+
105
+ @param providerOptions - Additional provider-specific options. They are passed through
106
+ to the provider from the AI SDK and enable provider-specific
107
+ functionality that can be fully encapsulated in the provider.
108
+
109
+ @returns
110
+ A result object that contains the generated object, the finish reason, the token usage, and additional information.
111
+
112
+ @deprecated Use `generateText` with an `output` setting instead.
113
+ */
114
+ export async function generateObject<
115
+ SCHEMA extends FlexibleSchema<unknown> = FlexibleSchema<JSONValue>,
116
+ OUTPUT extends
117
+ | 'object'
118
+ | 'array'
119
+ | 'enum'
120
+ | 'no-schema' = InferSchema<SCHEMA> extends string ? 'enum' : 'object',
121
+ RESULT = OUTPUT extends 'array'
122
+ ? Array<InferSchema<SCHEMA>>
123
+ : InferSchema<SCHEMA>,
124
+ >(
125
+ options: Omit<CallSettings, 'stopSequences'> &
126
+ Prompt &
127
+ (OUTPUT extends 'enum'
128
+ ? {
129
+ /**
130
+ The enum values that the model should use.
131
+ */
132
+ enum: Array<RESULT>;
133
+ output: 'enum';
134
+ }
135
+ : OUTPUT extends 'no-schema'
136
+ ? {}
137
+ : {
138
+ /**
139
+ The schema of the object that the model should generate.
140
+ */
141
+ schema: SCHEMA;
142
+
143
+ /**
144
+ Optional name of the output that should be generated.
145
+ Used by some providers for additional LLM guidance, e.g.
146
+ via tool or schema name.
147
+ */
148
+ schemaName?: string;
149
+
150
+ /**
151
+ Optional description of the output that should be generated.
152
+ Used by some providers for additional LLM guidance, e.g.
153
+ via tool or schema description.
154
+ */
155
+ schemaDescription?: string;
156
+ }) & {
157
+ output?: OUTPUT;
158
+
159
+ /**
160
+ The language model to use.
161
+ */
162
+ model: LanguageModel;
163
+ /**
164
+ A function that attempts to repair the raw output of the model
165
+ to enable JSON parsing.
166
+ */
167
+ experimental_repairText?: RepairTextFunction;
168
+
169
+ /**
170
+ Optional telemetry configuration (experimental).
171
+ */
172
+
173
+ experimental_telemetry?: TelemetrySettings;
174
+
175
+ /**
176
+ Custom download function to use for URLs.
177
+
178
+ By default, files are downloaded if the model does not support the URL for the given media type.
179
+ */
180
+ experimental_download?: DownloadFunction | undefined;
181
+
182
+ /**
183
+ Additional provider-specific options. They are passed through
184
+ to the provider from the AI SDK and enable provider-specific
185
+ functionality that can be fully encapsulated in the provider.
186
+ */
187
+ providerOptions?: ProviderOptions;
188
+
189
+ /**
190
+ * Internal. For test use only. May change without notice.
191
+ */
192
+ _internal?: {
193
+ generateId?: () => string;
194
+ currentDate?: () => Date;
195
+ };
196
+ },
197
+ ): Promise<GenerateObjectResult<RESULT>> {
198
+ const {
199
+ model: modelArg,
200
+ output = 'object',
201
+ system,
202
+ prompt,
203
+ messages,
204
+ maxRetries: maxRetriesArg,
205
+ abortSignal,
206
+ headers,
207
+ experimental_repairText: repairText,
208
+ experimental_telemetry: telemetry,
209
+ experimental_download: download,
210
+ providerOptions,
211
+ _internal: {
212
+ generateId = originalGenerateId,
213
+ currentDate = () => new Date(),
214
+ } = {},
215
+ ...settings
216
+ } = options;
217
+
218
+ const model = resolveLanguageModel(modelArg);
219
+
220
+ const enumValues = 'enum' in options ? options.enum : undefined;
221
+ const {
222
+ schema: inputSchema,
223
+ schemaDescription,
224
+ schemaName,
225
+ } = 'schema' in options ? options : {};
226
+
227
+ validateObjectGenerationInput({
228
+ output,
229
+ schema: inputSchema,
230
+ schemaName,
231
+ schemaDescription,
232
+ enumValues,
233
+ });
234
+
235
+ const { maxRetries, retry } = prepareRetries({
236
+ maxRetries: maxRetriesArg,
237
+ abortSignal,
238
+ });
239
+
240
+ const outputStrategy = getOutputStrategy({
241
+ output,
242
+ schema: inputSchema,
243
+ enumValues,
244
+ });
245
+
246
+ const callSettings = prepareCallSettings(settings);
247
+
248
+ const headersWithUserAgent = withUserAgentSuffix(
249
+ headers ?? {},
250
+ `ai/${VERSION}`,
251
+ );
252
+
253
+ const baseTelemetryAttributes = getBaseTelemetryAttributes({
254
+ model,
255
+ telemetry,
256
+ headers: headersWithUserAgent,
257
+ settings: { ...callSettings, maxRetries },
258
+ });
259
+
260
+ const tracer = getTracer(telemetry);
261
+ const jsonSchema = await outputStrategy.jsonSchema();
262
+
263
+ try {
264
+ return await recordSpan({
265
+ name: 'ai.generateObject',
266
+ attributes: selectTelemetryAttributes({
267
+ telemetry,
268
+ attributes: {
269
+ ...assembleOperationName({
270
+ operationId: 'ai.generateObject',
271
+ telemetry,
272
+ }),
273
+ ...baseTelemetryAttributes,
274
+ // specific settings that only make sense on the outer level:
275
+ 'ai.prompt': {
276
+ input: () => JSON.stringify({ system, prompt, messages }),
277
+ },
278
+ 'ai.schema':
279
+ jsonSchema != null
280
+ ? { input: () => JSON.stringify(jsonSchema) }
281
+ : undefined,
282
+ 'ai.schema.name': schemaName,
283
+ 'ai.schema.description': schemaDescription,
284
+ 'ai.settings.output': outputStrategy.type,
285
+ },
286
+ }),
287
+ tracer,
288
+ fn: async span => {
289
+ let result: string;
290
+ let finishReason: FinishReason;
291
+ let usage: LanguageModelUsage;
292
+ let warnings: CallWarning[] | undefined;
293
+ let response: LanguageModelResponseMetadata;
294
+ let request: LanguageModelRequestMetadata;
295
+ let resultProviderMetadata: ProviderMetadata | undefined;
296
+ let reasoning: string | undefined;
297
+
298
+ const standardizedPrompt = await standardizePrompt({
299
+ system,
300
+ prompt,
301
+ messages,
302
+ } as Prompt);
303
+
304
+ const promptMessages = await convertToLanguageModelPrompt({
305
+ prompt: standardizedPrompt,
306
+ supportedUrls: await model.supportedUrls,
307
+ download,
308
+ });
309
+
310
+ const generateResult = await retry(() =>
311
+ recordSpan({
312
+ name: 'ai.generateObject.doGenerate',
313
+ attributes: selectTelemetryAttributes({
314
+ telemetry,
315
+ attributes: {
316
+ ...assembleOperationName({
317
+ operationId: 'ai.generateObject.doGenerate',
318
+ telemetry,
319
+ }),
320
+ ...baseTelemetryAttributes,
321
+ 'ai.prompt.messages': {
322
+ input: () => stringifyForTelemetry(promptMessages),
323
+ },
324
+
325
+ // standardized gen-ai llm span attributes:
326
+ 'gen_ai.system': model.provider,
327
+ 'gen_ai.request.model': model.modelId,
328
+ 'gen_ai.request.frequency_penalty':
329
+ callSettings.frequencyPenalty,
330
+ 'gen_ai.request.max_tokens': callSettings.maxOutputTokens,
331
+ 'gen_ai.request.presence_penalty': callSettings.presencePenalty,
332
+ 'gen_ai.request.temperature': callSettings.temperature,
333
+ 'gen_ai.request.top_k': callSettings.topK,
334
+ 'gen_ai.request.top_p': callSettings.topP,
335
+ },
336
+ }),
337
+ tracer,
338
+ fn: async span => {
339
+ const result = await model.doGenerate({
340
+ responseFormat: {
341
+ type: 'json',
342
+ schema: jsonSchema,
343
+ name: schemaName,
344
+ description: schemaDescription,
345
+ },
346
+ ...prepareCallSettings(settings),
347
+ prompt: promptMessages,
348
+ providerOptions,
349
+ abortSignal,
350
+ headers: headersWithUserAgent,
351
+ });
352
+
353
+ const responseData = {
354
+ id: result.response?.id ?? generateId(),
355
+ timestamp: result.response?.timestamp ?? currentDate(),
356
+ modelId: result.response?.modelId ?? model.modelId,
357
+ headers: result.response?.headers,
358
+ body: result.response?.body,
359
+ };
360
+
361
+ const text = extractTextContent(result.content);
362
+ const reasoning = extractReasoningContent(result.content);
363
+
364
+ if (text === undefined) {
365
+ throw new NoObjectGeneratedError({
366
+ message:
367
+ 'No object generated: the model did not return a response.',
368
+ response: responseData,
369
+ usage: asLanguageModelUsage(result.usage),
370
+ finishReason: result.finishReason.unified,
371
+ });
372
+ }
373
+
374
+ // Add response information to the span:
375
+ span.setAttributes(
376
+ await selectTelemetryAttributes({
377
+ telemetry,
378
+ attributes: {
379
+ 'ai.response.finishReason': result.finishReason.unified,
380
+ 'ai.response.object': { output: () => text },
381
+ 'ai.response.id': responseData.id,
382
+ 'ai.response.model': responseData.modelId,
383
+ 'ai.response.timestamp':
384
+ responseData.timestamp.toISOString(),
385
+ 'ai.response.providerMetadata': JSON.stringify(
386
+ result.providerMetadata,
387
+ ),
388
+
389
+ // TODO rename telemetry attributes to inputTokens and outputTokens
390
+ 'ai.usage.promptTokens': result.usage.inputTokens.total,
391
+ 'ai.usage.completionTokens':
392
+ result.usage.outputTokens.total,
393
+
394
+ // standardized gen-ai llm span attributes:
395
+ 'gen_ai.response.finish_reasons': [
396
+ result.finishReason.unified,
397
+ ],
398
+ 'gen_ai.response.id': responseData.id,
399
+ 'gen_ai.response.model': responseData.modelId,
400
+ 'gen_ai.usage.input_tokens': result.usage.inputTokens.total,
401
+ 'gen_ai.usage.output_tokens':
402
+ result.usage.outputTokens.total,
403
+ },
404
+ }),
405
+ );
406
+
407
+ return {
408
+ ...result,
409
+ objectText: text,
410
+ reasoning,
411
+ responseData,
412
+ };
413
+ },
414
+ }),
415
+ );
416
+
417
+ result = generateResult.objectText;
418
+ finishReason = generateResult.finishReason.unified;
419
+ usage = asLanguageModelUsage(generateResult.usage);
420
+ warnings = generateResult.warnings;
421
+ resultProviderMetadata = generateResult.providerMetadata;
422
+ request = generateResult.request ?? {};
423
+ response = generateResult.responseData;
424
+ reasoning = generateResult.reasoning;
425
+
426
+ logWarnings({
427
+ warnings,
428
+ provider: model.provider,
429
+ model: model.modelId,
430
+ });
431
+
432
+ const object = await parseAndValidateObjectResultWithRepair(
433
+ result,
434
+ outputStrategy,
435
+ repairText,
436
+ {
437
+ response,
438
+ usage,
439
+ finishReason,
440
+ },
441
+ );
442
+
443
+ // Add response information to the span:
444
+ span.setAttributes(
445
+ await selectTelemetryAttributes({
446
+ telemetry,
447
+ attributes: {
448
+ 'ai.response.finishReason': finishReason,
449
+ 'ai.response.object': {
450
+ output: () => JSON.stringify(object),
451
+ },
452
+ 'ai.response.providerMetadata': JSON.stringify(
453
+ resultProviderMetadata,
454
+ ),
455
+
456
+ // TODO rename telemetry attributes to inputTokens and outputTokens
457
+ 'ai.usage.promptTokens': usage.inputTokens,
458
+ 'ai.usage.completionTokens': usage.outputTokens,
459
+ },
460
+ }),
461
+ );
462
+
463
+ return new DefaultGenerateObjectResult({
464
+ object,
465
+ reasoning,
466
+ finishReason,
467
+ usage,
468
+ warnings,
469
+ request,
470
+ response,
471
+ providerMetadata: resultProviderMetadata,
472
+ });
473
+ },
474
+ });
475
+ } catch (error) {
476
+ throw wrapGatewayError(error);
477
+ }
478
+ }
479
+
480
+ class DefaultGenerateObjectResult<T> implements GenerateObjectResult<T> {
481
+ readonly object: GenerateObjectResult<T>['object'];
482
+ readonly finishReason: GenerateObjectResult<T>['finishReason'];
483
+ readonly usage: GenerateObjectResult<T>['usage'];
484
+ readonly warnings: GenerateObjectResult<T>['warnings'];
485
+ readonly providerMetadata: GenerateObjectResult<T>['providerMetadata'];
486
+ readonly response: GenerateObjectResult<T>['response'];
487
+ readonly request: GenerateObjectResult<T>['request'];
488
+ readonly reasoning: GenerateObjectResult<T>['reasoning'];
489
+
490
+ constructor(options: {
491
+ object: GenerateObjectResult<T>['object'];
492
+ finishReason: GenerateObjectResult<T>['finishReason'];
493
+ usage: GenerateObjectResult<T>['usage'];
494
+ warnings: GenerateObjectResult<T>['warnings'];
495
+ providerMetadata: GenerateObjectResult<T>['providerMetadata'];
496
+ response: GenerateObjectResult<T>['response'];
497
+ request: GenerateObjectResult<T>['request'];
498
+ reasoning: GenerateObjectResult<T>['reasoning'];
499
+ }) {
500
+ this.object = options.object;
501
+ this.finishReason = options.finishReason;
502
+ this.usage = options.usage;
503
+ this.warnings = options.warnings;
504
+ this.providerMetadata = options.providerMetadata;
505
+ this.response = options.response;
506
+ this.request = options.request;
507
+ this.reasoning = options.reasoning;
508
+ }
509
+
510
+ toJsonResponse(init?: ResponseInit): Response {
511
+ return new Response(JSON.stringify(this.object), {
512
+ status: init?.status ?? 200,
513
+ headers: prepareHeaders(init?.headers, {
514
+ 'content-type': 'application/json; charset=utf-8',
515
+ }),
516
+ });
517
+ }
518
+ }
@@ -0,0 +1,9 @@
1
+ export { generateObject } from './generate-object';
2
+ export type { RepairTextFunction } from './repair-text';
3
+ export type { GenerateObjectResult } from './generate-object-result';
4
+ export { streamObject } from './stream-object';
5
+ export type { StreamObjectOnFinishCallback } from './stream-object';
6
+ export type {
7
+ ObjectStreamPart,
8
+ StreamObjectResult,
9
+ } from './stream-object-result';