ai 6.0.33 → 6.0.35

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 (357) hide show
  1. package/CHANGELOG.md +16 -0
  2. package/dist/index.d.mts +50 -21
  3. package/dist/index.d.ts +50 -21
  4. package/dist/index.js +348 -286
  5. package/dist/index.js.map +1 -1
  6. package/dist/index.mjs +280 -219
  7. package/dist/index.mjs.map +1 -1
  8. package/dist/internal/index.js +1 -1
  9. package/dist/internal/index.mjs +1 -1
  10. package/docs/02-foundations/03-prompts.mdx +2 -2
  11. package/docs/03-ai-sdk-core/15-tools-and-tool-calling.mdx +1 -1
  12. package/docs/07-reference/01-ai-sdk-core/28-output.mdx +1 -1
  13. package/docs/07-reference/05-ai-sdk-errors/ai-ui-message-stream-error.mdx +67 -0
  14. package/package.json +6 -4
  15. package/src/agent/agent.ts +116 -0
  16. package/src/agent/create-agent-ui-stream-response.test.ts +258 -0
  17. package/src/agent/create-agent-ui-stream-response.ts +50 -0
  18. package/src/agent/create-agent-ui-stream.ts +73 -0
  19. package/src/agent/index.ts +33 -0
  20. package/src/agent/infer-agent-tools.ts +7 -0
  21. package/src/agent/infer-agent-ui-message.test-d.ts +54 -0
  22. package/src/agent/infer-agent-ui-message.ts +11 -0
  23. package/src/agent/pipe-agent-ui-stream-to-response.ts +52 -0
  24. package/src/agent/tool-loop-agent-on-finish-callback.ts +31 -0
  25. package/src/agent/tool-loop-agent-on-step-finish-callback.ts +11 -0
  26. package/src/agent/tool-loop-agent-settings.ts +182 -0
  27. package/src/agent/tool-loop-agent.test-d.ts +114 -0
  28. package/src/agent/tool-loop-agent.test.ts +442 -0
  29. package/src/agent/tool-loop-agent.ts +114 -0
  30. package/src/embed/__snapshots__/embed-many.test.ts.snap +191 -0
  31. package/src/embed/__snapshots__/embed.test.ts.snap +81 -0
  32. package/src/embed/embed-many-result.ts +53 -0
  33. package/src/embed/embed-many.test.ts +653 -0
  34. package/src/embed/embed-many.ts +378 -0
  35. package/src/embed/embed-result.ts +50 -0
  36. package/src/embed/embed.test.ts +298 -0
  37. package/src/embed/embed.ts +211 -0
  38. package/src/embed/index.ts +4 -0
  39. package/src/error/index.ts +35 -0
  40. package/src/error/invalid-argument-error.ts +34 -0
  41. package/src/error/invalid-stream-part-error.ts +28 -0
  42. package/src/error/invalid-tool-approval-error.ts +26 -0
  43. package/src/error/invalid-tool-input-error.ts +33 -0
  44. package/src/error/no-image-generated-error.ts +39 -0
  45. package/src/error/no-object-generated-error.ts +70 -0
  46. package/src/error/no-output-generated-error.ts +26 -0
  47. package/src/error/no-speech-generated-error.ts +18 -0
  48. package/src/error/no-such-tool-error.ts +35 -0
  49. package/src/error/no-transcript-generated-error.ts +20 -0
  50. package/src/error/tool-call-not-found-for-approval-error.ts +32 -0
  51. package/src/error/tool-call-repair-error.ts +30 -0
  52. package/src/error/ui-message-stream-error.ts +48 -0
  53. package/src/error/unsupported-model-version-error.ts +23 -0
  54. package/src/error/verify-no-object-generated-error.ts +27 -0
  55. package/src/generate-image/generate-image-result.ts +42 -0
  56. package/src/generate-image/generate-image.test.ts +1420 -0
  57. package/src/generate-image/generate-image.ts +360 -0
  58. package/src/generate-image/index.ts +18 -0
  59. package/src/generate-object/__snapshots__/generate-object.test.ts.snap +133 -0
  60. package/src/generate-object/__snapshots__/stream-object.test.ts.snap +297 -0
  61. package/src/generate-object/generate-object-result.ts +67 -0
  62. package/src/generate-object/generate-object.test-d.ts +49 -0
  63. package/src/generate-object/generate-object.test.ts +1191 -0
  64. package/src/generate-object/generate-object.ts +518 -0
  65. package/src/generate-object/index.ts +9 -0
  66. package/src/generate-object/inject-json-instruction.test.ts +181 -0
  67. package/src/generate-object/inject-json-instruction.ts +30 -0
  68. package/src/generate-object/output-strategy.ts +415 -0
  69. package/src/generate-object/parse-and-validate-object-result.ts +111 -0
  70. package/src/generate-object/repair-text.ts +12 -0
  71. package/src/generate-object/stream-object-result.ts +120 -0
  72. package/src/generate-object/stream-object.test-d.ts +74 -0
  73. package/src/generate-object/stream-object.test.ts +1950 -0
  74. package/src/generate-object/stream-object.ts +986 -0
  75. package/src/generate-object/validate-object-generation-input.ts +144 -0
  76. package/src/generate-speech/generate-speech-result.ts +30 -0
  77. package/src/generate-speech/generate-speech.test.ts +300 -0
  78. package/src/generate-speech/generate-speech.ts +190 -0
  79. package/src/generate-speech/generated-audio-file.ts +65 -0
  80. package/src/generate-speech/index.ts +3 -0
  81. package/src/generate-text/__snapshots__/generate-text.test.ts.snap +1872 -0
  82. package/src/generate-text/__snapshots__/stream-text.test.ts.snap +1255 -0
  83. package/src/generate-text/collect-tool-approvals.test.ts +553 -0
  84. package/src/generate-text/collect-tool-approvals.ts +116 -0
  85. package/src/generate-text/content-part.ts +25 -0
  86. package/src/generate-text/execute-tool-call.ts +129 -0
  87. package/src/generate-text/extract-reasoning-content.ts +17 -0
  88. package/src/generate-text/extract-text-content.ts +15 -0
  89. package/src/generate-text/generate-text-result.ts +168 -0
  90. package/src/generate-text/generate-text.test-d.ts +68 -0
  91. package/src/generate-text/generate-text.test.ts +7011 -0
  92. package/src/generate-text/generate-text.ts +1223 -0
  93. package/src/generate-text/generated-file.ts +70 -0
  94. package/src/generate-text/index.ts +57 -0
  95. package/src/generate-text/is-approval-needed.ts +29 -0
  96. package/src/generate-text/output-utils.ts +23 -0
  97. package/src/generate-text/output.test.ts +698 -0
  98. package/src/generate-text/output.ts +590 -0
  99. package/src/generate-text/parse-tool-call.test.ts +570 -0
  100. package/src/generate-text/parse-tool-call.ts +188 -0
  101. package/src/generate-text/prepare-step.ts +103 -0
  102. package/src/generate-text/prune-messages.test.ts +720 -0
  103. package/src/generate-text/prune-messages.ts +167 -0
  104. package/src/generate-text/reasoning-output.ts +20 -0
  105. package/src/generate-text/reasoning.ts +8 -0
  106. package/src/generate-text/response-message.ts +10 -0
  107. package/src/generate-text/run-tools-transformation.test.ts +1143 -0
  108. package/src/generate-text/run-tools-transformation.ts +420 -0
  109. package/src/generate-text/smooth-stream.test.ts +2101 -0
  110. package/src/generate-text/smooth-stream.ts +162 -0
  111. package/src/generate-text/step-result.ts +238 -0
  112. package/src/generate-text/stop-condition.ts +29 -0
  113. package/src/generate-text/stream-text-result.ts +463 -0
  114. package/src/generate-text/stream-text.test-d.ts +200 -0
  115. package/src/generate-text/stream-text.test.ts +19979 -0
  116. package/src/generate-text/stream-text.ts +2505 -0
  117. package/src/generate-text/to-response-messages.test.ts +922 -0
  118. package/src/generate-text/to-response-messages.ts +163 -0
  119. package/src/generate-text/tool-approval-request-output.ts +21 -0
  120. package/src/generate-text/tool-call-repair-function.ts +27 -0
  121. package/src/generate-text/tool-call.ts +47 -0
  122. package/src/generate-text/tool-error.ts +34 -0
  123. package/src/generate-text/tool-output-denied.ts +21 -0
  124. package/src/generate-text/tool-output.ts +7 -0
  125. package/src/generate-text/tool-result.ts +36 -0
  126. package/src/generate-text/tool-set.ts +14 -0
  127. package/src/global.ts +24 -0
  128. package/src/index.ts +50 -0
  129. package/src/logger/index.ts +6 -0
  130. package/src/logger/log-warnings.test.ts +351 -0
  131. package/src/logger/log-warnings.ts +119 -0
  132. package/src/middleware/__snapshots__/simulate-streaming-middleware.test.ts.snap +64 -0
  133. package/src/middleware/add-tool-input-examples-middleware.test.ts +476 -0
  134. package/src/middleware/add-tool-input-examples-middleware.ts +90 -0
  135. package/src/middleware/default-embedding-settings-middleware.test.ts +126 -0
  136. package/src/middleware/default-embedding-settings-middleware.ts +22 -0
  137. package/src/middleware/default-settings-middleware.test.ts +388 -0
  138. package/src/middleware/default-settings-middleware.ts +33 -0
  139. package/src/middleware/extract-json-middleware.test.ts +827 -0
  140. package/src/middleware/extract-json-middleware.ts +197 -0
  141. package/src/middleware/extract-reasoning-middleware.test.ts +1028 -0
  142. package/src/middleware/extract-reasoning-middleware.ts +238 -0
  143. package/src/middleware/index.ts +10 -0
  144. package/src/middleware/simulate-streaming-middleware.test.ts +911 -0
  145. package/src/middleware/simulate-streaming-middleware.ts +79 -0
  146. package/src/middleware/wrap-embedding-model.test.ts +358 -0
  147. package/src/middleware/wrap-embedding-model.ts +86 -0
  148. package/src/middleware/wrap-image-model.test.ts +423 -0
  149. package/src/middleware/wrap-image-model.ts +85 -0
  150. package/src/middleware/wrap-language-model.test.ts +518 -0
  151. package/src/middleware/wrap-language-model.ts +104 -0
  152. package/src/middleware/wrap-provider.test.ts +120 -0
  153. package/src/middleware/wrap-provider.ts +51 -0
  154. package/src/model/as-embedding-model-v3.test.ts +319 -0
  155. package/src/model/as-embedding-model-v3.ts +24 -0
  156. package/src/model/as-image-model-v3.test.ts +409 -0
  157. package/src/model/as-image-model-v3.ts +24 -0
  158. package/src/model/as-language-model-v3.test.ts +508 -0
  159. package/src/model/as-language-model-v3.ts +103 -0
  160. package/src/model/as-provider-v3.ts +36 -0
  161. package/src/model/as-speech-model-v3.test.ts +356 -0
  162. package/src/model/as-speech-model-v3.ts +24 -0
  163. package/src/model/as-transcription-model-v3.test.ts +529 -0
  164. package/src/model/as-transcription-model-v3.ts +24 -0
  165. package/src/model/resolve-model.test.ts +244 -0
  166. package/src/model/resolve-model.ts +126 -0
  167. package/src/prompt/call-settings.ts +148 -0
  168. package/src/prompt/content-part.ts +209 -0
  169. package/src/prompt/convert-to-language-model-prompt.test.ts +2018 -0
  170. package/src/prompt/convert-to-language-model-prompt.ts +442 -0
  171. package/src/prompt/create-tool-model-output.test.ts +508 -0
  172. package/src/prompt/create-tool-model-output.ts +34 -0
  173. package/src/prompt/data-content.test.ts +15 -0
  174. package/src/prompt/data-content.ts +134 -0
  175. package/src/prompt/index.ts +27 -0
  176. package/src/prompt/invalid-data-content-error.ts +29 -0
  177. package/src/prompt/invalid-message-role-error.ts +27 -0
  178. package/src/prompt/message-conversion-error.ts +28 -0
  179. package/src/prompt/message.ts +68 -0
  180. package/src/prompt/prepare-call-settings.test.ts +159 -0
  181. package/src/prompt/prepare-call-settings.ts +108 -0
  182. package/src/prompt/prepare-tools-and-tool-choice.test.ts +461 -0
  183. package/src/prompt/prepare-tools-and-tool-choice.ts +86 -0
  184. package/src/prompt/prompt.ts +43 -0
  185. package/src/prompt/split-data-url.ts +17 -0
  186. package/src/prompt/standardize-prompt.test.ts +82 -0
  187. package/src/prompt/standardize-prompt.ts +99 -0
  188. package/src/prompt/wrap-gateway-error.ts +29 -0
  189. package/src/registry/custom-provider.test.ts +211 -0
  190. package/src/registry/custom-provider.ts +155 -0
  191. package/src/registry/index.ts +7 -0
  192. package/src/registry/no-such-provider-error.ts +41 -0
  193. package/src/registry/provider-registry.test.ts +691 -0
  194. package/src/registry/provider-registry.ts +328 -0
  195. package/src/rerank/index.ts +2 -0
  196. package/src/rerank/rerank-result.ts +70 -0
  197. package/src/rerank/rerank.test.ts +516 -0
  198. package/src/rerank/rerank.ts +237 -0
  199. package/src/telemetry/assemble-operation-name.ts +21 -0
  200. package/src/telemetry/get-base-telemetry-attributes.ts +53 -0
  201. package/src/telemetry/get-tracer.ts +20 -0
  202. package/src/telemetry/noop-tracer.ts +69 -0
  203. package/src/telemetry/record-span.ts +63 -0
  204. package/src/telemetry/select-telemetry-attributes.ts +78 -0
  205. package/src/telemetry/select-temetry-attributes.test.ts +114 -0
  206. package/src/telemetry/stringify-for-telemetry.test.ts +114 -0
  207. package/src/telemetry/stringify-for-telemetry.ts +33 -0
  208. package/src/telemetry/telemetry-settings.ts +44 -0
  209. package/src/test/mock-embedding-model-v2.ts +35 -0
  210. package/src/test/mock-embedding-model-v3.ts +48 -0
  211. package/src/test/mock-image-model-v2.ts +28 -0
  212. package/src/test/mock-image-model-v3.ts +28 -0
  213. package/src/test/mock-language-model-v2.ts +72 -0
  214. package/src/test/mock-language-model-v3.ts +77 -0
  215. package/src/test/mock-provider-v2.ts +68 -0
  216. package/src/test/mock-provider-v3.ts +80 -0
  217. package/src/test/mock-reranking-model-v3.ts +25 -0
  218. package/src/test/mock-server-response.ts +69 -0
  219. package/src/test/mock-speech-model-v2.ts +24 -0
  220. package/src/test/mock-speech-model-v3.ts +24 -0
  221. package/src/test/mock-tracer.ts +156 -0
  222. package/src/test/mock-transcription-model-v2.ts +24 -0
  223. package/src/test/mock-transcription-model-v3.ts +24 -0
  224. package/src/test/mock-values.ts +4 -0
  225. package/src/test/not-implemented.ts +3 -0
  226. package/src/text-stream/create-text-stream-response.test.ts +38 -0
  227. package/src/text-stream/create-text-stream-response.ts +18 -0
  228. package/src/text-stream/index.ts +2 -0
  229. package/src/text-stream/pipe-text-stream-to-response.test.ts +38 -0
  230. package/src/text-stream/pipe-text-stream-to-response.ts +26 -0
  231. package/src/transcribe/index.ts +2 -0
  232. package/src/transcribe/transcribe-result.ts +60 -0
  233. package/src/transcribe/transcribe.test.ts +313 -0
  234. package/src/transcribe/transcribe.ts +173 -0
  235. package/src/types/embedding-model-middleware.ts +3 -0
  236. package/src/types/embedding-model.ts +18 -0
  237. package/src/types/image-model-middleware.ts +3 -0
  238. package/src/types/image-model-response-metadata.ts +16 -0
  239. package/src/types/image-model.ts +19 -0
  240. package/src/types/index.ts +29 -0
  241. package/src/types/json-value.ts +15 -0
  242. package/src/types/language-model-middleware.ts +3 -0
  243. package/src/types/language-model-request-metadata.ts +6 -0
  244. package/src/types/language-model-response-metadata.ts +21 -0
  245. package/src/types/language-model.ts +104 -0
  246. package/src/types/provider-metadata.ts +16 -0
  247. package/src/types/provider.ts +55 -0
  248. package/src/types/reranking-model.ts +6 -0
  249. package/src/types/speech-model-response-metadata.ts +21 -0
  250. package/src/types/speech-model.ts +6 -0
  251. package/src/types/transcription-model-response-metadata.ts +16 -0
  252. package/src/types/transcription-model.ts +9 -0
  253. package/src/types/usage.ts +200 -0
  254. package/src/types/warning.ts +7 -0
  255. package/src/ui/__snapshots__/append-response-messages.test.ts.snap +416 -0
  256. package/src/ui/__snapshots__/convert-to-model-messages.test.ts.snap +419 -0
  257. package/src/ui/__snapshots__/process-chat-text-response.test.ts.snap +142 -0
  258. package/src/ui/call-completion-api.ts +157 -0
  259. package/src/ui/chat-transport.ts +83 -0
  260. package/src/ui/chat.test-d.ts +233 -0
  261. package/src/ui/chat.test.ts +2695 -0
  262. package/src/ui/chat.ts +716 -0
  263. package/src/ui/convert-file-list-to-file-ui-parts.ts +36 -0
  264. package/src/ui/convert-to-model-messages.test.ts +2775 -0
  265. package/src/ui/convert-to-model-messages.ts +373 -0
  266. package/src/ui/default-chat-transport.ts +36 -0
  267. package/src/ui/direct-chat-transport.test.ts +446 -0
  268. package/src/ui/direct-chat-transport.ts +118 -0
  269. package/src/ui/http-chat-transport.test.ts +185 -0
  270. package/src/ui/http-chat-transport.ts +292 -0
  271. package/src/ui/index.ts +71 -0
  272. package/src/ui/last-assistant-message-is-complete-with-approval-responses.ts +44 -0
  273. package/src/ui/last-assistant-message-is-complete-with-tool-calls.test.ts +371 -0
  274. package/src/ui/last-assistant-message-is-complete-with-tool-calls.ts +39 -0
  275. package/src/ui/process-text-stream.test.ts +38 -0
  276. package/src/ui/process-text-stream.ts +16 -0
  277. package/src/ui/process-ui-message-stream.test.ts +8294 -0
  278. package/src/ui/process-ui-message-stream.ts +761 -0
  279. package/src/ui/text-stream-chat-transport.ts +23 -0
  280. package/src/ui/transform-text-to-ui-message-stream.test.ts +124 -0
  281. package/src/ui/transform-text-to-ui-message-stream.ts +27 -0
  282. package/src/ui/ui-messages.test.ts +48 -0
  283. package/src/ui/ui-messages.ts +534 -0
  284. package/src/ui/use-completion.ts +84 -0
  285. package/src/ui/validate-ui-messages.test.ts +1428 -0
  286. package/src/ui/validate-ui-messages.ts +476 -0
  287. package/src/ui-message-stream/create-ui-message-stream-response.test.ts +266 -0
  288. package/src/ui-message-stream/create-ui-message-stream-response.ts +32 -0
  289. package/src/ui-message-stream/create-ui-message-stream.test.ts +639 -0
  290. package/src/ui-message-stream/create-ui-message-stream.ts +124 -0
  291. package/src/ui-message-stream/get-response-ui-message-id.test.ts +55 -0
  292. package/src/ui-message-stream/get-response-ui-message-id.ts +24 -0
  293. package/src/ui-message-stream/handle-ui-message-stream-finish.test.ts +429 -0
  294. package/src/ui-message-stream/handle-ui-message-stream-finish.ts +135 -0
  295. package/src/ui-message-stream/index.ts +13 -0
  296. package/src/ui-message-stream/json-to-sse-transform-stream.ts +12 -0
  297. package/src/ui-message-stream/pipe-ui-message-stream-to-response.test.ts +90 -0
  298. package/src/ui-message-stream/pipe-ui-message-stream-to-response.ts +40 -0
  299. package/src/ui-message-stream/read-ui-message-stream.test.ts +122 -0
  300. package/src/ui-message-stream/read-ui-message-stream.ts +87 -0
  301. package/src/ui-message-stream/ui-message-chunks.test-d.ts +18 -0
  302. package/src/ui-message-stream/ui-message-chunks.ts +344 -0
  303. package/src/ui-message-stream/ui-message-stream-headers.ts +7 -0
  304. package/src/ui-message-stream/ui-message-stream-on-finish-callback.ts +32 -0
  305. package/src/ui-message-stream/ui-message-stream-response-init.ts +5 -0
  306. package/src/ui-message-stream/ui-message-stream-writer.ts +24 -0
  307. package/src/util/as-array.ts +3 -0
  308. package/src/util/async-iterable-stream.test.ts +241 -0
  309. package/src/util/async-iterable-stream.ts +94 -0
  310. package/src/util/consume-stream.ts +29 -0
  311. package/src/util/cosine-similarity.test.ts +57 -0
  312. package/src/util/cosine-similarity.ts +47 -0
  313. package/src/util/create-resolvable-promise.ts +30 -0
  314. package/src/util/create-stitchable-stream.test.ts +239 -0
  315. package/src/util/create-stitchable-stream.ts +112 -0
  316. package/src/util/data-url.ts +17 -0
  317. package/src/util/deep-partial.ts +84 -0
  318. package/src/util/detect-media-type.test.ts +670 -0
  319. package/src/util/detect-media-type.ts +184 -0
  320. package/src/util/download/download-function.ts +45 -0
  321. package/src/util/download/download.test.ts +69 -0
  322. package/src/util/download/download.ts +46 -0
  323. package/src/util/error-handler.ts +1 -0
  324. package/src/util/fix-json.test.ts +279 -0
  325. package/src/util/fix-json.ts +401 -0
  326. package/src/util/get-potential-start-index.test.ts +34 -0
  327. package/src/util/get-potential-start-index.ts +30 -0
  328. package/src/util/index.ts +11 -0
  329. package/src/util/is-deep-equal-data.test.ts +119 -0
  330. package/src/util/is-deep-equal-data.ts +48 -0
  331. package/src/util/is-non-empty-object.ts +5 -0
  332. package/src/util/job.ts +1 -0
  333. package/src/util/log-v2-compatibility-warning.ts +21 -0
  334. package/src/util/merge-abort-signals.test.ts +155 -0
  335. package/src/util/merge-abort-signals.ts +43 -0
  336. package/src/util/merge-objects.test.ts +118 -0
  337. package/src/util/merge-objects.ts +79 -0
  338. package/src/util/now.ts +4 -0
  339. package/src/util/parse-partial-json.test.ts +80 -0
  340. package/src/util/parse-partial-json.ts +30 -0
  341. package/src/util/prepare-headers.test.ts +51 -0
  342. package/src/util/prepare-headers.ts +14 -0
  343. package/src/util/prepare-retries.test.ts +10 -0
  344. package/src/util/prepare-retries.ts +47 -0
  345. package/src/util/retry-error.ts +41 -0
  346. package/src/util/retry-with-exponential-backoff.test.ts +446 -0
  347. package/src/util/retry-with-exponential-backoff.ts +154 -0
  348. package/src/util/serial-job-executor.test.ts +162 -0
  349. package/src/util/serial-job-executor.ts +36 -0
  350. package/src/util/simulate-readable-stream.test.ts +98 -0
  351. package/src/util/simulate-readable-stream.ts +39 -0
  352. package/src/util/split-array.test.ts +60 -0
  353. package/src/util/split-array.ts +20 -0
  354. package/src/util/value-of.ts +65 -0
  355. package/src/util/write-to-server-response.test.ts +266 -0
  356. package/src/util/write-to-server-response.ts +49 -0
  357. package/src/version.ts +5 -0
@@ -0,0 +1,111 @@
1
+ import { JSONParseError, TypeValidationError } from '@ai-sdk/provider';
2
+ import { safeParseJSON } from '@ai-sdk/provider-utils';
3
+ import { NoObjectGeneratedError } from '../error/no-object-generated-error';
4
+ import type {
5
+ FinishReason,
6
+ LanguageModelResponseMetadata,
7
+ LanguageModelUsage,
8
+ } from '../types';
9
+ import type { OutputStrategy } from './output-strategy';
10
+ import { RepairTextFunction } from './repair-text';
11
+
12
+ /**
13
+ * Parses and validates a result string by parsing it as JSON and validating against the output strategy.
14
+ *
15
+ * @param result - The result string to parse and validate
16
+ * @param outputStrategy - The output strategy containing validation logic
17
+ * @param context - Additional context for error reporting
18
+ * @returns The validated result
19
+ * @throws NoObjectGeneratedError if parsing or validation fails
20
+ */
21
+ async function parseAndValidateObjectResult<RESULT>(
22
+ result: string,
23
+ outputStrategy: OutputStrategy<any, RESULT, any>,
24
+ context: {
25
+ response: LanguageModelResponseMetadata;
26
+ usage: LanguageModelUsage;
27
+ finishReason: FinishReason;
28
+ },
29
+ ): Promise<RESULT> {
30
+ const parseResult = await safeParseJSON({ text: result });
31
+
32
+ if (!parseResult.success) {
33
+ throw new NoObjectGeneratedError({
34
+ message: 'No object generated: could not parse the response.',
35
+ cause: parseResult.error,
36
+ text: result,
37
+ response: context.response,
38
+ usage: context.usage,
39
+ finishReason: context.finishReason,
40
+ });
41
+ }
42
+
43
+ const validationResult = await outputStrategy.validateFinalResult(
44
+ parseResult.value,
45
+ {
46
+ text: result,
47
+ response: context.response,
48
+ usage: context.usage,
49
+ },
50
+ );
51
+
52
+ if (!validationResult.success) {
53
+ throw new NoObjectGeneratedError({
54
+ message: 'No object generated: response did not match schema.',
55
+ cause: validationResult.error,
56
+ text: result,
57
+ response: context.response,
58
+ usage: context.usage,
59
+ finishReason: context.finishReason,
60
+ });
61
+ }
62
+
63
+ return validationResult.value;
64
+ }
65
+
66
+ /**
67
+ * Parses and validates a result string by parsing it as JSON and validating against the output strategy.
68
+ * If the result cannot be parsed, it attempts to repair the result using the repairText function.
69
+ *
70
+ * @param result - The result string to parse and validate
71
+ * @param outputStrategy - The output strategy containing validation logic
72
+ * @param repairText - A function that attempts to repair the result string
73
+ * @param context - Additional context for error reporting
74
+ * @returns The validated result
75
+ * @throws NoObjectGeneratedError if parsing or validation fails
76
+ */
77
+ export async function parseAndValidateObjectResultWithRepair<RESULT>(
78
+ result: string,
79
+ outputStrategy: OutputStrategy<any, RESULT, any>,
80
+ repairText: RepairTextFunction | undefined,
81
+ context: {
82
+ response: LanguageModelResponseMetadata;
83
+ usage: LanguageModelUsage;
84
+ finishReason: FinishReason;
85
+ },
86
+ ): Promise<RESULT> {
87
+ try {
88
+ return await parseAndValidateObjectResult(result, outputStrategy, context);
89
+ } catch (error) {
90
+ if (
91
+ repairText != null &&
92
+ NoObjectGeneratedError.isInstance(error) &&
93
+ (JSONParseError.isInstance(error.cause) ||
94
+ TypeValidationError.isInstance(error.cause))
95
+ ) {
96
+ const repairedText = await repairText({
97
+ text: result,
98
+ error: error.cause,
99
+ });
100
+ if (repairedText === null) {
101
+ throw error;
102
+ }
103
+ return await parseAndValidateObjectResult(
104
+ repairedText,
105
+ outputStrategy,
106
+ context,
107
+ );
108
+ }
109
+ throw error;
110
+ }
111
+ }
@@ -0,0 +1,12 @@
1
+ import { JSONParseError, TypeValidationError } from '@ai-sdk/provider';
2
+
3
+ /**
4
+ A function that attempts to repair the raw output of the model
5
+ to enable JSON parsing.
6
+
7
+ Should return the repaired text or null if the text cannot be repaired.
8
+ */
9
+ export type RepairTextFunction = (options: {
10
+ text: string;
11
+ error: JSONParseError | TypeValidationError;
12
+ }) => Promise<string | null>;
@@ -0,0 +1,120 @@
1
+ import { ServerResponse } from 'http';
2
+ import { AsyncIterableStream } from '../util/async-iterable-stream';
3
+ import {
4
+ CallWarning,
5
+ FinishReason,
6
+ LanguageModelRequestMetadata,
7
+ LanguageModelResponseMetadata,
8
+ ProviderMetadata,
9
+ } from '../types';
10
+ import { LanguageModelUsage } from '../types/usage';
11
+
12
+ /**
13
+ The result of a `streamObject` call that contains the partial object stream and additional information.
14
+ */
15
+ export interface StreamObjectResult<PARTIAL, RESULT, ELEMENT_STREAM> {
16
+ /**
17
+ Warnings from the model provider (e.g. unsupported settings)
18
+ */
19
+ readonly warnings: Promise<CallWarning[] | undefined>;
20
+
21
+ /**
22
+ The token usage of the generated response. Resolved when the response is finished.
23
+ */
24
+ readonly usage: Promise<LanguageModelUsage>;
25
+
26
+ /**
27
+ Additional provider-specific metadata. They are passed through
28
+ from the provider to the AI SDK and enable provider-specific
29
+ results that can be fully encapsulated in the provider.
30
+ */
31
+ readonly providerMetadata: Promise<ProviderMetadata | undefined>;
32
+
33
+ /**
34
+ Additional request information from the last step.
35
+ */
36
+ readonly request: Promise<LanguageModelRequestMetadata>;
37
+
38
+ /**
39
+ Additional response information.
40
+ */
41
+ readonly response: Promise<LanguageModelResponseMetadata>;
42
+
43
+ /**
44
+ The reason why the generation finished. Taken from the last step.
45
+
46
+ Resolved when the response is finished.
47
+ */
48
+ readonly finishReason: Promise<FinishReason>;
49
+
50
+ /**
51
+ The generated object (typed according to the schema). Resolved when the response is finished.
52
+ */
53
+ readonly object: Promise<RESULT>;
54
+
55
+ /**
56
+ Stream of partial objects. It gets more complete as the stream progresses.
57
+
58
+ Note that the partial object is not validated.
59
+ If you want to be certain that the actual content matches your schema, you need to implement your own validation for partial results.
60
+ */
61
+ readonly partialObjectStream: AsyncIterableStream<PARTIAL>;
62
+
63
+ /**
64
+ * Stream over complete array elements. Only available if the output strategy is set to `array`.
65
+ */
66
+ readonly elementStream: ELEMENT_STREAM;
67
+
68
+ /**
69
+ Text stream of the JSON representation of the generated object. It contains text chunks.
70
+ When the stream is finished, the object is valid JSON that can be parsed.
71
+ */
72
+ readonly textStream: AsyncIterableStream<string>;
73
+
74
+ /**
75
+ Stream of different types of events, including partial objects, errors, and finish events.
76
+ Only errors that stop the stream, such as network errors, are thrown.
77
+ */
78
+ readonly fullStream: AsyncIterableStream<ObjectStreamPart<PARTIAL>>;
79
+
80
+ /**
81
+ Writes text delta output to a Node.js response-like object.
82
+ It sets a `Content-Type` header to `text/plain; charset=utf-8` and
83
+ writes each text delta as a separate chunk.
84
+
85
+ @param response A Node.js response-like object (ServerResponse).
86
+ @param init Optional headers, status code, and status text.
87
+ */
88
+ pipeTextStreamToResponse(response: ServerResponse, init?: ResponseInit): void;
89
+
90
+ /**
91
+ Creates a simple text stream response.
92
+ The response has a `Content-Type` header set to `text/plain; charset=utf-8`.
93
+ Each text delta is encoded as UTF-8 and sent as a separate chunk.
94
+ Non-text-delta events are ignored.
95
+
96
+ @param init Optional headers, status code, and status text.
97
+ */
98
+ toTextStreamResponse(init?: ResponseInit): Response;
99
+ }
100
+
101
+ export type ObjectStreamPart<PARTIAL> =
102
+ | {
103
+ type: 'object';
104
+ object: PARTIAL;
105
+ }
106
+ | {
107
+ type: 'text-delta';
108
+ textDelta: string;
109
+ }
110
+ | {
111
+ type: 'error';
112
+ error: unknown;
113
+ }
114
+ | {
115
+ type: 'finish';
116
+ finishReason: FinishReason;
117
+ usage: LanguageModelUsage;
118
+ response: LanguageModelResponseMetadata;
119
+ providerMetadata?: ProviderMetadata;
120
+ };
@@ -0,0 +1,74 @@
1
+ import { JSONValue } from '@ai-sdk/provider';
2
+ import { expectTypeOf } from 'vitest';
3
+ import { z } from 'zod/v4';
4
+ import { AsyncIterableStream } from '../util/async-iterable-stream';
5
+ import { FinishReason } from '../types';
6
+ import { streamObject } from './stream-object';
7
+ import { describe, it } from 'vitest';
8
+
9
+ describe('streamObject', () => {
10
+ it('should have finishReason property with correct type', () => {
11
+ const result = streamObject({
12
+ schema: z.object({ number: z.number() }),
13
+ model: undefined!,
14
+ prompt: 'test',
15
+ });
16
+
17
+ expectTypeOf<typeof result.finishReason>().toEqualTypeOf<
18
+ Promise<FinishReason>
19
+ >();
20
+ });
21
+
22
+ it('should support enum types', async () => {
23
+ const result = await streamObject({
24
+ output: 'enum',
25
+ enum: ['a', 'b', 'c'] as const,
26
+ model: undefined!,
27
+ prompt: 'test',
28
+ });
29
+
30
+ expectTypeOf<typeof result.object>().toEqualTypeOf<
31
+ Promise<'a' | 'b' | 'c'>
32
+ >;
33
+
34
+ for await (const text of result.partialObjectStream) {
35
+ expectTypeOf(text).toEqualTypeOf<string>();
36
+ }
37
+ });
38
+
39
+ it('should support schema types', async () => {
40
+ const result = streamObject({
41
+ schema: z.object({ number: z.number() }),
42
+ model: undefined!,
43
+ prompt: 'test',
44
+ });
45
+
46
+ expectTypeOf<typeof result.object>().toEqualTypeOf<
47
+ Promise<{ number: number }>
48
+ >();
49
+ });
50
+
51
+ it('should support no-schema output mode', async () => {
52
+ const result = streamObject({
53
+ output: 'no-schema',
54
+ model: undefined!,
55
+ prompt: 'test',
56
+ });
57
+
58
+ expectTypeOf<typeof result.object>().toEqualTypeOf<Promise<JSONValue>>();
59
+ });
60
+
61
+ it('should support array output mode', async () => {
62
+ const result = streamObject({
63
+ output: 'array',
64
+ schema: z.number(),
65
+ model: undefined!,
66
+ prompt: 'test',
67
+ });
68
+
69
+ expectTypeOf<typeof result.partialObjectStream>().toEqualTypeOf<
70
+ AsyncIterableStream<number[]>
71
+ >();
72
+ expectTypeOf<typeof result.object>().toEqualTypeOf<Promise<number[]>>();
73
+ });
74
+ });