@ai-sdk/lmnt 3.0.0-beta.8 → 3.0.0-canary.32

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 CHANGED
@@ -1,5 +1,213 @@
1
1
  # @ai-sdk/lmnt
2
2
 
3
+ ## 3.0.0-canary.32
4
+
5
+ ### Patch Changes
6
+
7
+ - 0c4c275: trigger initial canary release
8
+ - Updated dependencies [0c4c275]
9
+ - @ai-sdk/provider-utils@5.0.0-canary.31
10
+ - @ai-sdk/provider@4.0.0-canary.15
11
+
12
+ ## 3.0.0-beta.31
13
+
14
+ ### Major Changes
15
+
16
+ - 04e9009: chore: make provider implementations code patterns more consistent, including renaming certain exported symbols
17
+
18
+ For all externally exported symbols that were renamed, the old names continue to work via deprecated aliases.
19
+
20
+ ### Patch Changes
21
+
22
+ - Updated dependencies [08d2129]
23
+ - @ai-sdk/provider-utils@5.0.0-beta.30
24
+
25
+ ## 3.0.0-beta.30
26
+
27
+ ### Patch Changes
28
+
29
+ - 258c093: chore: ensure consistent import handling and avoid import duplicates or cycles
30
+ - Updated dependencies [9bd6512]
31
+ - Updated dependencies [258c093]
32
+ - Updated dependencies [b6783da]
33
+ - @ai-sdk/provider-utils@5.0.0-beta.29
34
+ - @ai-sdk/provider@4.0.0-beta.14
35
+
36
+ ## 3.0.0-beta.29
37
+
38
+ ### Patch Changes
39
+
40
+ - 9f0e36c: trigger release for all packages after provenance setup
41
+ - Updated dependencies [9f0e36c]
42
+ - @ai-sdk/provider@4.0.0-beta.13
43
+ - @ai-sdk/provider-utils@5.0.0-beta.28
44
+
45
+ ## 3.0.0-beta.28
46
+
47
+ ### Patch Changes
48
+
49
+ - Updated dependencies [785fe16]
50
+ - Updated dependencies [67df0a0]
51
+ - Updated dependencies [befb78c]
52
+ - Updated dependencies [0458559]
53
+ - Updated dependencies [5852c0a]
54
+ - Updated dependencies [fc92055]
55
+ - @ai-sdk/provider-utils@5.0.0-beta.27
56
+
57
+ ## 3.0.0-beta.27
58
+
59
+ ### Patch Changes
60
+
61
+ - Updated dependencies [2e98477]
62
+ - @ai-sdk/provider-utils@5.0.0-beta.26
63
+
64
+ ## 3.0.0-beta.26
65
+
66
+ ### Patch Changes
67
+
68
+ - Updated dependencies [eea8d98]
69
+ - @ai-sdk/provider-utils@5.0.0-beta.25
70
+
71
+ ## 3.0.0-beta.25
72
+
73
+ ### Patch Changes
74
+
75
+ - Updated dependencies [f807e45]
76
+ - @ai-sdk/provider-utils@5.0.0-beta.24
77
+
78
+ ## 3.0.0-beta.24
79
+
80
+ ### Patch Changes
81
+
82
+ - Updated dependencies [350ea38]
83
+ - @ai-sdk/provider-utils@5.0.0-beta.23
84
+
85
+ ## 3.0.0-beta.23
86
+
87
+ ### Patch Changes
88
+
89
+ - Updated dependencies [083947b]
90
+ - @ai-sdk/provider-utils@5.0.0-beta.22
91
+
92
+ ## 3.0.0-beta.22
93
+
94
+ ### Patch Changes
95
+
96
+ - Updated dependencies [add1126]
97
+ - @ai-sdk/provider-utils@5.0.0-beta.21
98
+
99
+ ## 3.0.0-beta.21
100
+
101
+ ### Patch Changes
102
+
103
+ - b3976a2: Add workflow serialization support to all provider models.
104
+
105
+ **`@ai-sdk/provider-utils`:** New `serializeModel()` helper that extracts only serializable properties from a model instance, filtering out functions and objects containing functions. Third-party provider authors can use this to add workflow support to their own models.
106
+
107
+ **All providers:** `headers` is now optional in provider config types. This is non-breaking — existing code that passes `headers` continues to work. Custom provider implementations that construct model configs manually can now omit `headers`, which is useful when models are deserialized from a workflow step boundary where auth is provided separately.
108
+
109
+ All provider model classes now include `WORKFLOW_SERIALIZE` and `WORKFLOW_DESERIALIZE` static methods, enabling them to cross workflow step boundaries without serialization errors.
110
+
111
+ - Updated dependencies [b3976a2]
112
+ - Updated dependencies [ff5eba1]
113
+ - @ai-sdk/provider-utils@5.0.0-beta.20
114
+ - @ai-sdk/provider@4.0.0-beta.12
115
+
116
+ ## 3.0.0-beta.20
117
+
118
+ ### Major Changes
119
+
120
+ - ef992f8: Remove CommonJS exports from all packages. All packages are now ESM-only (`"type": "module"`). Consumers using `require()` must switch to ESM `import` syntax.
121
+
122
+ ### Patch Changes
123
+
124
+ - Updated dependencies [ef992f8]
125
+ - @ai-sdk/provider@4.0.0-beta.11
126
+ - @ai-sdk/provider-utils@5.0.0-beta.19
127
+
128
+ ## 3.0.0-beta.19
129
+
130
+ ### Patch Changes
131
+
132
+ - Updated dependencies [90e2d8a]
133
+ - @ai-sdk/provider-utils@5.0.0-beta.18
134
+
135
+ ## 3.0.0-beta.18
136
+
137
+ ### Patch Changes
138
+
139
+ - Updated dependencies [3ae1786]
140
+ - @ai-sdk/provider-utils@5.0.0-beta.17
141
+
142
+ ## 3.0.0-beta.17
143
+
144
+ ### Patch Changes
145
+
146
+ - Updated dependencies [176466a]
147
+ - @ai-sdk/provider@4.0.0-beta.10
148
+ - @ai-sdk/provider-utils@5.0.0-beta.16
149
+
150
+ ## 3.0.0-beta.16
151
+
152
+ ### Patch Changes
153
+
154
+ - Updated dependencies [e311194]
155
+ - @ai-sdk/provider@4.0.0-beta.9
156
+ - @ai-sdk/provider-utils@5.0.0-beta.15
157
+
158
+ ## 3.0.0-beta.15
159
+
160
+ ### Patch Changes
161
+
162
+ - Updated dependencies [34bd95d]
163
+ - Updated dependencies [008271d]
164
+ - @ai-sdk/provider@4.0.0-beta.8
165
+ - @ai-sdk/provider-utils@5.0.0-beta.14
166
+
167
+ ## 3.0.0-beta.14
168
+
169
+ ### Patch Changes
170
+
171
+ - Updated dependencies [b0c2869]
172
+ - Updated dependencies [7e26e81]
173
+ - @ai-sdk/provider-utils@5.0.0-beta.13
174
+
175
+ ## 3.0.0-beta.13
176
+
177
+ ### Patch Changes
178
+
179
+ - Updated dependencies [46d1149]
180
+ - @ai-sdk/provider-utils@5.0.0-beta.12
181
+
182
+ ## 3.0.0-beta.12
183
+
184
+ ### Patch Changes
185
+
186
+ - Updated dependencies [6fd51c0]
187
+ - @ai-sdk/provider-utils@5.0.0-beta.11
188
+ - @ai-sdk/provider@4.0.0-beta.7
189
+
190
+ ## 3.0.0-beta.11
191
+
192
+ ### Patch Changes
193
+
194
+ - Updated dependencies [c29a26f]
195
+ - @ai-sdk/provider-utils@5.0.0-beta.10
196
+ - @ai-sdk/provider@4.0.0-beta.6
197
+
198
+ ## 3.0.0-beta.10
199
+
200
+ ### Patch Changes
201
+
202
+ - 38fc777: Add AI Gateway hint to provider READMEs
203
+
204
+ ## 3.0.0-beta.9
205
+
206
+ ### Patch Changes
207
+
208
+ - Updated dependencies [2e17091]
209
+ - @ai-sdk/provider-utils@5.0.0-beta.9
210
+
3
211
  ## 3.0.0-beta.8
4
212
 
5
213
  ### Patch Changes
package/README.md CHANGED
@@ -3,6 +3,8 @@
3
3
  The **[LMNT provider](https://ai-sdk.dev/providers/ai-sdk-providers/lmnt)** for the [AI SDK](https://ai-sdk.dev/docs)
4
4
  contains language model support for the LMNT API.
5
5
 
6
+ > **Deploying to Vercel?** With Vercel's AI Gateway you can access LMNT (and hundreds of models from other providers) — no additional packages, API keys, or extra cost. [Get started with AI Gateway](https://vercel.com/ai-gateway).
7
+
6
8
  ## Setup
7
9
 
8
10
  The LMNT provider is available in the `@ai-sdk/lmnt` module. You can install it with
package/dist/index.d.ts CHANGED
@@ -1,5 +1,6 @@
1
+ import * as _ai_sdk_provider from '@ai-sdk/provider';
1
2
  import { SpeechModelV4, ProviderV4 } from '@ai-sdk/provider';
2
- import { FetchFunction } from '@ai-sdk/provider-utils';
3
+ import { FetchFunction, WORKFLOW_SERIALIZE, WORKFLOW_DESERIALIZE } from '@ai-sdk/provider-utils';
3
4
  import { z } from 'zod/v4';
4
5
 
5
6
  type LMNTConfig = {
@@ -8,34 +9,13 @@ type LMNTConfig = {
8
9
  modelId: string;
9
10
  path: string;
10
11
  }) => string;
11
- headers: () => Record<string, string | undefined>;
12
+ headers?: () => Record<string, string | undefined>;
12
13
  fetch?: FetchFunction;
13
14
  generateId?: () => string;
14
15
  };
15
16
 
16
17
  type LMNTSpeechModelId = 'aurora' | 'blizzard' | (string & {});
17
18
 
18
- declare const lmntSpeechModelOptionsSchema: z.ZodObject<{
19
- model: z.ZodDefault<z.ZodOptional<z.ZodNullable<z.ZodUnion<readonly [z.ZodEnum<{
20
- aurora: "aurora";
21
- blizzard: "blizzard";
22
- }>, z.ZodString]>>>>;
23
- format: z.ZodDefault<z.ZodOptional<z.ZodNullable<z.ZodEnum<{
24
- aac: "aac";
25
- mp3: "mp3";
26
- mulaw: "mulaw";
27
- raw: "raw";
28
- wav: "wav";
29
- }>>>>;
30
- sampleRate: z.ZodDefault<z.ZodOptional<z.ZodNullable<z.ZodUnion<readonly [z.ZodLiteral<8000>, z.ZodLiteral<16000>, z.ZodLiteral<24000>]>>>>;
31
- speed: z.ZodDefault<z.ZodOptional<z.ZodNullable<z.ZodNumber>>>;
32
- seed: z.ZodOptional<z.ZodNullable<z.ZodNumber>>;
33
- conversational: z.ZodDefault<z.ZodOptional<z.ZodNullable<z.ZodBoolean>>>;
34
- length: z.ZodOptional<z.ZodNullable<z.ZodNumber>>;
35
- topP: z.ZodDefault<z.ZodOptional<z.ZodNullable<z.ZodNumber>>>;
36
- temperature: z.ZodDefault<z.ZodOptional<z.ZodNullable<z.ZodNumber>>>;
37
- }, z.core.$strip>;
38
- type LMNTSpeechModelOptions = z.infer<typeof lmntSpeechModelOptionsSchema>;
39
19
  interface LMNTSpeechModelConfig extends LMNTConfig {
40
20
  _internal?: {
41
21
  currentDate?: () => Date;
@@ -46,12 +26,20 @@ declare class LMNTSpeechModel implements SpeechModelV4 {
46
26
  private readonly config;
47
27
  readonly specificationVersion = "v4";
48
28
  get provider(): string;
29
+ static [WORKFLOW_SERIALIZE](model: LMNTSpeechModel): {
30
+ modelId: string;
31
+ config: _ai_sdk_provider.JSONObject;
32
+ };
33
+ static [WORKFLOW_DESERIALIZE](options: {
34
+ modelId: LMNTSpeechModelId;
35
+ config: LMNTSpeechModelConfig;
36
+ }): LMNTSpeechModel;
49
37
  constructor(modelId: LMNTSpeechModelId, config: LMNTSpeechModelConfig);
50
38
  private getArgs;
51
39
  doGenerate(options: Parameters<SpeechModelV4['doGenerate']>[0]): Promise<Awaited<ReturnType<SpeechModelV4['doGenerate']>>>;
52
40
  }
53
41
 
54
- interface LMNTProvider extends Pick<ProviderV4, 'speechModel'> {
42
+ interface LMNTProvider extends ProviderV4 {
55
43
  (modelId: 'aurora', settings?: {}): {
56
44
  speech: LMNTSpeechModel;
57
45
  };
@@ -84,6 +72,28 @@ declare function createLMNT(options?: LMNTProviderSettings): LMNTProvider;
84
72
  */
85
73
  declare const lmnt: LMNTProvider;
86
74
 
75
+ declare const lmntSpeechModelOptionsSchema: z.ZodObject<{
76
+ model: z.ZodDefault<z.ZodOptional<z.ZodNullable<z.ZodUnion<readonly [z.ZodEnum<{
77
+ aurora: "aurora";
78
+ blizzard: "blizzard";
79
+ }>, z.ZodString]>>>>;
80
+ format: z.ZodDefault<z.ZodOptional<z.ZodNullable<z.ZodEnum<{
81
+ aac: "aac";
82
+ mp3: "mp3";
83
+ mulaw: "mulaw";
84
+ raw: "raw";
85
+ wav: "wav";
86
+ }>>>>;
87
+ sampleRate: z.ZodDefault<z.ZodOptional<z.ZodNullable<z.ZodUnion<readonly [z.ZodLiteral<8000>, z.ZodLiteral<16000>, z.ZodLiteral<24000>]>>>>;
88
+ speed: z.ZodDefault<z.ZodOptional<z.ZodNullable<z.ZodNumber>>>;
89
+ seed: z.ZodOptional<z.ZodNullable<z.ZodNumber>>;
90
+ conversational: z.ZodDefault<z.ZodOptional<z.ZodNullable<z.ZodBoolean>>>;
91
+ length: z.ZodOptional<z.ZodNullable<z.ZodNumber>>;
92
+ topP: z.ZodDefault<z.ZodOptional<z.ZodNullable<z.ZodNumber>>>;
93
+ temperature: z.ZodDefault<z.ZodOptional<z.ZodNullable<z.ZodNumber>>>;
94
+ }, z.core.$strip>;
95
+ type LMNTSpeechModelOptions = z.infer<typeof lmntSpeechModelOptionsSchema>;
96
+
87
97
  declare const VERSION: string;
88
98
 
89
99
  export { type LMNTProvider, type LMNTProviderSettings, type LMNTSpeechModelOptions, VERSION, createLMNT, lmnt };
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
- var import_provider_utils3 = require("@ai-sdk/provider-utils");
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
- var import_provider_utils2 = require("@ai-sdk/provider-utils");
34
- var import_v42 = require("zod/v4");
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
- var import_v4 = require("zod/v4");
38
- var import_provider_utils = require("@ai-sdk/provider-utils");
39
- var lmntErrorDataSchema = import_v4.z.object({
40
- error: import_v4.z.object({
41
- message: import_v4.z.string(),
42
- code: import_v4.z.number()
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 = (0, import_provider_utils.createJsonErrorResponseHandler)({
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
- var lmntSpeechModelOptionsSchema = import_v42.z.object({
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: import_v42.z.union([import_v42.z.enum(["aurora", "blizzard"]), import_v42.z.string()]).nullish().default("aurora"),
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: import_v42.z.enum(["aac", "mp3", "mulaw", "raw", "wav"]).nullish().default("mp3"),
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: import_v42.z.union([import_v42.z.literal(8e3), import_v42.z.literal(16e3), import_v42.z.literal(24e3)]).nullish().default(24e3),
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: import_v42.z.number().min(0.25).max(2).nullish().default(1),
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: import_v42.z.number().int().nullish(),
61
+ seed: z2.number().int().nullish(),
76
62
  /**
77
63
  * Whether to use a conversational style.
78
64
  * @default false
79
65
  */
80
- conversational: import_v42.z.boolean().nullish().default(false),
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: import_v42.z.number().max(300).nullish(),
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: import_v42.z.number().min(0).max(1).nullish().default(1),
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: import_v42.z.number().min(0).nullish().default(1)
80
+ temperature: z2.number().min(0).nullish().default(1)
95
81
  });
96
- var LMNTSpeechModel = class {
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 (0, import_provider_utils2.parseProviderOptions)({
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 (0, import_provider_utils2.postJsonToApi)({
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: (0, import_provider_utils2.combineHeaders)(this.config.headers(), options.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: (0, import_provider_utils2.createBinaryResponseHandler)(),
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.8" : "0.0.0-test";
197
+ var VERSION = true ? "3.0.0-canary.32" : "0.0.0-test";
201
198
 
202
199
  // src/lmnt-provider.ts
203
200
  function createLMNT(options = {}) {
204
- const getHeaders = () => (0, import_provider_utils3.withUserAgentSuffix)(
201
+ const getHeaders = () => withUserAgentSuffix(
205
202
  {
206
- "x-api-key": (0, import_provider_utils3.loadApiKey)({
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
- // Annotate the CommonJS export names for ESM import in node:
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/package.json CHANGED
@@ -1,10 +1,10 @@
1
1
  {
2
2
  "name": "@ai-sdk/lmnt",
3
- "version": "3.0.0-beta.8",
3
+ "version": "3.0.0-canary.32",
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,20 +24,20 @@
24
24
  "./package.json": "./package.json",
25
25
  ".": {
26
26
  "types": "./dist/index.d.ts",
27
- "import": "./dist/index.mjs",
28
- "require": "./dist/index.js"
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.5",
33
- "@ai-sdk/provider-utils": "5.0.0-beta.8"
32
+ "@ai-sdk/provider": "4.0.0-canary.15",
33
+ "@ai-sdk/provider-utils": "5.0.0-canary.31"
34
34
  },
35
35
  "devDependencies": {
36
36
  "@types/node": "20.17.24",
37
37
  "tsup": "^8",
38
38
  "typescript": "5.6.3",
39
39
  "zod": "3.25.76",
40
- "@ai-sdk/test-server": "2.0.0-beta.0",
40
+ "@ai-sdk/test-server": "2.0.0-canary.4",
41
41
  "@vercel/ai-tsconfig": "0.0.0"
42
42
  },
43
43
  "peerDependencies": {
@@ -47,12 +47,14 @@
47
47
  "node": ">=18"
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": "git+https://github.com/vercel/ai.git"
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"
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';
@@ -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: () => Record<string, string | undefined>;
6
+ headers?: () => Record<string, string | undefined>;
7
7
  fetch?: FetchFunction;
8
8
  generateId?: () => string;
9
9
  };
@@ -1,14 +1,18 @@
1
- import { SpeechModelV4, ProviderV4 } from '@ai-sdk/provider';
2
1
  import {
3
- FetchFunction,
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 Pick<ProviderV4, 'speechModel'> {
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
+ >;
@@ -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 { z } from 'zod/v4';
9
- import { LMNTConfig } from './lmnt-config';
11
+ import type { LMNTConfig } from './lmnt-config';
10
12
  import { lmntFailedResponseHandler } from './lmnt-error';
11
- import { LMNTSpeechModelId } from './lmnt-speech-options';
12
- import { LMNTSpeechAPITypes } from './lmnt-api-types';
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(),
package/dist/index.d.mts DELETED
@@ -1,89 +0,0 @@
1
- import { SpeechModelV4, ProviderV4 } from '@ai-sdk/provider';
2
- import { FetchFunction } from '@ai-sdk/provider-utils';
3
- import { z } from 'zod/v4';
4
-
5
- type LMNTConfig = {
6
- provider: string;
7
- url: (options: {
8
- modelId: string;
9
- path: string;
10
- }) => string;
11
- headers: () => Record<string, string | undefined>;
12
- fetch?: FetchFunction;
13
- generateId?: () => string;
14
- };
15
-
16
- type LMNTSpeechModelId = 'aurora' | 'blizzard' | (string & {});
17
-
18
- declare const lmntSpeechModelOptionsSchema: z.ZodObject<{
19
- model: z.ZodDefault<z.ZodOptional<z.ZodNullable<z.ZodUnion<readonly [z.ZodEnum<{
20
- aurora: "aurora";
21
- blizzard: "blizzard";
22
- }>, z.ZodString]>>>>;
23
- format: z.ZodDefault<z.ZodOptional<z.ZodNullable<z.ZodEnum<{
24
- aac: "aac";
25
- mp3: "mp3";
26
- mulaw: "mulaw";
27
- raw: "raw";
28
- wav: "wav";
29
- }>>>>;
30
- sampleRate: z.ZodDefault<z.ZodOptional<z.ZodNullable<z.ZodUnion<readonly [z.ZodLiteral<8000>, z.ZodLiteral<16000>, z.ZodLiteral<24000>]>>>>;
31
- speed: z.ZodDefault<z.ZodOptional<z.ZodNullable<z.ZodNumber>>>;
32
- seed: z.ZodOptional<z.ZodNullable<z.ZodNumber>>;
33
- conversational: z.ZodDefault<z.ZodOptional<z.ZodNullable<z.ZodBoolean>>>;
34
- length: z.ZodOptional<z.ZodNullable<z.ZodNumber>>;
35
- topP: z.ZodDefault<z.ZodOptional<z.ZodNullable<z.ZodNumber>>>;
36
- temperature: z.ZodDefault<z.ZodOptional<z.ZodNullable<z.ZodNumber>>>;
37
- }, z.core.$strip>;
38
- type LMNTSpeechModelOptions = z.infer<typeof lmntSpeechModelOptionsSchema>;
39
- interface LMNTSpeechModelConfig extends LMNTConfig {
40
- _internal?: {
41
- currentDate?: () => Date;
42
- };
43
- }
44
- declare class LMNTSpeechModel implements SpeechModelV4 {
45
- readonly modelId: LMNTSpeechModelId;
46
- private readonly config;
47
- readonly specificationVersion = "v4";
48
- get provider(): string;
49
- constructor(modelId: LMNTSpeechModelId, config: LMNTSpeechModelConfig);
50
- private getArgs;
51
- doGenerate(options: Parameters<SpeechModelV4['doGenerate']>[0]): Promise<Awaited<ReturnType<SpeechModelV4['doGenerate']>>>;
52
- }
53
-
54
- interface LMNTProvider extends Pick<ProviderV4, 'speechModel'> {
55
- (modelId: 'aurora', settings?: {}): {
56
- speech: LMNTSpeechModel;
57
- };
58
- /**
59
- * Creates a model for speech synthesis.
60
- */
61
- speech(modelId: LMNTSpeechModelId): SpeechModelV4;
62
- }
63
- interface LMNTProviderSettings {
64
- /**
65
- * API key for authenticating requests.
66
- */
67
- apiKey?: string;
68
- /**
69
- * Custom headers to include in the requests.
70
- */
71
- headers?: Record<string, string>;
72
- /**
73
- * Custom fetch implementation. You can use it as a middleware to intercept requests,
74
- * or to provide a custom fetch implementation for e.g. testing.
75
- */
76
- fetch?: FetchFunction;
77
- }
78
- /**
79
- * Create an LMNT provider instance.
80
- */
81
- declare function createLMNT(options?: LMNTProviderSettings): LMNTProvider;
82
- /**
83
- * Default LMNT provider instance.
84
- */
85
- declare const lmnt: LMNTProvider;
86
-
87
- declare const VERSION: string;
88
-
89
- export { type LMNTProvider, type LMNTProviderSettings, type LMNTSpeechModelOptions, VERSION, createLMNT, lmnt };
package/dist/index.mjs DELETED
@@ -1,216 +0,0 @@
1
- // src/lmnt-provider.ts
2
- import {
3
- loadApiKey,
4
- withUserAgentSuffix
5
- } from "@ai-sdk/provider-utils";
6
-
7
- // src/lmnt-speech-model.ts
8
- import {
9
- combineHeaders,
10
- createBinaryResponseHandler,
11
- parseProviderOptions,
12
- postJsonToApi
13
- } from "@ai-sdk/provider-utils";
14
- import { z as z2 } from "zod/v4";
15
-
16
- // src/lmnt-error.ts
17
- import { z } from "zod/v4";
18
- import { createJsonErrorResponseHandler } from "@ai-sdk/provider-utils";
19
- var lmntErrorDataSchema = z.object({
20
- error: z.object({
21
- message: z.string(),
22
- code: z.number()
23
- })
24
- });
25
- var lmntFailedResponseHandler = createJsonErrorResponseHandler({
26
- errorSchema: lmntErrorDataSchema,
27
- errorToMessage: (data) => data.error.message
28
- });
29
-
30
- // src/lmnt-speech-model.ts
31
- var lmntSpeechModelOptionsSchema = z2.object({
32
- /**
33
- * The model to use for speech synthesis e.g. 'aurora' or 'blizzard'.
34
- * @default 'aurora'
35
- */
36
- model: z2.union([z2.enum(["aurora", "blizzard"]), z2.string()]).nullish().default("aurora"),
37
- /**
38
- * The audio format of the output.
39
- * @default 'mp3'
40
- */
41
- format: z2.enum(["aac", "mp3", "mulaw", "raw", "wav"]).nullish().default("mp3"),
42
- /**
43
- * The sample rate of the output audio in Hz.
44
- * @default 24000
45
- */
46
- sampleRate: z2.union([z2.literal(8e3), z2.literal(16e3), z2.literal(24e3)]).nullish().default(24e3),
47
- /**
48
- * The speed of the speech. Range: 0.25 to 2.
49
- * @default 1
50
- */
51
- speed: z2.number().min(0.25).max(2).nullish().default(1),
52
- /**
53
- * A seed value for deterministic generation.
54
- */
55
- seed: z2.number().int().nullish(),
56
- /**
57
- * Whether to use a conversational style.
58
- * @default false
59
- */
60
- conversational: z2.boolean().nullish().default(false),
61
- /**
62
- * Maximum length of the output in seconds (up to 300).
63
- */
64
- length: z2.number().max(300).nullish(),
65
- /**
66
- * Top-p sampling parameter. Range: 0 to 1.
67
- * @default 1
68
- */
69
- topP: z2.number().min(0).max(1).nullish().default(1),
70
- /**
71
- * Temperature for sampling. Higher values increase randomness.
72
- * @default 1
73
- */
74
- temperature: z2.number().min(0).nullish().default(1)
75
- });
76
- var LMNTSpeechModel = class {
77
- constructor(modelId, config) {
78
- this.modelId = modelId;
79
- this.config = config;
80
- this.specificationVersion = "v4";
81
- }
82
- get provider() {
83
- return this.config.provider;
84
- }
85
- async getArgs({
86
- text,
87
- voice = "ava",
88
- outputFormat = "mp3",
89
- speed,
90
- language,
91
- providerOptions
92
- }) {
93
- var _a, _b, _c, _d, _e, _f, _g;
94
- const warnings = [];
95
- const lmntOptions = await parseProviderOptions({
96
- provider: "lmnt",
97
- providerOptions,
98
- schema: lmntSpeechModelOptionsSchema
99
- });
100
- const requestBody = {
101
- model: this.modelId,
102
- text,
103
- voice,
104
- response_format: "mp3",
105
- speed
106
- };
107
- if (outputFormat) {
108
- if (["mp3", "aac", "mulaw", "raw", "wav"].includes(outputFormat)) {
109
- requestBody.response_format = outputFormat;
110
- } else {
111
- warnings.push({
112
- type: "unsupported",
113
- feature: "outputFormat",
114
- details: `Unsupported output format: ${outputFormat}. Using mp3 instead.`
115
- });
116
- }
117
- }
118
- if (lmntOptions) {
119
- const speechModelOptions = {
120
- conversational: (_a = lmntOptions.conversational) != null ? _a : void 0,
121
- length: (_b = lmntOptions.length) != null ? _b : void 0,
122
- seed: (_c = lmntOptions.seed) != null ? _c : void 0,
123
- speed: (_d = lmntOptions.speed) != null ? _d : void 0,
124
- temperature: (_e = lmntOptions.temperature) != null ? _e : void 0,
125
- top_p: (_f = lmntOptions.topP) != null ? _f : void 0,
126
- sample_rate: (_g = lmntOptions.sampleRate) != null ? _g : void 0
127
- };
128
- for (const key in speechModelOptions) {
129
- const value = speechModelOptions[key];
130
- if (value !== void 0) {
131
- requestBody[key] = value;
132
- }
133
- }
134
- }
135
- if (language) {
136
- requestBody.language = language;
137
- }
138
- return {
139
- requestBody,
140
- warnings
141
- };
142
- }
143
- async doGenerate(options) {
144
- var _a, _b, _c;
145
- const currentDate = (_c = (_b = (_a = this.config._internal) == null ? void 0 : _a.currentDate) == null ? void 0 : _b.call(_a)) != null ? _c : /* @__PURE__ */ new Date();
146
- const { requestBody, warnings } = await this.getArgs(options);
147
- const {
148
- value: audio,
149
- responseHeaders,
150
- rawValue: rawResponse
151
- } = await postJsonToApi({
152
- url: this.config.url({
153
- path: "/v1/ai/speech/bytes",
154
- modelId: this.modelId
155
- }),
156
- headers: combineHeaders(this.config.headers(), options.headers),
157
- body: requestBody,
158
- failedResponseHandler: lmntFailedResponseHandler,
159
- successfulResponseHandler: createBinaryResponseHandler(),
160
- abortSignal: options.abortSignal,
161
- fetch: this.config.fetch
162
- });
163
- return {
164
- audio,
165
- warnings,
166
- request: {
167
- body: JSON.stringify(requestBody)
168
- },
169
- response: {
170
- timestamp: currentDate,
171
- modelId: this.modelId,
172
- headers: responseHeaders,
173
- body: rawResponse
174
- }
175
- };
176
- }
177
- };
178
-
179
- // src/version.ts
180
- var VERSION = true ? "3.0.0-beta.8" : "0.0.0-test";
181
-
182
- // src/lmnt-provider.ts
183
- function createLMNT(options = {}) {
184
- const getHeaders = () => withUserAgentSuffix(
185
- {
186
- "x-api-key": loadApiKey({
187
- apiKey: options.apiKey,
188
- environmentVariableName: "LMNT_API_KEY",
189
- description: "LMNT"
190
- }),
191
- ...options.headers
192
- },
193
- `ai-sdk/lmnt/${VERSION}`
194
- );
195
- const createSpeechModel = (modelId) => new LMNTSpeechModel(modelId, {
196
- provider: `lmnt.speech`,
197
- url: ({ path }) => `https://api.lmnt.com${path}`,
198
- headers: getHeaders,
199
- fetch: options.fetch
200
- });
201
- const provider = function(modelId) {
202
- return {
203
- speech: createSpeechModel(modelId)
204
- };
205
- };
206
- provider.speech = createSpeechModel;
207
- provider.speechModel = createSpeechModel;
208
- return provider;
209
- }
210
- var lmnt = createLMNT();
211
- export {
212
- VERSION,
213
- createLMNT,
214
- lmnt
215
- };
216
- //# sourceMappingURL=index.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/lmnt-provider.ts","../src/lmnt-speech-model.ts","../src/lmnt-error.ts","../src/version.ts"],"sourcesContent":["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":["z","z"]}