@ai-sdk/lmnt 3.0.0-beta.4 → 3.0.0-beta.50
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/CHANGELOG.md +378 -0
- package/README.md +3 -1
- package/dist/index.d.ts +34 -24
- package/dist/index.js +79 -61
- package/dist/index.js.map +1 -1
- package/docs/140-lmnt.mdx +2 -2
- package/package.json +14 -14
- package/src/index.ts +1 -1
- package/src/lmnt-config.ts +2 -2
- package/src/lmnt-provider.ts +33 -4
- package/src/lmnt-speech-model-options.ts +69 -0
- package/src/lmnt-speech-model.ts +23 -74
- package/dist/index.d.mts +0 -89
- package/dist/index.mjs +0 -216
- package/dist/index.mjs.map +0 -1
package/dist/index.js
CHANGED
|
@@ -1,99 +1,87 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __defProp = Object.defineProperty;
|
|
3
|
-
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
-
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
-
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
-
var __export = (target, all) => {
|
|
7
|
-
for (var name in all)
|
|
8
|
-
__defProp(target, name, { get: all[name], enumerable: true });
|
|
9
|
-
};
|
|
10
|
-
var __copyProps = (to, from, except, desc) => {
|
|
11
|
-
if (from && typeof from === "object" || typeof from === "function") {
|
|
12
|
-
for (let key of __getOwnPropNames(from))
|
|
13
|
-
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
14
|
-
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
15
|
-
}
|
|
16
|
-
return to;
|
|
17
|
-
};
|
|
18
|
-
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
19
|
-
|
|
20
|
-
// src/index.ts
|
|
21
|
-
var index_exports = {};
|
|
22
|
-
__export(index_exports, {
|
|
23
|
-
VERSION: () => VERSION,
|
|
24
|
-
createLMNT: () => createLMNT,
|
|
25
|
-
lmnt: () => lmnt
|
|
26
|
-
});
|
|
27
|
-
module.exports = __toCommonJS(index_exports);
|
|
28
|
-
|
|
29
1
|
// src/lmnt-provider.ts
|
|
30
|
-
|
|
2
|
+
import {
|
|
3
|
+
NoSuchModelError
|
|
4
|
+
} from "@ai-sdk/provider";
|
|
5
|
+
import {
|
|
6
|
+
loadApiKey,
|
|
7
|
+
withUserAgentSuffix
|
|
8
|
+
} from "@ai-sdk/provider-utils";
|
|
31
9
|
|
|
32
10
|
// src/lmnt-speech-model.ts
|
|
33
|
-
|
|
34
|
-
|
|
11
|
+
import {
|
|
12
|
+
combineHeaders,
|
|
13
|
+
createBinaryResponseHandler,
|
|
14
|
+
parseProviderOptions,
|
|
15
|
+
postJsonToApi,
|
|
16
|
+
serializeModelOptions,
|
|
17
|
+
WORKFLOW_SERIALIZE,
|
|
18
|
+
WORKFLOW_DESERIALIZE
|
|
19
|
+
} from "@ai-sdk/provider-utils";
|
|
35
20
|
|
|
36
21
|
// src/lmnt-error.ts
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
var lmntErrorDataSchema =
|
|
40
|
-
error:
|
|
41
|
-
message:
|
|
42
|
-
code:
|
|
22
|
+
import { z } from "zod/v4";
|
|
23
|
+
import { createJsonErrorResponseHandler } from "@ai-sdk/provider-utils";
|
|
24
|
+
var lmntErrorDataSchema = z.object({
|
|
25
|
+
error: z.object({
|
|
26
|
+
message: z.string(),
|
|
27
|
+
code: z.number()
|
|
43
28
|
})
|
|
44
29
|
});
|
|
45
|
-
var lmntFailedResponseHandler =
|
|
30
|
+
var lmntFailedResponseHandler = createJsonErrorResponseHandler({
|
|
46
31
|
errorSchema: lmntErrorDataSchema,
|
|
47
32
|
errorToMessage: (data) => data.error.message
|
|
48
33
|
});
|
|
49
34
|
|
|
50
|
-
// src/lmnt-speech-model.ts
|
|
51
|
-
|
|
35
|
+
// src/lmnt-speech-model-options.ts
|
|
36
|
+
import { z as z2 } from "zod/v4";
|
|
37
|
+
var lmntSpeechModelOptionsSchema = z2.object({
|
|
52
38
|
/**
|
|
53
39
|
* The model to use for speech synthesis e.g. 'aurora' or 'blizzard'.
|
|
54
40
|
* @default 'aurora'
|
|
55
41
|
*/
|
|
56
|
-
model:
|
|
42
|
+
model: z2.union([z2.enum(["aurora", "blizzard"]), z2.string()]).nullish().default("aurora"),
|
|
57
43
|
/**
|
|
58
44
|
* The audio format of the output.
|
|
59
45
|
* @default 'mp3'
|
|
60
46
|
*/
|
|
61
|
-
format:
|
|
47
|
+
format: z2.enum(["aac", "mp3", "mulaw", "raw", "wav"]).nullish().default("mp3"),
|
|
62
48
|
/**
|
|
63
49
|
* The sample rate of the output audio in Hz.
|
|
64
50
|
* @default 24000
|
|
65
51
|
*/
|
|
66
|
-
sampleRate:
|
|
52
|
+
sampleRate: z2.union([z2.literal(8e3), z2.literal(16e3), z2.literal(24e3)]).nullish().default(24e3),
|
|
67
53
|
/**
|
|
68
54
|
* The speed of the speech. Range: 0.25 to 2.
|
|
69
55
|
* @default 1
|
|
70
56
|
*/
|
|
71
|
-
speed:
|
|
57
|
+
speed: z2.number().min(0.25).max(2).nullish().default(1),
|
|
72
58
|
/**
|
|
73
59
|
* A seed value for deterministic generation.
|
|
74
60
|
*/
|
|
75
|
-
seed:
|
|
61
|
+
seed: z2.number().int().nullish(),
|
|
76
62
|
/**
|
|
77
63
|
* Whether to use a conversational style.
|
|
78
64
|
* @default false
|
|
79
65
|
*/
|
|
80
|
-
conversational:
|
|
66
|
+
conversational: z2.boolean().nullish().default(false),
|
|
81
67
|
/**
|
|
82
68
|
* Maximum length of the output in seconds (up to 300).
|
|
83
69
|
*/
|
|
84
|
-
length:
|
|
70
|
+
length: z2.number().max(300).nullish(),
|
|
85
71
|
/**
|
|
86
72
|
* Top-p sampling parameter. Range: 0 to 1.
|
|
87
73
|
* @default 1
|
|
88
74
|
*/
|
|
89
|
-
topP:
|
|
75
|
+
topP: z2.number().min(0).max(1).nullish().default(1),
|
|
90
76
|
/**
|
|
91
77
|
* Temperature for sampling. Higher values increase randomness.
|
|
92
78
|
* @default 1
|
|
93
79
|
*/
|
|
94
|
-
temperature:
|
|
80
|
+
temperature: z2.number().min(0).nullish().default(1)
|
|
95
81
|
});
|
|
96
|
-
|
|
82
|
+
|
|
83
|
+
// src/lmnt-speech-model.ts
|
|
84
|
+
var LMNTSpeechModel = class _LMNTSpeechModel {
|
|
97
85
|
constructor(modelId, config) {
|
|
98
86
|
this.modelId = modelId;
|
|
99
87
|
this.config = config;
|
|
@@ -102,6 +90,15 @@ var LMNTSpeechModel = class {
|
|
|
102
90
|
get provider() {
|
|
103
91
|
return this.config.provider;
|
|
104
92
|
}
|
|
93
|
+
static [WORKFLOW_SERIALIZE](model) {
|
|
94
|
+
return serializeModelOptions({
|
|
95
|
+
modelId: model.modelId,
|
|
96
|
+
config: model.config
|
|
97
|
+
});
|
|
98
|
+
}
|
|
99
|
+
static [WORKFLOW_DESERIALIZE](options) {
|
|
100
|
+
return new _LMNTSpeechModel(options.modelId, options.config);
|
|
101
|
+
}
|
|
105
102
|
async getArgs({
|
|
106
103
|
text,
|
|
107
104
|
voice = "ava",
|
|
@@ -112,7 +109,7 @@ var LMNTSpeechModel = class {
|
|
|
112
109
|
}) {
|
|
113
110
|
var _a, _b, _c, _d, _e, _f, _g;
|
|
114
111
|
const warnings = [];
|
|
115
|
-
const lmntOptions = await
|
|
112
|
+
const lmntOptions = await parseProviderOptions({
|
|
116
113
|
provider: "lmnt",
|
|
117
114
|
providerOptions,
|
|
118
115
|
schema: lmntSpeechModelOptionsSchema
|
|
@@ -161,22 +158,22 @@ var LMNTSpeechModel = class {
|
|
|
161
158
|
};
|
|
162
159
|
}
|
|
163
160
|
async doGenerate(options) {
|
|
164
|
-
var _a, _b, _c;
|
|
161
|
+
var _a, _b, _c, _d, _e;
|
|
165
162
|
const currentDate = (_c = (_b = (_a = this.config._internal) == null ? void 0 : _a.currentDate) == null ? void 0 : _b.call(_a)) != null ? _c : /* @__PURE__ */ new Date();
|
|
166
163
|
const { requestBody, warnings } = await this.getArgs(options);
|
|
167
164
|
const {
|
|
168
165
|
value: audio,
|
|
169
166
|
responseHeaders,
|
|
170
167
|
rawValue: rawResponse
|
|
171
|
-
} = await
|
|
168
|
+
} = await postJsonToApi({
|
|
172
169
|
url: this.config.url({
|
|
173
170
|
path: "/v1/ai/speech/bytes",
|
|
174
171
|
modelId: this.modelId
|
|
175
172
|
}),
|
|
176
|
-
headers: (
|
|
173
|
+
headers: combineHeaders((_e = (_d = this.config).headers) == null ? void 0 : _e.call(_d), options.headers),
|
|
177
174
|
body: requestBody,
|
|
178
175
|
failedResponseHandler: lmntFailedResponseHandler,
|
|
179
|
-
successfulResponseHandler:
|
|
176
|
+
successfulResponseHandler: createBinaryResponseHandler(),
|
|
180
177
|
abortSignal: options.abortSignal,
|
|
181
178
|
fetch: this.config.fetch
|
|
182
179
|
});
|
|
@@ -197,13 +194,13 @@ var LMNTSpeechModel = class {
|
|
|
197
194
|
};
|
|
198
195
|
|
|
199
196
|
// src/version.ts
|
|
200
|
-
var VERSION = true ? "3.0.0-beta.
|
|
197
|
+
var VERSION = true ? "3.0.0-beta.50" : "0.0.0-test";
|
|
201
198
|
|
|
202
199
|
// src/lmnt-provider.ts
|
|
203
200
|
function createLMNT(options = {}) {
|
|
204
|
-
const getHeaders = () =>
|
|
201
|
+
const getHeaders = () => withUserAgentSuffix(
|
|
205
202
|
{
|
|
206
|
-
"x-api-key":
|
|
203
|
+
"x-api-key": loadApiKey({
|
|
207
204
|
apiKey: options.apiKey,
|
|
208
205
|
environmentVariableName: "LMNT_API_KEY",
|
|
209
206
|
description: "LMNT"
|
|
@@ -223,15 +220,36 @@ function createLMNT(options = {}) {
|
|
|
223
220
|
speech: createSpeechModel(modelId)
|
|
224
221
|
};
|
|
225
222
|
};
|
|
223
|
+
provider.specificationVersion = "v4";
|
|
226
224
|
provider.speech = createSpeechModel;
|
|
227
225
|
provider.speechModel = createSpeechModel;
|
|
226
|
+
provider.languageModel = (modelId) => {
|
|
227
|
+
throw new NoSuchModelError({
|
|
228
|
+
modelId,
|
|
229
|
+
modelType: "languageModel",
|
|
230
|
+
message: "LMNT does not provide language models"
|
|
231
|
+
});
|
|
232
|
+
};
|
|
233
|
+
provider.embeddingModel = (modelId) => {
|
|
234
|
+
throw new NoSuchModelError({
|
|
235
|
+
modelId,
|
|
236
|
+
modelType: "embeddingModel",
|
|
237
|
+
message: "LMNT does not provide embedding models"
|
|
238
|
+
});
|
|
239
|
+
};
|
|
240
|
+
provider.imageModel = (modelId) => {
|
|
241
|
+
throw new NoSuchModelError({
|
|
242
|
+
modelId,
|
|
243
|
+
modelType: "imageModel",
|
|
244
|
+
message: "LMNT does not provide image models"
|
|
245
|
+
});
|
|
246
|
+
};
|
|
228
247
|
return provider;
|
|
229
248
|
}
|
|
230
249
|
var lmnt = createLMNT();
|
|
231
|
-
|
|
232
|
-
0 && (module.exports = {
|
|
250
|
+
export {
|
|
233
251
|
VERSION,
|
|
234
252
|
createLMNT,
|
|
235
253
|
lmnt
|
|
236
|
-
}
|
|
254
|
+
};
|
|
237
255
|
//# sourceMappingURL=index.js.map
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/index.ts","../src/lmnt-provider.ts","../src/lmnt-speech-model.ts","../src/lmnt-error.ts","../src/version.ts"],"sourcesContent":["export { createLMNT, lmnt } from './lmnt-provider';\nexport type { LMNTProvider, LMNTProviderSettings } from './lmnt-provider';\nexport type { LMNTSpeechModelOptions } from './lmnt-speech-model';\nexport { VERSION } from './version';\n","import { SpeechModelV4, ProviderV4 } from '@ai-sdk/provider';\nimport {\n FetchFunction,\n loadApiKey,\n withUserAgentSuffix,\n} from '@ai-sdk/provider-utils';\nimport { LMNTSpeechModel } from './lmnt-speech-model';\nimport { LMNTSpeechModelId } from './lmnt-speech-options';\nimport { VERSION } from './version';\n\nexport interface LMNTProvider extends Pick<ProviderV4, 'speechModel'> {\n (\n modelId: 'aurora',\n settings?: {},\n ): {\n speech: LMNTSpeechModel;\n };\n\n /**\n * Creates a model for speech synthesis.\n */\n speech(modelId: LMNTSpeechModelId): SpeechModelV4;\n}\n\nexport interface LMNTProviderSettings {\n /**\n * API key for authenticating requests.\n */\n apiKey?: string;\n\n /**\n * Custom headers to include in the requests.\n */\n headers?: Record<string, string>;\n\n /**\n * Custom fetch implementation. You can use it as a middleware to intercept requests,\n * or to provide a custom fetch implementation for e.g. testing.\n */\n fetch?: FetchFunction;\n}\n\n/**\n * Create an LMNT provider instance.\n */\nexport function createLMNT(options: LMNTProviderSettings = {}): LMNTProvider {\n const getHeaders = () =>\n withUserAgentSuffix(\n {\n 'x-api-key': loadApiKey({\n apiKey: options.apiKey,\n environmentVariableName: 'LMNT_API_KEY',\n description: 'LMNT',\n }),\n ...options.headers,\n },\n `ai-sdk/lmnt/${VERSION}`,\n );\n\n const createSpeechModel = (modelId: LMNTSpeechModelId) =>\n new LMNTSpeechModel(modelId, {\n provider: `lmnt.speech`,\n url: ({ path }) => `https://api.lmnt.com${path}`,\n headers: getHeaders,\n fetch: options.fetch,\n });\n\n const provider = function (modelId: LMNTSpeechModelId) {\n return {\n speech: createSpeechModel(modelId),\n };\n };\n\n provider.speech = createSpeechModel;\n provider.speechModel = createSpeechModel;\n\n return provider as LMNTProvider;\n}\n\n/**\n * Default LMNT provider instance.\n */\nexport const lmnt = createLMNT();\n","import { SpeechModelV4, SharedV4Warning } from '@ai-sdk/provider';\nimport {\n combineHeaders,\n createBinaryResponseHandler,\n parseProviderOptions,\n postJsonToApi,\n} from '@ai-sdk/provider-utils';\nimport { z } from 'zod/v4';\nimport { LMNTConfig } from './lmnt-config';\nimport { lmntFailedResponseHandler } from './lmnt-error';\nimport { LMNTSpeechModelId } from './lmnt-speech-options';\nimport { LMNTSpeechAPITypes } from './lmnt-api-types';\n\n// https://docs.lmnt.com/api-reference/speech/synthesize-speech-bytes\nconst lmntSpeechModelOptionsSchema = z.object({\n /**\n * The model to use for speech synthesis e.g. 'aurora' or 'blizzard'.\n * @default 'aurora'\n */\n model: z\n .union([z.enum(['aurora', 'blizzard']), z.string()])\n .nullish()\n .default('aurora'),\n\n /**\n * The audio format of the output.\n * @default 'mp3'\n */\n format: z\n .enum(['aac', 'mp3', 'mulaw', 'raw', 'wav'])\n .nullish()\n .default('mp3'),\n\n /**\n * The sample rate of the output audio in Hz.\n * @default 24000\n */\n sampleRate: z\n .union([z.literal(8000), z.literal(16000), z.literal(24000)])\n .nullish()\n .default(24000),\n\n /**\n * The speed of the speech. Range: 0.25 to 2.\n * @default 1\n */\n speed: z.number().min(0.25).max(2).nullish().default(1),\n\n /**\n * A seed value for deterministic generation.\n */\n seed: z.number().int().nullish(),\n\n /**\n * Whether to use a conversational style.\n * @default false\n */\n conversational: z.boolean().nullish().default(false),\n\n /**\n * Maximum length of the output in seconds (up to 300).\n */\n length: z.number().max(300).nullish(),\n\n /**\n * Top-p sampling parameter. Range: 0 to 1.\n * @default 1\n */\n topP: z.number().min(0).max(1).nullish().default(1),\n\n /**\n * Temperature for sampling. Higher values increase randomness.\n * @default 1\n */\n temperature: z.number().min(0).nullish().default(1),\n});\n\nexport type LMNTSpeechModelOptions = z.infer<\n typeof lmntSpeechModelOptionsSchema\n>;\n\ninterface LMNTSpeechModelConfig extends LMNTConfig {\n _internal?: {\n currentDate?: () => Date;\n };\n}\n\nexport class LMNTSpeechModel implements SpeechModelV4 {\n readonly specificationVersion = 'v4';\n\n get provider(): string {\n return this.config.provider;\n }\n\n constructor(\n readonly modelId: LMNTSpeechModelId,\n private readonly config: LMNTSpeechModelConfig,\n ) {}\n\n private async getArgs({\n text,\n voice = 'ava',\n outputFormat = 'mp3',\n speed,\n language,\n providerOptions,\n }: Parameters<SpeechModelV4['doGenerate']>[0]) {\n const warnings: SharedV4Warning[] = [];\n\n // Parse provider options\n const lmntOptions = await parseProviderOptions({\n provider: 'lmnt',\n providerOptions,\n schema: lmntSpeechModelOptionsSchema,\n });\n\n // Create request body\n const requestBody: Record<string, unknown> = {\n model: this.modelId,\n text,\n voice,\n response_format: 'mp3',\n speed,\n };\n\n if (outputFormat) {\n if (['mp3', 'aac', 'mulaw', 'raw', 'wav'].includes(outputFormat)) {\n requestBody.response_format = outputFormat;\n } else {\n warnings.push({\n type: 'unsupported',\n feature: 'outputFormat',\n details: `Unsupported output format: ${outputFormat}. Using mp3 instead.`,\n });\n }\n }\n\n // Add provider-specific options\n if (lmntOptions) {\n const speechModelOptions: Omit<LMNTSpeechAPITypes, 'voice' | 'text'> = {\n conversational: lmntOptions.conversational ?? undefined,\n length: lmntOptions.length ?? undefined,\n seed: lmntOptions.seed ?? undefined,\n speed: lmntOptions.speed ?? undefined,\n temperature: lmntOptions.temperature ?? undefined,\n top_p: lmntOptions.topP ?? undefined,\n sample_rate: lmntOptions.sampleRate ?? undefined,\n };\n\n for (const key in speechModelOptions) {\n const value =\n speechModelOptions[\n key as keyof Omit<LMNTSpeechAPITypes, 'voice' | 'text'>\n ];\n if (value !== undefined) {\n requestBody[key] = value;\n }\n }\n }\n\n if (language) {\n requestBody.language = language;\n }\n\n return {\n requestBody,\n warnings,\n };\n }\n\n async doGenerate(\n options: Parameters<SpeechModelV4['doGenerate']>[0],\n ): Promise<Awaited<ReturnType<SpeechModelV4['doGenerate']>>> {\n const currentDate = this.config._internal?.currentDate?.() ?? new Date();\n const { requestBody, warnings } = await this.getArgs(options);\n\n const {\n value: audio,\n responseHeaders,\n rawValue: rawResponse,\n } = await postJsonToApi({\n url: this.config.url({\n path: '/v1/ai/speech/bytes',\n modelId: this.modelId,\n }),\n headers: combineHeaders(this.config.headers(), options.headers),\n body: requestBody,\n failedResponseHandler: lmntFailedResponseHandler,\n successfulResponseHandler: createBinaryResponseHandler(),\n abortSignal: options.abortSignal,\n fetch: this.config.fetch,\n });\n\n return {\n audio,\n warnings,\n request: {\n body: JSON.stringify(requestBody),\n },\n response: {\n timestamp: currentDate,\n modelId: this.modelId,\n headers: responseHeaders,\n body: rawResponse,\n },\n };\n }\n}\n","import { z } from 'zod/v4';\nimport { createJsonErrorResponseHandler } from '@ai-sdk/provider-utils';\n\nexport const lmntErrorDataSchema = z.object({\n error: z.object({\n message: z.string(),\n code: z.number(),\n }),\n});\n\nexport type LMNTErrorData = z.infer<typeof lmntErrorDataSchema>;\n\nexport const lmntFailedResponseHandler = createJsonErrorResponseHandler({\n errorSchema: lmntErrorDataSchema,\n errorToMessage: data => data.error.message,\n});\n","// Version string of this package injected at build time.\ndeclare const __PACKAGE_VERSION__: string | undefined;\nexport const VERSION: string =\n typeof __PACKAGE_VERSION__ !== 'undefined'\n ? __PACKAGE_VERSION__\n : '0.0.0-test';\n"],"mappings":"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","names":["import_provider_utils","import_provider_utils","import_v4"]}
|
|
1
|
+
{"version":3,"sources":["../src/lmnt-provider.ts","../src/lmnt-speech-model.ts","../src/lmnt-error.ts","../src/lmnt-speech-model-options.ts","../src/version.ts"],"sourcesContent":["import {\n NoSuchModelError,\n type SpeechModelV4,\n type ProviderV4,\n} from '@ai-sdk/provider';\nimport {\n loadApiKey,\n withUserAgentSuffix,\n type FetchFunction,\n} from '@ai-sdk/provider-utils';\nimport { LMNTSpeechModel } from './lmnt-speech-model';\nimport type { LMNTSpeechModelId } from './lmnt-speech-options';\nimport { VERSION } from './version';\n\nexport interface LMNTProvider extends ProviderV4 {\n (\n modelId: 'aurora',\n settings?: {},\n ): {\n speech: LMNTSpeechModel;\n };\n\n /**\n * Creates a model for speech synthesis.\n */\n speech(modelId: LMNTSpeechModelId): SpeechModelV4;\n}\n\nexport interface LMNTProviderSettings {\n /**\n * API key for authenticating requests.\n */\n apiKey?: string;\n\n /**\n * Custom headers to include in the requests.\n */\n headers?: Record<string, string>;\n\n /**\n * Custom fetch implementation. You can use it as a middleware to intercept requests,\n * or to provide a custom fetch implementation for e.g. testing.\n */\n fetch?: FetchFunction;\n}\n\n/**\n * Create an LMNT provider instance.\n */\nexport function createLMNT(options: LMNTProviderSettings = {}): LMNTProvider {\n const getHeaders = () =>\n withUserAgentSuffix(\n {\n 'x-api-key': loadApiKey({\n apiKey: options.apiKey,\n environmentVariableName: 'LMNT_API_KEY',\n description: 'LMNT',\n }),\n ...options.headers,\n },\n `ai-sdk/lmnt/${VERSION}`,\n );\n\n const createSpeechModel = (modelId: LMNTSpeechModelId) =>\n new LMNTSpeechModel(modelId, {\n provider: `lmnt.speech`,\n url: ({ path }) => `https://api.lmnt.com${path}`,\n headers: getHeaders,\n fetch: options.fetch,\n });\n\n const provider = function (modelId: LMNTSpeechModelId) {\n return {\n speech: createSpeechModel(modelId),\n };\n };\n\n provider.specificationVersion = 'v4' as const;\n provider.speech = createSpeechModel;\n provider.speechModel = createSpeechModel;\n\n provider.languageModel = (modelId: string) => {\n throw new NoSuchModelError({\n modelId,\n modelType: 'languageModel',\n message: 'LMNT does not provide language models',\n });\n };\n\n provider.embeddingModel = (modelId: string) => {\n throw new NoSuchModelError({\n modelId,\n modelType: 'embeddingModel',\n message: 'LMNT does not provide embedding models',\n });\n };\n\n provider.imageModel = (modelId: string) => {\n throw new NoSuchModelError({\n modelId,\n modelType: 'imageModel',\n message: 'LMNT does not provide image models',\n });\n };\n\n return provider as LMNTProvider;\n}\n\n/**\n * Default LMNT provider instance.\n */\nexport const lmnt = createLMNT();\n","import type { SpeechModelV4, SharedV4Warning } from '@ai-sdk/provider';\nimport {\n combineHeaders,\n createBinaryResponseHandler,\n parseProviderOptions,\n postJsonToApi,\n serializeModelOptions,\n WORKFLOW_SERIALIZE,\n WORKFLOW_DESERIALIZE,\n} from '@ai-sdk/provider-utils';\nimport type { LMNTConfig } from './lmnt-config';\nimport { lmntFailedResponseHandler } from './lmnt-error';\nimport { lmntSpeechModelOptionsSchema } from './lmnt-speech-model-options';\nimport type { LMNTSpeechModelId } from './lmnt-speech-options';\nimport type { LMNTSpeechAPITypes } from './lmnt-api-types';\n\ninterface LMNTSpeechModelConfig extends LMNTConfig {\n _internal?: {\n currentDate?: () => Date;\n };\n}\n\nexport class LMNTSpeechModel implements SpeechModelV4 {\n readonly specificationVersion = 'v4';\n\n get provider(): string {\n return this.config.provider;\n }\n\n static [WORKFLOW_SERIALIZE](model: LMNTSpeechModel) {\n return serializeModelOptions({\n modelId: model.modelId,\n config: model.config,\n });\n }\n\n static [WORKFLOW_DESERIALIZE](options: {\n modelId: LMNTSpeechModelId;\n config: LMNTSpeechModelConfig;\n }) {\n return new LMNTSpeechModel(options.modelId, options.config);\n }\n\n constructor(\n readonly modelId: LMNTSpeechModelId,\n private readonly config: LMNTSpeechModelConfig,\n ) {}\n\n private async getArgs({\n text,\n voice = 'ava',\n outputFormat = 'mp3',\n speed,\n language,\n providerOptions,\n }: Parameters<SpeechModelV4['doGenerate']>[0]) {\n const warnings: SharedV4Warning[] = [];\n\n // Parse provider options\n const lmntOptions = await parseProviderOptions({\n provider: 'lmnt',\n providerOptions,\n schema: lmntSpeechModelOptionsSchema,\n });\n\n // Create request body\n const requestBody: Record<string, unknown> = {\n model: this.modelId,\n text,\n voice,\n response_format: 'mp3',\n speed,\n };\n\n if (outputFormat) {\n if (['mp3', 'aac', 'mulaw', 'raw', 'wav'].includes(outputFormat)) {\n requestBody.response_format = outputFormat;\n } else {\n warnings.push({\n type: 'unsupported',\n feature: 'outputFormat',\n details: `Unsupported output format: ${outputFormat}. Using mp3 instead.`,\n });\n }\n }\n\n // Add provider-specific options\n if (lmntOptions) {\n const speechModelOptions: Omit<LMNTSpeechAPITypes, 'voice' | 'text'> = {\n conversational: lmntOptions.conversational ?? undefined,\n length: lmntOptions.length ?? undefined,\n seed: lmntOptions.seed ?? undefined,\n speed: lmntOptions.speed ?? undefined,\n temperature: lmntOptions.temperature ?? undefined,\n top_p: lmntOptions.topP ?? undefined,\n sample_rate: lmntOptions.sampleRate ?? undefined,\n };\n\n for (const key in speechModelOptions) {\n const value =\n speechModelOptions[\n key as keyof Omit<LMNTSpeechAPITypes, 'voice' | 'text'>\n ];\n if (value !== undefined) {\n requestBody[key] = value;\n }\n }\n }\n\n if (language) {\n requestBody.language = language;\n }\n\n return {\n requestBody,\n warnings,\n };\n }\n\n async doGenerate(\n options: Parameters<SpeechModelV4['doGenerate']>[0],\n ): Promise<Awaited<ReturnType<SpeechModelV4['doGenerate']>>> {\n const currentDate = this.config._internal?.currentDate?.() ?? new Date();\n const { requestBody, warnings } = await this.getArgs(options);\n\n const {\n value: audio,\n responseHeaders,\n rawValue: rawResponse,\n } = await postJsonToApi({\n url: this.config.url({\n path: '/v1/ai/speech/bytes',\n modelId: this.modelId,\n }),\n headers: combineHeaders(this.config.headers?.(), options.headers),\n body: requestBody,\n failedResponseHandler: lmntFailedResponseHandler,\n successfulResponseHandler: createBinaryResponseHandler(),\n abortSignal: options.abortSignal,\n fetch: this.config.fetch,\n });\n\n return {\n audio,\n warnings,\n request: {\n body: JSON.stringify(requestBody),\n },\n response: {\n timestamp: currentDate,\n modelId: this.modelId,\n headers: responseHeaders,\n body: rawResponse,\n },\n };\n }\n}\n","import { z } from 'zod/v4';\nimport { createJsonErrorResponseHandler } from '@ai-sdk/provider-utils';\n\nexport const lmntErrorDataSchema = z.object({\n error: z.object({\n message: z.string(),\n code: z.number(),\n }),\n});\n\nexport type LMNTErrorData = z.infer<typeof lmntErrorDataSchema>;\n\nexport const lmntFailedResponseHandler = createJsonErrorResponseHandler({\n errorSchema: lmntErrorDataSchema,\n errorToMessage: data => data.error.message,\n});\n","import { z } from 'zod/v4';\n\n// https://docs.lmnt.com/api-reference/speech/synthesize-speech-bytes\nexport const lmntSpeechModelOptionsSchema = z.object({\n /**\n * The model to use for speech synthesis e.g. 'aurora' or 'blizzard'.\n * @default 'aurora'\n */\n model: z\n .union([z.enum(['aurora', 'blizzard']), z.string()])\n .nullish()\n .default('aurora'),\n\n /**\n * The audio format of the output.\n * @default 'mp3'\n */\n format: z\n .enum(['aac', 'mp3', 'mulaw', 'raw', 'wav'])\n .nullish()\n .default('mp3'),\n\n /**\n * The sample rate of the output audio in Hz.\n * @default 24000\n */\n sampleRate: z\n .union([z.literal(8000), z.literal(16000), z.literal(24000)])\n .nullish()\n .default(24000),\n\n /**\n * The speed of the speech. Range: 0.25 to 2.\n * @default 1\n */\n speed: z.number().min(0.25).max(2).nullish().default(1),\n\n /**\n * A seed value for deterministic generation.\n */\n seed: z.number().int().nullish(),\n\n /**\n * Whether to use a conversational style.\n * @default false\n */\n conversational: z.boolean().nullish().default(false),\n\n /**\n * Maximum length of the output in seconds (up to 300).\n */\n length: z.number().max(300).nullish(),\n\n /**\n * Top-p sampling parameter. Range: 0 to 1.\n * @default 1\n */\n topP: z.number().min(0).max(1).nullish().default(1),\n\n /**\n * Temperature for sampling. Higher values increase randomness.\n * @default 1\n */\n temperature: z.number().min(0).nullish().default(1),\n});\n\nexport type LMNTSpeechModelOptions = z.infer<\n typeof lmntSpeechModelOptionsSchema\n>;\n","// Version string of this package injected at build time.\ndeclare const __PACKAGE_VERSION__: string | undefined;\nexport const VERSION: string =\n typeof __PACKAGE_VERSION__ !== 'undefined'\n ? __PACKAGE_VERSION__\n : '0.0.0-test';\n"],"mappings":"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","names":["z"]}
|
package/docs/140-lmnt.mdx
CHANGED
|
@@ -78,7 +78,7 @@ const model = lmnt.speech('aurora');
|
|
|
78
78
|
The `voice` parameter can be set to a voice ID from LMNT. You can find available voices in the [LMNT documentation](https://docs.lmnt.com/api-reference/voices/list-voices).
|
|
79
79
|
|
|
80
80
|
```ts highlight="7"
|
|
81
|
-
import {
|
|
81
|
+
import { generateSpeech } from 'ai';
|
|
82
82
|
import { lmnt } from '@ai-sdk/lmnt';
|
|
83
83
|
|
|
84
84
|
const result = await generateSpeech({
|
|
@@ -92,7 +92,7 @@ const result = await generateSpeech({
|
|
|
92
92
|
You can also pass additional provider-specific options using the `providerOptions` argument:
|
|
93
93
|
|
|
94
94
|
```ts highlight="10-14"
|
|
95
|
-
import {
|
|
95
|
+
import { generateSpeech } from 'ai';
|
|
96
96
|
import { lmnt } from '@ai-sdk/lmnt';
|
|
97
97
|
import { type LMNTSpeechModelOptions } from '@ai-sdk/lmnt';
|
|
98
98
|
|
package/package.json
CHANGED
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@ai-sdk/lmnt",
|
|
3
|
-
"version": "3.0.0-beta.
|
|
3
|
+
"version": "3.0.0-beta.50",
|
|
4
|
+
"type": "module",
|
|
4
5
|
"license": "Apache-2.0",
|
|
5
6
|
"sideEffects": false,
|
|
6
7
|
"main": "./dist/index.js",
|
|
7
|
-
"module": "./dist/index.mjs",
|
|
8
8
|
"types": "./dist/index.d.ts",
|
|
9
9
|
"files": [
|
|
10
10
|
"dist/**/*",
|
|
@@ -24,35 +24,37 @@
|
|
|
24
24
|
"./package.json": "./package.json",
|
|
25
25
|
".": {
|
|
26
26
|
"types": "./dist/index.d.ts",
|
|
27
|
-
"import": "./dist/index.
|
|
28
|
-
"
|
|
27
|
+
"import": "./dist/index.js",
|
|
28
|
+
"default": "./dist/index.js"
|
|
29
29
|
}
|
|
30
30
|
},
|
|
31
31
|
"dependencies": {
|
|
32
|
-
"@ai-sdk/provider": "4.0.0-beta.
|
|
33
|
-
"@ai-sdk/provider-utils": "5.0.0-beta.
|
|
32
|
+
"@ai-sdk/provider": "4.0.0-beta.19",
|
|
33
|
+
"@ai-sdk/provider-utils": "5.0.0-beta.49"
|
|
34
34
|
},
|
|
35
35
|
"devDependencies": {
|
|
36
|
-
"@types/node": "
|
|
37
|
-
"tsup": "^8",
|
|
36
|
+
"@types/node": "22.19.19",
|
|
37
|
+
"tsup": "^8.5.1",
|
|
38
38
|
"typescript": "5.6.3",
|
|
39
39
|
"zod": "3.25.76",
|
|
40
|
-
"@ai-sdk/test-server": "2.0.0-beta.
|
|
40
|
+
"@ai-sdk/test-server": "2.0.0-beta.7",
|
|
41
41
|
"@vercel/ai-tsconfig": "0.0.0"
|
|
42
42
|
},
|
|
43
43
|
"peerDependencies": {
|
|
44
44
|
"zod": "^3.25.76 || ^4.1.8"
|
|
45
45
|
},
|
|
46
46
|
"engines": {
|
|
47
|
-
"node": ">=
|
|
47
|
+
"node": ">=22"
|
|
48
48
|
},
|
|
49
49
|
"publishConfig": {
|
|
50
|
-
"access": "public"
|
|
50
|
+
"access": "public",
|
|
51
|
+
"provenance": true
|
|
51
52
|
},
|
|
52
53
|
"homepage": "https://ai-sdk.dev/docs",
|
|
53
54
|
"repository": {
|
|
54
55
|
"type": "git",
|
|
55
|
-
"url": "
|
|
56
|
+
"url": "https://github.com/vercel/ai",
|
|
57
|
+
"directory": "packages/lmnt"
|
|
56
58
|
},
|
|
57
59
|
"bugs": {
|
|
58
60
|
"url": "https://github.com/vercel/ai/issues"
|
|
@@ -64,9 +66,7 @@
|
|
|
64
66
|
"build": "tsup --tsconfig tsconfig.build.json",
|
|
65
67
|
"build:watch": "tsup --tsconfig tsconfig.build.json --watch",
|
|
66
68
|
"clean": "del-cli dist docs",
|
|
67
|
-
"lint": "eslint \"./**/*.ts*\"",
|
|
68
69
|
"type-check": "tsc --noEmit",
|
|
69
|
-
"prettier-check": "prettier --check \"./**/*.ts*\"",
|
|
70
70
|
"test": "pnpm test:node && pnpm test:edge",
|
|
71
71
|
"test:watch": "vitest --config vitest.node.config.js --watch",
|
|
72
72
|
"test:edge": "vitest --config vitest.edge.config.js --run",
|
package/src/index.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
1
|
export { createLMNT, lmnt } from './lmnt-provider';
|
|
2
2
|
export type { LMNTProvider, LMNTProviderSettings } from './lmnt-provider';
|
|
3
|
-
export type { LMNTSpeechModelOptions } from './lmnt-speech-model';
|
|
3
|
+
export type { LMNTSpeechModelOptions } from './lmnt-speech-model-options';
|
|
4
4
|
export { VERSION } from './version';
|
package/src/lmnt-config.ts
CHANGED
|
@@ -1,9 +1,9 @@
|
|
|
1
|
-
import { FetchFunction } from '@ai-sdk/provider-utils';
|
|
1
|
+
import type { FetchFunction } from '@ai-sdk/provider-utils';
|
|
2
2
|
|
|
3
3
|
export type LMNTConfig = {
|
|
4
4
|
provider: string;
|
|
5
5
|
url: (options: { modelId: string; path: string }) => string;
|
|
6
|
-
headers
|
|
6
|
+
headers?: () => Record<string, string | undefined>;
|
|
7
7
|
fetch?: FetchFunction;
|
|
8
8
|
generateId?: () => string;
|
|
9
9
|
};
|
package/src/lmnt-provider.ts
CHANGED
|
@@ -1,14 +1,18 @@
|
|
|
1
|
-
import { SpeechModelV4, ProviderV4 } from '@ai-sdk/provider';
|
|
2
1
|
import {
|
|
3
|
-
|
|
2
|
+
NoSuchModelError,
|
|
3
|
+
type SpeechModelV4,
|
|
4
|
+
type ProviderV4,
|
|
5
|
+
} from '@ai-sdk/provider';
|
|
6
|
+
import {
|
|
4
7
|
loadApiKey,
|
|
5
8
|
withUserAgentSuffix,
|
|
9
|
+
type FetchFunction,
|
|
6
10
|
} from '@ai-sdk/provider-utils';
|
|
7
11
|
import { LMNTSpeechModel } from './lmnt-speech-model';
|
|
8
|
-
import { LMNTSpeechModelId } from './lmnt-speech-options';
|
|
12
|
+
import type { LMNTSpeechModelId } from './lmnt-speech-options';
|
|
9
13
|
import { VERSION } from './version';
|
|
10
14
|
|
|
11
|
-
export interface LMNTProvider extends
|
|
15
|
+
export interface LMNTProvider extends ProviderV4 {
|
|
12
16
|
(
|
|
13
17
|
modelId: 'aurora',
|
|
14
18
|
settings?: {},
|
|
@@ -71,9 +75,34 @@ export function createLMNT(options: LMNTProviderSettings = {}): LMNTProvider {
|
|
|
71
75
|
};
|
|
72
76
|
};
|
|
73
77
|
|
|
78
|
+
provider.specificationVersion = 'v4' as const;
|
|
74
79
|
provider.speech = createSpeechModel;
|
|
75
80
|
provider.speechModel = createSpeechModel;
|
|
76
81
|
|
|
82
|
+
provider.languageModel = (modelId: string) => {
|
|
83
|
+
throw new NoSuchModelError({
|
|
84
|
+
modelId,
|
|
85
|
+
modelType: 'languageModel',
|
|
86
|
+
message: 'LMNT does not provide language models',
|
|
87
|
+
});
|
|
88
|
+
};
|
|
89
|
+
|
|
90
|
+
provider.embeddingModel = (modelId: string) => {
|
|
91
|
+
throw new NoSuchModelError({
|
|
92
|
+
modelId,
|
|
93
|
+
modelType: 'embeddingModel',
|
|
94
|
+
message: 'LMNT does not provide embedding models',
|
|
95
|
+
});
|
|
96
|
+
};
|
|
97
|
+
|
|
98
|
+
provider.imageModel = (modelId: string) => {
|
|
99
|
+
throw new NoSuchModelError({
|
|
100
|
+
modelId,
|
|
101
|
+
modelType: 'imageModel',
|
|
102
|
+
message: 'LMNT does not provide image models',
|
|
103
|
+
});
|
|
104
|
+
};
|
|
105
|
+
|
|
77
106
|
return provider as LMNTProvider;
|
|
78
107
|
}
|
|
79
108
|
|
|
@@ -0,0 +1,69 @@
|
|
|
1
|
+
import { z } from 'zod/v4';
|
|
2
|
+
|
|
3
|
+
// https://docs.lmnt.com/api-reference/speech/synthesize-speech-bytes
|
|
4
|
+
export const lmntSpeechModelOptionsSchema = z.object({
|
|
5
|
+
/**
|
|
6
|
+
* The model to use for speech synthesis e.g. 'aurora' or 'blizzard'.
|
|
7
|
+
* @default 'aurora'
|
|
8
|
+
*/
|
|
9
|
+
model: z
|
|
10
|
+
.union([z.enum(['aurora', 'blizzard']), z.string()])
|
|
11
|
+
.nullish()
|
|
12
|
+
.default('aurora'),
|
|
13
|
+
|
|
14
|
+
/**
|
|
15
|
+
* The audio format of the output.
|
|
16
|
+
* @default 'mp3'
|
|
17
|
+
*/
|
|
18
|
+
format: z
|
|
19
|
+
.enum(['aac', 'mp3', 'mulaw', 'raw', 'wav'])
|
|
20
|
+
.nullish()
|
|
21
|
+
.default('mp3'),
|
|
22
|
+
|
|
23
|
+
/**
|
|
24
|
+
* The sample rate of the output audio in Hz.
|
|
25
|
+
* @default 24000
|
|
26
|
+
*/
|
|
27
|
+
sampleRate: z
|
|
28
|
+
.union([z.literal(8000), z.literal(16000), z.literal(24000)])
|
|
29
|
+
.nullish()
|
|
30
|
+
.default(24000),
|
|
31
|
+
|
|
32
|
+
/**
|
|
33
|
+
* The speed of the speech. Range: 0.25 to 2.
|
|
34
|
+
* @default 1
|
|
35
|
+
*/
|
|
36
|
+
speed: z.number().min(0.25).max(2).nullish().default(1),
|
|
37
|
+
|
|
38
|
+
/**
|
|
39
|
+
* A seed value for deterministic generation.
|
|
40
|
+
*/
|
|
41
|
+
seed: z.number().int().nullish(),
|
|
42
|
+
|
|
43
|
+
/**
|
|
44
|
+
* Whether to use a conversational style.
|
|
45
|
+
* @default false
|
|
46
|
+
*/
|
|
47
|
+
conversational: z.boolean().nullish().default(false),
|
|
48
|
+
|
|
49
|
+
/**
|
|
50
|
+
* Maximum length of the output in seconds (up to 300).
|
|
51
|
+
*/
|
|
52
|
+
length: z.number().max(300).nullish(),
|
|
53
|
+
|
|
54
|
+
/**
|
|
55
|
+
* Top-p sampling parameter. Range: 0 to 1.
|
|
56
|
+
* @default 1
|
|
57
|
+
*/
|
|
58
|
+
topP: z.number().min(0).max(1).nullish().default(1),
|
|
59
|
+
|
|
60
|
+
/**
|
|
61
|
+
* Temperature for sampling. Higher values increase randomness.
|
|
62
|
+
* @default 1
|
|
63
|
+
*/
|
|
64
|
+
temperature: z.number().min(0).nullish().default(1),
|
|
65
|
+
});
|
|
66
|
+
|
|
67
|
+
export type LMNTSpeechModelOptions = z.infer<
|
|
68
|
+
typeof lmntSpeechModelOptionsSchema
|
|
69
|
+
>;
|
package/src/lmnt-speech-model.ts
CHANGED
|
@@ -1,83 +1,18 @@
|
|
|
1
|
-
import { SpeechModelV4, SharedV4Warning } from '@ai-sdk/provider';
|
|
1
|
+
import type { SpeechModelV4, SharedV4Warning } from '@ai-sdk/provider';
|
|
2
2
|
import {
|
|
3
3
|
combineHeaders,
|
|
4
4
|
createBinaryResponseHandler,
|
|
5
5
|
parseProviderOptions,
|
|
6
6
|
postJsonToApi,
|
|
7
|
+
serializeModelOptions,
|
|
8
|
+
WORKFLOW_SERIALIZE,
|
|
9
|
+
WORKFLOW_DESERIALIZE,
|
|
7
10
|
} from '@ai-sdk/provider-utils';
|
|
8
|
-
import {
|
|
9
|
-
import { LMNTConfig } from './lmnt-config';
|
|
11
|
+
import type { LMNTConfig } from './lmnt-config';
|
|
10
12
|
import { lmntFailedResponseHandler } from './lmnt-error';
|
|
11
|
-
import {
|
|
12
|
-
import {
|
|
13
|
-
|
|
14
|
-
// https://docs.lmnt.com/api-reference/speech/synthesize-speech-bytes
|
|
15
|
-
const lmntSpeechModelOptionsSchema = z.object({
|
|
16
|
-
/**
|
|
17
|
-
* The model to use for speech synthesis e.g. 'aurora' or 'blizzard'.
|
|
18
|
-
* @default 'aurora'
|
|
19
|
-
*/
|
|
20
|
-
model: z
|
|
21
|
-
.union([z.enum(['aurora', 'blizzard']), z.string()])
|
|
22
|
-
.nullish()
|
|
23
|
-
.default('aurora'),
|
|
24
|
-
|
|
25
|
-
/**
|
|
26
|
-
* The audio format of the output.
|
|
27
|
-
* @default 'mp3'
|
|
28
|
-
*/
|
|
29
|
-
format: z
|
|
30
|
-
.enum(['aac', 'mp3', 'mulaw', 'raw', 'wav'])
|
|
31
|
-
.nullish()
|
|
32
|
-
.default('mp3'),
|
|
33
|
-
|
|
34
|
-
/**
|
|
35
|
-
* The sample rate of the output audio in Hz.
|
|
36
|
-
* @default 24000
|
|
37
|
-
*/
|
|
38
|
-
sampleRate: z
|
|
39
|
-
.union([z.literal(8000), z.literal(16000), z.literal(24000)])
|
|
40
|
-
.nullish()
|
|
41
|
-
.default(24000),
|
|
42
|
-
|
|
43
|
-
/**
|
|
44
|
-
* The speed of the speech. Range: 0.25 to 2.
|
|
45
|
-
* @default 1
|
|
46
|
-
*/
|
|
47
|
-
speed: z.number().min(0.25).max(2).nullish().default(1),
|
|
48
|
-
|
|
49
|
-
/**
|
|
50
|
-
* A seed value for deterministic generation.
|
|
51
|
-
*/
|
|
52
|
-
seed: z.number().int().nullish(),
|
|
53
|
-
|
|
54
|
-
/**
|
|
55
|
-
* Whether to use a conversational style.
|
|
56
|
-
* @default false
|
|
57
|
-
*/
|
|
58
|
-
conversational: z.boolean().nullish().default(false),
|
|
59
|
-
|
|
60
|
-
/**
|
|
61
|
-
* Maximum length of the output in seconds (up to 300).
|
|
62
|
-
*/
|
|
63
|
-
length: z.number().max(300).nullish(),
|
|
64
|
-
|
|
65
|
-
/**
|
|
66
|
-
* Top-p sampling parameter. Range: 0 to 1.
|
|
67
|
-
* @default 1
|
|
68
|
-
*/
|
|
69
|
-
topP: z.number().min(0).max(1).nullish().default(1),
|
|
70
|
-
|
|
71
|
-
/**
|
|
72
|
-
* Temperature for sampling. Higher values increase randomness.
|
|
73
|
-
* @default 1
|
|
74
|
-
*/
|
|
75
|
-
temperature: z.number().min(0).nullish().default(1),
|
|
76
|
-
});
|
|
77
|
-
|
|
78
|
-
export type LMNTSpeechModelOptions = z.infer<
|
|
79
|
-
typeof lmntSpeechModelOptionsSchema
|
|
80
|
-
>;
|
|
13
|
+
import { lmntSpeechModelOptionsSchema } from './lmnt-speech-model-options';
|
|
14
|
+
import type { LMNTSpeechModelId } from './lmnt-speech-options';
|
|
15
|
+
import type { LMNTSpeechAPITypes } from './lmnt-api-types';
|
|
81
16
|
|
|
82
17
|
interface LMNTSpeechModelConfig extends LMNTConfig {
|
|
83
18
|
_internal?: {
|
|
@@ -92,6 +27,20 @@ export class LMNTSpeechModel implements SpeechModelV4 {
|
|
|
92
27
|
return this.config.provider;
|
|
93
28
|
}
|
|
94
29
|
|
|
30
|
+
static [WORKFLOW_SERIALIZE](model: LMNTSpeechModel) {
|
|
31
|
+
return serializeModelOptions({
|
|
32
|
+
modelId: model.modelId,
|
|
33
|
+
config: model.config,
|
|
34
|
+
});
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
static [WORKFLOW_DESERIALIZE](options: {
|
|
38
|
+
modelId: LMNTSpeechModelId;
|
|
39
|
+
config: LMNTSpeechModelConfig;
|
|
40
|
+
}) {
|
|
41
|
+
return new LMNTSpeechModel(options.modelId, options.config);
|
|
42
|
+
}
|
|
43
|
+
|
|
95
44
|
constructor(
|
|
96
45
|
readonly modelId: LMNTSpeechModelId,
|
|
97
46
|
private readonly config: LMNTSpeechModelConfig,
|
|
@@ -183,7 +132,7 @@ export class LMNTSpeechModel implements SpeechModelV4 {
|
|
|
183
132
|
path: '/v1/ai/speech/bytes',
|
|
184
133
|
modelId: this.modelId,
|
|
185
134
|
}),
|
|
186
|
-
headers: combineHeaders(this.config.headers(), options.headers),
|
|
135
|
+
headers: combineHeaders(this.config.headers?.(), options.headers),
|
|
187
136
|
body: requestBody,
|
|
188
137
|
failedResponseHandler: lmntFailedResponseHandler,
|
|
189
138
|
successfulResponseHandler: createBinaryResponseHandler(),
|