@orpc/client 1.8.6 → 1.8.7

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.
@@ -1,8 +1,8 @@
1
1
  import { toArray, intercept } from '@orpc/shared';
2
2
  import { toFetchRequest, toStandardLazyResponse } from '@orpc/standard-server-fetch';
3
- import { C as CompositeStandardLinkPlugin, c as StandardRPCLink } from '../../shared/client.Bp1jlnBk.mjs';
3
+ import { C as CompositeStandardLinkPlugin, c as StandardRPCLink } from '../../shared/client.CH3WAlBG.mjs';
4
4
  import '@orpc/standard-server';
5
- import '../../shared/client.txdq_i5V.mjs';
5
+ import '../../shared/client.DO4HriUw.mjs';
6
6
 
7
7
  class CompositeLinkFetchPlugin extends CompositeStandardLinkPlugin {
8
8
  initRuntimeAdapter(options) {
@@ -1,9 +1,9 @@
1
1
  import { ClientPeer } from '@orpc/standard-server-peer';
2
2
  import '@orpc/shared';
3
- import { c as StandardRPCLink } from '../../shared/client.Bp1jlnBk.mjs';
3
+ import { c as StandardRPCLink } from '../../shared/client.CH3WAlBG.mjs';
4
4
  import '@orpc/standard-server';
5
+ import '../../shared/client.DO4HriUw.mjs';
5
6
  import '@orpc/standard-server-fetch';
6
- import '../../shared/client.txdq_i5V.mjs';
7
7
 
8
8
  function postMessagePortMessage(port, data) {
9
9
  port.postMessage(data);
@@ -1,5 +1,5 @@
1
- export { C as CompositeStandardLinkPlugin, a as STANDARD_RPC_JSON_SERIALIZER_BUILT_IN_TYPES, S as StandardLink, b as StandardRPCJsonSerializer, c as StandardRPCLink, d as StandardRPCLinkCodec, e as StandardRPCSerializer, g as getMalformedResponseErrorCode, t as toHttpPath, f as toStandardHeaders } from '../../shared/client.Bp1jlnBk.mjs';
1
+ export { C as CompositeStandardLinkPlugin, a as STANDARD_RPC_JSON_SERIALIZER_BUILT_IN_TYPES, S as StandardLink, b as StandardRPCJsonSerializer, c as StandardRPCLink, d as StandardRPCLinkCodec, e as StandardRPCSerializer, g as getMalformedResponseErrorCode, t as toHttpPath, f as toStandardHeaders } from '../../shared/client.CH3WAlBG.mjs';
2
2
  import '@orpc/shared';
3
3
  import '@orpc/standard-server';
4
- import '../../shared/client.txdq_i5V.mjs';
4
+ import '../../shared/client.DO4HriUw.mjs';
5
5
  import '@orpc/standard-server-fetch';
@@ -1,9 +1,9 @@
1
1
  import { readAsBuffer } from '@orpc/shared';
2
2
  import { ClientPeer } from '@orpc/standard-server-peer';
3
- import { c as StandardRPCLink } from '../../shared/client.Bp1jlnBk.mjs';
3
+ import { c as StandardRPCLink } from '../../shared/client.CH3WAlBG.mjs';
4
4
  import '@orpc/standard-server';
5
+ import '../../shared/client.DO4HriUw.mjs';
5
6
  import '@orpc/standard-server-fetch';
6
- import '../../shared/client.txdq_i5V.mjs';
7
7
 
8
8
  const WEBSOCKET_CONNECTING = 0;
9
9
  class LinkWebsocketClient {
package/dist/index.d.mts CHANGED
@@ -115,6 +115,19 @@ declare class ORPCError<TCode extends ORPCErrorCode, TData> extends Error {
115
115
  readonly data: TData;
116
116
  constructor(code: TCode, ...rest: MaybeOptionalOptions<ORPCErrorOptions<TData>>);
117
117
  toJSON(): ORPCErrorJSON<TCode, TData>;
118
+ /**
119
+ * Workaround for Next.js where different contexts use separate
120
+ * dependency graphs, causing multiple ORPCError constructors existing and breaking
121
+ * `instanceof` checks across contexts.
122
+ *
123
+ * This is particularly problematic with "Optimized SSR", where orpc-client
124
+ * executes in one context but is invoked from another. When an error is thrown
125
+ * in the execution context, `instanceof ORPCError` checks fail in the
126
+ * invocation context due to separate class constructors.
127
+ *
128
+ * @todo Remove this and related code if Next.js resolves the multiple dependency graph issue.
129
+ */
130
+ static [Symbol.hasInstance](instance: unknown): boolean;
118
131
  }
119
132
  type ORPCErrorJSON<TCode extends string, TData> = Pick<ORPCError<TCode, TData>, 'defined' | 'code' | 'status' | 'message' | 'data'>;
120
133
  declare function isDefinedError<T>(error: T): error is Extract<T, ORPCError<any, any>>;
@@ -164,6 +177,9 @@ type SafeClient<T extends NestedClient<any>> = T extends Client<infer UContext,
164
177
  */
165
178
  declare function createSafeClient<T extends NestedClient<any>>(client: T): SafeClient<T>;
166
179
 
180
+ declare const ORPC_CLIENT_PACKAGE_NAME = "@orpc/client";
181
+ declare const ORPC_CLIENT_PACKAGE_VERSION = "1.8.7";
182
+
167
183
  /**
168
184
  * DynamicLink provides a way to dynamically resolve and delegate calls to other ClientLinks
169
185
  * based on the request path, input, and context.
@@ -181,5 +197,5 @@ declare function mapEventIterator<TYield, TReturn, TNext, TMap = TYield | TRetur
181
197
  error: (error: unknown) => Promise<unknown>;
182
198
  }): AsyncIteratorClass<TMap, TMap, TNext>;
183
199
 
184
- export { COMMON_ORPC_ERROR_DEFS, Client, ClientContext, ClientLink, ClientOptions, ClientPromiseResult, ClientRest, DynamicLink, FriendlyClientOptions, InferClientContext, NestedClient, ORPCError, createORPCClient, createORPCErrorFromJson, createSafeClient, fallbackORPCErrorMessage, fallbackORPCErrorStatus, isDefinedError, isORPCErrorJson, isORPCErrorStatus, mapEventIterator, resolveFriendlyClientOptions, safe, toORPCError };
200
+ export { COMMON_ORPC_ERROR_DEFS, Client, ClientContext, ClientLink, ClientOptions, ClientPromiseResult, ClientRest, DynamicLink, FriendlyClientOptions, InferClientContext, NestedClient, ORPCError, ORPC_CLIENT_PACKAGE_NAME, ORPC_CLIENT_PACKAGE_VERSION, createORPCClient, createORPCErrorFromJson, createSafeClient, fallbackORPCErrorMessage, fallbackORPCErrorStatus, isDefinedError, isORPCErrorJson, isORPCErrorStatus, mapEventIterator, resolveFriendlyClientOptions, safe, toORPCError };
185
201
  export type { CommonORPCErrorCode, ORPCErrorCode, ORPCErrorJSON, ORPCErrorOptions, SafeClient, SafeResult, createORPCClientOptions };
package/dist/index.d.ts CHANGED
@@ -115,6 +115,19 @@ declare class ORPCError<TCode extends ORPCErrorCode, TData> extends Error {
115
115
  readonly data: TData;
116
116
  constructor(code: TCode, ...rest: MaybeOptionalOptions<ORPCErrorOptions<TData>>);
117
117
  toJSON(): ORPCErrorJSON<TCode, TData>;
118
+ /**
119
+ * Workaround for Next.js where different contexts use separate
120
+ * dependency graphs, causing multiple ORPCError constructors existing and breaking
121
+ * `instanceof` checks across contexts.
122
+ *
123
+ * This is particularly problematic with "Optimized SSR", where orpc-client
124
+ * executes in one context but is invoked from another. When an error is thrown
125
+ * in the execution context, `instanceof ORPCError` checks fail in the
126
+ * invocation context due to separate class constructors.
127
+ *
128
+ * @todo Remove this and related code if Next.js resolves the multiple dependency graph issue.
129
+ */
130
+ static [Symbol.hasInstance](instance: unknown): boolean;
118
131
  }
119
132
  type ORPCErrorJSON<TCode extends string, TData> = Pick<ORPCError<TCode, TData>, 'defined' | 'code' | 'status' | 'message' | 'data'>;
120
133
  declare function isDefinedError<T>(error: T): error is Extract<T, ORPCError<any, any>>;
@@ -164,6 +177,9 @@ type SafeClient<T extends NestedClient<any>> = T extends Client<infer UContext,
164
177
  */
165
178
  declare function createSafeClient<T extends NestedClient<any>>(client: T): SafeClient<T>;
166
179
 
180
+ declare const ORPC_CLIENT_PACKAGE_NAME = "@orpc/client";
181
+ declare const ORPC_CLIENT_PACKAGE_VERSION = "1.8.7";
182
+
167
183
  /**
168
184
  * DynamicLink provides a way to dynamically resolve and delegate calls to other ClientLinks
169
185
  * based on the request path, input, and context.
@@ -181,5 +197,5 @@ declare function mapEventIterator<TYield, TReturn, TNext, TMap = TYield | TRetur
181
197
  error: (error: unknown) => Promise<unknown>;
182
198
  }): AsyncIteratorClass<TMap, TMap, TNext>;
183
199
 
184
- export { COMMON_ORPC_ERROR_DEFS, Client, ClientContext, ClientLink, ClientOptions, ClientPromiseResult, ClientRest, DynamicLink, FriendlyClientOptions, InferClientContext, NestedClient, ORPCError, createORPCClient, createORPCErrorFromJson, createSafeClient, fallbackORPCErrorMessage, fallbackORPCErrorStatus, isDefinedError, isORPCErrorJson, isORPCErrorStatus, mapEventIterator, resolveFriendlyClientOptions, safe, toORPCError };
200
+ export { COMMON_ORPC_ERROR_DEFS, Client, ClientContext, ClientLink, ClientOptions, ClientPromiseResult, ClientRest, DynamicLink, FriendlyClientOptions, InferClientContext, NestedClient, ORPCError, ORPC_CLIENT_PACKAGE_NAME, ORPC_CLIENT_PACKAGE_VERSION, createORPCClient, createORPCErrorFromJson, createSafeClient, fallbackORPCErrorMessage, fallbackORPCErrorStatus, isDefinedError, isORPCErrorJson, isORPCErrorStatus, mapEventIterator, resolveFriendlyClientOptions, safe, toORPCError };
185
201
  export type { CommonORPCErrorCode, ORPCErrorCode, ORPCErrorJSON, ORPCErrorOptions, SafeClient, SafeResult, createORPCClientOptions };
package/dist/index.mjs CHANGED
@@ -1,7 +1,7 @@
1
1
  import { preventNativeAwait, isTypescriptObject } from '@orpc/shared';
2
2
  export { AsyncIteratorClass, EventPublisher, asyncIteratorToStream as eventIteratorToStream, onError, onFinish, onStart, onSuccess, streamToAsyncIteratorClass as streamToEventIterator } from '@orpc/shared';
3
- import { i as isDefinedError } from './shared/client.txdq_i5V.mjs';
4
- export { C as COMMON_ORPC_ERROR_DEFS, O as ORPCError, d as createORPCErrorFromJson, a as fallbackORPCErrorMessage, f as fallbackORPCErrorStatus, c as isORPCErrorJson, b as isORPCErrorStatus, m as mapEventIterator, t as toORPCError } from './shared/client.txdq_i5V.mjs';
3
+ import { i as isDefinedError } from './shared/client.DO4HriUw.mjs';
4
+ export { C as COMMON_ORPC_ERROR_DEFS, c as ORPCError, O as ORPC_CLIENT_PACKAGE_NAME, a as ORPC_CLIENT_PACKAGE_VERSION, g as createORPCErrorFromJson, b as fallbackORPCErrorMessage, f as fallbackORPCErrorStatus, e as isORPCErrorJson, d as isORPCErrorStatus, m as mapEventIterator, t as toORPCError } from './shared/client.DO4HriUw.mjs';
5
5
  export { ErrorEvent } from '@orpc/standard-server';
6
6
 
7
7
  async function safe(promise) {
@@ -1,4 +1,4 @@
1
- import { isAsyncIteratorObject, defer, value, splitInHalf, toArray, stringifyJSON } from '@orpc/shared';
1
+ import { isAsyncIteratorObject, defer, value, splitInHalf, toArray, stringifyJSON, AsyncIteratorClass } from '@orpc/shared';
2
2
  import { toBatchRequest, parseBatchResponse, toBatchAbortSignal } from '@orpc/standard-server/batch';
3
3
  import { replicateStandardLazyResponse, getEventMeta } from '@orpc/standard-server';
4
4
 
@@ -317,7 +317,7 @@ class ClientRetryPlugin {
317
317
  return await interceptorOptions.next(updatedInterceptorOptions);
318
318
  } catch (error) {
319
319
  currentError = { error };
320
- if (updatedInterceptorOptions.signal?.aborted === true) {
320
+ if (updatedInterceptorOptions.signal?.aborted) {
321
321
  throw error;
322
322
  }
323
323
  } finally {
@@ -330,19 +330,17 @@ class ClientRetryPlugin {
330
330
  if (!isAsyncIteratorObject(output)) {
331
331
  return output;
332
332
  }
333
- return (async function* () {
334
- let current = output;
335
- try {
333
+ let current = output;
334
+ let isIteratorAborted = false;
335
+ return new AsyncIteratorClass(
336
+ async () => {
336
337
  while (true) {
337
338
  try {
338
339
  const item = await current.next();
339
340
  const meta = getEventMeta(item.value);
340
341
  lastEventId = meta?.id ?? lastEventId;
341
342
  lastEventRetry = meta?.retry ?? lastEventRetry;
342
- if (item.done) {
343
- return item.value;
344
- }
345
- yield item.value;
343
+ return item;
346
344
  } catch (error) {
347
345
  const meta = getEventMeta(error);
348
346
  lastEventId = meta?.id ?? lastEventId;
@@ -354,12 +352,20 @@ class ClientRetryPlugin {
354
352
  );
355
353
  }
356
354
  current = maybeEventIterator;
355
+ if (isIteratorAborted) {
356
+ await current.return?.();
357
+ throw error;
358
+ }
357
359
  }
358
360
  }
359
- } finally {
360
- await current.return?.();
361
+ },
362
+ async (reason) => {
363
+ isIteratorAborted = true;
364
+ if (reason !== "next") {
365
+ await current.return?.();
366
+ }
361
367
  }
362
- })();
368
+ );
363
369
  });
364
370
  }
365
371
  }
@@ -1,6 +1,6 @@
1
1
  import { toArray, runWithSpan, ORPC_NAME, isAsyncIteratorObject, asyncIteratorWithSpan, intercept, getGlobalOtelConfig, isObject, value, stringifyJSON } from '@orpc/shared';
2
2
  import { mergeStandardHeaders, ErrorEvent } from '@orpc/standard-server';
3
- import { C as COMMON_ORPC_ERROR_DEFS, b as isORPCErrorStatus, c as isORPCErrorJson, d as createORPCErrorFromJson, O as ORPCError, m as mapEventIterator, t as toORPCError } from './client.txdq_i5V.mjs';
3
+ import { C as COMMON_ORPC_ERROR_DEFS, d as isORPCErrorStatus, e as isORPCErrorJson, g as createORPCErrorFromJson, c as ORPCError, m as mapEventIterator, t as toORPCError } from './client.DO4HriUw.mjs';
4
4
  import { toStandardHeaders as toStandardHeaders$1 } from '@orpc/standard-server-fetch';
5
5
 
6
6
  class CompositeStandardLinkPlugin {
@@ -1,6 +1,9 @@
1
- import { resolveMaybeOptionalOptions, isObject, AsyncIteratorClass, isTypescriptObject } from '@orpc/shared';
1
+ import { resolveMaybeOptionalOptions, getConstructor, isObject, AsyncIteratorClass, isTypescriptObject } from '@orpc/shared';
2
2
  import { getEventMeta, withEventMeta } from '@orpc/standard-server';
3
3
 
4
+ const ORPC_CLIENT_PACKAGE_NAME = "@orpc/client";
5
+ const ORPC_CLIENT_PACKAGE_VERSION = "1.8.7";
6
+
4
7
  const COMMON_ORPC_ERROR_DEFS = {
5
8
  BAD_REQUEST: {
6
9
  status: 400,
@@ -85,6 +88,9 @@ function fallbackORPCErrorStatus(code, status) {
85
88
  function fallbackORPCErrorMessage(code, message) {
86
89
  return message || COMMON_ORPC_ERROR_DEFS[code]?.message || code;
87
90
  }
91
+ const GLOBAL_ORPC_ERROR_CONSTRUCTORS_SYMBOL = Symbol.for(`__${ORPC_CLIENT_PACKAGE_NAME}@${ORPC_CLIENT_PACKAGE_VERSION}/error/ORPC_ERROR_CONSTRUCTORS__`);
92
+ void (globalThis[GLOBAL_ORPC_ERROR_CONSTRUCTORS_SYMBOL] ??= /* @__PURE__ */ new WeakSet());
93
+ const globalORPCErrorConstructors = globalThis[GLOBAL_ORPC_ERROR_CONSTRUCTORS_SYMBOL];
88
94
  class ORPCError extends Error {
89
95
  defined;
90
96
  code;
@@ -111,7 +117,29 @@ class ORPCError extends Error {
111
117
  data: this.data
112
118
  };
113
119
  }
120
+ /**
121
+ * Workaround for Next.js where different contexts use separate
122
+ * dependency graphs, causing multiple ORPCError constructors existing and breaking
123
+ * `instanceof` checks across contexts.
124
+ *
125
+ * This is particularly problematic with "Optimized SSR", where orpc-client
126
+ * executes in one context but is invoked from another. When an error is thrown
127
+ * in the execution context, `instanceof ORPCError` checks fail in the
128
+ * invocation context due to separate class constructors.
129
+ *
130
+ * @todo Remove this and related code if Next.js resolves the multiple dependency graph issue.
131
+ */
132
+ static [Symbol.hasInstance](instance) {
133
+ if (globalORPCErrorConstructors.has(this)) {
134
+ const constructor = getConstructor(instance);
135
+ if (constructor && globalORPCErrorConstructors.has(constructor)) {
136
+ return true;
137
+ }
138
+ }
139
+ return super[Symbol.hasInstance](instance);
140
+ }
114
141
  }
142
+ globalORPCErrorConstructors.add(ORPCError);
115
143
  function isDefinedError(error) {
116
144
  return error instanceof ORPCError && error.defined;
117
145
  }
@@ -177,4 +205,4 @@ function mapEventIterator(iterator, maps) {
177
205
  });
178
206
  }
179
207
 
180
- export { COMMON_ORPC_ERROR_DEFS as C, ORPCError as O, fallbackORPCErrorMessage as a, isORPCErrorStatus as b, isORPCErrorJson as c, createORPCErrorFromJson as d, fallbackORPCErrorStatus as f, isDefinedError as i, mapEventIterator as m, toORPCError as t };
208
+ export { COMMON_ORPC_ERROR_DEFS as C, ORPC_CLIENT_PACKAGE_NAME as O, ORPC_CLIENT_PACKAGE_VERSION as a, fallbackORPCErrorMessage as b, ORPCError as c, isORPCErrorStatus as d, isORPCErrorJson as e, fallbackORPCErrorStatus as f, createORPCErrorFromJson as g, isDefinedError as i, mapEventIterator as m, toORPCError as t };
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@orpc/client",
3
3
  "type": "module",
4
- "version": "1.8.6",
4
+ "version": "1.8.7",
5
5
  "license": "MIT",
6
6
  "homepage": "https://orpc.unnoq.com",
7
7
  "repository": {
@@ -49,13 +49,13 @@
49
49
  "dist"
50
50
  ],
51
51
  "dependencies": {
52
- "@orpc/shared": "1.8.6",
53
- "@orpc/standard-server": "1.8.6",
54
- "@orpc/standard-server-fetch": "1.8.6",
55
- "@orpc/standard-server-peer": "1.8.6"
52
+ "@orpc/standard-server": "1.8.7",
53
+ "@orpc/standard-server-fetch": "1.8.7",
54
+ "@orpc/shared": "1.8.7",
55
+ "@orpc/standard-server-peer": "1.8.7"
56
56
  },
57
57
  "devDependencies": {
58
- "zod": "^4.1.3"
58
+ "zod": "^4.1.5"
59
59
  },
60
60
  "scripts": {
61
61
  "build": "unbuild",