@cloudflare/tanstack-ai 0.1.6 → 0.1.7

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 (176) hide show
  1. package/README.md +6 -6
  2. package/dist/adapters/anthropic.cjs +32 -11
  3. package/dist/adapters/anthropic.cjs.map +1 -1
  4. package/dist/adapters/anthropic.d.cts +23 -5
  5. package/dist/adapters/anthropic.d.mts +23 -0
  6. package/dist/adapters/anthropic.mjs +30 -0
  7. package/dist/adapters/anthropic.mjs.map +1 -0
  8. package/dist/adapters/gemini.cjs +83 -20
  9. package/dist/adapters/gemini.cjs.map +1 -1
  10. package/dist/adapters/gemini.d.cts +52 -14
  11. package/dist/adapters/gemini.d.mts +52 -0
  12. package/dist/adapters/gemini.mjs +76 -0
  13. package/dist/adapters/gemini.mjs.map +1 -0
  14. package/dist/adapters/grok.cjs +44 -15
  15. package/dist/adapters/grok.cjs.map +1 -1
  16. package/dist/adapters/grok.d.cts +26 -9
  17. package/dist/adapters/grok.d.mts +26 -0
  18. package/dist/adapters/grok.mjs +40 -0
  19. package/dist/adapters/grok.mjs.map +1 -0
  20. package/dist/adapters/openai.cjs +76 -27
  21. package/dist/adapters/openai.cjs.map +1 -1
  22. package/dist/adapters/openai.d.cts +45 -17
  23. package/dist/adapters/openai.d.mts +45 -0
  24. package/dist/adapters/openai.mjs +66 -0
  25. package/dist/adapters/openai.mjs.map +1 -0
  26. package/dist/adapters/openrouter.cjs +83 -11
  27. package/dist/adapters/openrouter.cjs.map +1 -1
  28. package/dist/adapters/openrouter.d.cts +39 -7
  29. package/dist/adapters/openrouter.d.mts +39 -0
  30. package/dist/adapters/openrouter.mjs +81 -0
  31. package/dist/adapters/openrouter.mjs.map +1 -0
  32. package/dist/adapters/workers-ai-image.cjs +97 -11
  33. package/dist/adapters/workers-ai-image.cjs.map +1 -1
  34. package/dist/adapters/workers-ai-image.d.cts +41 -3
  35. package/dist/adapters/workers-ai-image.d.mts +41 -0
  36. package/dist/adapters/workers-ai-image.mjs +96 -0
  37. package/dist/adapters/workers-ai-image.mjs.map +1 -0
  38. package/dist/adapters/workers-ai-summarize.cjs +86 -10
  39. package/dist/adapters/workers-ai-summarize.cjs.map +1 -1
  40. package/dist/adapters/workers-ai-summarize.d.cts +42 -3
  41. package/dist/adapters/workers-ai-summarize.d.mts +42 -0
  42. package/dist/adapters/workers-ai-summarize.mjs +85 -0
  43. package/dist/adapters/workers-ai-summarize.mjs.map +1 -0
  44. package/dist/adapters/workers-ai-transcription.cjs +200 -11
  45. package/dist/adapters/workers-ai-transcription.cjs.map +1 -1
  46. package/dist/adapters/workers-ai-transcription.d.cts +74 -3
  47. package/dist/adapters/workers-ai-transcription.d.mts +74 -0
  48. package/dist/adapters/workers-ai-transcription.mjs +199 -0
  49. package/dist/adapters/workers-ai-transcription.mjs.map +1 -0
  50. package/dist/adapters/workers-ai-tts.cjs +112 -11
  51. package/dist/adapters/workers-ai-tts.cjs.map +1 -1
  52. package/dist/adapters/workers-ai-tts.d.cts +54 -3
  53. package/dist/adapters/workers-ai-tts.d.mts +54 -0
  54. package/dist/adapters/workers-ai-tts.mjs +111 -0
  55. package/dist/adapters/workers-ai-tts.mjs.map +1 -0
  56. package/dist/adapters/workers-ai.cjs +4 -11
  57. package/dist/adapters/workers-ai.d.cts +18 -3
  58. package/dist/adapters/workers-ai.d.mts +18 -0
  59. package/dist/adapters/workers-ai.mjs +470 -0
  60. package/dist/adapters/workers-ai.mjs.map +1 -0
  61. package/dist/binary-C9FAYwZj.cjs +70 -0
  62. package/dist/binary-C9FAYwZj.cjs.map +1 -0
  63. package/dist/binary-p4H_N_3M.mjs +59 -0
  64. package/dist/binary-p4H_N_3M.mjs.map +1 -0
  65. package/dist/create-fetcher-5iL34e6H.cjs +310 -0
  66. package/dist/create-fetcher-5iL34e6H.cjs.map +1 -0
  67. package/dist/create-fetcher-6p6heb85.d.mts +93 -0
  68. package/dist/create-fetcher-DY7wfYYy.mjs +281 -0
  69. package/dist/create-fetcher-DY7wfYYy.mjs.map +1 -0
  70. package/dist/create-fetcher-vAQ8WW-p.d.cts +93 -0
  71. package/dist/defineProperty-CbyrzcbA.mjs +39 -0
  72. package/dist/defineProperty-DQoAg20E.cjs +44 -0
  73. package/dist/index.cjs +50 -97
  74. package/dist/index.d.cts +12 -64
  75. package/dist/index.d.mts +12 -0
  76. package/dist/index.mjs +11 -0
  77. package/dist/workers-ai-Bm7Up4or.cjs +510 -0
  78. package/dist/workers-ai-Bm7Up4or.cjs.map +1 -0
  79. package/dist/workers-ai-rest-CkNCtBwv.cjs +85 -0
  80. package/dist/workers-ai-rest-CkNCtBwv.cjs.map +1 -0
  81. package/dist/workers-ai-rest-GKy2r7eG.mjs +74 -0
  82. package/dist/workers-ai-rest-GKy2r7eG.mjs.map +1 -0
  83. package/package.json +73 -40
  84. package/dist/_tsup-dts-rollup.d.cts +0 -837
  85. package/dist/_tsup-dts-rollup.d.ts +0 -837
  86. package/dist/adapters/anthropic.d.ts +0 -5
  87. package/dist/adapters/anthropic.js +0 -13
  88. package/dist/adapters/anthropic.js.map +0 -1
  89. package/dist/adapters/gemini.d.ts +0 -14
  90. package/dist/adapters/gemini.js +0 -22
  91. package/dist/adapters/gemini.js.map +0 -1
  92. package/dist/adapters/grok.d.ts +0 -9
  93. package/dist/adapters/grok.js +0 -17
  94. package/dist/adapters/grok.js.map +0 -1
  95. package/dist/adapters/openai.d.ts +0 -17
  96. package/dist/adapters/openai.js +0 -29
  97. package/dist/adapters/openai.js.map +0 -1
  98. package/dist/adapters/openrouter.d.ts +0 -7
  99. package/dist/adapters/openrouter.js +0 -13
  100. package/dist/adapters/openrouter.js.map +0 -1
  101. package/dist/adapters/workers-ai-image.d.ts +0 -3
  102. package/dist/adapters/workers-ai-image.js +0 -13
  103. package/dist/adapters/workers-ai-image.js.map +0 -1
  104. package/dist/adapters/workers-ai-summarize.d.ts +0 -3
  105. package/dist/adapters/workers-ai-summarize.js +0 -12
  106. package/dist/adapters/workers-ai-summarize.js.map +0 -1
  107. package/dist/adapters/workers-ai-transcription.d.ts +0 -3
  108. package/dist/adapters/workers-ai-transcription.js +0 -13
  109. package/dist/adapters/workers-ai-transcription.js.map +0 -1
  110. package/dist/adapters/workers-ai-tts.d.ts +0 -3
  111. package/dist/adapters/workers-ai-tts.js +0 -13
  112. package/dist/adapters/workers-ai-tts.js.map +0 -1
  113. package/dist/adapters/workers-ai.cjs.map +0 -1
  114. package/dist/adapters/workers-ai.d.ts +0 -3
  115. package/dist/adapters/workers-ai.js +0 -11
  116. package/dist/adapters/workers-ai.js.map +0 -1
  117. package/dist/chunk-2VII5BK2.js +0 -42
  118. package/dist/chunk-2VII5BK2.js.map +0 -1
  119. package/dist/chunk-3VQDXJLW.cjs +0 -46
  120. package/dist/chunk-3VQDXJLW.cjs.map +0 -1
  121. package/dist/chunk-3WK5ZD57.js +0 -57
  122. package/dist/chunk-3WK5ZD57.js.map +0 -1
  123. package/dist/chunk-4DE2IREA.cjs +0 -8
  124. package/dist/chunk-4DE2IREA.cjs.map +0 -1
  125. package/dist/chunk-53A2QIXV.js +0 -98
  126. package/dist/chunk-53A2QIXV.js.map +0 -1
  127. package/dist/chunk-6MEX2ZSM.cjs +0 -48
  128. package/dist/chunk-6MEX2ZSM.cjs.map +0 -1
  129. package/dist/chunk-7HSUHP63.cjs +0 -42
  130. package/dist/chunk-7HSUHP63.cjs.map +0 -1
  131. package/dist/chunk-AIAJANLC.js +0 -327
  132. package/dist/chunk-AIAJANLC.js.map +0 -1
  133. package/dist/chunk-CB3PSZY2.cjs +0 -218
  134. package/dist/chunk-CB3PSZY2.cjs.map +0 -1
  135. package/dist/chunk-FQE2UKUU.cjs +0 -57
  136. package/dist/chunk-FQE2UKUU.cjs.map +0 -1
  137. package/dist/chunk-GL3HHR4M.js +0 -523
  138. package/dist/chunk-GL3HHR4M.js.map +0 -1
  139. package/dist/chunk-J5DSSZTO.js +0 -71
  140. package/dist/chunk-J5DSSZTO.js.map +0 -1
  141. package/dist/chunk-JRFPCMSE.js +0 -57
  142. package/dist/chunk-JRFPCMSE.js.map +0 -1
  143. package/dist/chunk-KWYOUT2Y.js +0 -111
  144. package/dist/chunk-KWYOUT2Y.js.map +0 -1
  145. package/dist/chunk-MJ45L566.cjs +0 -57
  146. package/dist/chunk-MJ45L566.cjs.map +0 -1
  147. package/dist/chunk-N6U27RQW.cjs +0 -111
  148. package/dist/chunk-N6U27RQW.cjs.map +0 -1
  149. package/dist/chunk-NH3FF5JC.js +0 -86
  150. package/dist/chunk-NH3FF5JC.js.map +0 -1
  151. package/dist/chunk-OFUYHQZE.cjs +0 -31
  152. package/dist/chunk-OFUYHQZE.cjs.map +0 -1
  153. package/dist/chunk-OUEAAP25.cjs +0 -523
  154. package/dist/chunk-OUEAAP25.cjs.map +0 -1
  155. package/dist/chunk-Q33U5I5S.js +0 -31
  156. package/dist/chunk-Q33U5I5S.js.map +0 -1
  157. package/dist/chunk-V4LKHWJA.cjs +0 -71
  158. package/dist/chunk-V4LKHWJA.cjs.map +0 -1
  159. package/dist/chunk-V6TY7KAL.js +0 -8
  160. package/dist/chunk-V6TY7KAL.js.map +0 -1
  161. package/dist/chunk-WBTQKWFN.cjs +0 -327
  162. package/dist/chunk-WBTQKWFN.cjs.map +0 -1
  163. package/dist/chunk-XU7YEPML.js +0 -46
  164. package/dist/chunk-XU7YEPML.js.map +0 -1
  165. package/dist/chunk-YCGNMVQZ.js +0 -218
  166. package/dist/chunk-YCGNMVQZ.js.map +0 -1
  167. package/dist/chunk-Z5ZC5ZOQ.js +0 -48
  168. package/dist/chunk-Z5ZC5ZOQ.js.map +0 -1
  169. package/dist/chunk-ZFB72L57.cjs +0 -86
  170. package/dist/chunk-ZFB72L57.cjs.map +0 -1
  171. package/dist/chunk-ZGLSJM26.cjs +0 -98
  172. package/dist/chunk-ZGLSJM26.cjs.map +0 -1
  173. package/dist/index.cjs.map +0 -1
  174. package/dist/index.d.ts +0 -64
  175. package/dist/index.js +0 -97
  176. package/dist/index.js.map +0 -1
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/adapters/gemini.ts"],"sourcesContent":["import {\n\tGeminiTextAdapter,\n\tGeminiImageAdapter,\n\tGeminiSummarizeAdapter,\n\tGeminiTTSAdapter,\n\tGeminiTextModels,\n\tGeminiImageModels,\n\tGeminiSummarizeModels,\n\tGeminiTTSModels,\n\ttype GeminiTextModel,\n\ttype GeminiImageModel,\n\ttype GeminiSummarizeModel,\n} from \"@tanstack/ai-gemini\";\n\n/** Derived from GeminiTTSModels since @tanstack/ai-gemini doesn't export a GeminiTTSModel type. */\nexport type GeminiTTSModel = (typeof GeminiTTSModels)[number];\nimport type { AnyTextAdapter } from \"@tanstack/ai\";\nimport type { AiGatewayCredentialsConfig, AiGatewayConfig } from \"../utils/create-fetcher\";\n\n/**\n * Gemini-specific gateway config (credentials only, no binding support).\n * Includes cache control options from AiGatewayConfig.\n * See {@link https://github.com/googleapis/js-genai/issues/999 | googleapis/js-genai#999}.\n */\nexport type GeminiGatewayConfig = AiGatewayCredentialsConfig & AiGatewayConfig;\n\n/**\n * Build Gemini client config that routes through AI Gateway.\n * Since GeminiClientConfig extends GoogleGenAIOptions, we can inject\n * httpOptions.baseUrl directly — no subclassing needed.\n *\n * The Google GenAI SDK doesn't support a custom `fetch` override,\n * so we set the baseUrl to the AI Gateway endpoint for Google AI Studio.\n *\n * Tracking issue: https://github.com/googleapis/js-genai/issues/999\n */\nfunction buildGeminiGatewayConfig(config: GeminiGatewayConfig) {\n\t// Runtime guard: catch binding configs that bypass TypeScript (JS callers, `as any`, etc.)\n\t// We integrate with the Gemini SDK via `httpOptions` (baseUrl + headers), which allows\n\t// gateway routing and cache control but not request interception. A binding config\n\t// requires a custom `fetch` to route through the AI Gateway binding, and the Google\n\t// GenAI SDK doesn't support that yet.\n\tif (\"binding\" in config) {\n\t\tthrow new Error(\n\t\t\t\"Gemini adapters do not support binding config. \" +\n\t\t\t\t\"The Google GenAI SDK does not support a custom fetch function — \" +\n\t\t\t\t\"only credential-based config ({ accountId, gatewayId }) is supported. \" +\n\t\t\t\t\"See https://github.com/googleapis/js-genai/issues/999\",\n\t\t);\n\t}\n\n\tconst headers: Record<string, string> = {};\n\n\tif (config.apiKey && config.cfApiKey) {\n\t\theaders[\"cf-aig-authorization\"] = `Bearer ${config.cfApiKey}`;\n\t}\n\n\tif (config.skipCache) {\n\t\theaders[\"cf-aig-skip-cache\"] = \"true\";\n\t}\n\tif (typeof config.cacheTtl === \"number\") {\n\t\theaders[\"cf-aig-cache-ttl\"] = String(config.cacheTtl);\n\t}\n\tif (typeof config.customCacheKey === \"string\") {\n\t\theaders[\"cf-aig-cache-key\"] = config.customCacheKey;\n\t}\n\tif (typeof config.metadata === \"object\") {\n\t\theaders[\"cf-aig-metadata\"] = JSON.stringify(config.metadata);\n\t}\n\n\tconst apiKey = config.apiKey ?? config.cfApiKey;\n\n\tif (!apiKey) {\n\t\tthrow new Error(\n\t\t\t\"If you want to use BYOK or unified billing, you need to pass the Cloudflare AI Gateway API key.\",\n\t\t);\n\t}\n\n\treturn {\n\t\tapiKey,\n\t\thttpOptions: {\n\t\t\tbaseUrl: `https://gateway.ai.cloudflare.com/v1/${config.accountId}/${config.gatewayId}/google-ai-studio`,\n\t\t\theaders: Object.keys(headers).length > 0 ? headers : undefined,\n\t\t},\n\t};\n}\n\n/** Alias for consistency with other providers (AnthropicChatModel, GrokChatModel, etc.) */\nexport type GeminiChatModel = GeminiTextModel;\n\n/**\n * Creates a Gemini adapter which uses Cloudflare AI Gateway.\n * Does not support the AI binding (Google GenAI SDK lacks custom fetch support).\n * See {@link https://github.com/googleapis/js-genai/issues/999 | googleapis/js-genai#999}.\n * @param model The Gemini model to use\n * @param config Configuration options (credentials only)\n */\nexport function createGeminiChat(\n\tmodel: GeminiChatModel,\n\tconfig: GeminiGatewayConfig,\n): AnyTextAdapter {\n\treturn new GeminiTextAdapter(buildGeminiGatewayConfig(config), model);\n}\n\n/**\n * Creates a Gemini Image adapter which uses Cloudflare AI Gateway.\n * Does not support the AI binding (Google GenAI SDK lacks custom fetch support).\n * See {@link https://github.com/googleapis/js-genai/issues/999 | googleapis/js-genai#999}.\n * @param model The Gemini model to use\n * @param config Configuration options (credentials only)\n */\nexport function createGeminiImage(model: GeminiImageModel, config: GeminiGatewayConfig) {\n\treturn new GeminiImageAdapter(buildGeminiGatewayConfig(config), model);\n}\n\n/**\n * Creates a Gemini Summarize adapter which uses Cloudflare AI Gateway.\n * Does not support the AI binding (Google GenAI SDK lacks custom fetch support).\n * See {@link https://github.com/googleapis/js-genai/issues/999 | googleapis/js-genai#999}.\n * @param model The Gemini model to use\n * @param config Configuration options (credentials only)\n */\nexport function createGeminiSummarize(model: GeminiSummarizeModel, config: GeminiGatewayConfig) {\n\treturn new GeminiSummarizeAdapter(buildGeminiGatewayConfig(config), model);\n}\n\n/**\n * Creates a Gemini TTS adapter which uses Cloudflare AI Gateway.\n * Does not support the AI binding (Google GenAI SDK lacks custom fetch support).\n * See {@link https://github.com/googleapis/js-genai/issues/999 | googleapis/js-genai#999}.\n *\n * @experimental Gemini TTS is an experimental feature and may change.\n * @param model The Gemini TTS model to use\n * @param config Configuration options (credentials only)\n */\nexport function createGeminiTts(model: GeminiTTSModel, config: GeminiGatewayConfig) {\n\treturn new GeminiTTSAdapter(buildGeminiGatewayConfig(config), model);\n}\n\nexport {\n\tGeminiTextModels,\n\tGeminiImageModels,\n\tGeminiSummarizeModels,\n\tGeminiTTSModels,\n\ttype GeminiTextModel,\n\ttype GeminiImageModel,\n\ttype GeminiSummarizeModel,\n};\n"],"mappings":";AAAA;AAAA,EACC;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,OAIM;AAwBP,SAAS,yBAAyB,QAA6B;AAM9D,MAAI,aAAa,QAAQ;AACxB,UAAM,IAAI;AAAA,MACT;AAAA,IAID;AAAA,EACD;AAEA,QAAM,UAAkC,CAAC;AAEzC,MAAI,OAAO,UAAU,OAAO,UAAU;AACrC,YAAQ,sBAAsB,IAAI,UAAU,OAAO,QAAQ;AAAA,EAC5D;AAEA,MAAI,OAAO,WAAW;AACrB,YAAQ,mBAAmB,IAAI;AAAA,EAChC;AACA,MAAI,OAAO,OAAO,aAAa,UAAU;AACxC,YAAQ,kBAAkB,IAAI,OAAO,OAAO,QAAQ;AAAA,EACrD;AACA,MAAI,OAAO,OAAO,mBAAmB,UAAU;AAC9C,YAAQ,kBAAkB,IAAI,OAAO;AAAA,EACtC;AACA,MAAI,OAAO,OAAO,aAAa,UAAU;AACxC,YAAQ,iBAAiB,IAAI,KAAK,UAAU,OAAO,QAAQ;AAAA,EAC5D;AAEA,QAAM,SAAS,OAAO,UAAU,OAAO;AAEvC,MAAI,CAAC,QAAQ;AACZ,UAAM,IAAI;AAAA,MACT;AAAA,IACD;AAAA,EACD;AAEA,SAAO;AAAA,IACN;AAAA,IACA,aAAa;AAAA,MACZ,SAAS,wCAAwC,OAAO,SAAS,IAAI,OAAO,SAAS;AAAA,MACrF,SAAS,OAAO,KAAK,OAAO,EAAE,SAAS,IAAI,UAAU;AAAA,IACtD;AAAA,EACD;AACD;AAYO,SAAS,iBACf,OACA,QACiB;AACjB,SAAO,IAAI,kBAAkB,yBAAyB,MAAM,GAAG,KAAK;AACrE;AASO,SAAS,kBAAkB,OAAyB,QAA6B;AACvF,SAAO,IAAI,mBAAmB,yBAAyB,MAAM,GAAG,KAAK;AACtE;AASO,SAAS,sBAAsB,OAA6B,QAA6B;AAC/F,SAAO,IAAI,uBAAuB,yBAAyB,MAAM,GAAG,KAAK;AAC1E;AAWO,SAAS,gBAAgB,OAAuB,QAA6B;AACnF,SAAO,IAAI,iBAAiB,yBAAyB,MAAM,GAAG,KAAK;AACpE;","names":[]}
@@ -1,57 +0,0 @@
1
- import {
2
- createGatewayFetch
3
- } from "./chunk-AIAJANLC.js";
4
-
5
- // src/adapters/openrouter.ts
6
- import {
7
- OpenRouterTextAdapter,
8
- OpenRouterImageAdapter,
9
- OpenRouterSummarizeAdapter
10
- } from "@tanstack/ai-openrouter";
11
- import { HTTPClient } from "@openrouter/sdk";
12
- function buildOpenRouterConfig(config) {
13
- const httpClient = new HTTPClient({
14
- fetcher: createGatewayFetch("openrouter", config)
15
- });
16
- return {
17
- apiKey: config.apiKey ?? "unused",
18
- // Cast needed: the installed @openrouter/sdk version may differ from the
19
- // version @tanstack/ai-openrouter was built against. The HTTPClient interface
20
- // is structurally compatible but TypeScript sees them as separate declarations.
21
- httpClient
22
- };
23
- }
24
- function buildOpenRouterImageConfig(config) {
25
- const httpClient = new HTTPClient({
26
- fetcher: createGatewayFetch("openrouter", config)
27
- });
28
- return {
29
- apiKey: config.apiKey ?? "unused",
30
- httpClient
31
- };
32
- }
33
- function buildOpenRouterSummarizeConfig(config) {
34
- const httpClient = new HTTPClient({
35
- fetcher: createGatewayFetch("openrouter", config)
36
- });
37
- return {
38
- apiKey: config.apiKey ?? "unused",
39
- httpClient
40
- };
41
- }
42
- function createOpenRouterChat(model, config) {
43
- return new OpenRouterTextAdapter(buildOpenRouterConfig(config), model);
44
- }
45
- function createOpenRouterImage(model, config) {
46
- return new OpenRouterImageAdapter(buildOpenRouterImageConfig(config), model);
47
- }
48
- function createOpenRouterSummarize(model, config) {
49
- return new OpenRouterSummarizeAdapter(buildOpenRouterSummarizeConfig(config), model);
50
- }
51
-
52
- export {
53
- createOpenRouterChat,
54
- createOpenRouterImage,
55
- createOpenRouterSummarize
56
- };
57
- //# sourceMappingURL=chunk-JRFPCMSE.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/adapters/openrouter.ts"],"sourcesContent":["import {\n\tOpenRouterTextAdapter,\n\tOpenRouterImageAdapter,\n\tOpenRouterSummarizeAdapter,\n\ttype OpenRouterConfig,\n\ttype OpenRouterImageConfig,\n\ttype OpenRouterSummarizeConfig,\n} from \"@tanstack/ai-openrouter\";\nimport { HTTPClient } from \"@openrouter/sdk\";\nimport { createGatewayFetch, type AiGatewayAdapterConfig } from \"../utils/create-fetcher\";\nimport type { AnyTextAdapter } from \"@tanstack/ai\";\n\nexport type OpenRouterGatewayConfig = AiGatewayAdapterConfig;\n\n/**\n * Build OpenRouter config that routes requests through AI Gateway.\n *\n * The OpenRouter SDK accepts an `httpClient` with a custom `fetcher`,\n * which we use to inject the AI Gateway fetch.\n */\nfunction buildOpenRouterConfig(config: OpenRouterGatewayConfig): OpenRouterConfig {\n\tconst httpClient = new HTTPClient({\n\t\tfetcher: createGatewayFetch(\"openrouter\", config),\n\t});\n\treturn {\n\t\tapiKey: config.apiKey ?? \"unused\",\n\t\t// Cast needed: the installed @openrouter/sdk version may differ from the\n\t\t// version @tanstack/ai-openrouter was built against. The HTTPClient interface\n\t\t// is structurally compatible but TypeScript sees them as separate declarations.\n\t\thttpClient: httpClient as unknown as OpenRouterConfig[\"httpClient\"],\n\t};\n}\n\n/**\n * Build OpenRouter image config that routes requests through AI Gateway.\n *\n * `OpenRouterImageConfig` extends `OpenRouterClientConfig` which declares\n * `baseURL` and `apiKey` but not `httpClient`. However, the image adapter\n * internally creates an `OpenRouter` SDK instance (which does accept\n * `httpClient` via `SDKOptions`). The double-cast is needed because the\n * declared config type is narrower than what the SDK constructor accepts.\n */\nfunction buildOpenRouterImageConfig(config: OpenRouterGatewayConfig): OpenRouterImageConfig {\n\tconst httpClient = new HTTPClient({\n\t\tfetcher: createGatewayFetch(\"openrouter\", config),\n\t});\n\treturn {\n\t\tapiKey: config.apiKey ?? \"unused\",\n\t\thttpClient,\n\t} as unknown as OpenRouterImageConfig;\n}\n\n/**\n * Build OpenRouter summarize config.\n *\n * `OpenRouterSummarizeConfig` extends `OpenRouterConfig` with optional\n * `temperature` and `maxTokens` fields. Since those are optional, a plain\n * `OpenRouterConfig` is structurally compatible — no cast needed.\n */\nfunction buildOpenRouterSummarizeConfig(\n\tconfig: OpenRouterGatewayConfig,\n): OpenRouterSummarizeConfig {\n\tconst httpClient = new HTTPClient({\n\t\tfetcher: createGatewayFetch(\"openrouter\", config),\n\t});\n\treturn {\n\t\tapiKey: config.apiKey ?? \"unused\",\n\t\thttpClient: httpClient as unknown as OpenRouterSummarizeConfig[\"httpClient\"],\n\t};\n}\n\n// ---------------------------------------------------------------------------\n// Chat model type — OpenRouter supports many models; we use a loose string type\n// ---------------------------------------------------------------------------\n\n/** OpenRouter chat model identifier. Accepts any string since OpenRouter proxies hundreds of models. */\nexport type OpenRouterChatModel = string;\n\n/** OpenRouter image model identifier. */\nexport type OpenRouterImageModel = string;\n\n/** OpenRouter summarize model identifier (same as chat models). */\nexport type OpenRouterSummarizeModel = string;\n\n// ---------------------------------------------------------------------------\n// Factory functions\n// ---------------------------------------------------------------------------\n\n/**\n * Creates an OpenRouter chat adapter which uses Cloudflare AI Gateway.\n * Supports both binding and credential-based configurations.\n *\n * @param model The model to use (e.g. \"openai/gpt-4o\", \"anthropic/claude-sonnet-4-5\")\n * @param config Configuration options\n */\nexport function createOpenRouterChat(\n\tmodel: OpenRouterChatModel,\n\tconfig: OpenRouterGatewayConfig,\n): AnyTextAdapter {\n\t// Cast needed: we accept any string model while upstream expects a literal union\n\treturn new OpenRouterTextAdapter(buildOpenRouterConfig(config), model as any);\n}\n\n/**\n * Creates an OpenRouter image adapter which uses Cloudflare AI Gateway.\n * Supports both binding and credential-based configurations.\n *\n * @param model The image model to use\n * @param config Configuration options\n */\nexport function createOpenRouterImage(\n\tmodel: OpenRouterImageModel,\n\tconfig: OpenRouterGatewayConfig,\n) {\n\t// Cast needed: we accept any string model while upstream expects a literal union\n\treturn new OpenRouterImageAdapter(buildOpenRouterImageConfig(config), model as any);\n}\n\n/**\n * Creates an OpenRouter summarize adapter which uses Cloudflare AI Gateway.\n * Supports both binding and credential-based configurations.\n *\n * @param model The model to use for summarization\n * @param config Configuration options\n */\nexport function createOpenRouterSummarize(\n\tmodel: OpenRouterSummarizeModel,\n\tconfig: OpenRouterGatewayConfig,\n) {\n\t// Cast needed: we accept any string model while upstream expects a literal union\n\treturn new OpenRouterSummarizeAdapter(buildOpenRouterSummarizeConfig(config), model as any);\n}\n"],"mappings":";;;;;AAAA;AAAA,EACC;AAAA,EACA;AAAA,EACA;AAAA,OAIM;AACP,SAAS,kBAAkB;AAY3B,SAAS,sBAAsB,QAAmD;AACjF,QAAM,aAAa,IAAI,WAAW;AAAA,IACjC,SAAS,mBAAmB,cAAc,MAAM;AAAA,EACjD,CAAC;AACD,SAAO;AAAA,IACN,QAAQ,OAAO,UAAU;AAAA;AAAA;AAAA;AAAA,IAIzB;AAAA,EACD;AACD;AAWA,SAAS,2BAA2B,QAAwD;AAC3F,QAAM,aAAa,IAAI,WAAW;AAAA,IACjC,SAAS,mBAAmB,cAAc,MAAM;AAAA,EACjD,CAAC;AACD,SAAO;AAAA,IACN,QAAQ,OAAO,UAAU;AAAA,IACzB;AAAA,EACD;AACD;AASA,SAAS,+BACR,QAC4B;AAC5B,QAAM,aAAa,IAAI,WAAW;AAAA,IACjC,SAAS,mBAAmB,cAAc,MAAM;AAAA,EACjD,CAAC;AACD,SAAO;AAAA,IACN,QAAQ,OAAO,UAAU;AAAA,IACzB;AAAA,EACD;AACD;AA0BO,SAAS,qBACf,OACA,QACiB;AAEjB,SAAO,IAAI,sBAAsB,sBAAsB,MAAM,GAAG,KAAY;AAC7E;AASO,SAAS,sBACf,OACA,QACC;AAED,SAAO,IAAI,uBAAuB,2BAA2B,MAAM,GAAG,KAAY;AACnF;AASO,SAAS,0BACf,OACA,QACC;AAED,SAAO,IAAI,2BAA2B,+BAA+B,MAAM,GAAG,KAAY;AAC3F;","names":[]}
@@ -1,111 +0,0 @@
1
- import {
2
- binaryToBase64,
3
- uint8ArrayToBase64
4
- } from "./chunk-XU7YEPML.js";
5
- import {
6
- workersAiRestFetch
7
- } from "./chunk-2VII5BK2.js";
8
- import {
9
- createGatewayFetch,
10
- isDirectBindingConfig,
11
- isDirectCredentialsConfig,
12
- validateWorkersAiConfig
13
- } from "./chunk-AIAJANLC.js";
14
- import {
15
- __publicField
16
- } from "./chunk-V6TY7KAL.js";
17
-
18
- // src/adapters/workers-ai-tts.ts
19
- import { BaseTTSAdapter } from "@tanstack/ai/adapters";
20
- var WorkersAiTTSAdapter = class extends BaseTTSAdapter {
21
- constructor(config, model) {
22
- super({}, model);
23
- __publicField(this, "name", "workers-ai-tts");
24
- __publicField(this, "adapterConfig");
25
- validateWorkersAiConfig(config);
26
- this.adapterConfig = config;
27
- }
28
- async generateSpeech(options) {
29
- const { text, voice, format, speed, modelOptions } = options;
30
- const extra = { ...modelOptions };
31
- if (voice) extra.voice = voice;
32
- if (speed != null) extra.speed = speed;
33
- if (isDirectBindingConfig(this.adapterConfig)) {
34
- return this.generateViaBinding(text, format, extra);
35
- }
36
- if (isDirectCredentialsConfig(this.adapterConfig)) {
37
- return this.generateViaRest(text, format, extra);
38
- }
39
- return this.generateViaGateway(text, format, extra);
40
- }
41
- async generateViaBinding(text, format, options) {
42
- const ai = this.adapterConfig.binding;
43
- const result = await ai.run(this.model, { text, ...options });
44
- return this.normalizeResult(result, format);
45
- }
46
- async generateViaRest(text, format, options) {
47
- const config = this.adapterConfig;
48
- const response = await workersAiRestFetch(
49
- config,
50
- this.model,
51
- { text, ...options },
52
- { label: "Workers AI TTS", signal: options.signal }
53
- );
54
- const buffer = await response.arrayBuffer();
55
- return this.wrapAudioResult(new Uint8Array(buffer), format);
56
- }
57
- async generateViaGateway(text, format, options) {
58
- const gatewayConfig = this.adapterConfig;
59
- const gatewayFetch = createGatewayFetch("workers-ai", gatewayConfig);
60
- const response = await gatewayFetch("https://api.cloudflare.com/v1/audio/speech", {
61
- method: "POST",
62
- body: JSON.stringify({
63
- model: this.model,
64
- text,
65
- ...options
66
- })
67
- });
68
- if (!response.ok) {
69
- const errorText = await response.text();
70
- throw new Error(
71
- `Workers AI TTS gateway request failed (${response.status}): ${errorText}`
72
- );
73
- }
74
- const buffer = await response.arrayBuffer();
75
- return this.wrapAudioResult(new Uint8Array(buffer), format);
76
- }
77
- /**
78
- * Normalize binding results. Workers AI TTS can return:
79
- * - Uint8Array / ArrayBuffer (raw audio bytes)
80
- * - ReadableStream<Uint8Array> (streamed audio bytes)
81
- * - { audio: "base64..." } (JSON wrapper)
82
- */
83
- async normalizeResult(result, format) {
84
- const b64 = await binaryToBase64(result, "audio");
85
- return {
86
- id: this.generateId(),
87
- model: this.model,
88
- audio: b64,
89
- format: format ?? "mp3",
90
- contentType: `audio/${format ?? "mp3"}`
91
- };
92
- }
93
- wrapAudioResult(bytes, format) {
94
- return {
95
- id: this.generateId(),
96
- model: this.model,
97
- audio: uint8ArrayToBase64(bytes),
98
- format: format ?? "mp3",
99
- contentType: `audio/${format ?? "mp3"}`
100
- };
101
- }
102
- };
103
- function createWorkersAiTts(model, config) {
104
- return new WorkersAiTTSAdapter(config, model);
105
- }
106
-
107
- export {
108
- WorkersAiTTSAdapter,
109
- createWorkersAiTts
110
- };
111
- //# sourceMappingURL=chunk-KWYOUT2Y.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/adapters/workers-ai-tts.ts"],"sourcesContent":["import { BaseTTSAdapter } from \"@tanstack/ai/adapters\";\nimport type { TTSOptions, TTSResult } from \"@tanstack/ai\";\nimport {\n\ttype WorkersAiAdapterConfig,\n\ttype WorkersAiDirectBindingConfig,\n\ttype WorkersAiDirectCredentialsConfig,\n\ttype AiGatewayAdapterConfig,\n\tcreateGatewayFetch,\n\tisDirectBindingConfig,\n\tisDirectCredentialsConfig,\n\tvalidateWorkersAiConfig,\n} from \"../utils/create-fetcher\";\nimport { workersAiRestFetch } from \"../utils/workers-ai-rest\";\nimport { binaryToBase64, uint8ArrayToBase64 } from \"../utils/binary\";\n\n// ---------------------------------------------------------------------------\n// Model types\n// ---------------------------------------------------------------------------\n\n/**\n * Workers AI models that support text-to-speech generation.\n *\n * Note: the typed `AiModels` interface in `@cloudflare/workers-types` may lag\n * behind what's deployed. We use a string union here that matches the known\n * models including Deepgram partner models.\n */\nexport type WorkersAiTTSModel =\n\t| \"@cf/deepgram/aura-1\"\n\t| \"@cf/deepgram/aura-2-en\"\n\t| \"@cf/deepgram/aura-2-es\"\n\t| (string & {});\n\n// ---------------------------------------------------------------------------\n// WorkersAiTTSAdapter\n// ---------------------------------------------------------------------------\n\nexport class WorkersAiTTSAdapter extends BaseTTSAdapter<WorkersAiTTSModel> {\n\treadonly name = \"workers-ai-tts\" as const;\n\tprivate adapterConfig: WorkersAiAdapterConfig;\n\n\tconstructor(config: WorkersAiAdapterConfig, model: WorkersAiTTSModel) {\n\t\tsuper({}, model);\n\t\tvalidateWorkersAiConfig(config);\n\t\tthis.adapterConfig = config;\n\t}\n\n\tasync generateSpeech(options: TTSOptions): Promise<TTSResult> {\n\t\tconst { text, voice, format, speed, modelOptions } = options;\n\n\t\t// Workers AI TTS models (Deepgram aura-1) accept { text, lang? }\n\t\tconst extra: Record<string, unknown> = { ...modelOptions };\n\t\tif (voice) extra.voice = voice;\n\t\tif (speed != null) extra.speed = speed;\n\n\t\tif (isDirectBindingConfig(this.adapterConfig)) {\n\t\t\treturn this.generateViaBinding(text, format, extra);\n\t\t}\n\n\t\tif (isDirectCredentialsConfig(this.adapterConfig)) {\n\t\t\treturn this.generateViaRest(text, format, extra);\n\t\t}\n\n\t\treturn this.generateViaGateway(text, format, extra);\n\t}\n\n\tprivate async generateViaBinding(\n\t\ttext: string,\n\t\tformat: string | undefined,\n\t\toptions: Record<string, unknown>,\n\t): Promise<TTSResult> {\n\t\tconst ai = (this.adapterConfig as WorkersAiDirectBindingConfig).binding;\n\t\tconst result = await ai.run(this.model, { text, ...options });\n\n\t\treturn this.normalizeResult(result, format);\n\t}\n\n\tprivate async generateViaRest(\n\t\ttext: string,\n\t\tformat: string | undefined,\n\t\toptions: Record<string, unknown>,\n\t): Promise<TTSResult> {\n\t\tconst config = this.adapterConfig as WorkersAiDirectCredentialsConfig;\n\t\tconst response = await workersAiRestFetch(\n\t\t\tconfig,\n\t\t\tthis.model,\n\t\t\t{ text, ...options },\n\t\t\t{ label: \"Workers AI TTS\", signal: (options as { signal?: AbortSignal }).signal },\n\t\t);\n\n\t\t// Workers AI TTS returns audio bytes directly\n\t\tconst buffer = await response.arrayBuffer();\n\t\treturn this.wrapAudioResult(new Uint8Array(buffer), format);\n\t}\n\n\tprivate async generateViaGateway(\n\t\ttext: string,\n\t\tformat: string | undefined,\n\t\toptions: Record<string, unknown>,\n\t): Promise<TTSResult> {\n\t\tconst gatewayConfig = this.adapterConfig as AiGatewayAdapterConfig;\n\t\tconst gatewayFetch = createGatewayFetch(\"workers-ai\", gatewayConfig);\n\n\t\t// The URL here is a placeholder — createGatewayFetch for \"workers-ai\" extracts\n\t\t// the model from the body, sets it as the endpoint, and routes through the gateway.\n\t\t// The actual URL path is not used.\n\t\tconst response = await gatewayFetch(\"https://api.cloudflare.com/v1/audio/speech\", {\n\t\t\tmethod: \"POST\",\n\t\t\tbody: JSON.stringify({\n\t\t\t\tmodel: this.model,\n\t\t\t\ttext,\n\t\t\t\t...options,\n\t\t\t}),\n\t\t});\n\n\t\tif (!response.ok) {\n\t\t\tconst errorText = await response.text();\n\t\t\tthrow new Error(\n\t\t\t\t`Workers AI TTS gateway request failed (${response.status}): ${errorText}`,\n\t\t\t);\n\t\t}\n\n\t\tconst buffer = await response.arrayBuffer();\n\t\treturn this.wrapAudioResult(new Uint8Array(buffer), format);\n\t}\n\n\t/**\n\t * Normalize binding results. Workers AI TTS can return:\n\t * - Uint8Array / ArrayBuffer (raw audio bytes)\n\t * - ReadableStream<Uint8Array> (streamed audio bytes)\n\t * - { audio: \"base64...\" } (JSON wrapper)\n\t */\n\tprivate async normalizeResult(result: unknown, format: string | undefined): Promise<TTSResult> {\n\t\t// Use the shared binaryToBase64 helper for Uint8Array/ArrayBuffer/ReadableStream\n\t\t// and { audio: \"base64...\" } JSON wrapper\n\t\tconst b64 = await binaryToBase64(result, \"audio\");\n\t\treturn {\n\t\t\tid: this.generateId(),\n\t\t\tmodel: this.model,\n\t\t\taudio: b64,\n\t\t\tformat: format ?? \"mp3\",\n\t\t\tcontentType: `audio/${format ?? \"mp3\"}`,\n\t\t};\n\t}\n\n\tprivate wrapAudioResult(bytes: Uint8Array, format: string | undefined): TTSResult {\n\t\treturn {\n\t\t\tid: this.generateId(),\n\t\t\tmodel: this.model,\n\t\t\taudio: uint8ArrayToBase64(bytes),\n\t\t\tformat: format ?? \"mp3\",\n\t\t\tcontentType: `audio/${format ?? \"mp3\"}`,\n\t\t};\n\t}\n}\n\n// ---------------------------------------------------------------------------\n// Factory function\n// ---------------------------------------------------------------------------\n\n/**\n * Creates a Workers AI text-to-speech adapter.\n *\n * Works with TanStack AI's `generateSpeech()` activity function:\n * ```ts\n * import { generateSpeech } from \"@tanstack/ai\";\n * import { createWorkersAiTts } from \"@cloudflare/tanstack-ai\";\n *\n * const adapter = createWorkersAiTts(\n * \"@cf/deepgram/aura-1\",\n * { binding: env.AI },\n * );\n *\n * const result = await generateSpeech({ adapter, text: \"Hello world\" });\n * // result.audio — base64-encoded audio\n * ```\n *\n * Note: Factory takes `(model, config)` for ergonomics — the class constructor\n * uses `(config, model)` to match TanStack AI's upstream convention.\n */\nexport function createWorkersAiTts(model: WorkersAiTTSModel, config: WorkersAiAdapterConfig) {\n\treturn new WorkersAiTTSAdapter(config, model);\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;AAAA,SAAS,sBAAsB;AAoCxB,IAAM,sBAAN,cAAkC,eAAkC;AAAA,EAI1E,YAAY,QAAgC,OAA0B;AACrE,UAAM,CAAC,GAAG,KAAK;AAJhB,wBAAS,QAAO;AAChB,wBAAQ;AAIP,4BAAwB,MAAM;AAC9B,SAAK,gBAAgB;AAAA,EACtB;AAAA,EAEA,MAAM,eAAe,SAAyC;AAC7D,UAAM,EAAE,MAAM,OAAO,QAAQ,OAAO,aAAa,IAAI;AAGrD,UAAM,QAAiC,EAAE,GAAG,aAAa;AACzD,QAAI,MAAO,OAAM,QAAQ;AACzB,QAAI,SAAS,KAAM,OAAM,QAAQ;AAEjC,QAAI,sBAAsB,KAAK,aAAa,GAAG;AAC9C,aAAO,KAAK,mBAAmB,MAAM,QAAQ,KAAK;AAAA,IACnD;AAEA,QAAI,0BAA0B,KAAK,aAAa,GAAG;AAClD,aAAO,KAAK,gBAAgB,MAAM,QAAQ,KAAK;AAAA,IAChD;AAEA,WAAO,KAAK,mBAAmB,MAAM,QAAQ,KAAK;AAAA,EACnD;AAAA,EAEA,MAAc,mBACb,MACA,QACA,SACqB;AACrB,UAAM,KAAM,KAAK,cAA+C;AAChE,UAAM,SAAS,MAAM,GAAG,IAAI,KAAK,OAAO,EAAE,MAAM,GAAG,QAAQ,CAAC;AAE5D,WAAO,KAAK,gBAAgB,QAAQ,MAAM;AAAA,EAC3C;AAAA,EAEA,MAAc,gBACb,MACA,QACA,SACqB;AACrB,UAAM,SAAS,KAAK;AACpB,UAAM,WAAW,MAAM;AAAA,MACtB;AAAA,MACA,KAAK;AAAA,MACL,EAAE,MAAM,GAAG,QAAQ;AAAA,MACnB,EAAE,OAAO,kBAAkB,QAAS,QAAqC,OAAO;AAAA,IACjF;AAGA,UAAM,SAAS,MAAM,SAAS,YAAY;AAC1C,WAAO,KAAK,gBAAgB,IAAI,WAAW,MAAM,GAAG,MAAM;AAAA,EAC3D;AAAA,EAEA,MAAc,mBACb,MACA,QACA,SACqB;AACrB,UAAM,gBAAgB,KAAK;AAC3B,UAAM,eAAe,mBAAmB,cAAc,aAAa;AAKnE,UAAM,WAAW,MAAM,aAAa,8CAA8C;AAAA,MACjF,QAAQ;AAAA,MACR,MAAM,KAAK,UAAU;AAAA,QACpB,OAAO,KAAK;AAAA,QACZ;AAAA,QACA,GAAG;AAAA,MACJ,CAAC;AAAA,IACF,CAAC;AAED,QAAI,CAAC,SAAS,IAAI;AACjB,YAAM,YAAY,MAAM,SAAS,KAAK;AACtC,YAAM,IAAI;AAAA,QACT,0CAA0C,SAAS,MAAM,MAAM,SAAS;AAAA,MACzE;AAAA,IACD;AAEA,UAAM,SAAS,MAAM,SAAS,YAAY;AAC1C,WAAO,KAAK,gBAAgB,IAAI,WAAW,MAAM,GAAG,MAAM;AAAA,EAC3D;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQA,MAAc,gBAAgB,QAAiB,QAAgD;AAG9F,UAAM,MAAM,MAAM,eAAe,QAAQ,OAAO;AAChD,WAAO;AAAA,MACN,IAAI,KAAK,WAAW;AAAA,MACpB,OAAO,KAAK;AAAA,MACZ,OAAO;AAAA,MACP,QAAQ,UAAU;AAAA,MAClB,aAAa,SAAS,UAAU,KAAK;AAAA,IACtC;AAAA,EACD;AAAA,EAEQ,gBAAgB,OAAmB,QAAuC;AACjF,WAAO;AAAA,MACN,IAAI,KAAK,WAAW;AAAA,MACpB,OAAO,KAAK;AAAA,MACZ,OAAO,mBAAmB,KAAK;AAAA,MAC/B,QAAQ,UAAU;AAAA,MAClB,aAAa,SAAS,UAAU,KAAK;AAAA,IACtC;AAAA,EACD;AACD;AA0BO,SAAS,mBAAmB,OAA0B,QAAgC;AAC5F,SAAO,IAAI,oBAAoB,QAAQ,KAAK;AAC7C;","names":[]}
@@ -1,57 +0,0 @@
1
- "use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _nullishCoalesce(lhs, rhsFn) { if (lhs != null) { return lhs; } else { return rhsFn(); } }
2
-
3
- var _chunkWBTQKWFNcjs = require('./chunk-WBTQKWFN.cjs');
4
-
5
- // src/adapters/openrouter.ts
6
-
7
-
8
-
9
-
10
- var _aiopenrouter = require('@tanstack/ai-openrouter');
11
- var _sdk = require('@openrouter/sdk');
12
- function buildOpenRouterConfig(config) {
13
- const httpClient = new (0, _sdk.HTTPClient)({
14
- fetcher: _chunkWBTQKWFNcjs.createGatewayFetch.call(void 0, "openrouter", config)
15
- });
16
- return {
17
- apiKey: _nullishCoalesce(config.apiKey, () => ( "unused")),
18
- // Cast needed: the installed @openrouter/sdk version may differ from the
19
- // version @tanstack/ai-openrouter was built against. The HTTPClient interface
20
- // is structurally compatible but TypeScript sees them as separate declarations.
21
- httpClient
22
- };
23
- }
24
- function buildOpenRouterImageConfig(config) {
25
- const httpClient = new (0, _sdk.HTTPClient)({
26
- fetcher: _chunkWBTQKWFNcjs.createGatewayFetch.call(void 0, "openrouter", config)
27
- });
28
- return {
29
- apiKey: _nullishCoalesce(config.apiKey, () => ( "unused")),
30
- httpClient
31
- };
32
- }
33
- function buildOpenRouterSummarizeConfig(config) {
34
- const httpClient = new (0, _sdk.HTTPClient)({
35
- fetcher: _chunkWBTQKWFNcjs.createGatewayFetch.call(void 0, "openrouter", config)
36
- });
37
- return {
38
- apiKey: _nullishCoalesce(config.apiKey, () => ( "unused")),
39
- httpClient
40
- };
41
- }
42
- function createOpenRouterChat(model, config) {
43
- return new (0, _aiopenrouter.OpenRouterTextAdapter)(buildOpenRouterConfig(config), model);
44
- }
45
- function createOpenRouterImage(model, config) {
46
- return new (0, _aiopenrouter.OpenRouterImageAdapter)(buildOpenRouterImageConfig(config), model);
47
- }
48
- function createOpenRouterSummarize(model, config) {
49
- return new (0, _aiopenrouter.OpenRouterSummarizeAdapter)(buildOpenRouterSummarizeConfig(config), model);
50
- }
51
-
52
-
53
-
54
-
55
-
56
- exports.createOpenRouterChat = createOpenRouterChat; exports.createOpenRouterImage = createOpenRouterImage; exports.createOpenRouterSummarize = createOpenRouterSummarize;
57
- //# sourceMappingURL=chunk-MJ45L566.cjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["/home/runner/work/ai/ai/packages/tanstack-ai/dist/chunk-MJ45L566.cjs","../src/adapters/openrouter.ts"],"names":[],"mappings":"AAAA;AACE;AACF,wDAA6B;AAC7B;AACA;ACJA;AACC;AACA;AACA;AAAA,uDAIM;AACP,sCAA2B;AAY3B,SAAS,qBAAA,CAAsB,MAAA,EAAmD;AACjF,EAAA,MAAM,WAAA,EAAa,IAAI,oBAAA,CAAW;AAAA,IACjC,OAAA,EAAS,kDAAA,YAAmB,EAAc,MAAM;AAAA,EACjD,CAAC,CAAA;AACD,EAAA,OAAO;AAAA,IACN,MAAA,mBAAQ,MAAA,CAAO,MAAA,UAAU,UAAA;AAAA;AAAA;AAAA;AAAA,IAIzB;AAAA,EACD,CAAA;AACD;AAWA,SAAS,0BAAA,CAA2B,MAAA,EAAwD;AAC3F,EAAA,MAAM,WAAA,EAAa,IAAI,oBAAA,CAAW;AAAA,IACjC,OAAA,EAAS,kDAAA,YAAmB,EAAc,MAAM;AAAA,EACjD,CAAC,CAAA;AACD,EAAA,OAAO;AAAA,IACN,MAAA,mBAAQ,MAAA,CAAO,MAAA,UAAU,UAAA;AAAA,IACzB;AAAA,EACD,CAAA;AACD;AASA,SAAS,8BAAA,CACR,MAAA,EAC4B;AAC5B,EAAA,MAAM,WAAA,EAAa,IAAI,oBAAA,CAAW;AAAA,IACjC,OAAA,EAAS,kDAAA,YAAmB,EAAc,MAAM;AAAA,EACjD,CAAC,CAAA;AACD,EAAA,OAAO;AAAA,IACN,MAAA,mBAAQ,MAAA,CAAO,MAAA,UAAU,UAAA;AAAA,IACzB;AAAA,EACD,CAAA;AACD;AA0BO,SAAS,oBAAA,CACf,KAAA,EACA,MAAA,EACiB;AAEjB,EAAA,OAAO,IAAI,wCAAA,CAAsB,qBAAA,CAAsB,MAAM,CAAA,EAAG,KAAY,CAAA;AAC7E;AASO,SAAS,qBAAA,CACf,KAAA,EACA,MAAA,EACC;AAED,EAAA,OAAO,IAAI,yCAAA,CAAuB,0BAAA,CAA2B,MAAM,CAAA,EAAG,KAAY,CAAA;AACnF;AASO,SAAS,yBAAA,CACf,KAAA,EACA,MAAA,EACC;AAED,EAAA,OAAO,IAAI,6CAAA,CAA2B,8BAAA,CAA+B,MAAM,CAAA,EAAG,KAAY,CAAA;AAC3F;ADjFA;AACA;AACE;AACA;AACA;AACF,0KAAC","file":"/home/runner/work/ai/ai/packages/tanstack-ai/dist/chunk-MJ45L566.cjs","sourcesContent":[null,"import {\n\tOpenRouterTextAdapter,\n\tOpenRouterImageAdapter,\n\tOpenRouterSummarizeAdapter,\n\ttype OpenRouterConfig,\n\ttype OpenRouterImageConfig,\n\ttype OpenRouterSummarizeConfig,\n} from \"@tanstack/ai-openrouter\";\nimport { HTTPClient } from \"@openrouter/sdk\";\nimport { createGatewayFetch, type AiGatewayAdapterConfig } from \"../utils/create-fetcher\";\nimport type { AnyTextAdapter } from \"@tanstack/ai\";\n\nexport type OpenRouterGatewayConfig = AiGatewayAdapterConfig;\n\n/**\n * Build OpenRouter config that routes requests through AI Gateway.\n *\n * The OpenRouter SDK accepts an `httpClient` with a custom `fetcher`,\n * which we use to inject the AI Gateway fetch.\n */\nfunction buildOpenRouterConfig(config: OpenRouterGatewayConfig): OpenRouterConfig {\n\tconst httpClient = new HTTPClient({\n\t\tfetcher: createGatewayFetch(\"openrouter\", config),\n\t});\n\treturn {\n\t\tapiKey: config.apiKey ?? \"unused\",\n\t\t// Cast needed: the installed @openrouter/sdk version may differ from the\n\t\t// version @tanstack/ai-openrouter was built against. The HTTPClient interface\n\t\t// is structurally compatible but TypeScript sees them as separate declarations.\n\t\thttpClient: httpClient as unknown as OpenRouterConfig[\"httpClient\"],\n\t};\n}\n\n/**\n * Build OpenRouter image config that routes requests through AI Gateway.\n *\n * `OpenRouterImageConfig` extends `OpenRouterClientConfig` which declares\n * `baseURL` and `apiKey` but not `httpClient`. However, the image adapter\n * internally creates an `OpenRouter` SDK instance (which does accept\n * `httpClient` via `SDKOptions`). The double-cast is needed because the\n * declared config type is narrower than what the SDK constructor accepts.\n */\nfunction buildOpenRouterImageConfig(config: OpenRouterGatewayConfig): OpenRouterImageConfig {\n\tconst httpClient = new HTTPClient({\n\t\tfetcher: createGatewayFetch(\"openrouter\", config),\n\t});\n\treturn {\n\t\tapiKey: config.apiKey ?? \"unused\",\n\t\thttpClient,\n\t} as unknown as OpenRouterImageConfig;\n}\n\n/**\n * Build OpenRouter summarize config.\n *\n * `OpenRouterSummarizeConfig` extends `OpenRouterConfig` with optional\n * `temperature` and `maxTokens` fields. Since those are optional, a plain\n * `OpenRouterConfig` is structurally compatible — no cast needed.\n */\nfunction buildOpenRouterSummarizeConfig(\n\tconfig: OpenRouterGatewayConfig,\n): OpenRouterSummarizeConfig {\n\tconst httpClient = new HTTPClient({\n\t\tfetcher: createGatewayFetch(\"openrouter\", config),\n\t});\n\treturn {\n\t\tapiKey: config.apiKey ?? \"unused\",\n\t\thttpClient: httpClient as unknown as OpenRouterSummarizeConfig[\"httpClient\"],\n\t};\n}\n\n// ---------------------------------------------------------------------------\n// Chat model type — OpenRouter supports many models; we use a loose string type\n// ---------------------------------------------------------------------------\n\n/** OpenRouter chat model identifier. Accepts any string since OpenRouter proxies hundreds of models. */\nexport type OpenRouterChatModel = string;\n\n/** OpenRouter image model identifier. */\nexport type OpenRouterImageModel = string;\n\n/** OpenRouter summarize model identifier (same as chat models). */\nexport type OpenRouterSummarizeModel = string;\n\n// ---------------------------------------------------------------------------\n// Factory functions\n// ---------------------------------------------------------------------------\n\n/**\n * Creates an OpenRouter chat adapter which uses Cloudflare AI Gateway.\n * Supports both binding and credential-based configurations.\n *\n * @param model The model to use (e.g. \"openai/gpt-4o\", \"anthropic/claude-sonnet-4-5\")\n * @param config Configuration options\n */\nexport function createOpenRouterChat(\n\tmodel: OpenRouterChatModel,\n\tconfig: OpenRouterGatewayConfig,\n): AnyTextAdapter {\n\t// Cast needed: we accept any string model while upstream expects a literal union\n\treturn new OpenRouterTextAdapter(buildOpenRouterConfig(config), model as any);\n}\n\n/**\n * Creates an OpenRouter image adapter which uses Cloudflare AI Gateway.\n * Supports both binding and credential-based configurations.\n *\n * @param model The image model to use\n * @param config Configuration options\n */\nexport function createOpenRouterImage(\n\tmodel: OpenRouterImageModel,\n\tconfig: OpenRouterGatewayConfig,\n) {\n\t// Cast needed: we accept any string model while upstream expects a literal union\n\treturn new OpenRouterImageAdapter(buildOpenRouterImageConfig(config), model as any);\n}\n\n/**\n * Creates an OpenRouter summarize adapter which uses Cloudflare AI Gateway.\n * Supports both binding and credential-based configurations.\n *\n * @param model The model to use for summarization\n * @param config Configuration options\n */\nexport function createOpenRouterSummarize(\n\tmodel: OpenRouterSummarizeModel,\n\tconfig: OpenRouterGatewayConfig,\n) {\n\t// Cast needed: we accept any string model while upstream expects a literal union\n\treturn new OpenRouterSummarizeAdapter(buildOpenRouterSummarizeConfig(config), model as any);\n}\n"]}
@@ -1,111 +0,0 @@
1
- "use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _nullishCoalesce(lhs, rhsFn) { if (lhs != null) { return lhs; } else { return rhsFn(); } }
2
-
3
-
4
- var _chunk3VQDXJLWcjs = require('./chunk-3VQDXJLW.cjs');
5
-
6
-
7
- var _chunk7HSUHP63cjs = require('./chunk-7HSUHP63.cjs');
8
-
9
-
10
-
11
-
12
-
13
- var _chunkWBTQKWFNcjs = require('./chunk-WBTQKWFN.cjs');
14
-
15
-
16
- var _chunk4DE2IREAcjs = require('./chunk-4DE2IREA.cjs');
17
-
18
- // src/adapters/workers-ai-tts.ts
19
- var _adapters = require('@tanstack/ai/adapters');
20
- var WorkersAiTTSAdapter = class extends _adapters.BaseTTSAdapter {
21
- constructor(config, model) {
22
- super({}, model);
23
- _chunk4DE2IREAcjs.__publicField.call(void 0, this, "name", "workers-ai-tts");
24
- _chunk4DE2IREAcjs.__publicField.call(void 0, this, "adapterConfig");
25
- _chunkWBTQKWFNcjs.validateWorkersAiConfig.call(void 0, config);
26
- this.adapterConfig = config;
27
- }
28
- async generateSpeech(options) {
29
- const { text, voice, format, speed, modelOptions } = options;
30
- const extra = { ...modelOptions };
31
- if (voice) extra.voice = voice;
32
- if (speed != null) extra.speed = speed;
33
- if (_chunkWBTQKWFNcjs.isDirectBindingConfig.call(void 0, this.adapterConfig)) {
34
- return this.generateViaBinding(text, format, extra);
35
- }
36
- if (_chunkWBTQKWFNcjs.isDirectCredentialsConfig.call(void 0, this.adapterConfig)) {
37
- return this.generateViaRest(text, format, extra);
38
- }
39
- return this.generateViaGateway(text, format, extra);
40
- }
41
- async generateViaBinding(text, format, options) {
42
- const ai = this.adapterConfig.binding;
43
- const result = await ai.run(this.model, { text, ...options });
44
- return this.normalizeResult(result, format);
45
- }
46
- async generateViaRest(text, format, options) {
47
- const config = this.adapterConfig;
48
- const response = await _chunk7HSUHP63cjs.workersAiRestFetch.call(void 0,
49
- config,
50
- this.model,
51
- { text, ...options },
52
- { label: "Workers AI TTS", signal: options.signal }
53
- );
54
- const buffer = await response.arrayBuffer();
55
- return this.wrapAudioResult(new Uint8Array(buffer), format);
56
- }
57
- async generateViaGateway(text, format, options) {
58
- const gatewayConfig = this.adapterConfig;
59
- const gatewayFetch = _chunkWBTQKWFNcjs.createGatewayFetch.call(void 0, "workers-ai", gatewayConfig);
60
- const response = await gatewayFetch("https://api.cloudflare.com/v1/audio/speech", {
61
- method: "POST",
62
- body: JSON.stringify({
63
- model: this.model,
64
- text,
65
- ...options
66
- })
67
- });
68
- if (!response.ok) {
69
- const errorText = await response.text();
70
- throw new Error(
71
- `Workers AI TTS gateway request failed (${response.status}): ${errorText}`
72
- );
73
- }
74
- const buffer = await response.arrayBuffer();
75
- return this.wrapAudioResult(new Uint8Array(buffer), format);
76
- }
77
- /**
78
- * Normalize binding results. Workers AI TTS can return:
79
- * - Uint8Array / ArrayBuffer (raw audio bytes)
80
- * - ReadableStream<Uint8Array> (streamed audio bytes)
81
- * - { audio: "base64..." } (JSON wrapper)
82
- */
83
- async normalizeResult(result, format) {
84
- const b64 = await _chunk3VQDXJLWcjs.binaryToBase64.call(void 0, result, "audio");
85
- return {
86
- id: this.generateId(),
87
- model: this.model,
88
- audio: b64,
89
- format: _nullishCoalesce(format, () => ( "mp3")),
90
- contentType: `audio/${_nullishCoalesce(format, () => ( "mp3"))}`
91
- };
92
- }
93
- wrapAudioResult(bytes, format) {
94
- return {
95
- id: this.generateId(),
96
- model: this.model,
97
- audio: _chunk3VQDXJLWcjs.uint8ArrayToBase64.call(void 0, bytes),
98
- format: _nullishCoalesce(format, () => ( "mp3")),
99
- contentType: `audio/${_nullishCoalesce(format, () => ( "mp3"))}`
100
- };
101
- }
102
- };
103
- function createWorkersAiTts(model, config) {
104
- return new WorkersAiTTSAdapter(config, model);
105
- }
106
-
107
-
108
-
109
-
110
- exports.WorkersAiTTSAdapter = WorkersAiTTSAdapter; exports.createWorkersAiTts = createWorkersAiTts;
111
- //# sourceMappingURL=chunk-N6U27RQW.cjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["/home/runner/work/ai/ai/packages/tanstack-ai/dist/chunk-N6U27RQW.cjs","../src/adapters/workers-ai-tts.ts"],"names":[],"mappings":"AAAA;AACE;AACA;AACF,wDAA6B;AAC7B;AACE;AACF,wDAA6B;AAC7B;AACE;AACA;AACA;AACA;AACF,wDAA6B;AAC7B;AACE;AACF,wDAA6B;AAC7B;AACA;ACjBA,iDAA+B;AAoCxB,IAAM,oBAAA,EAAN,MAAA,QAAkC,yBAAkC;AAAA,EAI1E,WAAA,CAAY,MAAA,EAAgC,KAAA,EAA0B;AACrE,IAAA,KAAA,CAAM,CAAC,CAAA,EAAG,KAAK,CAAA;AAJhB,IAAA,6CAAA,IAAA,EAAS,MAAA,EAAO,gBAAA,CAAA;AAChB,IAAA,6CAAA,IAAA,EAAQ,eAAA,CAAA;AAIP,IAAA,uDAAA,MAA8B,CAAA;AAC9B,IAAA,IAAA,CAAK,cAAA,EAAgB,MAAA;AAAA,EACtB;AAAA,EAEA,MAAM,cAAA,CAAe,OAAA,EAAyC;AAC7D,IAAA,MAAM,EAAE,IAAA,EAAM,KAAA,EAAO,MAAA,EAAQ,KAAA,EAAO,aAAa,EAAA,EAAI,OAAA;AAGrD,IAAA,MAAM,MAAA,EAAiC,EAAE,GAAG,aAAa,CAAA;AACzD,IAAA,GAAA,CAAI,KAAA,EAAO,KAAA,CAAM,MAAA,EAAQ,KAAA;AACzB,IAAA,GAAA,CAAI,MAAA,GAAS,IAAA,EAAM,KAAA,CAAM,MAAA,EAAQ,KAAA;AAEjC,IAAA,GAAA,CAAI,qDAAA,IAAsB,CAAK,aAAa,CAAA,EAAG;AAC9C,MAAA,OAAO,IAAA,CAAK,kBAAA,CAAmB,IAAA,EAAM,MAAA,EAAQ,KAAK,CAAA;AAAA,IACnD;AAEA,IAAA,GAAA,CAAI,yDAAA,IAA0B,CAAK,aAAa,CAAA,EAAG;AAClD,MAAA,OAAO,IAAA,CAAK,eAAA,CAAgB,IAAA,EAAM,MAAA,EAAQ,KAAK,CAAA;AAAA,IAChD;AAEA,IAAA,OAAO,IAAA,CAAK,kBAAA,CAAmB,IAAA,EAAM,MAAA,EAAQ,KAAK,CAAA;AAAA,EACnD;AAAA,EAEA,MAAc,kBAAA,CACb,IAAA,EACA,MAAA,EACA,OAAA,EACqB;AACrB,IAAA,MAAM,GAAA,EAAM,IAAA,CAAK,aAAA,CAA+C,OAAA;AAChE,IAAA,MAAM,OAAA,EAAS,MAAM,EAAA,CAAG,GAAA,CAAI,IAAA,CAAK,KAAA,EAAO,EAAE,IAAA,EAAM,GAAG,QAAQ,CAAC,CAAA;AAE5D,IAAA,OAAO,IAAA,CAAK,eAAA,CAAgB,MAAA,EAAQ,MAAM,CAAA;AAAA,EAC3C;AAAA,EAEA,MAAc,eAAA,CACb,IAAA,EACA,MAAA,EACA,OAAA,EACqB;AACrB,IAAA,MAAM,OAAA,EAAS,IAAA,CAAK,aAAA;AACpB,IAAA,MAAM,SAAA,EAAW,MAAM,kDAAA;AAAA,MACtB,MAAA;AAAA,MACA,IAAA,CAAK,KAAA;AAAA,MACL,EAAE,IAAA,EAAM,GAAG,QAAQ,CAAA;AAAA,MACnB,EAAE,KAAA,EAAO,gBAAA,EAAkB,MAAA,EAAS,OAAA,CAAqC,OAAO;AAAA,IACjF,CAAA;AAGA,IAAA,MAAM,OAAA,EAAS,MAAM,QAAA,CAAS,WAAA,CAAY,CAAA;AAC1C,IAAA,OAAO,IAAA,CAAK,eAAA,CAAgB,IAAI,UAAA,CAAW,MAAM,CAAA,EAAG,MAAM,CAAA;AAAA,EAC3D;AAAA,EAEA,MAAc,kBAAA,CACb,IAAA,EACA,MAAA,EACA,OAAA,EACqB;AACrB,IAAA,MAAM,cAAA,EAAgB,IAAA,CAAK,aAAA;AAC3B,IAAA,MAAM,aAAA,EAAe,kDAAA,YAAmB,EAAc,aAAa,CAAA;AAKnE,IAAA,MAAM,SAAA,EAAW,MAAM,YAAA,CAAa,4CAAA,EAA8C;AAAA,MACjF,MAAA,EAAQ,MAAA;AAAA,MACR,IAAA,EAAM,IAAA,CAAK,SAAA,CAAU;AAAA,QACpB,KAAA,EAAO,IAAA,CAAK,KAAA;AAAA,QACZ,IAAA;AAAA,QACA,GAAG;AAAA,MACJ,CAAC;AAAA,IACF,CAAC,CAAA;AAED,IAAA,GAAA,CAAI,CAAC,QAAA,CAAS,EAAA,EAAI;AACjB,MAAA,MAAM,UAAA,EAAY,MAAM,QAAA,CAAS,IAAA,CAAK,CAAA;AACtC,MAAA,MAAM,IAAI,KAAA;AAAA,QACT,CAAA,uCAAA,EAA0C,QAAA,CAAS,MAAM,CAAA,GAAA,EAAM,SAAS,CAAA;AAAA,MAAA;AACzE,IAAA;AAGD,IAAA;AACA,IAAA;AAA0D,EAAA;AAC3D;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAAA;AAWC,IAAA;AACA,IAAA;AAAO,MAAA;AACc,MAAA;AACR,MAAA;AACL,MAAA;AACW,MAAA;AACmB,IAAA;AACtC,EAAA;AACD,EAAA;AAGC,IAAA;AAAO,MAAA;AACc,MAAA;AACR,MAAA;AACmB,MAAA;AACb,MAAA;AACmB,IAAA;AACtC,EAAA;AAEF;AA0BO;AACN,EAAA;AACD;AD5EA;AACA;AACA;AACA;AACA","file":"/home/runner/work/ai/ai/packages/tanstack-ai/dist/chunk-N6U27RQW.cjs","sourcesContent":[null,"import { BaseTTSAdapter } from \"@tanstack/ai/adapters\";\nimport type { TTSOptions, TTSResult } from \"@tanstack/ai\";\nimport {\n\ttype WorkersAiAdapterConfig,\n\ttype WorkersAiDirectBindingConfig,\n\ttype WorkersAiDirectCredentialsConfig,\n\ttype AiGatewayAdapterConfig,\n\tcreateGatewayFetch,\n\tisDirectBindingConfig,\n\tisDirectCredentialsConfig,\n\tvalidateWorkersAiConfig,\n} from \"../utils/create-fetcher\";\nimport { workersAiRestFetch } from \"../utils/workers-ai-rest\";\nimport { binaryToBase64, uint8ArrayToBase64 } from \"../utils/binary\";\n\n// ---------------------------------------------------------------------------\n// Model types\n// ---------------------------------------------------------------------------\n\n/**\n * Workers AI models that support text-to-speech generation.\n *\n * Note: the typed `AiModels` interface in `@cloudflare/workers-types` may lag\n * behind what's deployed. We use a string union here that matches the known\n * models including Deepgram partner models.\n */\nexport type WorkersAiTTSModel =\n\t| \"@cf/deepgram/aura-1\"\n\t| \"@cf/deepgram/aura-2-en\"\n\t| \"@cf/deepgram/aura-2-es\"\n\t| (string & {});\n\n// ---------------------------------------------------------------------------\n// WorkersAiTTSAdapter\n// ---------------------------------------------------------------------------\n\nexport class WorkersAiTTSAdapter extends BaseTTSAdapter<WorkersAiTTSModel> {\n\treadonly name = \"workers-ai-tts\" as const;\n\tprivate adapterConfig: WorkersAiAdapterConfig;\n\n\tconstructor(config: WorkersAiAdapterConfig, model: WorkersAiTTSModel) {\n\t\tsuper({}, model);\n\t\tvalidateWorkersAiConfig(config);\n\t\tthis.adapterConfig = config;\n\t}\n\n\tasync generateSpeech(options: TTSOptions): Promise<TTSResult> {\n\t\tconst { text, voice, format, speed, modelOptions } = options;\n\n\t\t// Workers AI TTS models (Deepgram aura-1) accept { text, lang? }\n\t\tconst extra: Record<string, unknown> = { ...modelOptions };\n\t\tif (voice) extra.voice = voice;\n\t\tif (speed != null) extra.speed = speed;\n\n\t\tif (isDirectBindingConfig(this.adapterConfig)) {\n\t\t\treturn this.generateViaBinding(text, format, extra);\n\t\t}\n\n\t\tif (isDirectCredentialsConfig(this.adapterConfig)) {\n\t\t\treturn this.generateViaRest(text, format, extra);\n\t\t}\n\n\t\treturn this.generateViaGateway(text, format, extra);\n\t}\n\n\tprivate async generateViaBinding(\n\t\ttext: string,\n\t\tformat: string | undefined,\n\t\toptions: Record<string, unknown>,\n\t): Promise<TTSResult> {\n\t\tconst ai = (this.adapterConfig as WorkersAiDirectBindingConfig).binding;\n\t\tconst result = await ai.run(this.model, { text, ...options });\n\n\t\treturn this.normalizeResult(result, format);\n\t}\n\n\tprivate async generateViaRest(\n\t\ttext: string,\n\t\tformat: string | undefined,\n\t\toptions: Record<string, unknown>,\n\t): Promise<TTSResult> {\n\t\tconst config = this.adapterConfig as WorkersAiDirectCredentialsConfig;\n\t\tconst response = await workersAiRestFetch(\n\t\t\tconfig,\n\t\t\tthis.model,\n\t\t\t{ text, ...options },\n\t\t\t{ label: \"Workers AI TTS\", signal: (options as { signal?: AbortSignal }).signal },\n\t\t);\n\n\t\t// Workers AI TTS returns audio bytes directly\n\t\tconst buffer = await response.arrayBuffer();\n\t\treturn this.wrapAudioResult(new Uint8Array(buffer), format);\n\t}\n\n\tprivate async generateViaGateway(\n\t\ttext: string,\n\t\tformat: string | undefined,\n\t\toptions: Record<string, unknown>,\n\t): Promise<TTSResult> {\n\t\tconst gatewayConfig = this.adapterConfig as AiGatewayAdapterConfig;\n\t\tconst gatewayFetch = createGatewayFetch(\"workers-ai\", gatewayConfig);\n\n\t\t// The URL here is a placeholder — createGatewayFetch for \"workers-ai\" extracts\n\t\t// the model from the body, sets it as the endpoint, and routes through the gateway.\n\t\t// The actual URL path is not used.\n\t\tconst response = await gatewayFetch(\"https://api.cloudflare.com/v1/audio/speech\", {\n\t\t\tmethod: \"POST\",\n\t\t\tbody: JSON.stringify({\n\t\t\t\tmodel: this.model,\n\t\t\t\ttext,\n\t\t\t\t...options,\n\t\t\t}),\n\t\t});\n\n\t\tif (!response.ok) {\n\t\t\tconst errorText = await response.text();\n\t\t\tthrow new Error(\n\t\t\t\t`Workers AI TTS gateway request failed (${response.status}): ${errorText}`,\n\t\t\t);\n\t\t}\n\n\t\tconst buffer = await response.arrayBuffer();\n\t\treturn this.wrapAudioResult(new Uint8Array(buffer), format);\n\t}\n\n\t/**\n\t * Normalize binding results. Workers AI TTS can return:\n\t * - Uint8Array / ArrayBuffer (raw audio bytes)\n\t * - ReadableStream<Uint8Array> (streamed audio bytes)\n\t * - { audio: \"base64...\" } (JSON wrapper)\n\t */\n\tprivate async normalizeResult(result: unknown, format: string | undefined): Promise<TTSResult> {\n\t\t// Use the shared binaryToBase64 helper for Uint8Array/ArrayBuffer/ReadableStream\n\t\t// and { audio: \"base64...\" } JSON wrapper\n\t\tconst b64 = await binaryToBase64(result, \"audio\");\n\t\treturn {\n\t\t\tid: this.generateId(),\n\t\t\tmodel: this.model,\n\t\t\taudio: b64,\n\t\t\tformat: format ?? \"mp3\",\n\t\t\tcontentType: `audio/${format ?? \"mp3\"}`,\n\t\t};\n\t}\n\n\tprivate wrapAudioResult(bytes: Uint8Array, format: string | undefined): TTSResult {\n\t\treturn {\n\t\t\tid: this.generateId(),\n\t\t\tmodel: this.model,\n\t\t\taudio: uint8ArrayToBase64(bytes),\n\t\t\tformat: format ?? \"mp3\",\n\t\t\tcontentType: `audio/${format ?? \"mp3\"}`,\n\t\t};\n\t}\n}\n\n// ---------------------------------------------------------------------------\n// Factory function\n// ---------------------------------------------------------------------------\n\n/**\n * Creates a Workers AI text-to-speech adapter.\n *\n * Works with TanStack AI's `generateSpeech()` activity function:\n * ```ts\n * import { generateSpeech } from \"@tanstack/ai\";\n * import { createWorkersAiTts } from \"@cloudflare/tanstack-ai\";\n *\n * const adapter = createWorkersAiTts(\n * \"@cf/deepgram/aura-1\",\n * { binding: env.AI },\n * );\n *\n * const result = await generateSpeech({ adapter, text: \"Hello world\" });\n * // result.audio — base64-encoded audio\n * ```\n *\n * Note: Factory takes `(model, config)` for ergonomics — the class constructor\n * uses `(config, model)` to match TanStack AI's upstream convention.\n */\nexport function createWorkersAiTts(model: WorkersAiTTSModel, config: WorkersAiAdapterConfig) {\n\treturn new WorkersAiTTSAdapter(config, model);\n}\n"]}
@@ -1,86 +0,0 @@
1
- import {
2
- workersAiRestFetch
3
- } from "./chunk-2VII5BK2.js";
4
- import {
5
- createGatewayFetch,
6
- isDirectBindingConfig,
7
- isDirectCredentialsConfig,
8
- validateWorkersAiConfig
9
- } from "./chunk-AIAJANLC.js";
10
- import {
11
- __publicField
12
- } from "./chunk-V6TY7KAL.js";
13
-
14
- // src/adapters/workers-ai-summarize.ts
15
- import { BaseSummarizeAdapter } from "@tanstack/ai/adapters";
16
- var WorkersAiSummarizeAdapter = class extends BaseSummarizeAdapter {
17
- constructor(config, model) {
18
- super({}, model);
19
- __publicField(this, "name", "workers-ai-summarize");
20
- __publicField(this, "adapterConfig");
21
- validateWorkersAiConfig(config);
22
- this.adapterConfig = config;
23
- }
24
- async summarize(options) {
25
- const { text, maxLength } = options;
26
- const payload = { input_text: text };
27
- if (maxLength != null) payload.max_length = maxLength;
28
- if (isDirectBindingConfig(this.adapterConfig)) {
29
- return this.summarizeViaBinding(payload);
30
- }
31
- if (isDirectCredentialsConfig(this.adapterConfig)) {
32
- return this.summarizeViaRest(payload);
33
- }
34
- return this.summarizeViaGateway(payload);
35
- }
36
- async summarizeViaBinding(payload) {
37
- const ai = this.adapterConfig.binding;
38
- const result = await ai.run(this.model, payload);
39
- return this.wrapResult(result.summary ?? "");
40
- }
41
- async summarizeViaRest(payload) {
42
- const config = this.adapterConfig;
43
- const response = await workersAiRestFetch(config, this.model, payload, {
44
- label: "Workers AI summarize"
45
- });
46
- const data = await response.json();
47
- return this.wrapResult(data.result?.summary ?? "");
48
- }
49
- async summarizeViaGateway(payload) {
50
- const gatewayConfig = this.adapterConfig;
51
- const gatewayFetch = createGatewayFetch("workers-ai", gatewayConfig);
52
- const response = await gatewayFetch("https://api.cloudflare.com/v1/ai/summarization", {
53
- method: "POST",
54
- body: JSON.stringify({
55
- model: this.model,
56
- ...payload
57
- })
58
- });
59
- if (!response.ok) {
60
- const errorText = await response.text();
61
- throw new Error(
62
- `Workers AI summarize gateway request failed (${response.status}): ${errorText}`
63
- );
64
- }
65
- const data = await response.json();
66
- return this.wrapResult(data.result?.summary ?? data.summary ?? "");
67
- }
68
- wrapResult(summary) {
69
- return {
70
- id: this.generateId(),
71
- model: this.model,
72
- summary,
73
- // BART-large-CNN doesn't return token usage
74
- usage: { promptTokens: 0, completionTokens: 0, totalTokens: 0 }
75
- };
76
- }
77
- };
78
- function createWorkersAiSummarize(model, config) {
79
- return new WorkersAiSummarizeAdapter(config, model);
80
- }
81
-
82
- export {
83
- WorkersAiSummarizeAdapter,
84
- createWorkersAiSummarize
85
- };
86
- //# sourceMappingURL=chunk-NH3FF5JC.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/adapters/workers-ai-summarize.ts"],"sourcesContent":["import { BaseSummarizeAdapter } from \"@tanstack/ai/adapters\";\nimport type { SummarizationOptions, SummarizationResult } from \"@tanstack/ai\";\nimport {\n\ttype WorkersAiAdapterConfig,\n\ttype WorkersAiDirectBindingConfig,\n\ttype WorkersAiDirectCredentialsConfig,\n\ttype AiGatewayAdapterConfig,\n\tcreateGatewayFetch,\n\tisDirectBindingConfig,\n\tisDirectCredentialsConfig,\n\tvalidateWorkersAiConfig,\n} from \"../utils/create-fetcher\";\nimport { workersAiRestFetch } from \"../utils/workers-ai-rest\";\n\n// ---------------------------------------------------------------------------\n// Model types\n// ---------------------------------------------------------------------------\n\n/**\n * Workers AI models that support summarization.\n */\nexport type WorkersAiSummarizeModel = \"@cf/facebook/bart-large-cnn\" | (string & {});\n\n// ---------------------------------------------------------------------------\n// WorkersAiSummarizeAdapter\n// ---------------------------------------------------------------------------\n\nexport class WorkersAiSummarizeAdapter extends BaseSummarizeAdapter<WorkersAiSummarizeModel> {\n\treadonly name = \"workers-ai-summarize\" as const;\n\tprivate adapterConfig: WorkersAiAdapterConfig;\n\n\tconstructor(config: WorkersAiAdapterConfig, model: WorkersAiSummarizeModel) {\n\t\tsuper({}, model);\n\t\tvalidateWorkersAiConfig(config);\n\t\tthis.adapterConfig = config;\n\t}\n\n\tasync summarize(options: SummarizationOptions): Promise<SummarizationResult> {\n\t\tconst { text, maxLength } = options;\n\n\t\tconst payload: Record<string, unknown> = { input_text: text };\n\t\tif (maxLength != null) payload.max_length = maxLength;\n\n\t\tif (isDirectBindingConfig(this.adapterConfig)) {\n\t\t\treturn this.summarizeViaBinding(payload);\n\t\t}\n\n\t\tif (isDirectCredentialsConfig(this.adapterConfig)) {\n\t\t\treturn this.summarizeViaRest(payload);\n\t\t}\n\n\t\treturn this.summarizeViaGateway(payload);\n\t}\n\n\tprivate async summarizeViaBinding(\n\t\tpayload: Record<string, unknown>,\n\t): Promise<SummarizationResult> {\n\t\tconst ai = (this.adapterConfig as WorkersAiDirectBindingConfig).binding;\n\t\tconst result = (await ai.run(this.model, payload)) as Record<string, unknown>;\n\t\treturn this.wrapResult((result.summary as string) ?? \"\");\n\t}\n\n\tprivate async summarizeViaRest(payload: Record<string, unknown>): Promise<SummarizationResult> {\n\t\tconst config = this.adapterConfig as WorkersAiDirectCredentialsConfig;\n\t\tconst response = await workersAiRestFetch(config, this.model, payload, {\n\t\t\tlabel: \"Workers AI summarize\",\n\t\t});\n\n\t\tconst data = (await response.json()) as { result?: { summary?: string } };\n\t\treturn this.wrapResult(data.result?.summary ?? \"\");\n\t}\n\n\tprivate async summarizeViaGateway(\n\t\tpayload: Record<string, unknown>,\n\t): Promise<SummarizationResult> {\n\t\tconst gatewayConfig = this.adapterConfig as AiGatewayAdapterConfig;\n\t\tconst gatewayFetch = createGatewayFetch(\"workers-ai\", gatewayConfig);\n\n\t\t// The URL here is a placeholder — createGatewayFetch for \"workers-ai\" extracts\n\t\t// the model from the body, sets it as the endpoint, and routes through the gateway.\n\t\t// The actual URL path is not used.\n\t\tconst response = await gatewayFetch(\"https://api.cloudflare.com/v1/ai/summarization\", {\n\t\t\tmethod: \"POST\",\n\t\t\tbody: JSON.stringify({\n\t\t\t\tmodel: this.model,\n\t\t\t\t...payload,\n\t\t\t}),\n\t\t});\n\n\t\tif (!response.ok) {\n\t\t\tconst errorText = await response.text();\n\t\t\tthrow new Error(\n\t\t\t\t`Workers AI summarize gateway request failed (${response.status}): ${errorText}`,\n\t\t\t);\n\t\t}\n\n\t\tconst data = (await response.json()) as { result?: { summary?: string }; summary?: string };\n\t\treturn this.wrapResult(data.result?.summary ?? data.summary ?? \"\");\n\t}\n\n\tprivate wrapResult(summary: string): SummarizationResult {\n\t\treturn {\n\t\t\tid: this.generateId(),\n\t\t\tmodel: this.model,\n\t\t\tsummary,\n\t\t\t// BART-large-CNN doesn't return token usage\n\t\t\tusage: { promptTokens: 0, completionTokens: 0, totalTokens: 0 },\n\t\t};\n\t}\n}\n\n// ---------------------------------------------------------------------------\n// Factory function\n// ---------------------------------------------------------------------------\n\n/**\n * Creates a Workers AI summarization adapter.\n *\n * Works with TanStack AI's `summarize()` activity function:\n * ```ts\n * import { summarize } from \"@tanstack/ai\";\n * import { createWorkersAiSummarize } from \"@cloudflare/tanstack-ai\";\n *\n * const adapter = createWorkersAiSummarize(\"@cf/facebook/bart-large-cnn\", {\n * binding: env.AI,\n * });\n *\n * const result = await summarize({ adapter, text: \"Long article here...\" });\n * // result.summary\n * ```\n *\n * Note: Factory takes `(model, config)` for ergonomics — the class constructor\n * uses `(config, model)` to match TanStack AI's upstream convention.\n */\nexport function createWorkersAiSummarize(\n\tmodel: WorkersAiSummarizeModel,\n\tconfig: WorkersAiAdapterConfig,\n) {\n\treturn new WorkersAiSummarizeAdapter(config, model);\n}\n"],"mappings":";;;;;;;;;;;;;;AAAA,SAAS,4BAA4B;AA2B9B,IAAM,4BAAN,cAAwC,qBAA8C;AAAA,EAI5F,YAAY,QAAgC,OAAgC;AAC3E,UAAM,CAAC,GAAG,KAAK;AAJhB,wBAAS,QAAO;AAChB,wBAAQ;AAIP,4BAAwB,MAAM;AAC9B,SAAK,gBAAgB;AAAA,EACtB;AAAA,EAEA,MAAM,UAAU,SAA6D;AAC5E,UAAM,EAAE,MAAM,UAAU,IAAI;AAE5B,UAAM,UAAmC,EAAE,YAAY,KAAK;AAC5D,QAAI,aAAa,KAAM,SAAQ,aAAa;AAE5C,QAAI,sBAAsB,KAAK,aAAa,GAAG;AAC9C,aAAO,KAAK,oBAAoB,OAAO;AAAA,IACxC;AAEA,QAAI,0BAA0B,KAAK,aAAa,GAAG;AAClD,aAAO,KAAK,iBAAiB,OAAO;AAAA,IACrC;AAEA,WAAO,KAAK,oBAAoB,OAAO;AAAA,EACxC;AAAA,EAEA,MAAc,oBACb,SAC+B;AAC/B,UAAM,KAAM,KAAK,cAA+C;AAChE,UAAM,SAAU,MAAM,GAAG,IAAI,KAAK,OAAO,OAAO;AAChD,WAAO,KAAK,WAAY,OAAO,WAAsB,EAAE;AAAA,EACxD;AAAA,EAEA,MAAc,iBAAiB,SAAgE;AAC9F,UAAM,SAAS,KAAK;AACpB,UAAM,WAAW,MAAM,mBAAmB,QAAQ,KAAK,OAAO,SAAS;AAAA,MACtE,OAAO;AAAA,IACR,CAAC;AAED,UAAM,OAAQ,MAAM,SAAS,KAAK;AAClC,WAAO,KAAK,WAAW,KAAK,QAAQ,WAAW,EAAE;AAAA,EAClD;AAAA,EAEA,MAAc,oBACb,SAC+B;AAC/B,UAAM,gBAAgB,KAAK;AAC3B,UAAM,eAAe,mBAAmB,cAAc,aAAa;AAKnE,UAAM,WAAW,MAAM,aAAa,kDAAkD;AAAA,MACrF,QAAQ;AAAA,MACR,MAAM,KAAK,UAAU;AAAA,QACpB,OAAO,KAAK;AAAA,QACZ,GAAG;AAAA,MACJ,CAAC;AAAA,IACF,CAAC;AAED,QAAI,CAAC,SAAS,IAAI;AACjB,YAAM,YAAY,MAAM,SAAS,KAAK;AACtC,YAAM,IAAI;AAAA,QACT,gDAAgD,SAAS,MAAM,MAAM,SAAS;AAAA,MAC/E;AAAA,IACD;AAEA,UAAM,OAAQ,MAAM,SAAS,KAAK;AAClC,WAAO,KAAK,WAAW,KAAK,QAAQ,WAAW,KAAK,WAAW,EAAE;AAAA,EAClE;AAAA,EAEQ,WAAW,SAAsC;AACxD,WAAO;AAAA,MACN,IAAI,KAAK,WAAW;AAAA,MACpB,OAAO,KAAK;AAAA,MACZ;AAAA;AAAA,MAEA,OAAO,EAAE,cAAc,GAAG,kBAAkB,GAAG,aAAa,EAAE;AAAA,IAC/D;AAAA,EACD;AACD;AAyBO,SAAS,yBACf,OACA,QACC;AACD,SAAO,IAAI,0BAA0B,QAAQ,KAAK;AACnD;","names":[]}
@@ -1,31 +0,0 @@
1
- "use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _nullishCoalesce(lhs, rhsFn) { if (lhs != null) { return lhs; } else { return rhsFn(); } }
2
-
3
- var _chunkWBTQKWFNcjs = require('./chunk-WBTQKWFN.cjs');
4
-
5
- // src/adapters/anthropic.ts
6
-
7
-
8
-
9
-
10
- var _aianthropic = require('@tanstack/ai-anthropic');
11
- function buildAnthropicConfig(config) {
12
- return {
13
- apiKey: _nullishCoalesce(config.apiKey, () => ( "unused")),
14
- fetch: _chunkWBTQKWFNcjs.createGatewayFetch.call(void 0, "anthropic", config, {
15
- "anthropic-version": _nullishCoalesce(config.anthropicVersion, () => ( "2023-06-01"))
16
- })
17
- };
18
- }
19
- function createAnthropicChat(model, config) {
20
- return new (0, _aianthropic.AnthropicTextAdapter)(buildAnthropicConfig(config), model);
21
- }
22
- function createAnthropicSummarize(model, config) {
23
- return new (0, _aianthropic.AnthropicSummarizeAdapter)(buildAnthropicConfig(config), model);
24
- }
25
-
26
-
27
-
28
-
29
-
30
- exports.ANTHROPIC_MODELS = _aianthropic.ANTHROPIC_MODELS; exports.createAnthropicChat = createAnthropicChat; exports.createAnthropicSummarize = createAnthropicSummarize;
31
- //# sourceMappingURL=chunk-OFUYHQZE.cjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["/home/runner/work/ai/ai/packages/tanstack-ai/dist/chunk-OFUYHQZE.cjs","../src/adapters/anthropic.ts"],"names":[],"mappings":"AAAA;AACE;AACF,wDAA6B;AAC7B;AACA;ACJA;AACC;AACA;AACA;AAAA,qDAEM;AAKP,SAAS,oBAAA,CAAqB,MAAA,EAAgC;AAC7D,EAAA,OAAO;AAAA,IACN,MAAA,mBAAQ,MAAA,CAAO,MAAA,UAAU,UAAA;AAAA,IACzB,KAAA,EAAO,kDAAA,WAAmB,EAAa,MAAA,EAAQ;AAAA,MAC9C,mBAAA,mBAAqB,MAAA,CAAO,gBAAA,UAAoB;AAAA,IACjD,CAAC;AAAA,EACF,CAAA;AACD;AASO,SAAS,mBAAA,CACf,KAAA,EACA,MAAA,EAC2C;AAC3C,EAAA,OAAO,IAAI,sCAAA,CAAqB,oBAAA,CAAqB,MAAM,CAAA,EAAG,KAAK,CAAA;AACpE;AAMO,SAAS,wBAAA,CACf,KAAA,EACA,MAAA,EACC;AACD,EAAA,OAAO,IAAI,2CAAA,CAA0B,oBAAA,CAAqB,MAAM,CAAA,EAAG,KAAK,CAAA;AACzE;ADlBA;AACA;AACE;AACA;AACA;AACF,yKAAC","file":"/home/runner/work/ai/ai/packages/tanstack-ai/dist/chunk-OFUYHQZE.cjs","sourcesContent":[null,"import {\n\tAnthropicTextAdapter,\n\tAnthropicSummarizeAdapter,\n\tANTHROPIC_MODELS,\n\ttype AnthropicChatModel,\n} from \"@tanstack/ai-anthropic\";\nimport { createGatewayFetch, type AiGatewayAdapterConfig } from \"../utils/create-fetcher\";\n\nexport type AnthropicGatewayConfig = AiGatewayAdapterConfig & { anthropicVersion?: string };\n\nfunction buildAnthropicConfig(config: AnthropicGatewayConfig) {\n\treturn {\n\t\tapiKey: config.apiKey ?? \"unused\",\n\t\tfetch: createGatewayFetch(\"anthropic\", config, {\n\t\t\t\"anthropic-version\": config.anthropicVersion ?? \"2023-06-01\",\n\t\t}),\n\t};\n}\n\n/**\n * Creates an Anthropic chat adapter which uses Cloudflare AI Gateway.\n * Supports both binding and credential-based configurations.\n *\n * Since AnthropicTextConfig extends the Anthropic SDK's ClientOptions,\n * we can inject the gateway fetch directly — no subclassing needed.\n */\nexport function createAnthropicChat(\n\tmodel: AnthropicChatModel,\n\tconfig: AnthropicGatewayConfig,\n): AnthropicTextAdapter<AnthropicChatModel> {\n\treturn new AnthropicTextAdapter(buildAnthropicConfig(config), model);\n}\n\n/**\n * Creates an Anthropic summarize adapter which uses Cloudflare AI Gateway.\n * Supports both binding and credential-based configurations.\n */\nexport function createAnthropicSummarize(\n\tmodel: AnthropicChatModel,\n\tconfig: AnthropicGatewayConfig,\n) {\n\treturn new AnthropicSummarizeAdapter(buildAnthropicConfig(config), model);\n}\n\nexport { ANTHROPIC_MODELS, type AnthropicChatModel };\n"]}