@openrouter/ai-sdk-provider 1.0.0-beta.6 → 1.0.0

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.
@@ -139,7 +139,7 @@ type OpenRouterChatSettings = {
139
139
  /**
140
140
  Return the log probabilities of the tokens. Including logprobs will increase
141
141
  the response size and can slow down response times. However, it can
142
- be useful to better understand how the model is behaving.
142
+ be useful to understand better how the model is behaving.
143
143
 
144
144
  Setting to true will return the log probabilities of the tokens that
145
145
  were generated.
@@ -139,7 +139,7 @@ type OpenRouterChatSettings = {
139
139
  /**
140
140
  Return the log probabilities of the tokens. Including logprobs will increase
141
141
  the response size and can slow down response times. However, it can
142
- be useful to better understand how the model is behaving.
142
+ be useful to understand better how the model is behaving.
143
143
 
144
144
  Setting to true will return the log probabilities of the tokens that
145
145
  were generated.
@@ -52,7 +52,7 @@ __export(index_exports, {
52
52
  });
53
53
  module.exports = __toCommonJS(index_exports);
54
54
 
55
- // node_modules/.pnpm/@ai-sdk+provider@2.0.0-beta.1/node_modules/@ai-sdk/provider/dist/index.mjs
55
+ // node_modules/.pnpm/@ai-sdk+provider@2.0.0/node_modules/@ai-sdk/provider/dist/index.mjs
56
56
  var marker = "vercel.ai.error";
57
57
  var symbol = Symbol.for(marker);
58
58
  var _a;
@@ -436,28 +436,25 @@ var EventSourceParserStream = class extends TransformStream {
436
436
  }
437
437
  };
438
438
 
439
- // node_modules/.pnpm/@ai-sdk+provider-utils@3.0.0-beta.5_zod@3.25.76/node_modules/@ai-sdk/provider-utils/dist/index.mjs
439
+ // node_modules/.pnpm/@ai-sdk+provider-utils@3.0.1_zod@3.25.76/node_modules/@ai-sdk/provider-utils/dist/index.mjs
440
440
  var z4 = __toESM(require("zod/v4"), 1);
441
441
 
442
- // node_modules/.pnpm/zod-to-json-schema@3.24.5_zod@3.25.76/node_modules/zod-to-json-schema/dist/esm/Options.js
442
+ // node_modules/.pnpm/zod-to-json-schema@3.24.6_zod@3.25.76/node_modules/zod-to-json-schema/dist/esm/Options.js
443
443
  var ignoreOverride = Symbol("Let zodToJsonSchema decide on which parser to use");
444
444
 
445
- // node_modules/.pnpm/zod-to-json-schema@3.24.5_zod@3.25.76/node_modules/zod-to-json-schema/dist/esm/selectParser.js
446
- var import_zod4 = require("zod");
445
+ // node_modules/.pnpm/zod-to-json-schema@3.24.6_zod@3.25.76/node_modules/zod-to-json-schema/dist/esm/selectParser.js
446
+ var import_zod3 = require("zod");
447
447
 
448
- // node_modules/.pnpm/zod-to-json-schema@3.24.5_zod@3.25.76/node_modules/zod-to-json-schema/dist/esm/parsers/array.js
448
+ // node_modules/.pnpm/zod-to-json-schema@3.24.6_zod@3.25.76/node_modules/zod-to-json-schema/dist/esm/parsers/array.js
449
449
  var import_zod = require("zod");
450
450
 
451
- // node_modules/.pnpm/zod-to-json-schema@3.24.5_zod@3.25.76/node_modules/zod-to-json-schema/dist/esm/parsers/record.js
451
+ // node_modules/.pnpm/zod-to-json-schema@3.24.6_zod@3.25.76/node_modules/zod-to-json-schema/dist/esm/parsers/record.js
452
452
  var import_zod2 = require("zod");
453
453
 
454
- // node_modules/.pnpm/zod-to-json-schema@3.24.5_zod@3.25.76/node_modules/zod-to-json-schema/dist/esm/parsers/string.js
454
+ // node_modules/.pnpm/zod-to-json-schema@3.24.6_zod@3.25.76/node_modules/zod-to-json-schema/dist/esm/parsers/string.js
455
455
  var ALPHA_NUMERIC = new Set("ABCDEFGHIJKLMNOPQRSTUVXYZabcdefghijklmnopqrstuvxyz0123456789");
456
456
 
457
- // node_modules/.pnpm/zod-to-json-schema@3.24.5_zod@3.25.76/node_modules/zod-to-json-schema/dist/esm/parsers/object.js
458
- var import_zod3 = require("zod");
459
-
460
- // node_modules/.pnpm/@ai-sdk+provider-utils@3.0.0-beta.5_zod@3.25.76/node_modules/@ai-sdk/provider-utils/dist/index.mjs
457
+ // node_modules/.pnpm/@ai-sdk+provider-utils@3.0.1_zod@3.25.76/node_modules/@ai-sdk/provider-utils/dist/index.mjs
461
458
  function combineHeaders(...headers) {
462
459
  return headers.reduce(
463
460
  (combinedHeaders, currentHeaders) => __spreadValues(__spreadValues({}, combinedHeaders), currentHeaders != null ? currentHeaders : {}),
@@ -494,7 +491,7 @@ var createIdGenerator = ({
494
491
  };
495
492
  var generateId = createIdGenerator();
496
493
  function isAbortError(error) {
497
- return error instanceof Error && (error.name === "AbortError" || error.name === "ResponseAborted" || // Next.js
494
+ return (error instanceof Error || error instanceof DOMException) && (error.name === "AbortError" || error.name === "ResponseAborted" || // Next.js
498
495
  error.name === "TimeoutError");
499
496
  }
500
497
  var FETCH_FAILED_ERROR_MESSAGES = ["fetch failed", "failed to fetch"];
@@ -1309,6 +1306,7 @@ var OpenRouterChatLanguageModel = class {
1309
1306
  tools,
1310
1307
  toolChoice
1311
1308
  }) {
1309
+ var _a15;
1312
1310
  const baseArgs = __spreadValues(__spreadValues({
1313
1311
  // model id:
1314
1312
  model: this.modelId,
@@ -1336,9 +1334,18 @@ var OpenRouterChatLanguageModel = class {
1336
1334
  reasoning: this.settings.reasoning,
1337
1335
  usage: this.settings.usage
1338
1336
  }, this.config.extraBody), this.settings.extraBody);
1339
- if ((responseFormat == null ? void 0 : responseFormat.type) === "json") {
1337
+ if ((responseFormat == null ? void 0 : responseFormat.type) === "json" && responseFormat.schema != null) {
1340
1338
  return __spreadProps(__spreadValues({}, baseArgs), {
1341
- response_format: { type: "json_object" }
1339
+ response_format: {
1340
+ type: "json_schema",
1341
+ json_schema: __spreadValues({
1342
+ schema: responseFormat.schema,
1343
+ strict: true,
1344
+ name: (_a15 = responseFormat.name) != null ? _a15 : "response"
1345
+ }, responseFormat.description && {
1346
+ description: responseFormat.description
1347
+ })
1348
+ }
1342
1349
  });
1343
1350
  }
1344
1351
  if (tools && tools.length > 0) {
@@ -1626,10 +1633,17 @@ var OpenRouterChatLanguageModel = class {
1626
1633
  }
1627
1634
  }
1628
1635
  }
1629
- } else if (delta.reasoning != null) {
1636
+ } else if (delta.reasoning) {
1630
1637
  emitReasoningChunk(delta.reasoning);
1631
1638
  }
1632
- if (delta.content != null) {
1639
+ if (delta.content) {
1640
+ if (reasoningStarted && !textStarted) {
1641
+ controller.enqueue({
1642
+ type: "reasoning-end",
1643
+ id: reasoningId || generateId()
1644
+ });
1645
+ reasoningStarted = false;
1646
+ }
1633
1647
  if (!textStarted) {
1634
1648
  textId = openrouterResponseId || generateId();
1635
1649
  controller.enqueue({
@@ -1754,18 +1768,18 @@ var OpenRouterChatLanguageModel = class {
1754
1768
  }
1755
1769
  }
1756
1770
  }
1757
- if (textStarted) {
1758
- controller.enqueue({
1759
- type: "text-end",
1760
- id: textId || generateId()
1761
- });
1762
- }
1763
1771
  if (reasoningStarted) {
1764
1772
  controller.enqueue({
1765
1773
  type: "reasoning-end",
1766
1774
  id: reasoningId || generateId()
1767
1775
  });
1768
1776
  }
1777
+ if (textStarted) {
1778
+ controller.enqueue({
1779
+ type: "text-end",
1780
+ id: textId || generateId()
1781
+ });
1782
+ }
1769
1783
  controller.enqueue({
1770
1784
  type: "finish",
1771
1785
  finishReason,