ai 6.0.33 → 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 (351) hide show
  1. package/CHANGELOG.md +10 -0
  2. package/dist/index.js +1 -1
  3. package/dist/index.mjs +1 -1
  4. package/dist/internal/index.js +1 -1
  5. package/dist/internal/index.mjs +1 -1
  6. package/docs/02-foundations/03-prompts.mdx +2 -2
  7. package/docs/03-ai-sdk-core/15-tools-and-tool-calling.mdx +1 -1
  8. package/docs/07-reference/01-ai-sdk-core/28-output.mdx +1 -1
  9. package/package.json +6 -4
  10. package/src/agent/agent.ts +116 -0
  11. package/src/agent/create-agent-ui-stream-response.test.ts +258 -0
  12. package/src/agent/create-agent-ui-stream-response.ts +50 -0
  13. package/src/agent/create-agent-ui-stream.ts +73 -0
  14. package/src/agent/index.ts +33 -0
  15. package/src/agent/infer-agent-tools.ts +7 -0
  16. package/src/agent/infer-agent-ui-message.test-d.ts +54 -0
  17. package/src/agent/infer-agent-ui-message.ts +11 -0
  18. package/src/agent/pipe-agent-ui-stream-to-response.ts +52 -0
  19. package/src/agent/tool-loop-agent-on-finish-callback.ts +31 -0
  20. package/src/agent/tool-loop-agent-on-step-finish-callback.ts +11 -0
  21. package/src/agent/tool-loop-agent-settings.ts +182 -0
  22. package/src/agent/tool-loop-agent.test-d.ts +114 -0
  23. package/src/agent/tool-loop-agent.test.ts +442 -0
  24. package/src/agent/tool-loop-agent.ts +114 -0
  25. package/src/embed/__snapshots__/embed-many.test.ts.snap +191 -0
  26. package/src/embed/__snapshots__/embed.test.ts.snap +81 -0
  27. package/src/embed/embed-many-result.ts +53 -0
  28. package/src/embed/embed-many.test.ts +653 -0
  29. package/src/embed/embed-many.ts +378 -0
  30. package/src/embed/embed-result.ts +50 -0
  31. package/src/embed/embed.test.ts +298 -0
  32. package/src/embed/embed.ts +211 -0
  33. package/src/embed/index.ts +4 -0
  34. package/src/error/index.ts +34 -0
  35. package/src/error/invalid-argument-error.ts +34 -0
  36. package/src/error/invalid-stream-part-error.ts +28 -0
  37. package/src/error/invalid-tool-approval-error.ts +26 -0
  38. package/src/error/invalid-tool-input-error.ts +33 -0
  39. package/src/error/no-image-generated-error.ts +39 -0
  40. package/src/error/no-object-generated-error.ts +70 -0
  41. package/src/error/no-output-generated-error.ts +26 -0
  42. package/src/error/no-speech-generated-error.ts +18 -0
  43. package/src/error/no-such-tool-error.ts +35 -0
  44. package/src/error/no-transcript-generated-error.ts +20 -0
  45. package/src/error/tool-call-not-found-for-approval-error.ts +32 -0
  46. package/src/error/tool-call-repair-error.ts +30 -0
  47. package/src/error/unsupported-model-version-error.ts +23 -0
  48. package/src/error/verify-no-object-generated-error.ts +27 -0
  49. package/src/generate-image/generate-image-result.ts +42 -0
  50. package/src/generate-image/generate-image.test.ts +1420 -0
  51. package/src/generate-image/generate-image.ts +360 -0
  52. package/src/generate-image/index.ts +18 -0
  53. package/src/generate-object/__snapshots__/generate-object.test.ts.snap +133 -0
  54. package/src/generate-object/__snapshots__/stream-object.test.ts.snap +297 -0
  55. package/src/generate-object/generate-object-result.ts +67 -0
  56. package/src/generate-object/generate-object.test-d.ts +49 -0
  57. package/src/generate-object/generate-object.test.ts +1191 -0
  58. package/src/generate-object/generate-object.ts +518 -0
  59. package/src/generate-object/index.ts +9 -0
  60. package/src/generate-object/inject-json-instruction.test.ts +181 -0
  61. package/src/generate-object/inject-json-instruction.ts +30 -0
  62. package/src/generate-object/output-strategy.ts +415 -0
  63. package/src/generate-object/parse-and-validate-object-result.ts +111 -0
  64. package/src/generate-object/repair-text.ts +12 -0
  65. package/src/generate-object/stream-object-result.ts +120 -0
  66. package/src/generate-object/stream-object.test-d.ts +74 -0
  67. package/src/generate-object/stream-object.test.ts +1950 -0
  68. package/src/generate-object/stream-object.ts +986 -0
  69. package/src/generate-object/validate-object-generation-input.ts +144 -0
  70. package/src/generate-speech/generate-speech-result.ts +30 -0
  71. package/src/generate-speech/generate-speech.test.ts +300 -0
  72. package/src/generate-speech/generate-speech.ts +190 -0
  73. package/src/generate-speech/generated-audio-file.ts +65 -0
  74. package/src/generate-speech/index.ts +3 -0
  75. package/src/generate-text/__snapshots__/generate-text.test.ts.snap +1872 -0
  76. package/src/generate-text/__snapshots__/stream-text.test.ts.snap +1255 -0
  77. package/src/generate-text/collect-tool-approvals.test.ts +553 -0
  78. package/src/generate-text/collect-tool-approvals.ts +116 -0
  79. package/src/generate-text/content-part.ts +25 -0
  80. package/src/generate-text/execute-tool-call.ts +129 -0
  81. package/src/generate-text/extract-reasoning-content.ts +17 -0
  82. package/src/generate-text/extract-text-content.ts +15 -0
  83. package/src/generate-text/generate-text-result.ts +168 -0
  84. package/src/generate-text/generate-text.test-d.ts +68 -0
  85. package/src/generate-text/generate-text.test.ts +7011 -0
  86. package/src/generate-text/generate-text.ts +1223 -0
  87. package/src/generate-text/generated-file.ts +70 -0
  88. package/src/generate-text/index.ts +57 -0
  89. package/src/generate-text/is-approval-needed.ts +29 -0
  90. package/src/generate-text/output-utils.ts +23 -0
  91. package/src/generate-text/output.test.ts +698 -0
  92. package/src/generate-text/output.ts +590 -0
  93. package/src/generate-text/parse-tool-call.test.ts +570 -0
  94. package/src/generate-text/parse-tool-call.ts +188 -0
  95. package/src/generate-text/prepare-step.ts +103 -0
  96. package/src/generate-text/prune-messages.test.ts +720 -0
  97. package/src/generate-text/prune-messages.ts +167 -0
  98. package/src/generate-text/reasoning-output.ts +20 -0
  99. package/src/generate-text/reasoning.ts +8 -0
  100. package/src/generate-text/response-message.ts +10 -0
  101. package/src/generate-text/run-tools-transformation.test.ts +1143 -0
  102. package/src/generate-text/run-tools-transformation.ts +420 -0
  103. package/src/generate-text/smooth-stream.test.ts +2101 -0
  104. package/src/generate-text/smooth-stream.ts +162 -0
  105. package/src/generate-text/step-result.ts +238 -0
  106. package/src/generate-text/stop-condition.ts +29 -0
  107. package/src/generate-text/stream-text-result.ts +463 -0
  108. package/src/generate-text/stream-text.test-d.ts +200 -0
  109. package/src/generate-text/stream-text.test.ts +19979 -0
  110. package/src/generate-text/stream-text.ts +2505 -0
  111. package/src/generate-text/to-response-messages.test.ts +922 -0
  112. package/src/generate-text/to-response-messages.ts +163 -0
  113. package/src/generate-text/tool-approval-request-output.ts +21 -0
  114. package/src/generate-text/tool-call-repair-function.ts +27 -0
  115. package/src/generate-text/tool-call.ts +47 -0
  116. package/src/generate-text/tool-error.ts +34 -0
  117. package/src/generate-text/tool-output-denied.ts +21 -0
  118. package/src/generate-text/tool-output.ts +7 -0
  119. package/src/generate-text/tool-result.ts +36 -0
  120. package/src/generate-text/tool-set.ts +14 -0
  121. package/src/global.ts +24 -0
  122. package/src/index.ts +50 -0
  123. package/src/logger/index.ts +6 -0
  124. package/src/logger/log-warnings.test.ts +351 -0
  125. package/src/logger/log-warnings.ts +119 -0
  126. package/src/middleware/__snapshots__/simulate-streaming-middleware.test.ts.snap +64 -0
  127. package/src/middleware/add-tool-input-examples-middleware.test.ts +476 -0
  128. package/src/middleware/add-tool-input-examples-middleware.ts +90 -0
  129. package/src/middleware/default-embedding-settings-middleware.test.ts +126 -0
  130. package/src/middleware/default-embedding-settings-middleware.ts +22 -0
  131. package/src/middleware/default-settings-middleware.test.ts +388 -0
  132. package/src/middleware/default-settings-middleware.ts +33 -0
  133. package/src/middleware/extract-json-middleware.test.ts +827 -0
  134. package/src/middleware/extract-json-middleware.ts +197 -0
  135. package/src/middleware/extract-reasoning-middleware.test.ts +1028 -0
  136. package/src/middleware/extract-reasoning-middleware.ts +238 -0
  137. package/src/middleware/index.ts +10 -0
  138. package/src/middleware/simulate-streaming-middleware.test.ts +911 -0
  139. package/src/middleware/simulate-streaming-middleware.ts +79 -0
  140. package/src/middleware/wrap-embedding-model.test.ts +358 -0
  141. package/src/middleware/wrap-embedding-model.ts +86 -0
  142. package/src/middleware/wrap-image-model.test.ts +423 -0
  143. package/src/middleware/wrap-image-model.ts +85 -0
  144. package/src/middleware/wrap-language-model.test.ts +518 -0
  145. package/src/middleware/wrap-language-model.ts +104 -0
  146. package/src/middleware/wrap-provider.test.ts +120 -0
  147. package/src/middleware/wrap-provider.ts +51 -0
  148. package/src/model/as-embedding-model-v3.test.ts +319 -0
  149. package/src/model/as-embedding-model-v3.ts +24 -0
  150. package/src/model/as-image-model-v3.test.ts +409 -0
  151. package/src/model/as-image-model-v3.ts +24 -0
  152. package/src/model/as-language-model-v3.test.ts +508 -0
  153. package/src/model/as-language-model-v3.ts +103 -0
  154. package/src/model/as-provider-v3.ts +36 -0
  155. package/src/model/as-speech-model-v3.test.ts +356 -0
  156. package/src/model/as-speech-model-v3.ts +24 -0
  157. package/src/model/as-transcription-model-v3.test.ts +529 -0
  158. package/src/model/as-transcription-model-v3.ts +24 -0
  159. package/src/model/resolve-model.test.ts +244 -0
  160. package/src/model/resolve-model.ts +126 -0
  161. package/src/prompt/call-settings.ts +148 -0
  162. package/src/prompt/content-part.ts +209 -0
  163. package/src/prompt/convert-to-language-model-prompt.test.ts +2018 -0
  164. package/src/prompt/convert-to-language-model-prompt.ts +442 -0
  165. package/src/prompt/create-tool-model-output.test.ts +508 -0
  166. package/src/prompt/create-tool-model-output.ts +34 -0
  167. package/src/prompt/data-content.test.ts +15 -0
  168. package/src/prompt/data-content.ts +134 -0
  169. package/src/prompt/index.ts +27 -0
  170. package/src/prompt/invalid-data-content-error.ts +29 -0
  171. package/src/prompt/invalid-message-role-error.ts +27 -0
  172. package/src/prompt/message-conversion-error.ts +28 -0
  173. package/src/prompt/message.ts +68 -0
  174. package/src/prompt/prepare-call-settings.test.ts +159 -0
  175. package/src/prompt/prepare-call-settings.ts +108 -0
  176. package/src/prompt/prepare-tools-and-tool-choice.test.ts +461 -0
  177. package/src/prompt/prepare-tools-and-tool-choice.ts +86 -0
  178. package/src/prompt/prompt.ts +43 -0
  179. package/src/prompt/split-data-url.ts +17 -0
  180. package/src/prompt/standardize-prompt.test.ts +82 -0
  181. package/src/prompt/standardize-prompt.ts +99 -0
  182. package/src/prompt/wrap-gateway-error.ts +29 -0
  183. package/src/registry/custom-provider.test.ts +211 -0
  184. package/src/registry/custom-provider.ts +155 -0
  185. package/src/registry/index.ts +7 -0
  186. package/src/registry/no-such-provider-error.ts +41 -0
  187. package/src/registry/provider-registry.test.ts +691 -0
  188. package/src/registry/provider-registry.ts +328 -0
  189. package/src/rerank/index.ts +2 -0
  190. package/src/rerank/rerank-result.ts +70 -0
  191. package/src/rerank/rerank.test.ts +516 -0
  192. package/src/rerank/rerank.ts +237 -0
  193. package/src/telemetry/assemble-operation-name.ts +21 -0
  194. package/src/telemetry/get-base-telemetry-attributes.ts +53 -0
  195. package/src/telemetry/get-tracer.ts +20 -0
  196. package/src/telemetry/noop-tracer.ts +69 -0
  197. package/src/telemetry/record-span.ts +63 -0
  198. package/src/telemetry/select-telemetry-attributes.ts +78 -0
  199. package/src/telemetry/select-temetry-attributes.test.ts +114 -0
  200. package/src/telemetry/stringify-for-telemetry.test.ts +114 -0
  201. package/src/telemetry/stringify-for-telemetry.ts +33 -0
  202. package/src/telemetry/telemetry-settings.ts +44 -0
  203. package/src/test/mock-embedding-model-v2.ts +35 -0
  204. package/src/test/mock-embedding-model-v3.ts +48 -0
  205. package/src/test/mock-image-model-v2.ts +28 -0
  206. package/src/test/mock-image-model-v3.ts +28 -0
  207. package/src/test/mock-language-model-v2.ts +72 -0
  208. package/src/test/mock-language-model-v3.ts +77 -0
  209. package/src/test/mock-provider-v2.ts +68 -0
  210. package/src/test/mock-provider-v3.ts +80 -0
  211. package/src/test/mock-reranking-model-v3.ts +25 -0
  212. package/src/test/mock-server-response.ts +69 -0
  213. package/src/test/mock-speech-model-v2.ts +24 -0
  214. package/src/test/mock-speech-model-v3.ts +24 -0
  215. package/src/test/mock-tracer.ts +156 -0
  216. package/src/test/mock-transcription-model-v2.ts +24 -0
  217. package/src/test/mock-transcription-model-v3.ts +24 -0
  218. package/src/test/mock-values.ts +4 -0
  219. package/src/test/not-implemented.ts +3 -0
  220. package/src/text-stream/create-text-stream-response.test.ts +38 -0
  221. package/src/text-stream/create-text-stream-response.ts +18 -0
  222. package/src/text-stream/index.ts +2 -0
  223. package/src/text-stream/pipe-text-stream-to-response.test.ts +38 -0
  224. package/src/text-stream/pipe-text-stream-to-response.ts +26 -0
  225. package/src/transcribe/index.ts +2 -0
  226. package/src/transcribe/transcribe-result.ts +60 -0
  227. package/src/transcribe/transcribe.test.ts +313 -0
  228. package/src/transcribe/transcribe.ts +173 -0
  229. package/src/types/embedding-model-middleware.ts +3 -0
  230. package/src/types/embedding-model.ts +18 -0
  231. package/src/types/image-model-middleware.ts +3 -0
  232. package/src/types/image-model-response-metadata.ts +16 -0
  233. package/src/types/image-model.ts +19 -0
  234. package/src/types/index.ts +29 -0
  235. package/src/types/json-value.ts +15 -0
  236. package/src/types/language-model-middleware.ts +3 -0
  237. package/src/types/language-model-request-metadata.ts +6 -0
  238. package/src/types/language-model-response-metadata.ts +21 -0
  239. package/src/types/language-model.ts +104 -0
  240. package/src/types/provider-metadata.ts +16 -0
  241. package/src/types/provider.ts +55 -0
  242. package/src/types/reranking-model.ts +6 -0
  243. package/src/types/speech-model-response-metadata.ts +21 -0
  244. package/src/types/speech-model.ts +6 -0
  245. package/src/types/transcription-model-response-metadata.ts +16 -0
  246. package/src/types/transcription-model.ts +9 -0
  247. package/src/types/usage.ts +200 -0
  248. package/src/types/warning.ts +7 -0
  249. package/src/ui/__snapshots__/append-response-messages.test.ts.snap +416 -0
  250. package/src/ui/__snapshots__/convert-to-model-messages.test.ts.snap +419 -0
  251. package/src/ui/__snapshots__/process-chat-text-response.test.ts.snap +142 -0
  252. package/src/ui/call-completion-api.ts +157 -0
  253. package/src/ui/chat-transport.ts +83 -0
  254. package/src/ui/chat.test-d.ts +233 -0
  255. package/src/ui/chat.test.ts +2695 -0
  256. package/src/ui/chat.ts +716 -0
  257. package/src/ui/convert-file-list-to-file-ui-parts.ts +36 -0
  258. package/src/ui/convert-to-model-messages.test.ts +2775 -0
  259. package/src/ui/convert-to-model-messages.ts +373 -0
  260. package/src/ui/default-chat-transport.ts +36 -0
  261. package/src/ui/direct-chat-transport.test.ts +446 -0
  262. package/src/ui/direct-chat-transport.ts +118 -0
  263. package/src/ui/http-chat-transport.test.ts +185 -0
  264. package/src/ui/http-chat-transport.ts +292 -0
  265. package/src/ui/index.ts +71 -0
  266. package/src/ui/last-assistant-message-is-complete-with-approval-responses.ts +44 -0
  267. package/src/ui/last-assistant-message-is-complete-with-tool-calls.test.ts +371 -0
  268. package/src/ui/last-assistant-message-is-complete-with-tool-calls.ts +39 -0
  269. package/src/ui/process-text-stream.test.ts +38 -0
  270. package/src/ui/process-text-stream.ts +16 -0
  271. package/src/ui/process-ui-message-stream.test.ts +8052 -0
  272. package/src/ui/process-ui-message-stream.ts +713 -0
  273. package/src/ui/text-stream-chat-transport.ts +23 -0
  274. package/src/ui/transform-text-to-ui-message-stream.test.ts +124 -0
  275. package/src/ui/transform-text-to-ui-message-stream.ts +27 -0
  276. package/src/ui/ui-messages.test.ts +48 -0
  277. package/src/ui/ui-messages.ts +534 -0
  278. package/src/ui/use-completion.ts +84 -0
  279. package/src/ui/validate-ui-messages.test.ts +1428 -0
  280. package/src/ui/validate-ui-messages.ts +476 -0
  281. package/src/ui-message-stream/create-ui-message-stream-response.test.ts +266 -0
  282. package/src/ui-message-stream/create-ui-message-stream-response.ts +32 -0
  283. package/src/ui-message-stream/create-ui-message-stream.test.ts +639 -0
  284. package/src/ui-message-stream/create-ui-message-stream.ts +124 -0
  285. package/src/ui-message-stream/get-response-ui-message-id.test.ts +55 -0
  286. package/src/ui-message-stream/get-response-ui-message-id.ts +24 -0
  287. package/src/ui-message-stream/handle-ui-message-stream-finish.test.ts +429 -0
  288. package/src/ui-message-stream/handle-ui-message-stream-finish.ts +135 -0
  289. package/src/ui-message-stream/index.ts +13 -0
  290. package/src/ui-message-stream/json-to-sse-transform-stream.ts +12 -0
  291. package/src/ui-message-stream/pipe-ui-message-stream-to-response.test.ts +90 -0
  292. package/src/ui-message-stream/pipe-ui-message-stream-to-response.ts +40 -0
  293. package/src/ui-message-stream/read-ui-message-stream.test.ts +122 -0
  294. package/src/ui-message-stream/read-ui-message-stream.ts +87 -0
  295. package/src/ui-message-stream/ui-message-chunks.test-d.ts +18 -0
  296. package/src/ui-message-stream/ui-message-chunks.ts +344 -0
  297. package/src/ui-message-stream/ui-message-stream-headers.ts +7 -0
  298. package/src/ui-message-stream/ui-message-stream-on-finish-callback.ts +32 -0
  299. package/src/ui-message-stream/ui-message-stream-response-init.ts +5 -0
  300. package/src/ui-message-stream/ui-message-stream-writer.ts +24 -0
  301. package/src/util/as-array.ts +3 -0
  302. package/src/util/async-iterable-stream.test.ts +241 -0
  303. package/src/util/async-iterable-stream.ts +94 -0
  304. package/src/util/consume-stream.ts +29 -0
  305. package/src/util/cosine-similarity.test.ts +57 -0
  306. package/src/util/cosine-similarity.ts +47 -0
  307. package/src/util/create-resolvable-promise.ts +30 -0
  308. package/src/util/create-stitchable-stream.test.ts +239 -0
  309. package/src/util/create-stitchable-stream.ts +112 -0
  310. package/src/util/data-url.ts +17 -0
  311. package/src/util/deep-partial.ts +84 -0
  312. package/src/util/detect-media-type.test.ts +670 -0
  313. package/src/util/detect-media-type.ts +184 -0
  314. package/src/util/download/download-function.ts +45 -0
  315. package/src/util/download/download.test.ts +69 -0
  316. package/src/util/download/download.ts +46 -0
  317. package/src/util/error-handler.ts +1 -0
  318. package/src/util/fix-json.test.ts +279 -0
  319. package/src/util/fix-json.ts +401 -0
  320. package/src/util/get-potential-start-index.test.ts +34 -0
  321. package/src/util/get-potential-start-index.ts +30 -0
  322. package/src/util/index.ts +11 -0
  323. package/src/util/is-deep-equal-data.test.ts +119 -0
  324. package/src/util/is-deep-equal-data.ts +48 -0
  325. package/src/util/is-non-empty-object.ts +5 -0
  326. package/src/util/job.ts +1 -0
  327. package/src/util/log-v2-compatibility-warning.ts +21 -0
  328. package/src/util/merge-abort-signals.test.ts +155 -0
  329. package/src/util/merge-abort-signals.ts +43 -0
  330. package/src/util/merge-objects.test.ts +118 -0
  331. package/src/util/merge-objects.ts +79 -0
  332. package/src/util/now.ts +4 -0
  333. package/src/util/parse-partial-json.test.ts +80 -0
  334. package/src/util/parse-partial-json.ts +30 -0
  335. package/src/util/prepare-headers.test.ts +51 -0
  336. package/src/util/prepare-headers.ts +14 -0
  337. package/src/util/prepare-retries.test.ts +10 -0
  338. package/src/util/prepare-retries.ts +47 -0
  339. package/src/util/retry-error.ts +41 -0
  340. package/src/util/retry-with-exponential-backoff.test.ts +446 -0
  341. package/src/util/retry-with-exponential-backoff.ts +154 -0
  342. package/src/util/serial-job-executor.test.ts +162 -0
  343. package/src/util/serial-job-executor.ts +36 -0
  344. package/src/util/simulate-readable-stream.test.ts +98 -0
  345. package/src/util/simulate-readable-stream.ts +39 -0
  346. package/src/util/split-array.test.ts +60 -0
  347. package/src/util/split-array.ts +20 -0
  348. package/src/util/value-of.ts +65 -0
  349. package/src/util/write-to-server-response.test.ts +266 -0
  350. package/src/util/write-to-server-response.ts +49 -0
  351. package/src/version.ts +5 -0
@@ -0,0 +1,360 @@
1
+ import {
2
+ ImageModelV3,
3
+ ImageModelV3CallOptions,
4
+ ImageModelV3File,
5
+ ImageModelV3ProviderMetadata,
6
+ } from '@ai-sdk/provider';
7
+ import {
8
+ convertBase64ToUint8Array,
9
+ DataContent,
10
+ ProviderOptions,
11
+ withUserAgentSuffix,
12
+ } from '@ai-sdk/provider-utils';
13
+ import { NoImageGeneratedError } from '../error/no-image-generated-error';
14
+ import {
15
+ DefaultGeneratedFile,
16
+ GeneratedFile,
17
+ } from '../generate-text/generated-file';
18
+ import { logWarnings } from '../logger/log-warnings';
19
+ import { resolveImageModel } from '../model/resolve-model';
20
+ import type { ImageModel } from '../types/image-model';
21
+ import { ImageModelResponseMetadata } from '../types/image-model-response-metadata';
22
+ import { addImageModelUsage, ImageModelUsage } from '../types/usage';
23
+ import { Warning } from '../types/warning';
24
+ import {
25
+ detectMediaType,
26
+ imageMediaTypeSignatures,
27
+ } from '../util/detect-media-type';
28
+ import { prepareRetries } from '../util/prepare-retries';
29
+ import { VERSION } from '../version';
30
+ import { GenerateImageResult } from './generate-image-result';
31
+ import { convertDataContentToUint8Array } from '../prompt/data-content';
32
+ import { splitDataUrl } from '../prompt/split-data-url';
33
+
34
+ export type GenerateImagePrompt =
35
+ | string
36
+ | {
37
+ images: Array<DataContent>;
38
+ text?: string;
39
+ mask?: DataContent;
40
+ };
41
+
42
+ /**
43
+ Generates images using an image model.
44
+
45
+ @param model - The image model to use.
46
+ @param prompt - The prompt that should be used to generate the image.
47
+ @param n - Number of images to generate. Default: 1.
48
+ @param size - Size of the images to generate. Must have the format `{width}x{height}`.
49
+ @param aspectRatio - Aspect ratio of the images to generate. Must have the format `{width}:{height}`.
50
+ @param seed - Seed for the image generation.
51
+ @param providerOptions - Additional provider-specific options that are passed through to the provider
52
+ as body parameters.
53
+ @param maxRetries - Maximum number of retries. Set to 0 to disable retries. Default: 2.
54
+ @param abortSignal - An optional abort signal that can be used to cancel the call.
55
+ @param headers - Additional HTTP headers to be sent with the request. Only applicable for HTTP-based providers.
56
+
57
+ @returns A result object that contains the generated images.
58
+ */
59
+ export async function generateImage({
60
+ model: modelArg,
61
+ prompt: promptArg,
62
+ n = 1,
63
+ maxImagesPerCall,
64
+ size,
65
+ aspectRatio,
66
+ seed,
67
+ providerOptions,
68
+ maxRetries: maxRetriesArg,
69
+ abortSignal,
70
+ headers,
71
+ }: {
72
+ /**
73
+ The image model to use.
74
+ */
75
+ model: ImageModel;
76
+
77
+ /**
78
+ The prompt that should be used to generate the image.
79
+ */
80
+ prompt: GenerateImagePrompt;
81
+
82
+ /**
83
+ Number of images to generate.
84
+ */
85
+ n?: number;
86
+
87
+ /**
88
+ Number of images to generate.
89
+ */
90
+ maxImagesPerCall?: number;
91
+
92
+ /**
93
+ Size of the images to generate. Must have the format `{width}x{height}`. If not provided, the default size will be used.
94
+ */
95
+ size?: `${number}x${number}`;
96
+
97
+ /**
98
+ Aspect ratio of the images to generate. Must have the format `{width}:{height}`. If not provided, the default aspect ratio will be used.
99
+ */
100
+ aspectRatio?: `${number}:${number}`;
101
+
102
+ /**
103
+ Seed for the image generation. If not provided, the default seed will be used.
104
+ */
105
+ seed?: number;
106
+
107
+ /**
108
+ Additional provider-specific options that are passed through to the provider
109
+ as body parameters.
110
+
111
+ The outer record is keyed by the provider name, and the inner
112
+ record is keyed by the provider-specific metadata key.
113
+ ```ts
114
+ {
115
+ "openai": {
116
+ "style": "vivid"
117
+ }
118
+ }
119
+ ```
120
+ */
121
+ providerOptions?: ProviderOptions;
122
+
123
+ /**
124
+ Maximum number of retries per embedding model call. Set to 0 to disable retries.
125
+
126
+ @default 2
127
+ */
128
+ maxRetries?: number;
129
+
130
+ /**
131
+ Abort signal.
132
+ */
133
+ abortSignal?: AbortSignal;
134
+
135
+ /**
136
+ Additional headers to include in the request.
137
+ Only applicable for HTTP-based providers.
138
+ */
139
+ headers?: Record<string, string>;
140
+ }): Promise<GenerateImageResult> {
141
+ const model = resolveImageModel(modelArg);
142
+
143
+ const headersWithUserAgent = withUserAgentSuffix(
144
+ headers ?? {},
145
+ `ai/${VERSION}`,
146
+ );
147
+
148
+ const { retry } = prepareRetries({
149
+ maxRetries: maxRetriesArg,
150
+ abortSignal,
151
+ });
152
+
153
+ // default to 1 if the model has not specified limits on
154
+ // how many images can be generated in a single call
155
+ const maxImagesPerCallWithDefault =
156
+ maxImagesPerCall ?? (await invokeModelMaxImagesPerCall(model)) ?? 1;
157
+
158
+ // parallelize calls to the model:
159
+ const callCount = Math.ceil(n / maxImagesPerCallWithDefault);
160
+ const callImageCounts = Array.from({ length: callCount }, (_, i) => {
161
+ if (i < callCount - 1) {
162
+ return maxImagesPerCallWithDefault;
163
+ }
164
+
165
+ const remainder = n % maxImagesPerCallWithDefault;
166
+ return remainder === 0 ? maxImagesPerCallWithDefault : remainder;
167
+ });
168
+
169
+ const results = await Promise.all(
170
+ callImageCounts.map(async callImageCount =>
171
+ retry(() => {
172
+ const { prompt, files, mask } = normalizePrompt(promptArg);
173
+
174
+ return model.doGenerate({
175
+ prompt,
176
+ files,
177
+ mask,
178
+ n: callImageCount,
179
+ abortSignal,
180
+ headers: headersWithUserAgent,
181
+ size,
182
+ aspectRatio,
183
+ seed,
184
+ providerOptions: providerOptions ?? {},
185
+ });
186
+ }),
187
+ ),
188
+ );
189
+
190
+ // collect result images, warnings, and response metadata
191
+ const images: Array<DefaultGeneratedFile> = [];
192
+ const warnings: Array<Warning> = [];
193
+ const responses: Array<ImageModelResponseMetadata> = [];
194
+ const providerMetadata: ImageModelV3ProviderMetadata = {};
195
+ let totalUsage: ImageModelUsage = {
196
+ inputTokens: undefined,
197
+ outputTokens: undefined,
198
+ totalTokens: undefined,
199
+ };
200
+ for (const result of results) {
201
+ images.push(
202
+ ...result.images.map(
203
+ image =>
204
+ new DefaultGeneratedFile({
205
+ data: image,
206
+ mediaType:
207
+ detectMediaType({
208
+ data: image,
209
+ signatures: imageMediaTypeSignatures,
210
+ }) ?? 'image/png',
211
+ }),
212
+ ),
213
+ );
214
+ warnings.push(...result.warnings);
215
+
216
+ if (result.usage != null) {
217
+ totalUsage = addImageModelUsage(totalUsage, result.usage);
218
+ }
219
+
220
+ if (result.providerMetadata) {
221
+ for (const [providerName, metadata] of Object.entries<{
222
+ images: unknown;
223
+ }>(result.providerMetadata)) {
224
+ if (providerName === 'gateway') {
225
+ const currentEntry = providerMetadata[providerName];
226
+ if (currentEntry != null && typeof currentEntry === 'object') {
227
+ providerMetadata[providerName] = {
228
+ ...(currentEntry as object),
229
+ ...metadata,
230
+ } as ImageModelV3ProviderMetadata[string];
231
+ } else {
232
+ providerMetadata[providerName] =
233
+ metadata as ImageModelV3ProviderMetadata[string];
234
+ }
235
+ const imagesValue = (
236
+ providerMetadata[providerName] as { images?: unknown }
237
+ ).images;
238
+ if (Array.isArray(imagesValue) && imagesValue.length === 0) {
239
+ delete (providerMetadata[providerName] as { images?: unknown })
240
+ .images;
241
+ }
242
+ } else {
243
+ providerMetadata[providerName] ??= { images: [] };
244
+ providerMetadata[providerName].images.push(
245
+ ...result.providerMetadata[providerName].images,
246
+ );
247
+ }
248
+ }
249
+ }
250
+
251
+ responses.push(result.response);
252
+ }
253
+
254
+ logWarnings({ warnings, provider: model.provider, model: model.modelId });
255
+
256
+ if (!images.length) {
257
+ throw new NoImageGeneratedError({ responses });
258
+ }
259
+
260
+ return new DefaultGenerateImageResult({
261
+ images,
262
+ warnings,
263
+ responses,
264
+ providerMetadata,
265
+ usage: totalUsage,
266
+ });
267
+ }
268
+
269
+ class DefaultGenerateImageResult implements GenerateImageResult {
270
+ readonly images: Array<GeneratedFile>;
271
+ readonly warnings: Array<Warning>;
272
+ readonly responses: Array<ImageModelResponseMetadata>;
273
+ readonly providerMetadata: ImageModelV3ProviderMetadata;
274
+ readonly usage: ImageModelUsage;
275
+
276
+ constructor(options: {
277
+ images: Array<GeneratedFile>;
278
+ warnings: Array<Warning>;
279
+ responses: Array<ImageModelResponseMetadata>;
280
+ providerMetadata: ImageModelV3ProviderMetadata;
281
+ usage: ImageModelUsage;
282
+ }) {
283
+ this.images = options.images;
284
+ this.warnings = options.warnings;
285
+ this.responses = options.responses;
286
+ this.providerMetadata = options.providerMetadata;
287
+ this.usage = options.usage;
288
+ }
289
+
290
+ get image() {
291
+ return this.images[0];
292
+ }
293
+ }
294
+
295
+ async function invokeModelMaxImagesPerCall(model: ImageModelV3) {
296
+ const isFunction = model.maxImagesPerCall instanceof Function;
297
+
298
+ if (!isFunction) {
299
+ return model.maxImagesPerCall;
300
+ }
301
+
302
+ return model.maxImagesPerCall({
303
+ modelId: model.modelId,
304
+ });
305
+ }
306
+
307
+ function normalizePrompt(
308
+ prompt: GenerateImagePrompt,
309
+ ): Pick<ImageModelV3CallOptions, 'prompt' | 'files' | 'mask'> {
310
+ if (typeof prompt === 'string') {
311
+ return { prompt, files: undefined, mask: undefined };
312
+ }
313
+
314
+ return {
315
+ prompt: prompt.text,
316
+ files: prompt.images.map(toImageModelV3File),
317
+ mask: prompt.mask ? toImageModelV3File(prompt.mask) : undefined,
318
+ };
319
+ }
320
+
321
+ function toImageModelV3File(dataContent: DataContent): ImageModelV3File {
322
+ if (typeof dataContent === 'string' && dataContent.startsWith('http')) {
323
+ return {
324
+ type: 'url',
325
+ url: dataContent,
326
+ };
327
+ }
328
+
329
+ // Handle data URLs
330
+ if (typeof dataContent === 'string' && dataContent.startsWith('data:')) {
331
+ const { mediaType: dataUrlMediaType, base64Content } =
332
+ splitDataUrl(dataContent);
333
+
334
+ if (base64Content != null) {
335
+ const uint8Data = convertBase64ToUint8Array(base64Content);
336
+ return {
337
+ type: 'file',
338
+ data: uint8Data,
339
+ mediaType:
340
+ dataUrlMediaType ||
341
+ detectMediaType({
342
+ data: uint8Data,
343
+ signatures: imageMediaTypeSignatures,
344
+ }) ||
345
+ 'image/png',
346
+ };
347
+ }
348
+ }
349
+
350
+ const uint8Data = convertDataContentToUint8Array(dataContent);
351
+ return {
352
+ type: 'file',
353
+ data: uint8Data,
354
+ mediaType:
355
+ detectMediaType({
356
+ data: uint8Data,
357
+ signatures: imageMediaTypeSignatures,
358
+ }) || 'image/png',
359
+ };
360
+ }
@@ -0,0 +1,18 @@
1
+ export { generateImage } from './generate-image';
2
+ export type { GenerateImageResult } from './generate-image-result';
3
+
4
+ // depreacted exports
5
+
6
+ import { generateImage } from './generate-image';
7
+ /**
8
+ * @deprecated Use `generateImage` instead.
9
+ */
10
+ const experimental_generateImage = generateImage;
11
+ export { experimental_generateImage };
12
+
13
+ import type { GenerateImageResult } from './generate-image-result';
14
+ /**
15
+ * @deprecated Use `GenerateImageResult` instead.
16
+ */
17
+ type Experimental_GenerateImageResult = GenerateImageResult;
18
+ export type { Experimental_GenerateImageResult };
@@ -0,0 +1,133 @@
1
+ // Vitest Snapshot v1, https://vitest.dev/guide/snapshot.html
2
+
3
+ exports[`generateObject > telemetry > should not record telemetry inputs / outputs when disabled 1`] = `
4
+ [
5
+ {
6
+ "attributes": {
7
+ "ai.model.id": "mock-model-id",
8
+ "ai.model.provider": "mock-provider",
9
+ "ai.operationId": "ai.generateObject",
10
+ "ai.request.headers.user-agent": "ai/0.0.0-test",
11
+ "ai.response.finishReason": "stop",
12
+ "ai.settings.maxRetries": 2,
13
+ "ai.settings.output": "object",
14
+ "ai.usage.completionTokens": 20,
15
+ "ai.usage.promptTokens": 10,
16
+ "operation.name": "ai.generateObject",
17
+ },
18
+ "events": [],
19
+ "name": "ai.generateObject",
20
+ },
21
+ {
22
+ "attributes": {
23
+ "ai.model.id": "mock-model-id",
24
+ "ai.model.provider": "mock-provider",
25
+ "ai.operationId": "ai.generateObject.doGenerate",
26
+ "ai.request.headers.user-agent": "ai/0.0.0-test",
27
+ "ai.response.finishReason": "stop",
28
+ "ai.response.id": "test-id-from-model",
29
+ "ai.response.model": "test-response-model-id",
30
+ "ai.response.timestamp": "1970-01-01T00:00:10.000Z",
31
+ "ai.settings.maxRetries": 2,
32
+ "ai.usage.completionTokens": 20,
33
+ "ai.usage.promptTokens": 10,
34
+ "gen_ai.request.model": "mock-model-id",
35
+ "gen_ai.response.finish_reasons": [
36
+ "stop",
37
+ ],
38
+ "gen_ai.response.id": "test-id-from-model",
39
+ "gen_ai.response.model": "test-response-model-id",
40
+ "gen_ai.system": "mock-provider",
41
+ "gen_ai.usage.input_tokens": 10,
42
+ "gen_ai.usage.output_tokens": 20,
43
+ "operation.name": "ai.generateObject.doGenerate",
44
+ },
45
+ "events": [],
46
+ "name": "ai.generateObject.doGenerate",
47
+ },
48
+ ]
49
+ `;
50
+
51
+ exports[`generateObject > telemetry > should record telemetry data when enabled 1`] = `
52
+ [
53
+ {
54
+ "attributes": {
55
+ "ai.model.id": "mock-model-id",
56
+ "ai.model.provider": "mock-provider",
57
+ "ai.operationId": "ai.generateObject",
58
+ "ai.prompt": "{"prompt":"prompt"}",
59
+ "ai.request.headers.header1": "value1",
60
+ "ai.request.headers.header2": "value2",
61
+ "ai.request.headers.user-agent": "ai/0.0.0-test",
62
+ "ai.response.finishReason": "stop",
63
+ "ai.response.object": "{"content":"Hello, world!"}",
64
+ "ai.response.providerMetadata": "{"testProvider":{"testKey":"testValue"}}",
65
+ "ai.schema": "{"$schema":"http://json-schema.org/draft-07/schema#","type":"object","properties":{"content":{"type":"string"}},"required":["content"],"additionalProperties":false}",
66
+ "ai.schema.description": "test description",
67
+ "ai.schema.name": "test-name",
68
+ "ai.settings.frequencyPenalty": 0.3,
69
+ "ai.settings.maxRetries": 2,
70
+ "ai.settings.output": "object",
71
+ "ai.settings.presencePenalty": 0.4,
72
+ "ai.settings.temperature": 0.5,
73
+ "ai.settings.topK": 0.1,
74
+ "ai.settings.topP": 0.2,
75
+ "ai.telemetry.functionId": "test-function-id",
76
+ "ai.telemetry.metadata.test1": "value1",
77
+ "ai.telemetry.metadata.test2": false,
78
+ "ai.usage.completionTokens": 20,
79
+ "ai.usage.promptTokens": 10,
80
+ "operation.name": "ai.generateObject test-function-id",
81
+ "resource.name": "test-function-id",
82
+ },
83
+ "events": [],
84
+ "name": "ai.generateObject",
85
+ },
86
+ {
87
+ "attributes": {
88
+ "ai.model.id": "mock-model-id",
89
+ "ai.model.provider": "mock-provider",
90
+ "ai.operationId": "ai.generateObject.doGenerate",
91
+ "ai.prompt.messages": "[{"role":"user","content":[{"type":"text","text":"prompt"}]}]",
92
+ "ai.request.headers.header1": "value1",
93
+ "ai.request.headers.header2": "value2",
94
+ "ai.request.headers.user-agent": "ai/0.0.0-test",
95
+ "ai.response.finishReason": "stop",
96
+ "ai.response.id": "test-id-from-model",
97
+ "ai.response.model": "test-response-model-id",
98
+ "ai.response.object": "{ "content": "Hello, world!" }",
99
+ "ai.response.providerMetadata": "{"testProvider":{"testKey":"testValue"}}",
100
+ "ai.response.timestamp": "1970-01-01T00:00:10.000Z",
101
+ "ai.settings.frequencyPenalty": 0.3,
102
+ "ai.settings.maxRetries": 2,
103
+ "ai.settings.presencePenalty": 0.4,
104
+ "ai.settings.temperature": 0.5,
105
+ "ai.settings.topK": 0.1,
106
+ "ai.settings.topP": 0.2,
107
+ "ai.telemetry.functionId": "test-function-id",
108
+ "ai.telemetry.metadata.test1": "value1",
109
+ "ai.telemetry.metadata.test2": false,
110
+ "ai.usage.completionTokens": 20,
111
+ "ai.usage.promptTokens": 10,
112
+ "gen_ai.request.frequency_penalty": 0.3,
113
+ "gen_ai.request.model": "mock-model-id",
114
+ "gen_ai.request.presence_penalty": 0.4,
115
+ "gen_ai.request.temperature": 0.5,
116
+ "gen_ai.request.top_k": 0.1,
117
+ "gen_ai.request.top_p": 0.2,
118
+ "gen_ai.response.finish_reasons": [
119
+ "stop",
120
+ ],
121
+ "gen_ai.response.id": "test-id-from-model",
122
+ "gen_ai.response.model": "test-response-model-id",
123
+ "gen_ai.system": "mock-provider",
124
+ "gen_ai.usage.input_tokens": 10,
125
+ "gen_ai.usage.output_tokens": 20,
126
+ "operation.name": "ai.generateObject.doGenerate test-function-id",
127
+ "resource.name": "test-function-id",
128
+ },
129
+ "events": [],
130
+ "name": "ai.generateObject.doGenerate",
131
+ },
132
+ ]
133
+ `;