@openrouter/ai-sdk-provider 2.1.0 → 2.1.2

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/README.md CHANGED
@@ -19,13 +19,13 @@ yarn add @openrouter/ai-sdk-provider
19
19
 
20
20
  ```bash
21
21
  # For pnpm
22
- pnpm add @openrouter/ai-sdk-provider@ai-sdk-v5
22
+ pnpm add @openrouter/ai-sdk-provider@1.5.4
23
23
 
24
24
  # For npm
25
- npm install @openrouter/ai-sdk-provider@ai-sdk-v5
25
+ npm install @openrouter/ai-sdk-provider@1.5.4
26
26
 
27
27
  # For yarn
28
- yarn add @openrouter/ai-sdk-provider@ai-sdk-v5
28
+ yarn add @openrouter/ai-sdk-provider@1.5.4
29
29
  ```
30
30
 
31
31
  ## Provider Instance
package/dist/index.js CHANGED
@@ -9,6 +9,9 @@ var __getOwnPropSymbols = Object.getOwnPropertySymbols;
9
9
  var __getProtoOf = Object.getPrototypeOf;
10
10
  var __hasOwnProp = Object.prototype.hasOwnProperty;
11
11
  var __propIsEnum = Object.prototype.propertyIsEnumerable;
12
+ var __typeError = (msg) => {
13
+ throw TypeError(msg);
14
+ };
12
15
  var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
13
16
  var __spreadValues = (a, b) => {
14
17
  for (var prop in b || (b = {}))
@@ -55,6 +58,9 @@ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__ge
55
58
  mod
56
59
  ));
57
60
  var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
61
+ var __accessCheck = (obj, member, msg) => member.has(obj) || __typeError("Cannot " + msg);
62
+ var __privateGet = (obj, member, getter) => (__accessCheck(obj, member, "read from private field"), getter ? getter.call(obj) : member.get(obj));
63
+ var __privateAdd = (obj, member, value) => member.has(obj) ? __typeError("Cannot add the same private member more than once") : member instanceof WeakSet ? member.add(obj) : member.set(obj, value);
58
64
 
59
65
  // src/index.ts
60
66
  var index_exports = {};
@@ -2349,6 +2355,54 @@ function createFinishReason(unified, raw) {
2349
2355
  return { unified, raw };
2350
2356
  }
2351
2357
 
2358
+ // src/utils/reasoning-details-duplicate-tracker.ts
2359
+ var _seenKeys;
2360
+ var ReasoningDetailsDuplicateTracker = class {
2361
+ constructor() {
2362
+ __privateAdd(this, _seenKeys, /* @__PURE__ */ new Set());
2363
+ }
2364
+ /**
2365
+ * Attempts to track a detail.
2366
+ * Returns true if this is a NEW detail (not seen before and has valid key),
2367
+ * false if it was skipped (no valid key) or already seen (duplicate).
2368
+ */
2369
+ upsert(detail) {
2370
+ const key = this.getCanonicalKey(detail);
2371
+ if (key === null) {
2372
+ return false;
2373
+ }
2374
+ if (__privateGet(this, _seenKeys).has(key)) {
2375
+ return false;
2376
+ }
2377
+ __privateGet(this, _seenKeys).add(key);
2378
+ return true;
2379
+ }
2380
+ getCanonicalKey(detail) {
2381
+ switch (detail.type) {
2382
+ case "reasoning.summary" /* Summary */:
2383
+ return detail.summary;
2384
+ case "reasoning.encrypted" /* Encrypted */:
2385
+ if (detail.id) {
2386
+ return detail.id;
2387
+ }
2388
+ return detail.data;
2389
+ case "reasoning.text" /* Text */: {
2390
+ if (detail.text) {
2391
+ return detail.text;
2392
+ }
2393
+ if (detail.signature) {
2394
+ return detail.signature;
2395
+ }
2396
+ return null;
2397
+ }
2398
+ default: {
2399
+ return null;
2400
+ }
2401
+ }
2402
+ }
2403
+ };
2404
+ _seenKeys = new WeakMap();
2405
+
2352
2406
  // src/types/openrouter-chat-completions-input.ts
2353
2407
  var OPENROUTER_AUDIO_FORMATS = [
2354
2408
  "wav",
@@ -2480,6 +2534,7 @@ function getCacheControl(providerMetadata) {
2480
2534
  function convertToOpenRouterChatMessages(prompt) {
2481
2535
  var _a16, _b16, _c, _d, _e, _f, _g, _h;
2482
2536
  const messages = [];
2537
+ const reasoningDetailsTracker = new ReasoningDetailsDuplicateTracker();
2483
2538
  for (const { role, content, providerOptions } of prompt) {
2484
2539
  switch (role) {
2485
2540
  case "system": {
@@ -2622,7 +2677,17 @@ function convertToOpenRouterChatMessages(prompt) {
2622
2677
  const parsedProviderOptions = OpenRouterProviderOptionsSchema.safeParse(providerOptions);
2623
2678
  const messageReasoningDetails = parsedProviderOptions.success ? (_e = (_d = parsedProviderOptions.data) == null ? void 0 : _d.openrouter) == null ? void 0 : _e.reasoning_details : void 0;
2624
2679
  const messageAnnotations = parsedProviderOptions.success ? (_g = (_f = parsedProviderOptions.data) == null ? void 0 : _f.openrouter) == null ? void 0 : _g.annotations : void 0;
2625
- const finalReasoningDetails = messageReasoningDetails && Array.isArray(messageReasoningDetails) && messageReasoningDetails.length > 0 ? messageReasoningDetails : findFirstReasoningDetails(content);
2680
+ const candidateReasoningDetails = messageReasoningDetails && Array.isArray(messageReasoningDetails) && messageReasoningDetails.length > 0 ? messageReasoningDetails : findFirstReasoningDetails(content);
2681
+ let finalReasoningDetails;
2682
+ if (candidateReasoningDetails && candidateReasoningDetails.length > 0) {
2683
+ const uniqueDetails = [];
2684
+ for (const detail of candidateReasoningDetails) {
2685
+ if (reasoningDetailsTracker.upsert(detail)) {
2686
+ uniqueDetails.push(detail);
2687
+ }
2688
+ }
2689
+ finalReasoningDetails = uniqueDetails.length > 0 ? uniqueDetails : void 0;
2690
+ }
2626
2691
  messages.push({
2627
2692
  role: "assistant",
2628
2693
  content: text,
@@ -3447,7 +3512,16 @@ var OpenRouterChatLanguageModel = class {
3447
3512
  if (reasoningStarted && !textStarted) {
3448
3513
  controller.enqueue({
3449
3514
  type: "reasoning-end",
3450
- id: reasoningId || generateId()
3515
+ id: reasoningId || generateId(),
3516
+ // Include accumulated reasoning_details so the AI SDK can update
3517
+ // the reasoning part's providerMetadata with the correct signature.
3518
+ // The signature typically arrives in the last reasoning delta,
3519
+ // but reasoning-start only carries the first delta's metadata.
3520
+ providerMetadata: accumulatedReasoningDetails.length > 0 ? {
3521
+ openrouter: {
3522
+ reasoning_details: accumulatedReasoningDetails
3523
+ }
3524
+ } : void 0
3451
3525
  });
3452
3526
  reasoningStarted = false;
3453
3527
  }
@@ -3649,7 +3723,14 @@ var OpenRouterChatLanguageModel = class {
3649
3723
  if (reasoningStarted) {
3650
3724
  controller.enqueue({
3651
3725
  type: "reasoning-end",
3652
- id: reasoningId || generateId()
3726
+ id: reasoningId || generateId(),
3727
+ // Include accumulated reasoning_details so the AI SDK can update
3728
+ // the reasoning part's providerMetadata with the correct signature.
3729
+ providerMetadata: accumulatedReasoningDetails.length > 0 ? {
3730
+ openrouter: {
3731
+ reasoning_details: accumulatedReasoningDetails
3732
+ }
3733
+ } : void 0
3653
3734
  });
3654
3735
  }
3655
3736
  if (textStarted) {
@@ -4440,7 +4521,7 @@ function withUserAgentSuffix2(headers, ...userAgentSuffixParts) {
4440
4521
  }
4441
4522
 
4442
4523
  // src/version.ts
4443
- var VERSION2 = false ? "0.0.0-test" : "2.1.0";
4524
+ var VERSION2 = false ? "0.0.0-test" : "2.1.2";
4444
4525
 
4445
4526
  // src/provider.ts
4446
4527
  function createOpenRouter(options = {}) {