@cloudflare/tanstack-ai 0.0.0 → 0.1.1
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.
- package/LICENSE +21 -0
- package/README.md +282 -0
- package/dist/_tsup-dts-rollup.d.cts +820 -0
- package/dist/_tsup-dts-rollup.d.ts +820 -0
- package/dist/adapters/anthropic.cjs +13 -0
- package/dist/adapters/anthropic.cjs.map +1 -0
- package/dist/adapters/anthropic.d.cts +5 -0
- package/dist/adapters/anthropic.d.ts +5 -0
- package/dist/adapters/anthropic.js +13 -0
- package/dist/adapters/anthropic.js.map +1 -0
- package/dist/adapters/gemini.cjs +22 -0
- package/dist/adapters/gemini.cjs.map +1 -0
- package/dist/adapters/gemini.d.cts +14 -0
- package/dist/adapters/gemini.d.ts +14 -0
- package/dist/adapters/gemini.js +22 -0
- package/dist/adapters/gemini.js.map +1 -0
- package/dist/adapters/grok.cjs +17 -0
- package/dist/adapters/grok.cjs.map +1 -0
- package/dist/adapters/grok.d.cts +9 -0
- package/dist/adapters/grok.d.ts +9 -0
- package/dist/adapters/grok.js +17 -0
- package/dist/adapters/grok.js.map +1 -0
- package/dist/adapters/openai.cjs +29 -0
- package/dist/adapters/openai.cjs.map +1 -0
- package/dist/adapters/openai.d.cts +17 -0
- package/dist/adapters/openai.d.ts +17 -0
- package/dist/adapters/openai.js +29 -0
- package/dist/adapters/openai.js.map +1 -0
- package/dist/adapters/openrouter.cjs +13 -0
- package/dist/adapters/openrouter.cjs.map +1 -0
- package/dist/adapters/openrouter.d.cts +7 -0
- package/dist/adapters/openrouter.d.ts +7 -0
- package/dist/adapters/openrouter.js +13 -0
- package/dist/adapters/openrouter.js.map +1 -0
- package/dist/adapters/workers-ai-image.cjs +13 -0
- package/dist/adapters/workers-ai-image.cjs.map +1 -0
- package/dist/adapters/workers-ai-image.d.cts +3 -0
- package/dist/adapters/workers-ai-image.d.ts +3 -0
- package/dist/adapters/workers-ai-image.js +13 -0
- package/dist/adapters/workers-ai-image.js.map +1 -0
- package/dist/adapters/workers-ai-summarize.cjs +12 -0
- package/dist/adapters/workers-ai-summarize.cjs.map +1 -0
- package/dist/adapters/workers-ai-summarize.d.cts +3 -0
- package/dist/adapters/workers-ai-summarize.d.ts +3 -0
- package/dist/adapters/workers-ai-summarize.js +12 -0
- package/dist/adapters/workers-ai-summarize.js.map +1 -0
- package/dist/adapters/workers-ai-transcription.cjs +13 -0
- package/dist/adapters/workers-ai-transcription.cjs.map +1 -0
- package/dist/adapters/workers-ai-transcription.d.cts +3 -0
- package/dist/adapters/workers-ai-transcription.d.ts +3 -0
- package/dist/adapters/workers-ai-transcription.js +13 -0
- package/dist/adapters/workers-ai-transcription.js.map +1 -0
- package/dist/adapters/workers-ai-tts.cjs +13 -0
- package/dist/adapters/workers-ai-tts.cjs.map +1 -0
- package/dist/adapters/workers-ai-tts.d.cts +3 -0
- package/dist/adapters/workers-ai-tts.d.ts +3 -0
- package/dist/adapters/workers-ai-tts.js +13 -0
- package/dist/adapters/workers-ai-tts.js.map +1 -0
- package/dist/adapters/workers-ai.cjs +11 -0
- package/dist/adapters/workers-ai.cjs.map +1 -0
- package/dist/adapters/workers-ai.d.cts +3 -0
- package/dist/adapters/workers-ai.d.ts +3 -0
- package/dist/adapters/workers-ai.js +11 -0
- package/dist/adapters/workers-ai.js.map +1 -0
- package/dist/chunk-2RO3A3R4.js +96 -0
- package/dist/chunk-2RO3A3R4.js.map +1 -0
- package/dist/chunk-2VII5BK2.js +42 -0
- package/dist/chunk-2VII5BK2.js.map +1 -0
- package/dist/chunk-3VQDXJLW.cjs +46 -0
- package/dist/chunk-3VQDXJLW.cjs.map +1 -0
- package/dist/chunk-4ACSLQDI.cjs +216 -0
- package/dist/chunk-4ACSLQDI.cjs.map +1 -0
- package/dist/chunk-4DE2IREA.cjs +8 -0
- package/dist/chunk-4DE2IREA.cjs.map +1 -0
- package/dist/chunk-5YEJ5ZRQ.js +503 -0
- package/dist/chunk-5YEJ5ZRQ.js.map +1 -0
- package/dist/chunk-6FBIXTAL.cjs +315 -0
- package/dist/chunk-6FBIXTAL.cjs.map +1 -0
- package/dist/chunk-6OXP4IVS.cjs +48 -0
- package/dist/chunk-6OXP4IVS.cjs.map +1 -0
- package/dist/chunk-7AEFXYJG.js +65 -0
- package/dist/chunk-7AEFXYJG.js.map +1 -0
- package/dist/chunk-7HSUHP63.cjs +42 -0
- package/dist/chunk-7HSUHP63.cjs.map +1 -0
- package/dist/chunk-AHXFO2BB.cjs +31 -0
- package/dist/chunk-AHXFO2BB.cjs.map +1 -0
- package/dist/chunk-ALUCJNDE.js +109 -0
- package/dist/chunk-ALUCJNDE.js.map +1 -0
- package/dist/chunk-AN23SOZX.cjs +96 -0
- package/dist/chunk-AN23SOZX.cjs.map +1 -0
- package/dist/chunk-F75IZQCM.js +48 -0
- package/dist/chunk-F75IZQCM.js.map +1 -0
- package/dist/chunk-GL2EQLMI.cjs +109 -0
- package/dist/chunk-GL2EQLMI.cjs.map +1 -0
- package/dist/chunk-M64PETK7.cjs +84 -0
- package/dist/chunk-M64PETK7.cjs.map +1 -0
- package/dist/chunk-OV65IEEY.cjs +57 -0
- package/dist/chunk-OV65IEEY.cjs.map +1 -0
- package/dist/chunk-PAVBM57P.js +57 -0
- package/dist/chunk-PAVBM57P.js.map +1 -0
- package/dist/chunk-R2MRGLZ4.js +84 -0
- package/dist/chunk-R2MRGLZ4.js.map +1 -0
- package/dist/chunk-RGDUK5KX.cjs +65 -0
- package/dist/chunk-RGDUK5KX.cjs.map +1 -0
- package/dist/chunk-S3ALRROX.js +57 -0
- package/dist/chunk-S3ALRROX.js.map +1 -0
- package/dist/chunk-SFZAUNHJ.cjs +57 -0
- package/dist/chunk-SFZAUNHJ.cjs.map +1 -0
- package/dist/chunk-SIOQQHXS.js +31 -0
- package/dist/chunk-SIOQQHXS.js.map +1 -0
- package/dist/chunk-UUFEOQ6B.js +315 -0
- package/dist/chunk-UUFEOQ6B.js.map +1 -0
- package/dist/chunk-V6TY7KAL.js +8 -0
- package/dist/chunk-V6TY7KAL.js.map +1 -0
- package/dist/chunk-VV3JFKAN.js +216 -0
- package/dist/chunk-VV3JFKAN.js.map +1 -0
- package/dist/chunk-VZJHRPOT.cjs +503 -0
- package/dist/chunk-VZJHRPOT.cjs.map +1 -0
- package/dist/chunk-XU7YEPML.js +46 -0
- package/dist/chunk-XU7YEPML.js.map +1 -0
- package/dist/index.cjs +97 -0
- package/dist/index.cjs.map +1 -0
- package/dist/index.d.cts +64 -0
- package/dist/index.d.ts +64 -0
- package/dist/index.js +97 -0
- package/dist/index.js.map +1 -0
- package/package.json +119 -10
|
@@ -0,0 +1,109 @@
|
|
|
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
|
+
} from "./chunk-UUFEOQ6B.js";
|
|
13
|
+
import {
|
|
14
|
+
__publicField
|
|
15
|
+
} from "./chunk-V6TY7KAL.js";
|
|
16
|
+
|
|
17
|
+
// src/adapters/workers-ai-tts.ts
|
|
18
|
+
import { BaseTTSAdapter } from "@tanstack/ai/adapters";
|
|
19
|
+
var WorkersAiTTSAdapter = class extends BaseTTSAdapter {
|
|
20
|
+
constructor(config, model) {
|
|
21
|
+
super({}, model);
|
|
22
|
+
__publicField(this, "name", "workers-ai-tts");
|
|
23
|
+
__publicField(this, "adapterConfig");
|
|
24
|
+
this.adapterConfig = config;
|
|
25
|
+
}
|
|
26
|
+
async generateSpeech(options) {
|
|
27
|
+
const { text, voice, format, speed, modelOptions } = options;
|
|
28
|
+
const extra = { ...modelOptions };
|
|
29
|
+
if (voice) extra.voice = voice;
|
|
30
|
+
if (speed != null) extra.speed = speed;
|
|
31
|
+
if (isDirectBindingConfig(this.adapterConfig)) {
|
|
32
|
+
return this.generateViaBinding(text, format, extra);
|
|
33
|
+
}
|
|
34
|
+
if (isDirectCredentialsConfig(this.adapterConfig)) {
|
|
35
|
+
return this.generateViaRest(text, format, extra);
|
|
36
|
+
}
|
|
37
|
+
return this.generateViaGateway(text, format, extra);
|
|
38
|
+
}
|
|
39
|
+
async generateViaBinding(text, format, options) {
|
|
40
|
+
const ai = this.adapterConfig.binding;
|
|
41
|
+
const result = await ai.run(this.model, { text, ...options });
|
|
42
|
+
return this.normalizeResult(result, format);
|
|
43
|
+
}
|
|
44
|
+
async generateViaRest(text, format, options) {
|
|
45
|
+
const config = this.adapterConfig;
|
|
46
|
+
const response = await workersAiRestFetch(
|
|
47
|
+
config,
|
|
48
|
+
this.model,
|
|
49
|
+
{ text, ...options },
|
|
50
|
+
{ label: "Workers AI TTS", signal: options.signal }
|
|
51
|
+
);
|
|
52
|
+
const buffer = await response.arrayBuffer();
|
|
53
|
+
return this.wrapAudioResult(new Uint8Array(buffer), format);
|
|
54
|
+
}
|
|
55
|
+
async generateViaGateway(text, format, options) {
|
|
56
|
+
const gatewayConfig = this.adapterConfig;
|
|
57
|
+
const gatewayFetch = createGatewayFetch("workers-ai", gatewayConfig);
|
|
58
|
+
const response = await gatewayFetch("https://api.cloudflare.com/v1/audio/speech", {
|
|
59
|
+
method: "POST",
|
|
60
|
+
body: JSON.stringify({
|
|
61
|
+
model: this.model,
|
|
62
|
+
text,
|
|
63
|
+
...options
|
|
64
|
+
})
|
|
65
|
+
});
|
|
66
|
+
if (!response.ok) {
|
|
67
|
+
const errorText = await response.text();
|
|
68
|
+
throw new Error(
|
|
69
|
+
`Workers AI TTS gateway request failed (${response.status}): ${errorText}`
|
|
70
|
+
);
|
|
71
|
+
}
|
|
72
|
+
const buffer = await response.arrayBuffer();
|
|
73
|
+
return this.wrapAudioResult(new Uint8Array(buffer), format);
|
|
74
|
+
}
|
|
75
|
+
/**
|
|
76
|
+
* Normalize binding results. Workers AI TTS can return:
|
|
77
|
+
* - Uint8Array / ArrayBuffer (raw audio bytes)
|
|
78
|
+
* - ReadableStream<Uint8Array> (streamed audio bytes)
|
|
79
|
+
* - { audio: "base64..." } (JSON wrapper)
|
|
80
|
+
*/
|
|
81
|
+
async normalizeResult(result, format) {
|
|
82
|
+
const b64 = await binaryToBase64(result, "audio");
|
|
83
|
+
return {
|
|
84
|
+
id: this.generateId(),
|
|
85
|
+
model: this.model,
|
|
86
|
+
audio: b64,
|
|
87
|
+
format: format ?? "mp3",
|
|
88
|
+
contentType: `audio/${format ?? "mp3"}`
|
|
89
|
+
};
|
|
90
|
+
}
|
|
91
|
+
wrapAudioResult(bytes, format) {
|
|
92
|
+
return {
|
|
93
|
+
id: this.generateId(),
|
|
94
|
+
model: this.model,
|
|
95
|
+
audio: uint8ArrayToBase64(bytes),
|
|
96
|
+
format: format ?? "mp3",
|
|
97
|
+
contentType: `audio/${format ?? "mp3"}`
|
|
98
|
+
};
|
|
99
|
+
}
|
|
100
|
+
};
|
|
101
|
+
function createWorkersAiTts(model, config) {
|
|
102
|
+
return new WorkersAiTTSAdapter(config, model);
|
|
103
|
+
}
|
|
104
|
+
|
|
105
|
+
export {
|
|
106
|
+
WorkersAiTTSAdapter,
|
|
107
|
+
createWorkersAiTts
|
|
108
|
+
};
|
|
109
|
+
//# sourceMappingURL=chunk-ALUCJNDE.js.map
|
|
@@ -0,0 +1 @@
|
|
|
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} 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\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\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;AAkCxB,IAAM,sBAAN,cAAkC,eAAkC;AAAA,EAI1E,YAAY,QAAgC,OAA0B;AACrE,UAAM,CAAC,GAAG,KAAK;AAJhB,wBAAS,QAAO;AAChB,wBAAQ;AAIP,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":[]}
|
|
@@ -0,0 +1,96 @@
|
|
|
1
|
+
"use strict";Object.defineProperty(exports, "__esModule", {value: true});
|
|
2
|
+
|
|
3
|
+
|
|
4
|
+
var _chunk3VQDXJLWcjs = require('./chunk-3VQDXJLW.cjs');
|
|
5
|
+
|
|
6
|
+
|
|
7
|
+
var _chunk7HSUHP63cjs = require('./chunk-7HSUHP63.cjs');
|
|
8
|
+
|
|
9
|
+
|
|
10
|
+
|
|
11
|
+
|
|
12
|
+
var _chunk6FBIXTALcjs = require('./chunk-6FBIXTAL.cjs');
|
|
13
|
+
|
|
14
|
+
|
|
15
|
+
var _chunk4DE2IREAcjs = require('./chunk-4DE2IREA.cjs');
|
|
16
|
+
|
|
17
|
+
// src/adapters/workers-ai-image.ts
|
|
18
|
+
var _adapters = require('@tanstack/ai/adapters');
|
|
19
|
+
var WorkersAiImageAdapter = class extends _adapters.BaseImageAdapter {
|
|
20
|
+
constructor(config, model) {
|
|
21
|
+
super({}, model);
|
|
22
|
+
_chunk4DE2IREAcjs.__publicField.call(void 0, this, "name", "workers-ai-image");
|
|
23
|
+
_chunk4DE2IREAcjs.__publicField.call(void 0, this, "adapterConfig");
|
|
24
|
+
this.adapterConfig = config;
|
|
25
|
+
}
|
|
26
|
+
async generateImages(options) {
|
|
27
|
+
const { prompt, size, modelOptions } = options;
|
|
28
|
+
const extra = { ...modelOptions };
|
|
29
|
+
if (size) {
|
|
30
|
+
const [w, h] = size.split("x");
|
|
31
|
+
if (w) extra.width = Number(w);
|
|
32
|
+
if (h) extra.height = Number(h);
|
|
33
|
+
}
|
|
34
|
+
if (_chunk6FBIXTALcjs.isDirectBindingConfig.call(void 0, this.adapterConfig)) {
|
|
35
|
+
return this.generateViaBinding(prompt, extra);
|
|
36
|
+
}
|
|
37
|
+
if (_chunk6FBIXTALcjs.isDirectCredentialsConfig.call(void 0, this.adapterConfig)) {
|
|
38
|
+
return this.generateViaRest(prompt, extra);
|
|
39
|
+
}
|
|
40
|
+
return this.generateViaGateway(prompt, extra);
|
|
41
|
+
}
|
|
42
|
+
async generateViaBinding(prompt, options) {
|
|
43
|
+
const ai = this.adapterConfig.binding;
|
|
44
|
+
const result = await ai.run(this.model, { prompt, ...options });
|
|
45
|
+
const b64 = await _chunk3VQDXJLWcjs.binaryToBase64.call(void 0, result, "image");
|
|
46
|
+
return this.wrapResult(b64);
|
|
47
|
+
}
|
|
48
|
+
async generateViaRest(prompt, options) {
|
|
49
|
+
const config = this.adapterConfig;
|
|
50
|
+
const response = await _chunk7HSUHP63cjs.workersAiRestFetch.call(void 0,
|
|
51
|
+
config,
|
|
52
|
+
this.model,
|
|
53
|
+
{ prompt, ...options },
|
|
54
|
+
{ label: "Workers AI image", signal: options.signal }
|
|
55
|
+
);
|
|
56
|
+
const buffer = await response.arrayBuffer();
|
|
57
|
+
return this.wrapResult(_chunk3VQDXJLWcjs.uint8ArrayToBase64.call(void 0, new Uint8Array(buffer)));
|
|
58
|
+
}
|
|
59
|
+
async generateViaGateway(prompt, options) {
|
|
60
|
+
const gatewayConfig = this.adapterConfig;
|
|
61
|
+
const gatewayFetch = _chunk6FBIXTALcjs.createGatewayFetch.call(void 0, "workers-ai", gatewayConfig);
|
|
62
|
+
const response = await gatewayFetch("https://api.cloudflare.com/v1/images/generations", {
|
|
63
|
+
method: "POST",
|
|
64
|
+
body: JSON.stringify({
|
|
65
|
+
model: this.model,
|
|
66
|
+
prompt,
|
|
67
|
+
...options
|
|
68
|
+
})
|
|
69
|
+
});
|
|
70
|
+
if (!response.ok) {
|
|
71
|
+
const errorText = await response.text();
|
|
72
|
+
throw new Error(
|
|
73
|
+
`Workers AI image gateway request failed (${response.status}): ${errorText}`
|
|
74
|
+
);
|
|
75
|
+
}
|
|
76
|
+
const buffer = await response.arrayBuffer();
|
|
77
|
+
return this.wrapResult(_chunk3VQDXJLWcjs.uint8ArrayToBase64.call(void 0, new Uint8Array(buffer)));
|
|
78
|
+
}
|
|
79
|
+
/** Wrap a base64 image string into the standard ImageGenerationResult. */
|
|
80
|
+
wrapResult(b64) {
|
|
81
|
+
return {
|
|
82
|
+
id: this.generateId(),
|
|
83
|
+
model: this.model,
|
|
84
|
+
images: [{ b64Json: b64 }]
|
|
85
|
+
};
|
|
86
|
+
}
|
|
87
|
+
};
|
|
88
|
+
function createWorkersAiImage(model, config) {
|
|
89
|
+
return new WorkersAiImageAdapter(config, model);
|
|
90
|
+
}
|
|
91
|
+
|
|
92
|
+
|
|
93
|
+
|
|
94
|
+
|
|
95
|
+
exports.WorkersAiImageAdapter = WorkersAiImageAdapter; exports.createWorkersAiImage = createWorkersAiImage;
|
|
96
|
+
//# sourceMappingURL=chunk-AN23SOZX.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["/home/runner/work/ai/ai/packages/tanstack-ai/dist/chunk-AN23SOZX.cjs","../src/adapters/workers-ai-image.ts"],"names":[],"mappings":"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","file":"/home/runner/work/ai/ai/packages/tanstack-ai/dist/chunk-AN23SOZX.cjs","sourcesContent":[null,"import { BaseImageAdapter } from \"@tanstack/ai/adapters\";\nimport type { ImageGenerationOptions, ImageGenerationResult } from \"@tanstack/ai\";\nimport type { AiModels, BaseAiTextToImage } from \"@cloudflare/workers-types\";\nimport {\n\ttype WorkersAiAdapterConfig,\n\ttype WorkersAiDirectBindingConfig,\n\ttype AiGatewayAdapterConfig,\n\tcreateGatewayFetch,\n\tisDirectBindingConfig,\n\tisDirectCredentialsConfig,\n} from \"../utils/create-fetcher\";\nimport { workersAiRestFetch } from \"../utils/workers-ai-rest\";\nimport { binaryToBase64, uint8ArrayToBase64 } from \"../utils/binary\";\nimport type { WorkersAiDirectCredentialsConfig } from \"../utils/create-fetcher\";\n\n// ---------------------------------------------------------------------------\n// Model type derived from @cloudflare/workers-types\n// ---------------------------------------------------------------------------\n\nexport type WorkersAiImageModel = {\n\t[K in keyof AiModels]: AiModels[K] extends BaseAiTextToImage ? K : never;\n}[keyof AiModels];\n\n// ---------------------------------------------------------------------------\n// WorkersAiImageAdapter: image generation via Workers AI\n// Extends BaseImageAdapter so it works with TanStack AI's generateImage()\n// ---------------------------------------------------------------------------\n\nexport class WorkersAiImageAdapter extends BaseImageAdapter<WorkersAiImageModel> {\n\treadonly name = \"workers-ai-image\" as const;\n\tprivate adapterConfig: WorkersAiAdapterConfig;\n\n\tconstructor(config: WorkersAiAdapterConfig, model: WorkersAiImageModel) {\n\t\tsuper({}, model);\n\t\tthis.adapterConfig = config;\n\t}\n\n\tasync generateImages(options: ImageGenerationOptions): Promise<ImageGenerationResult> {\n\t\tconst { prompt, size, modelOptions } = options;\n\t\tconst extra: Record<string, unknown> = { ...modelOptions };\n\n\t\t// Note: Workers AI Stable Diffusion models only generate a single image\n\t\t// per request — there is no multi-image parameter. `numberOfImages` from\n\t\t// the TanStack AI options is intentionally not forwarded. Use\n\t\t// `modelOptions.num_steps` to control the number of diffusion steps.\n\n\t\tif (size) {\n\t\t\tconst [w, h] = size.split(\"x\");\n\t\t\tif (w) extra.width = Number(w);\n\t\t\tif (h) extra.height = Number(h);\n\t\t}\n\n\t\tif (isDirectBindingConfig(this.adapterConfig)) {\n\t\t\treturn this.generateViaBinding(prompt, extra);\n\t\t}\n\n\t\tif (isDirectCredentialsConfig(this.adapterConfig)) {\n\t\t\treturn this.generateViaRest(prompt, extra);\n\t\t}\n\n\t\t// Gateway mode\n\t\treturn this.generateViaGateway(prompt, extra);\n\t}\n\n\tprivate async generateViaBinding(\n\t\tprompt: string,\n\t\toptions: Record<string, unknown>,\n\t): Promise<ImageGenerationResult> {\n\t\tconst ai = (this.adapterConfig as WorkersAiDirectBindingConfig).binding;\n\t\tconst result = await ai.run(this.model, { prompt, ...options });\n\n\t\tconst b64 = await binaryToBase64(result, \"image\");\n\t\treturn this.wrapResult(b64);\n\t}\n\n\tprivate async generateViaRest(\n\t\tprompt: string,\n\t\toptions: Record<string, unknown>,\n\t): Promise<ImageGenerationResult> {\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{ prompt, ...options },\n\t\t\t{ label: \"Workers AI image\", signal: (options as { signal?: AbortSignal }).signal },\n\t\t);\n\n\t\tconst buffer = await response.arrayBuffer();\n\t\treturn this.wrapResult(uint8ArrayToBase64(new Uint8Array(buffer)));\n\t}\n\n\tprivate async generateViaGateway(\n\t\tprompt: string,\n\t\toptions: Record<string, unknown>,\n\t): Promise<ImageGenerationResult> {\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/images/generations\", {\n\t\t\tmethod: \"POST\",\n\t\t\tbody: JSON.stringify({\n\t\t\t\tmodel: this.model,\n\t\t\t\tprompt,\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 image 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.wrapResult(uint8ArrayToBase64(new Uint8Array(buffer)));\n\t}\n\n\t/** Wrap a base64 image string into the standard ImageGenerationResult. */\n\tprivate wrapResult(b64: string): ImageGenerationResult {\n\t\treturn {\n\t\t\tid: this.generateId(),\n\t\t\tmodel: this.model,\n\t\t\timages: [{ b64Json: b64 }],\n\t\t};\n\t}\n}\n\n// ---------------------------------------------------------------------------\n// Factory function\n// ---------------------------------------------------------------------------\n\n/**\n * Creates a Workers AI image generation adapter.\n *\n * Works with TanStack AI's `generateImage()` activity function:\n * ```ts\n * import { generateImage } from \"@tanstack/ai\";\n * import { createWorkersAiImage } from \"@cloudflare/tanstack-ai\";\n *\n * const adapter = createWorkersAiImage(\n * \"@cf/stabilityai/stable-diffusion-xl-base-1.0\",\n * { binding: env.AI },\n * );\n *\n * const result = await generateImage({ adapter, prompt: \"a cat in space\" });\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 createWorkersAiImage(model: WorkersAiImageModel, config: WorkersAiAdapterConfig) {\n\treturn new WorkersAiImageAdapter(config, model);\n}\n"]}
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
import {
|
|
2
|
+
createGatewayFetch
|
|
3
|
+
} from "./chunk-UUFEOQ6B.js";
|
|
4
|
+
|
|
5
|
+
// src/adapters/grok.ts
|
|
6
|
+
import {
|
|
7
|
+
GrokTextAdapter,
|
|
8
|
+
GrokImageAdapter,
|
|
9
|
+
GrokSummarizeAdapter,
|
|
10
|
+
GROK_CHAT_MODELS,
|
|
11
|
+
GROK_IMAGE_MODELS
|
|
12
|
+
} from "@tanstack/ai-grok";
|
|
13
|
+
function createGrokChat(model, config) {
|
|
14
|
+
return new GrokTextAdapter(
|
|
15
|
+
{
|
|
16
|
+
apiKey: config.apiKey ?? "unused",
|
|
17
|
+
fetch: createGatewayFetch("grok", config)
|
|
18
|
+
},
|
|
19
|
+
model
|
|
20
|
+
);
|
|
21
|
+
}
|
|
22
|
+
function createGrokImage(model, config) {
|
|
23
|
+
return new GrokImageAdapter(
|
|
24
|
+
{
|
|
25
|
+
apiKey: config.apiKey ?? "unused",
|
|
26
|
+
fetch: createGatewayFetch("grok", config)
|
|
27
|
+
},
|
|
28
|
+
model
|
|
29
|
+
);
|
|
30
|
+
}
|
|
31
|
+
function createGrokSummarize(model, config) {
|
|
32
|
+
return new GrokSummarizeAdapter(
|
|
33
|
+
{
|
|
34
|
+
apiKey: config.apiKey ?? "unused",
|
|
35
|
+
fetch: createGatewayFetch("grok", config)
|
|
36
|
+
},
|
|
37
|
+
model
|
|
38
|
+
);
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
export {
|
|
42
|
+
GROK_CHAT_MODELS,
|
|
43
|
+
GROK_IMAGE_MODELS,
|
|
44
|
+
createGrokChat,
|
|
45
|
+
createGrokImage,
|
|
46
|
+
createGrokSummarize
|
|
47
|
+
};
|
|
48
|
+
//# sourceMappingURL=chunk-F75IZQCM.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/adapters/grok.ts"],"sourcesContent":["import {\n\tGrokTextAdapter,\n\tGrokImageAdapter,\n\tGrokSummarizeAdapter,\n\tGROK_CHAT_MODELS,\n\tGROK_IMAGE_MODELS,\n\ttype GrokChatModel,\n\ttype GrokImageModel,\n\ttype GrokSummarizeModel,\n} from \"@tanstack/ai-grok\";\nimport { createGatewayFetch, type AiGatewayAdapterConfig } from \"../utils/create-fetcher\";\n\nexport type GrokGatewayConfig = AiGatewayAdapterConfig;\n\n/**\n * Creates a Grok chat adapter which uses Cloudflare AI Gateway.\n * Supports both binding and credential-based configurations.\n *\n * Since GrokTextConfig extends the OpenAI SDK's ClientOptions,\n * we can inject the gateway fetch directly — no subclassing needed.\n */\nexport function createGrokChat(model: GrokChatModel, config: GrokGatewayConfig) {\n\treturn new GrokTextAdapter(\n\t\t{\n\t\t\tapiKey: config.apiKey ?? \"unused\",\n\t\t\tfetch: createGatewayFetch(\"grok\", config),\n\t\t},\n\t\tmodel,\n\t);\n}\n\n/**\n * Creates a Grok image adapter which uses Cloudflare AI Gateway.\n * Supports both binding and credential-based configurations.\n */\nexport function createGrokImage(model: GrokImageModel, config: GrokGatewayConfig) {\n\treturn new GrokImageAdapter(\n\t\t{\n\t\t\tapiKey: config.apiKey ?? \"unused\",\n\t\t\tfetch: createGatewayFetch(\"grok\", config),\n\t\t},\n\t\tmodel,\n\t);\n}\n\n/**\n * Creates a Grok summarize adapter which uses Cloudflare AI Gateway.\n * Supports both binding and credential-based configurations.\n */\nexport function createGrokSummarize(model: GrokSummarizeModel, config: GrokGatewayConfig) {\n\treturn new GrokSummarizeAdapter(\n\t\t{\n\t\t\tapiKey: config.apiKey ?? \"unused\",\n\t\t\tfetch: createGatewayFetch(\"grok\", config),\n\t\t},\n\t\tmodel,\n\t);\n}\n\nexport {\n\tGROK_CHAT_MODELS,\n\tGROK_IMAGE_MODELS,\n\ttype GrokChatModel,\n\ttype GrokImageModel,\n\ttype GrokSummarizeModel,\n};\n"],"mappings":";;;;;AAAA;AAAA,EACC;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,OAIM;AAYA,SAAS,eAAe,OAAsB,QAA2B;AAC/E,SAAO,IAAI;AAAA,IACV;AAAA,MACC,QAAQ,OAAO,UAAU;AAAA,MACzB,OAAO,mBAAmB,QAAQ,MAAM;AAAA,IACzC;AAAA,IACA;AAAA,EACD;AACD;AAMO,SAAS,gBAAgB,OAAuB,QAA2B;AACjF,SAAO,IAAI;AAAA,IACV;AAAA,MACC,QAAQ,OAAO,UAAU;AAAA,MACzB,OAAO,mBAAmB,QAAQ,MAAM;AAAA,IACzC;AAAA,IACA;AAAA,EACD;AACD;AAMO,SAAS,oBAAoB,OAA2B,QAA2B;AACzF,SAAO,IAAI;AAAA,IACV;AAAA,MACC,QAAQ,OAAO,UAAU;AAAA,MACzB,OAAO,mBAAmB,QAAQ,MAAM;AAAA,IACzC;AAAA,IACA;AAAA,EACD;AACD;","names":[]}
|
|
@@ -0,0 +1,109 @@
|
|
|
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
|
+
var _chunk6FBIXTALcjs = require('./chunk-6FBIXTAL.cjs');
|
|
13
|
+
|
|
14
|
+
|
|
15
|
+
var _chunk4DE2IREAcjs = require('./chunk-4DE2IREA.cjs');
|
|
16
|
+
|
|
17
|
+
// src/adapters/workers-ai-tts.ts
|
|
18
|
+
var _adapters = require('@tanstack/ai/adapters');
|
|
19
|
+
var WorkersAiTTSAdapter = class extends _adapters.BaseTTSAdapter {
|
|
20
|
+
constructor(config, model) {
|
|
21
|
+
super({}, model);
|
|
22
|
+
_chunk4DE2IREAcjs.__publicField.call(void 0, this, "name", "workers-ai-tts");
|
|
23
|
+
_chunk4DE2IREAcjs.__publicField.call(void 0, this, "adapterConfig");
|
|
24
|
+
this.adapterConfig = config;
|
|
25
|
+
}
|
|
26
|
+
async generateSpeech(options) {
|
|
27
|
+
const { text, voice, format, speed, modelOptions } = options;
|
|
28
|
+
const extra = { ...modelOptions };
|
|
29
|
+
if (voice) extra.voice = voice;
|
|
30
|
+
if (speed != null) extra.speed = speed;
|
|
31
|
+
if (_chunk6FBIXTALcjs.isDirectBindingConfig.call(void 0, this.adapterConfig)) {
|
|
32
|
+
return this.generateViaBinding(text, format, extra);
|
|
33
|
+
}
|
|
34
|
+
if (_chunk6FBIXTALcjs.isDirectCredentialsConfig.call(void 0, this.adapterConfig)) {
|
|
35
|
+
return this.generateViaRest(text, format, extra);
|
|
36
|
+
}
|
|
37
|
+
return this.generateViaGateway(text, format, extra);
|
|
38
|
+
}
|
|
39
|
+
async generateViaBinding(text, format, options) {
|
|
40
|
+
const ai = this.adapterConfig.binding;
|
|
41
|
+
const result = await ai.run(this.model, { text, ...options });
|
|
42
|
+
return this.normalizeResult(result, format);
|
|
43
|
+
}
|
|
44
|
+
async generateViaRest(text, format, options) {
|
|
45
|
+
const config = this.adapterConfig;
|
|
46
|
+
const response = await _chunk7HSUHP63cjs.workersAiRestFetch.call(void 0,
|
|
47
|
+
config,
|
|
48
|
+
this.model,
|
|
49
|
+
{ text, ...options },
|
|
50
|
+
{ label: "Workers AI TTS", signal: options.signal }
|
|
51
|
+
);
|
|
52
|
+
const buffer = await response.arrayBuffer();
|
|
53
|
+
return this.wrapAudioResult(new Uint8Array(buffer), format);
|
|
54
|
+
}
|
|
55
|
+
async generateViaGateway(text, format, options) {
|
|
56
|
+
const gatewayConfig = this.adapterConfig;
|
|
57
|
+
const gatewayFetch = _chunk6FBIXTALcjs.createGatewayFetch.call(void 0, "workers-ai", gatewayConfig);
|
|
58
|
+
const response = await gatewayFetch("https://api.cloudflare.com/v1/audio/speech", {
|
|
59
|
+
method: "POST",
|
|
60
|
+
body: JSON.stringify({
|
|
61
|
+
model: this.model,
|
|
62
|
+
text,
|
|
63
|
+
...options
|
|
64
|
+
})
|
|
65
|
+
});
|
|
66
|
+
if (!response.ok) {
|
|
67
|
+
const errorText = await response.text();
|
|
68
|
+
throw new Error(
|
|
69
|
+
`Workers AI TTS gateway request failed (${response.status}): ${errorText}`
|
|
70
|
+
);
|
|
71
|
+
}
|
|
72
|
+
const buffer = await response.arrayBuffer();
|
|
73
|
+
return this.wrapAudioResult(new Uint8Array(buffer), format);
|
|
74
|
+
}
|
|
75
|
+
/**
|
|
76
|
+
* Normalize binding results. Workers AI TTS can return:
|
|
77
|
+
* - Uint8Array / ArrayBuffer (raw audio bytes)
|
|
78
|
+
* - ReadableStream<Uint8Array> (streamed audio bytes)
|
|
79
|
+
* - { audio: "base64..." } (JSON wrapper)
|
|
80
|
+
*/
|
|
81
|
+
async normalizeResult(result, format) {
|
|
82
|
+
const b64 = await _chunk3VQDXJLWcjs.binaryToBase64.call(void 0, result, "audio");
|
|
83
|
+
return {
|
|
84
|
+
id: this.generateId(),
|
|
85
|
+
model: this.model,
|
|
86
|
+
audio: b64,
|
|
87
|
+
format: _nullishCoalesce(format, () => ( "mp3")),
|
|
88
|
+
contentType: `audio/${_nullishCoalesce(format, () => ( "mp3"))}`
|
|
89
|
+
};
|
|
90
|
+
}
|
|
91
|
+
wrapAudioResult(bytes, format) {
|
|
92
|
+
return {
|
|
93
|
+
id: this.generateId(),
|
|
94
|
+
model: this.model,
|
|
95
|
+
audio: _chunk3VQDXJLWcjs.uint8ArrayToBase64.call(void 0, bytes),
|
|
96
|
+
format: _nullishCoalesce(format, () => ( "mp3")),
|
|
97
|
+
contentType: `audio/${_nullishCoalesce(format, () => ( "mp3"))}`
|
|
98
|
+
};
|
|
99
|
+
}
|
|
100
|
+
};
|
|
101
|
+
function createWorkersAiTts(model, config) {
|
|
102
|
+
return new WorkersAiTTSAdapter(config, model);
|
|
103
|
+
}
|
|
104
|
+
|
|
105
|
+
|
|
106
|
+
|
|
107
|
+
|
|
108
|
+
exports.WorkersAiTTSAdapter = WorkersAiTTSAdapter; exports.createWorkersAiTts = createWorkersAiTts;
|
|
109
|
+
//# sourceMappingURL=chunk-GL2EQLMI.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["/home/runner/work/ai/ai/packages/tanstack-ai/dist/chunk-GL2EQLMI.cjs","../src/adapters/workers-ai-tts.ts"],"names":[],"mappings":"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","file":"/home/runner/work/ai/ai/packages/tanstack-ai/dist/chunk-GL2EQLMI.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} 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\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\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"]}
|
|
@@ -0,0 +1,84 @@
|
|
|
1
|
+
"use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _nullishCoalesce(lhs, rhsFn) { if (lhs != null) { return lhs; } else { return rhsFn(); } } function _optionalChain(ops) { let lastAccessLHS = undefined; let value = ops[0]; let i = 1; while (i < ops.length) { const op = ops[i]; const fn = ops[i + 1]; i += 2; if ((op === 'optionalAccess' || op === 'optionalCall') && value == null) { return undefined; } if (op === 'access' || op === 'optionalAccess') { lastAccessLHS = value; value = fn(value); } else if (op === 'call' || op === 'optionalCall') { value = fn((...args) => value.call(lastAccessLHS, ...args)); lastAccessLHS = undefined; } } return value; }
|
|
2
|
+
|
|
3
|
+
var _chunk7HSUHP63cjs = require('./chunk-7HSUHP63.cjs');
|
|
4
|
+
|
|
5
|
+
|
|
6
|
+
|
|
7
|
+
|
|
8
|
+
var _chunk6FBIXTALcjs = require('./chunk-6FBIXTAL.cjs');
|
|
9
|
+
|
|
10
|
+
|
|
11
|
+
var _chunk4DE2IREAcjs = require('./chunk-4DE2IREA.cjs');
|
|
12
|
+
|
|
13
|
+
// src/adapters/workers-ai-summarize.ts
|
|
14
|
+
var _adapters = require('@tanstack/ai/adapters');
|
|
15
|
+
var WorkersAiSummarizeAdapter = class extends _adapters.BaseSummarizeAdapter {
|
|
16
|
+
constructor(config, model) {
|
|
17
|
+
super({}, model);
|
|
18
|
+
_chunk4DE2IREAcjs.__publicField.call(void 0, this, "name", "workers-ai-summarize");
|
|
19
|
+
_chunk4DE2IREAcjs.__publicField.call(void 0, this, "adapterConfig");
|
|
20
|
+
this.adapterConfig = config;
|
|
21
|
+
}
|
|
22
|
+
async summarize(options) {
|
|
23
|
+
const { text, maxLength } = options;
|
|
24
|
+
const payload = { input_text: text };
|
|
25
|
+
if (maxLength != null) payload.max_length = maxLength;
|
|
26
|
+
if (_chunk6FBIXTALcjs.isDirectBindingConfig.call(void 0, this.adapterConfig)) {
|
|
27
|
+
return this.summarizeViaBinding(payload);
|
|
28
|
+
}
|
|
29
|
+
if (_chunk6FBIXTALcjs.isDirectCredentialsConfig.call(void 0, this.adapterConfig)) {
|
|
30
|
+
return this.summarizeViaRest(payload);
|
|
31
|
+
}
|
|
32
|
+
return this.summarizeViaGateway(payload);
|
|
33
|
+
}
|
|
34
|
+
async summarizeViaBinding(payload) {
|
|
35
|
+
const ai = this.adapterConfig.binding;
|
|
36
|
+
const result = await ai.run(this.model, payload);
|
|
37
|
+
return this.wrapResult(_nullishCoalesce(result.summary, () => ( "")));
|
|
38
|
+
}
|
|
39
|
+
async summarizeViaRest(payload) {
|
|
40
|
+
const config = this.adapterConfig;
|
|
41
|
+
const response = await _chunk7HSUHP63cjs.workersAiRestFetch.call(void 0, config, this.model, payload, {
|
|
42
|
+
label: "Workers AI summarize"
|
|
43
|
+
});
|
|
44
|
+
const data = await response.json();
|
|
45
|
+
return this.wrapResult(_nullishCoalesce(_optionalChain([data, 'access', _ => _.result, 'optionalAccess', _2 => _2.summary]), () => ( "")));
|
|
46
|
+
}
|
|
47
|
+
async summarizeViaGateway(payload) {
|
|
48
|
+
const gatewayConfig = this.adapterConfig;
|
|
49
|
+
const gatewayFetch = _chunk6FBIXTALcjs.createGatewayFetch.call(void 0, "workers-ai", gatewayConfig);
|
|
50
|
+
const response = await gatewayFetch("https://api.cloudflare.com/v1/ai/summarization", {
|
|
51
|
+
method: "POST",
|
|
52
|
+
body: JSON.stringify({
|
|
53
|
+
model: this.model,
|
|
54
|
+
...payload
|
|
55
|
+
})
|
|
56
|
+
});
|
|
57
|
+
if (!response.ok) {
|
|
58
|
+
const errorText = await response.text();
|
|
59
|
+
throw new Error(
|
|
60
|
+
`Workers AI summarize gateway request failed (${response.status}): ${errorText}`
|
|
61
|
+
);
|
|
62
|
+
}
|
|
63
|
+
const data = await response.json();
|
|
64
|
+
return this.wrapResult(_nullishCoalesce(_nullishCoalesce(_optionalChain([data, 'access', _3 => _3.result, 'optionalAccess', _4 => _4.summary]), () => ( data.summary)), () => ( "")));
|
|
65
|
+
}
|
|
66
|
+
wrapResult(summary) {
|
|
67
|
+
return {
|
|
68
|
+
id: this.generateId(),
|
|
69
|
+
model: this.model,
|
|
70
|
+
summary,
|
|
71
|
+
// BART-large-CNN doesn't return token usage
|
|
72
|
+
usage: { promptTokens: 0, completionTokens: 0, totalTokens: 0 }
|
|
73
|
+
};
|
|
74
|
+
}
|
|
75
|
+
};
|
|
76
|
+
function createWorkersAiSummarize(model, config) {
|
|
77
|
+
return new WorkersAiSummarizeAdapter(config, model);
|
|
78
|
+
}
|
|
79
|
+
|
|
80
|
+
|
|
81
|
+
|
|
82
|
+
|
|
83
|
+
exports.WorkersAiSummarizeAdapter = WorkersAiSummarizeAdapter; exports.createWorkersAiSummarize = createWorkersAiSummarize;
|
|
84
|
+
//# sourceMappingURL=chunk-M64PETK7.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["/home/runner/work/ai/ai/packages/tanstack-ai/dist/chunk-M64PETK7.cjs","../src/adapters/workers-ai-summarize.ts"],"names":[],"mappings":"AAAA;AACE;AACF,wDAA6B;AAC7B;AACE;AACA;AACA;AACF,wDAA6B;AAC7B;AACE;AACF,wDAA6B;AAC7B;AACA;ACZA,iDAAqC;AA0B9B,IAAM,0BAAA,EAAN,MAAA,QAAwC,+BAA8C;AAAA,EAI5F,WAAA,CAAY,MAAA,EAAgC,KAAA,EAAgC;AAC3E,IAAA,KAAA,CAAM,CAAC,CAAA,EAAG,KAAK,CAAA;AAJhB,IAAA,6CAAA,IAAA,EAAS,MAAA,EAAO,sBAAA,CAAA;AAChB,IAAA,6CAAA,IAAA,EAAQ,eAAA,CAAA;AAIP,IAAA,IAAA,CAAK,cAAA,EAAgB,MAAA;AAAA,EACtB;AAAA,EAEA,MAAM,SAAA,CAAU,OAAA,EAA6D;AAC5E,IAAA,MAAM,EAAE,IAAA,EAAM,UAAU,EAAA,EAAI,OAAA;AAE5B,IAAA,MAAM,QAAA,EAAmC,EAAE,UAAA,EAAY,KAAK,CAAA;AAC5D,IAAA,GAAA,CAAI,UAAA,GAAa,IAAA,EAAM,OAAA,CAAQ,WAAA,EAAa,SAAA;AAE5C,IAAA,GAAA,CAAI,qDAAA,IAAsB,CAAK,aAAa,CAAA,EAAG;AAC9C,MAAA,OAAO,IAAA,CAAK,mBAAA,CAAoB,OAAO,CAAA;AAAA,IACxC;AAEA,IAAA,GAAA,CAAI,yDAAA,IAA0B,CAAK,aAAa,CAAA,EAAG;AAClD,MAAA,OAAO,IAAA,CAAK,gBAAA,CAAiB,OAAO,CAAA;AAAA,IACrC;AAEA,IAAA,OAAO,IAAA,CAAK,mBAAA,CAAoB,OAAO,CAAA;AAAA,EACxC;AAAA,EAEA,MAAc,mBAAA,CACb,OAAA,EAC+B;AAC/B,IAAA,MAAM,GAAA,EAAM,IAAA,CAAK,aAAA,CAA+C,OAAA;AAChE,IAAA,MAAM,OAAA,EAAU,MAAM,EAAA,CAAG,GAAA,CAAI,IAAA,CAAK,KAAA,EAAO,OAAO,CAAA;AAChD,IAAA,OAAO,IAAA,CAAK,UAAA,kBAAY,MAAA,CAAO,OAAA,UAAsB,IAAE,CAAA;AAAA,EACxD;AAAA,EAEA,MAAc,gBAAA,CAAiB,OAAA,EAAgE;AAC9F,IAAA,MAAM,OAAA,EAAS,IAAA,CAAK,aAAA;AACpB,IAAA,MAAM,SAAA,EAAW,MAAM,kDAAA,MAAmB,EAAQ,IAAA,CAAK,KAAA,EAAO,OAAA,EAAS;AAAA,MACtE,KAAA,EAAO;AAAA,IACR,CAAC,CAAA;AAED,IAAA,MAAM,KAAA,EAAQ,MAAM,QAAA,CAAS,IAAA,CAAK,CAAA;AAClC,IAAA,OAAO,IAAA,CAAK,UAAA,kCAAW,IAAA,mBAAK,MAAA,6BAAQ,SAAA,UAAW,IAAE,CAAA;AAAA,EAClD;AAAA,EAEA,MAAc,mBAAA,CACb,OAAA,EAC+B;AAC/B,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,gDAAA,EAAkD;AAAA,MACrF,MAAA,EAAQ,MAAA;AAAA,MACR,IAAA,EAAM,IAAA,CAAK,SAAA,CAAU;AAAA,QACpB,KAAA,EAAO,IAAA,CAAK,KAAA;AAAA,QACZ,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,6CAAA,EAAgD,QAAA,CAAS,MAAM,CAAA,GAAA,EAAM,SAAS,CAAA;AAAA,MAAA;AAC/E,IAAA;AAGD,IAAA;AACA,IAAA;AAAiE,EAAA;AAClE,EAAA;AAGC,IAAA;AAAO,MAAA;AACc,MAAA;AACR,MAAA;AACZ;AAAA,MAAA;AAE8D,IAAA;AAC/D,EAAA;AAEF;AAyBO;AAIN,EAAA;AACD;AD3DA;AACA;AACA;AACA;AACA","file":"/home/runner/work/ai/ai/packages/tanstack-ai/dist/chunk-M64PETK7.cjs","sourcesContent":[null,"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} 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\";\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\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"]}
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
"use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _nullishCoalesce(lhs, rhsFn) { if (lhs != null) { return lhs; } else { return rhsFn(); } }
|
|
2
|
+
|
|
3
|
+
var _chunk6FBIXTALcjs = require('./chunk-6FBIXTAL.cjs');
|
|
4
|
+
|
|
5
|
+
// src/adapters/openai.ts
|
|
6
|
+
|
|
7
|
+
|
|
8
|
+
|
|
9
|
+
|
|
10
|
+
|
|
11
|
+
|
|
12
|
+
|
|
13
|
+
|
|
14
|
+
|
|
15
|
+
|
|
16
|
+
|
|
17
|
+
|
|
18
|
+
var _aiopenai = require('@tanstack/ai-openai');
|
|
19
|
+
function buildOpenAiConfig(provider, config) {
|
|
20
|
+
return {
|
|
21
|
+
apiKey: _nullishCoalesce(config.apiKey, () => ( "unused")),
|
|
22
|
+
fetch: _chunk6FBIXTALcjs.createGatewayFetch.call(void 0, provider, config)
|
|
23
|
+
};
|
|
24
|
+
}
|
|
25
|
+
function createOpenAiChat(model, config) {
|
|
26
|
+
return new (0, _aiopenai.OpenAITextAdapter)(buildOpenAiConfig("openai", config), model);
|
|
27
|
+
}
|
|
28
|
+
function createOpenAiSummarize(model, config) {
|
|
29
|
+
return new (0, _aiopenai.OpenAISummarizeAdapter)(buildOpenAiConfig("openai", config), model);
|
|
30
|
+
}
|
|
31
|
+
function createOpenAiImage(model, config) {
|
|
32
|
+
return new (0, _aiopenai.OpenAIImageAdapter)(buildOpenAiConfig("openai", config), model);
|
|
33
|
+
}
|
|
34
|
+
function createOpenAiTranscription(model, config) {
|
|
35
|
+
return new (0, _aiopenai.OpenAITranscriptionAdapter)(buildOpenAiConfig("openai", config), model);
|
|
36
|
+
}
|
|
37
|
+
function createOpenAiTts(model, config) {
|
|
38
|
+
return new (0, _aiopenai.OpenAITTSAdapter)(buildOpenAiConfig("openai", config), model);
|
|
39
|
+
}
|
|
40
|
+
function createOpenAiVideo(model, config) {
|
|
41
|
+
return new (0, _aiopenai.OpenAIVideoAdapter)(buildOpenAiConfig("openai", config), model);
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
|
|
45
|
+
|
|
46
|
+
|
|
47
|
+
|
|
48
|
+
|
|
49
|
+
|
|
50
|
+
|
|
51
|
+
|
|
52
|
+
|
|
53
|
+
|
|
54
|
+
|
|
55
|
+
|
|
56
|
+
exports.OPENAI_CHAT_MODELS = _aiopenai.OPENAI_CHAT_MODELS; exports.OPENAI_IMAGE_MODELS = _aiopenai.OPENAI_IMAGE_MODELS; exports.OPENAI_TRANSCRIPTION_MODELS = _aiopenai.OPENAI_TRANSCRIPTION_MODELS; exports.OPENAI_TTS_MODELS = _aiopenai.OPENAI_TTS_MODELS; exports.OPENAI_VIDEO_MODELS = _aiopenai.OPENAI_VIDEO_MODELS; exports.createOpenAiChat = createOpenAiChat; exports.createOpenAiSummarize = createOpenAiSummarize; exports.createOpenAiImage = createOpenAiImage; exports.createOpenAiTranscription = createOpenAiTranscription; exports.createOpenAiTts = createOpenAiTts; exports.createOpenAiVideo = createOpenAiVideo;
|
|
57
|
+
//# sourceMappingURL=chunk-OV65IEEY.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["/home/runner/work/ai/ai/packages/tanstack-ai/dist/chunk-OV65IEEY.cjs","../src/adapters/openai.ts"],"names":[],"mappings":"AAAA;AACE;AACF,wDAA6B;AAC7B;AACA;ACJA;AACC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA,+CAMM;AASP,SAAS,iBAAA,CAAkB,QAAA,EAAkB,MAAA,EAA6B;AACzE,EAAA,OAAO;AAAA,IACN,MAAA,mBAAQ,MAAA,CAAO,MAAA,UAAU,UAAA;AAAA,IACzB,KAAA,EAAO,kDAAA,QAAmB,EAAU,MAAM;AAAA,EAC3C,CAAA;AACD;AAQO,SAAS,gBAAA,CAAiB,KAAA,EAAwB,MAAA,EAA6B;AACrF,EAAA,OAAO,IAAI,gCAAA,CAAkB,iBAAA,CAAkB,QAAA,EAAU,MAAM,CAAA,EAAG,KAAK,CAAA;AACxE;AAOO,SAAS,qBAAA,CAAsB,KAAA,EAAwB,MAAA,EAA6B;AAC1F,EAAA,OAAO,IAAI,qCAAA,CAAuB,iBAAA,CAAkB,QAAA,EAAU,MAAM,CAAA,EAAG,KAAK,CAAA;AAC7E;AAOO,SAAS,iBAAA,CAAkB,KAAA,EAAyB,MAAA,EAA6B;AACvF,EAAA,OAAO,IAAI,iCAAA,CAAmB,iBAAA,CAAkB,QAAA,EAAU,MAAM,CAAA,EAAG,KAAK,CAAA;AACzE;AAOO,SAAS,yBAAA,CACf,KAAA,EACA,MAAA,EACC;AACD,EAAA,OAAO,IAAI,yCAAA,CAA2B,iBAAA,CAAkB,QAAA,EAAU,MAAM,CAAA,EAAG,KAAK,CAAA;AACjF;AAOO,SAAS,eAAA,CAAgB,KAAA,EAAuB,MAAA,EAA6B;AACnF,EAAA,OAAO,IAAI,+BAAA,CAAiB,iBAAA,CAAkB,QAAA,EAAU,MAAM,CAAA,EAAG,KAAK,CAAA;AACvE;AAOO,SAAS,iBAAA,CAAkB,KAAA,EAAyB,MAAA,EAA6B;AACvF,EAAA,OAAO,IAAI,iCAAA,CAAmB,iBAAA,CAAkB,QAAA,EAAU,MAAM,CAAA,EAAG,KAAK,CAAA;AACzE;AD/CA;AACA;AACE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACF,smBAAC","file":"/home/runner/work/ai/ai/packages/tanstack-ai/dist/chunk-OV65IEEY.cjs","sourcesContent":[null,"import {\n\tOpenAIImageAdapter,\n\tOpenAISummarizeAdapter,\n\tOpenAITextAdapter,\n\tOpenAITranscriptionAdapter,\n\tOpenAITTSAdapter,\n\tOpenAIVideoAdapter,\n\tOPENAI_CHAT_MODELS,\n\tOPENAI_IMAGE_MODELS,\n\tOPENAI_TRANSCRIPTION_MODELS,\n\tOPENAI_TTS_MODELS,\n\tOPENAI_VIDEO_MODELS,\n\ttype OpenAIChatModel,\n\ttype OpenAIImageModel,\n\ttype OpenAITranscriptionModel,\n\ttype OpenAITTSModel,\n\ttype OpenAIVideoModel,\n} from \"@tanstack/ai-openai\";\nimport { createGatewayFetch, type AiGatewayAdapterConfig } from \"../utils/create-fetcher\";\n\nexport type OpenAiGatewayConfig = AiGatewayAdapterConfig;\n\n/**\n * Builds an OpenAI-compatible config that injects the gateway fetch.\n * OpenAITextConfig extends OpenAI SDK's ClientOptions, which supports a `fetch` parameter.\n */\nfunction buildOpenAiConfig(provider: string, config: OpenAiGatewayConfig) {\n\treturn {\n\t\tapiKey: config.apiKey ?? \"unused\",\n\t\tfetch: createGatewayFetch(provider, config),\n\t};\n}\n\n/**\n * Creates an OpenAI chat adapter which uses Cloudflare AI Gateway.\n * Supports both binding and credential-based configurations.\n * @param model The OpenAI model to use\n * @param config Configuration options\n */\nexport function createOpenAiChat(model: OpenAIChatModel, config: OpenAiGatewayConfig) {\n\treturn new OpenAITextAdapter(buildOpenAiConfig(\"openai\", config), model);\n}\n\n/**\n * Creates an OpenAI summarize adapter which uses Cloudflare AI Gateway.\n * @param model The OpenAI model to use\n * @param config Configuration options\n */\nexport function createOpenAiSummarize(model: OpenAIChatModel, config: OpenAiGatewayConfig) {\n\treturn new OpenAISummarizeAdapter(buildOpenAiConfig(\"openai\", config), model);\n}\n\n/**\n * Creates an OpenAI image adapter which uses Cloudflare AI Gateway.\n * @param model The OpenAI image model to use\n * @param config Configuration options\n */\nexport function createOpenAiImage(model: OpenAIImageModel, config: OpenAiGatewayConfig) {\n\treturn new OpenAIImageAdapter(buildOpenAiConfig(\"openai\", config), model);\n}\n\n/**\n * Creates an OpenAI transcription adapter which uses Cloudflare AI Gateway.\n * @param model The OpenAI transcription model to use\n * @param config Configuration options\n */\nexport function createOpenAiTranscription(\n\tmodel: OpenAITranscriptionModel,\n\tconfig: OpenAiGatewayConfig,\n) {\n\treturn new OpenAITranscriptionAdapter(buildOpenAiConfig(\"openai\", config), model);\n}\n\n/**\n * Creates an OpenAI TTS adapter which uses Cloudflare AI Gateway.\n * @param model The OpenAI TTS model to use\n * @param config Configuration options\n */\nexport function createOpenAiTts(model: OpenAITTSModel, config: OpenAiGatewayConfig) {\n\treturn new OpenAITTSAdapter(buildOpenAiConfig(\"openai\", config), model);\n}\n\n/**\n * Creates an OpenAI video adapter which uses Cloudflare AI Gateway.\n * @param model The OpenAI video model to use\n * @param config Configuration options\n */\nexport function createOpenAiVideo(model: OpenAIVideoModel, config: OpenAiGatewayConfig) {\n\treturn new OpenAIVideoAdapter(buildOpenAiConfig(\"openai\", config), model);\n}\n\nexport {\n\tOPENAI_CHAT_MODELS,\n\tOPENAI_IMAGE_MODELS,\n\tOPENAI_TRANSCRIPTION_MODELS,\n\tOPENAI_TTS_MODELS,\n\tOPENAI_VIDEO_MODELS,\n\ttype OpenAIChatModel,\n\ttype OpenAIImageModel,\n\ttype OpenAITranscriptionModel,\n\ttype OpenAITTSModel,\n\ttype OpenAIVideoModel,\n};\n"]}
|