@orpc/client 1.8.5 → 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.
- package/dist/adapters/fetch/index.d.mts +1 -1
- package/dist/adapters/fetch/index.d.ts +1 -1
- package/dist/adapters/fetch/index.mjs +2 -2
- package/dist/adapters/message-port/index.d.mts +1 -1
- package/dist/adapters/message-port/index.d.ts +1 -1
- package/dist/adapters/message-port/index.mjs +3 -2
- package/dist/adapters/standard/index.d.mts +4 -3
- package/dist/adapters/standard/index.d.ts +4 -3
- package/dist/adapters/standard/index.mjs +3 -2
- package/dist/adapters/websocket/index.d.mts +1 -1
- package/dist/adapters/websocket/index.d.ts +1 -1
- package/dist/adapters/websocket/index.mjs +3 -2
- package/dist/index.d.mts +17 -1
- package/dist/index.d.ts +17 -1
- package/dist/index.mjs +2 -2
- package/dist/plugins/index.mjs +18 -12
- package/dist/shared/{client.DKmRtVO2.mjs → client.CH3WAlBG.mjs} +13 -6
- package/dist/shared/{client.C176log5.d.ts → client.CVVVqf1Y.d.ts} +1 -1
- package/dist/shared/{client.txdq_i5V.mjs → client.DO4HriUw.mjs} +30 -2
- package/dist/shared/{client.Ycwr4Tuo.d.mts → client._Y_enhib.d.mts} +1 -1
- package/package.json +6 -6
@@ -3,7 +3,7 @@ import { StandardRequest, StandardLazyResponse } from '@orpc/standard-server';
|
|
3
3
|
import { ToFetchRequestOptions } from '@orpc/standard-server-fetch';
|
4
4
|
import { b as ClientContext, c as ClientOptions } from '../../shared/client.BOYsZIRq.mjs';
|
5
5
|
import { a as StandardLinkPlugin, f as StandardLinkClient } from '../../shared/client.Bwgm6dgk.mjs';
|
6
|
-
import { f as StandardRPCLinkOptions, g as StandardRPCLink } from '../../shared/client.
|
6
|
+
import { f as StandardRPCLinkOptions, g as StandardRPCLink } from '../../shared/client._Y_enhib.mjs';
|
7
7
|
|
8
8
|
interface LinkFetchPlugin<T extends ClientContext> extends StandardLinkPlugin<T> {
|
9
9
|
initRuntimeAdapter?(options: LinkFetchClientOptions<T>): void;
|
@@ -3,7 +3,7 @@ import { StandardRequest, StandardLazyResponse } from '@orpc/standard-server';
|
|
3
3
|
import { ToFetchRequestOptions } from '@orpc/standard-server-fetch';
|
4
4
|
import { b as ClientContext, c as ClientOptions } from '../../shared/client.BOYsZIRq.js';
|
5
5
|
import { a as StandardLinkPlugin, f as StandardLinkClient } from '../../shared/client.BG98rYdO.js';
|
6
|
-
import { f as StandardRPCLinkOptions, g as StandardRPCLink } from '../../shared/client.
|
6
|
+
import { f as StandardRPCLinkOptions, g as StandardRPCLink } from '../../shared/client.CVVVqf1Y.js';
|
7
7
|
|
8
8
|
interface LinkFetchPlugin<T extends ClientContext> extends StandardLinkPlugin<T> {
|
9
9
|
initRuntimeAdapter?(options: LinkFetchClientOptions<T>): void;
|
@@ -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.
|
3
|
+
import { C as CompositeStandardLinkPlugin, c as StandardRPCLink } from '../../shared/client.CH3WAlBG.mjs';
|
4
4
|
import '@orpc/standard-server';
|
5
|
-
import '../../shared/client.
|
5
|
+
import '../../shared/client.DO4HriUw.mjs';
|
6
6
|
|
7
7
|
class CompositeLinkFetchPlugin extends CompositeStandardLinkPlugin {
|
8
8
|
initRuntimeAdapter(options) {
|
@@ -1,7 +1,7 @@
|
|
1
1
|
import { StandardRequest, StandardLazyResponse } from '@orpc/standard-server';
|
2
2
|
import { b as ClientContext, c as ClientOptions } from '../../shared/client.BOYsZIRq.mjs';
|
3
3
|
import { f as StandardLinkClient } from '../../shared/client.Bwgm6dgk.mjs';
|
4
|
-
import { f as StandardRPCLinkOptions, g as StandardRPCLink } from '../../shared/client.
|
4
|
+
import { f as StandardRPCLinkOptions, g as StandardRPCLink } from '../../shared/client._Y_enhib.mjs';
|
5
5
|
import '@orpc/shared';
|
6
6
|
|
7
7
|
/**
|
@@ -1,7 +1,7 @@
|
|
1
1
|
import { StandardRequest, StandardLazyResponse } from '@orpc/standard-server';
|
2
2
|
import { b as ClientContext, c as ClientOptions } from '../../shared/client.BOYsZIRq.js';
|
3
3
|
import { f as StandardLinkClient } from '../../shared/client.BG98rYdO.js';
|
4
|
-
import { f as StandardRPCLinkOptions, g as StandardRPCLink } from '../../shared/client.
|
4
|
+
import { f as StandardRPCLinkOptions, g as StandardRPCLink } from '../../shared/client.CVVVqf1Y.js';
|
5
5
|
import '@orpc/shared';
|
6
6
|
|
7
7
|
/**
|
@@ -1,8 +1,9 @@
|
|
1
1
|
import { ClientPeer } from '@orpc/standard-server-peer';
|
2
2
|
import '@orpc/shared';
|
3
|
-
import { c as StandardRPCLink } from '../../shared/client.
|
3
|
+
import { c as StandardRPCLink } from '../../shared/client.CH3WAlBG.mjs';
|
4
4
|
import '@orpc/standard-server';
|
5
|
-
import '../../shared/client.
|
5
|
+
import '../../shared/client.DO4HriUw.mjs';
|
6
|
+
import '@orpc/standard-server-fetch';
|
6
7
|
|
7
8
|
function postMessagePortMessage(port, data) {
|
8
9
|
port.postMessage(data);
|
@@ -1,10 +1,11 @@
|
|
1
1
|
export { C as CompositeStandardLinkPlugin, d as StandardLink, f as StandardLinkClient, S as StandardLinkClientInterceptorOptions, e as StandardLinkCodec, c as StandardLinkInterceptorOptions, b as StandardLinkOptions, a as StandardLinkPlugin } from '../../shared/client.Bwgm6dgk.mjs';
|
2
|
-
export { S as STANDARD_RPC_JSON_SERIALIZER_BUILT_IN_TYPES, c as StandardRPCCustomJsonSerializer, b as StandardRPCJsonSerialized, a as StandardRPCJsonSerializedMetaItem, e as StandardRPCJsonSerializer, d as StandardRPCJsonSerializerOptions, g as StandardRPCLink, i as StandardRPCLinkCodec, h as StandardRPCLinkCodecOptions, f as StandardRPCLinkOptions, j as StandardRPCSerializer } from '../../shared/client.
|
2
|
+
export { S as STANDARD_RPC_JSON_SERIALIZER_BUILT_IN_TYPES, c as StandardRPCCustomJsonSerializer, b as StandardRPCJsonSerialized, a as StandardRPCJsonSerializedMetaItem, e as StandardRPCJsonSerializer, d as StandardRPCJsonSerializerOptions, g as StandardRPCLink, i as StandardRPCLinkCodec, h as StandardRPCLinkCodecOptions, f as StandardRPCLinkOptions, j as StandardRPCSerializer } from '../../shared/client._Y_enhib.mjs';
|
3
|
+
import { StandardHeaders } from '@orpc/standard-server';
|
3
4
|
import { H as HTTPPath } from '../../shared/client.BOYsZIRq.mjs';
|
4
5
|
import '@orpc/shared';
|
5
|
-
import '@orpc/standard-server';
|
6
6
|
|
7
7
|
declare function toHttpPath(path: readonly string[]): HTTPPath;
|
8
|
+
declare function toStandardHeaders(headers: Headers | StandardHeaders): StandardHeaders;
|
8
9
|
declare function getMalformedResponseErrorCode(status: number): string;
|
9
10
|
|
10
|
-
export { getMalformedResponseErrorCode, toHttpPath };
|
11
|
+
export { getMalformedResponseErrorCode, toHttpPath, toStandardHeaders };
|
@@ -1,10 +1,11 @@
|
|
1
1
|
export { C as CompositeStandardLinkPlugin, d as StandardLink, f as StandardLinkClient, S as StandardLinkClientInterceptorOptions, e as StandardLinkCodec, c as StandardLinkInterceptorOptions, b as StandardLinkOptions, a as StandardLinkPlugin } from '../../shared/client.BG98rYdO.js';
|
2
|
-
export { S as STANDARD_RPC_JSON_SERIALIZER_BUILT_IN_TYPES, c as StandardRPCCustomJsonSerializer, b as StandardRPCJsonSerialized, a as StandardRPCJsonSerializedMetaItem, e as StandardRPCJsonSerializer, d as StandardRPCJsonSerializerOptions, g as StandardRPCLink, i as StandardRPCLinkCodec, h as StandardRPCLinkCodecOptions, f as StandardRPCLinkOptions, j as StandardRPCSerializer } from '../../shared/client.
|
2
|
+
export { S as STANDARD_RPC_JSON_SERIALIZER_BUILT_IN_TYPES, c as StandardRPCCustomJsonSerializer, b as StandardRPCJsonSerialized, a as StandardRPCJsonSerializedMetaItem, e as StandardRPCJsonSerializer, d as StandardRPCJsonSerializerOptions, g as StandardRPCLink, i as StandardRPCLinkCodec, h as StandardRPCLinkCodecOptions, f as StandardRPCLinkOptions, j as StandardRPCSerializer } from '../../shared/client.CVVVqf1Y.js';
|
3
|
+
import { StandardHeaders } from '@orpc/standard-server';
|
3
4
|
import { H as HTTPPath } from '../../shared/client.BOYsZIRq.js';
|
4
5
|
import '@orpc/shared';
|
5
|
-
import '@orpc/standard-server';
|
6
6
|
|
7
7
|
declare function toHttpPath(path: readonly string[]): HTTPPath;
|
8
|
+
declare function toStandardHeaders(headers: Headers | StandardHeaders): StandardHeaders;
|
8
9
|
declare function getMalformedResponseErrorCode(status: number): string;
|
9
10
|
|
10
|
-
export { getMalformedResponseErrorCode, toHttpPath };
|
11
|
+
export { getMalformedResponseErrorCode, toHttpPath, toStandardHeaders };
|
@@ -1,4 +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 } from '../../shared/client.
|
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.
|
4
|
+
import '../../shared/client.DO4HriUw.mjs';
|
5
|
+
import '@orpc/standard-server-fetch';
|
@@ -1,7 +1,7 @@
|
|
1
1
|
import { StandardRequest, StandardLazyResponse } from '@orpc/standard-server';
|
2
2
|
import { b as ClientContext, c as ClientOptions } from '../../shared/client.BOYsZIRq.mjs';
|
3
3
|
import { f as StandardLinkClient } from '../../shared/client.Bwgm6dgk.mjs';
|
4
|
-
import { f as StandardRPCLinkOptions, g as StandardRPCLink } from '../../shared/client.
|
4
|
+
import { f as StandardRPCLinkOptions, g as StandardRPCLink } from '../../shared/client._Y_enhib.mjs';
|
5
5
|
import '@orpc/shared';
|
6
6
|
|
7
7
|
interface LinkWebsocketClientOptions {
|
@@ -1,7 +1,7 @@
|
|
1
1
|
import { StandardRequest, StandardLazyResponse } from '@orpc/standard-server';
|
2
2
|
import { b as ClientContext, c as ClientOptions } from '../../shared/client.BOYsZIRq.js';
|
3
3
|
import { f as StandardLinkClient } from '../../shared/client.BG98rYdO.js';
|
4
|
-
import { f as StandardRPCLinkOptions, g as StandardRPCLink } from '../../shared/client.
|
4
|
+
import { f as StandardRPCLinkOptions, g as StandardRPCLink } from '../../shared/client.CVVVqf1Y.js';
|
5
5
|
import '@orpc/shared';
|
6
6
|
|
7
7
|
interface LinkWebsocketClientOptions {
|
@@ -1,8 +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.
|
3
|
+
import { c as StandardRPCLink } from '../../shared/client.CH3WAlBG.mjs';
|
4
4
|
import '@orpc/standard-server';
|
5
|
-
import '../../shared/client.
|
5
|
+
import '../../shared/client.DO4HriUw.mjs';
|
6
|
+
import '@orpc/standard-server-fetch';
|
6
7
|
|
7
8
|
const WEBSOCKET_CONNECTING = 0;
|
8
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.
|
4
|
-
export { C as COMMON_ORPC_ERROR_DEFS,
|
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) {
|
package/dist/plugins/index.mjs
CHANGED
@@ -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
|
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
|
-
|
334
|
-
|
335
|
-
|
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
|
-
|
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
|
-
}
|
360
|
-
|
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,7 @@
|
|
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,
|
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
|
+
import { toStandardHeaders as toStandardHeaders$1 } from '@orpc/standard-server-fetch';
|
4
5
|
|
5
6
|
class CompositeStandardLinkPlugin {
|
6
7
|
plugins;
|
@@ -224,6 +225,12 @@ class StandardRPCJsonSerializer {
|
|
224
225
|
function toHttpPath(path) {
|
225
226
|
return `/${path.map(encodeURIComponent).join("/")}`;
|
226
227
|
}
|
228
|
+
function toStandardHeaders(headers) {
|
229
|
+
if (typeof headers.forEach === "function") {
|
230
|
+
return toStandardHeaders$1(headers);
|
231
|
+
}
|
232
|
+
return headers;
|
233
|
+
}
|
227
234
|
function getMalformedResponseErrorCode(status) {
|
228
235
|
return Object.entries(COMMON_ORPC_ERROR_DEFS).find(([, def]) => def.status === status)?.[0] ?? "MALFORMED_ORPC_ERROR_RESPONSE";
|
229
236
|
}
|
@@ -243,14 +250,14 @@ class StandardRPCLinkCodec {
|
|
243
250
|
expectedMethod;
|
244
251
|
headers;
|
245
252
|
async encode(path, input, options) {
|
253
|
+
let headers = toStandardHeaders(await value(this.headers, options, path, input));
|
254
|
+
if (options.lastEventId !== void 0) {
|
255
|
+
headers = mergeStandardHeaders(headers, { "last-event-id": options.lastEventId });
|
256
|
+
}
|
246
257
|
const expectedMethod = await value(this.expectedMethod, options, path, input);
|
247
|
-
let headers = await value(this.headers, options, path, input);
|
248
258
|
const baseUrl = await value(this.baseUrl, options, path, input);
|
249
259
|
const url = new URL(baseUrl);
|
250
260
|
url.pathname = `${url.pathname.replace(/\/$/, "")}${toHttpPath(path)}`;
|
251
|
-
if (options.lastEventId !== void 0) {
|
252
|
-
headers = mergeStandardHeaders(headers, { "last-event-id": options.lastEventId });
|
253
|
-
}
|
254
261
|
const serialized = this.serializer.serialize(input);
|
255
262
|
if (expectedMethod === "GET" && !(serialized instanceof FormData) && !isAsyncIteratorObject(serialized)) {
|
256
263
|
const maxUrlLength = await value(this.maxUrlLength, options, path, input);
|
@@ -387,4 +394,4 @@ class StandardRPCLink extends StandardLink {
|
|
387
394
|
}
|
388
395
|
}
|
389
396
|
|
390
|
-
export { CompositeStandardLinkPlugin as C, StandardLink as S, STANDARD_RPC_JSON_SERIALIZER_BUILT_IN_TYPES as a, StandardRPCJsonSerializer as b, StandardRPCLink as c, StandardRPCLinkCodec as d, StandardRPCSerializer as e, getMalformedResponseErrorCode as g, toHttpPath as t };
|
397
|
+
export { CompositeStandardLinkPlugin as C, StandardLink as S, STANDARD_RPC_JSON_SERIALIZER_BUILT_IN_TYPES as a, StandardRPCJsonSerializer as b, StandardRPCLink as c, StandardRPCLinkCodec as d, StandardRPCSerializer as e, toStandardHeaders as f, getMalformedResponseErrorCode as g, toHttpPath as t };
|
@@ -67,7 +67,7 @@ interface StandardRPCLinkCodecOptions<T extends ClientContext> {
|
|
67
67
|
/**
|
68
68
|
* Inject headers to the request.
|
69
69
|
*/
|
70
|
-
headers?: Value<Promisable<StandardHeaders>, [options: ClientOptions<T>, path: readonly string[], input: unknown]>;
|
70
|
+
headers?: Value<Promisable<StandardHeaders | Headers>, [options: ClientOptions<T>, path: readonly string[], input: unknown]>;
|
71
71
|
}
|
72
72
|
declare class StandardRPCLinkCodec<T extends ClientContext> implements StandardLinkCodec<T> {
|
73
73
|
private readonly serializer;
|
@@ -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,
|
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 };
|
@@ -67,7 +67,7 @@ interface StandardRPCLinkCodecOptions<T extends ClientContext> {
|
|
67
67
|
/**
|
68
68
|
* Inject headers to the request.
|
69
69
|
*/
|
70
|
-
headers?: Value<Promisable<StandardHeaders>, [options: ClientOptions<T>, path: readonly string[], input: unknown]>;
|
70
|
+
headers?: Value<Promisable<StandardHeaders | Headers>, [options: ClientOptions<T>, path: readonly string[], input: unknown]>;
|
71
71
|
}
|
72
72
|
declare class StandardRPCLinkCodec<T extends ClientContext> implements StandardLinkCodec<T> {
|
73
73
|
private readonly serializer;
|
package/package.json
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
{
|
2
2
|
"name": "@orpc/client",
|
3
3
|
"type": "module",
|
4
|
-
"version": "1.8.
|
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/
|
53
|
-
"@orpc/standard-server": "1.8.
|
54
|
-
"@orpc/
|
55
|
-
"@orpc/standard-server-peer": "1.8.
|
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.
|
58
|
+
"zod": "^4.1.5"
|
59
59
|
},
|
60
60
|
"scripts": {
|
61
61
|
"build": "unbuild",
|