@orpc/client 0.0.0-next.d16a1b6 → 0.0.0-next.d177d36
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 +27 -17
- package/dist/adapters/fetch/index.d.mts +20 -16
- package/dist/adapters/fetch/index.d.ts +20 -16
- package/dist/adapters/fetch/index.mjs +11 -14
- package/dist/adapters/message-port/index.d.mts +59 -0
- package/dist/adapters/message-port/index.d.ts +59 -0
- package/dist/adapters/message-port/index.mjs +71 -0
- package/dist/adapters/standard/index.d.mts +8 -147
- package/dist/adapters/standard/index.d.ts +8 -147
- package/dist/adapters/standard/index.mjs +2 -2
- package/dist/adapters/websocket/index.d.mts +29 -0
- package/dist/adapters/websocket/index.d.ts +29 -0
- package/dist/adapters/websocket/index.mjs +31 -0
- package/dist/index.d.mts +36 -20
- package/dist/index.d.ts +36 -20
- package/dist/index.mjs +35 -33
- package/dist/plugins/index.d.mts +202 -0
- package/dist/plugins/index.d.ts +202 -0
- package/dist/plugins/index.mjs +389 -0
- package/dist/shared/client.4TS_0JaO.d.mts +29 -0
- package/dist/shared/client.4TS_0JaO.d.ts +29 -0
- package/dist/shared/client.7UM0t5o-.d.ts +91 -0
- package/dist/shared/client.BMoG_EdN.d.mts +46 -0
- package/dist/shared/client.BdD8cpjs.d.mts +91 -0
- package/dist/shared/client.C0KbSWlC.d.ts +46 -0
- package/dist/shared/client.CRWEpqLB.mjs +175 -0
- package/dist/shared/{client.MkoaGU3v.mjs → client.DpICn1BD.mjs} +174 -140
- package/package.json +21 -5
- package/dist/shared/client.D_CzLDyB.d.mts +0 -42
- package/dist/shared/client.D_CzLDyB.d.ts +0 -42
- package/dist/shared/client.DcaJQZfy.mjs +0 -265
@@ -1,149 +1,10 @@
|
|
1
|
-
|
2
|
-
|
3
|
-
import {
|
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.C0KbSWlC.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.7UM0t5o-.js';
|
3
|
+
import { H as HTTPPath } from '../../shared/client.4TS_0JaO.js';
|
4
|
+
import '@orpc/shared';
|
5
|
+
import '@orpc/standard-server';
|
4
6
|
|
5
|
-
|
6
|
-
|
7
|
-
decode(response: StandardLazyResponse, options: ClientOptionsOut<T>, path: readonly string[], input: unknown): Promise<unknown>;
|
8
|
-
}
|
9
|
-
interface StandardLinkClient<T extends ClientContext> {
|
10
|
-
call(request: StandardRequest, options: ClientOptionsOut<T>, path: readonly string[], input: unknown): Promise<StandardLazyResponse>;
|
11
|
-
}
|
7
|
+
declare function toHttpPath(path: readonly string[]): HTTPPath;
|
8
|
+
declare function getMalformedResponseErrorCode(status: number): string;
|
12
9
|
|
13
|
-
|
14
|
-
}
|
15
|
-
interface StandardLinkOptions<T extends ClientContext> {
|
16
|
-
/**
|
17
|
-
* Maximum number of retry attempts for event iterator errors before throwing.
|
18
|
-
*
|
19
|
-
* @default 5
|
20
|
-
*/
|
21
|
-
eventIteratorMaxRetries?: Value<number, [
|
22
|
-
reconnectOptions: EventIteratorReconnectOptions,
|
23
|
-
options: ClientOptionsOut<T>,
|
24
|
-
path: readonly string[],
|
25
|
-
input: unknown
|
26
|
-
]>;
|
27
|
-
/**
|
28
|
-
* Delay (in ms) before retrying an event iterator call.
|
29
|
-
*
|
30
|
-
* @default (o) => o.lastRetry ?? (1000 * 2 ** o.retryTimes)
|
31
|
-
*/
|
32
|
-
eventIteratorRetryDelay?: Value<number, [
|
33
|
-
reconnectOptions: EventIteratorReconnectOptions,
|
34
|
-
options: ClientOptionsOut<T>,
|
35
|
-
path: readonly string[],
|
36
|
-
input: unknown
|
37
|
-
]>;
|
38
|
-
/**
|
39
|
-
* Function to determine if an error is retryable.
|
40
|
-
*
|
41
|
-
* @default true
|
42
|
-
*/
|
43
|
-
eventIteratorShouldRetry?: Value<boolean, [
|
44
|
-
reconnectOptions: EventIteratorReconnectOptions,
|
45
|
-
options: ClientOptionsOut<T>,
|
46
|
-
path: readonly string[],
|
47
|
-
input: unknown
|
48
|
-
]>;
|
49
|
-
interceptors?: Interceptor<{
|
50
|
-
path: readonly string[];
|
51
|
-
input: unknown;
|
52
|
-
options: ClientOptionsOut<T>;
|
53
|
-
}, unknown, unknown>[];
|
54
|
-
clientInterceptors?: Interceptor<{
|
55
|
-
request: StandardRequest;
|
56
|
-
}, StandardLazyResponse, unknown>[];
|
57
|
-
}
|
58
|
-
declare class StandardLink<T extends ClientContext> implements ClientLink<T> {
|
59
|
-
#private;
|
60
|
-
readonly codec: StandardLinkCodec<T>;
|
61
|
-
readonly sender: StandardLinkClient<T>;
|
62
|
-
private readonly eventIteratorMaxRetries;
|
63
|
-
private readonly eventIteratorRetryDelay;
|
64
|
-
private readonly eventIteratorShouldRetry;
|
65
|
-
private readonly interceptors;
|
66
|
-
private readonly clientInterceptors;
|
67
|
-
constructor(codec: StandardLinkCodec<T>, sender: StandardLinkClient<T>, options: StandardLinkOptions<T>);
|
68
|
-
call(path: readonly string[], input: unknown, options: ClientOptionsOut<T>): Promise<unknown>;
|
69
|
-
}
|
70
|
-
|
71
|
-
type RPCJsonSerializedMeta = [
|
72
|
-
0 | 1 | 2 | 3 | 4 | 5 | 6 | 7,
|
73
|
-
Segment[]
|
74
|
-
][];
|
75
|
-
type RPCJsonSerialized = [json: unknown, meta: RPCJsonSerializedMeta, maps: Segment[][], blobs: Blob[]];
|
76
|
-
declare class RPCJsonSerializer {
|
77
|
-
serialize(data: unknown, segments?: Segment[], meta?: RPCJsonSerializedMeta, maps?: Segment[][], blobs?: Blob[]): RPCJsonSerialized;
|
78
|
-
deserialize(json: unknown, meta: RPCJsonSerializedMeta): unknown;
|
79
|
-
deserialize(json: unknown, meta: RPCJsonSerializedMeta, maps: Segment[][], getBlob: (index: number) => Blob): unknown;
|
80
|
-
}
|
81
|
-
|
82
|
-
declare class RPCSerializer {
|
83
|
-
#private;
|
84
|
-
private readonly jsonSerializer;
|
85
|
-
constructor(jsonSerializer?: RPCJsonSerializer);
|
86
|
-
serialize(data: unknown): unknown;
|
87
|
-
deserialize(data: unknown): unknown;
|
88
|
-
}
|
89
|
-
|
90
|
-
type HTTPMethod = 'GET' | 'POST' | 'PUT' | 'DELETE' | 'PATCH';
|
91
|
-
interface StandardRPCLinkCodecOptions<T extends ClientContext> {
|
92
|
-
/**
|
93
|
-
* Base url for all requests.
|
94
|
-
*/
|
95
|
-
url: Value<string | URL, [
|
96
|
-
options: ClientOptionsOut<T>,
|
97
|
-
path: readonly string[],
|
98
|
-
input: unknown
|
99
|
-
]>;
|
100
|
-
/**
|
101
|
-
* The maximum length of the URL.
|
102
|
-
*
|
103
|
-
* @default 2083
|
104
|
-
*/
|
105
|
-
maxUrlLength?: Value<number, [
|
106
|
-
options: ClientOptionsOut<T>,
|
107
|
-
path: readonly string[],
|
108
|
-
input: unknown
|
109
|
-
]>;
|
110
|
-
/**
|
111
|
-
* The method used to make the request.
|
112
|
-
*
|
113
|
-
* @default 'POST'
|
114
|
-
*/
|
115
|
-
method?: Value<HTTPMethod, [
|
116
|
-
options: ClientOptionsOut<T>,
|
117
|
-
path: readonly string[],
|
118
|
-
input: unknown
|
119
|
-
]>;
|
120
|
-
/**
|
121
|
-
* The method to use when the payload cannot safely pass to the server with method return from method function.
|
122
|
-
* GET is not allowed, it's very dangerous.
|
123
|
-
*
|
124
|
-
* @default 'POST'
|
125
|
-
*/
|
126
|
-
fallbackMethod?: Exclude<HTTPMethod, 'GET'>;
|
127
|
-
/**
|
128
|
-
* Inject headers to the request.
|
129
|
-
*/
|
130
|
-
headers?: Value<StandardHeaders, [
|
131
|
-
options: ClientOptionsOut<T>,
|
132
|
-
path: readonly string[],
|
133
|
-
input: unknown
|
134
|
-
]>;
|
135
|
-
rpcSerializer?: RPCSerializer;
|
136
|
-
}
|
137
|
-
declare class StandardRPCLinkCodec<T extends ClientContext> implements StandardLinkCodec<T> {
|
138
|
-
private readonly baseUrl;
|
139
|
-
private readonly maxUrlLength;
|
140
|
-
private readonly fallbackMethod;
|
141
|
-
private readonly expectedMethod;
|
142
|
-
private readonly headers;
|
143
|
-
private readonly rpcSerializer;
|
144
|
-
constructor(options: StandardRPCLinkCodecOptions<T>);
|
145
|
-
encode(path: readonly string[], input: unknown, options: ClientOptionsOut<any>): Promise<StandardRequest>;
|
146
|
-
decode(response: StandardLazyResponse): Promise<unknown>;
|
147
|
-
}
|
148
|
-
|
149
|
-
export { InvalidEventIteratorRetryResponse, type RPCJsonSerialized, type RPCJsonSerializedMeta, RPCJsonSerializer, RPCSerializer, StandardLink, type StandardLinkClient, type StandardLinkCodec, type StandardLinkOptions, StandardRPCLinkCodec, type StandardRPCLinkCodecOptions };
|
10
|
+
export { getMalformedResponseErrorCode, toHttpPath };
|
@@ -1,4 +1,4 @@
|
|
1
|
-
export {
|
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.DpICn1BD.mjs';
|
2
2
|
import '@orpc/shared';
|
3
|
-
import '../../shared/client.DcaJQZfy.mjs';
|
4
3
|
import '@orpc/standard-server';
|
4
|
+
import '../../shared/client.CRWEpqLB.mjs';
|
@@ -0,0 +1,29 @@
|
|
1
|
+
import { StandardRequest, StandardLazyResponse } from '@orpc/standard-server';
|
2
|
+
import { a as ClientContext, b as ClientOptions } from '../../shared/client.4TS_0JaO.mjs';
|
3
|
+
import { f as StandardLinkClient } from '../../shared/client.BMoG_EdN.mjs';
|
4
|
+
import { f as StandardRPCLinkOptions, g as StandardRPCLink } from '../../shared/client.BdD8cpjs.mjs';
|
5
|
+
import '@orpc/shared';
|
6
|
+
|
7
|
+
interface experimental_LinkWebsocketClientOptions {
|
8
|
+
websocket: Pick<WebSocket, 'addEventListener' | 'send'>;
|
9
|
+
}
|
10
|
+
declare class experimental_LinkWebsocketClient<T extends ClientContext> implements StandardLinkClient<T> {
|
11
|
+
private readonly peer;
|
12
|
+
constructor(options: experimental_LinkWebsocketClientOptions);
|
13
|
+
call(request: StandardRequest, _options: ClientOptions<T>, _path: readonly string[], _input: unknown): Promise<StandardLazyResponse>;
|
14
|
+
}
|
15
|
+
|
16
|
+
interface experimental_RPCLinkOptions<T extends ClientContext> extends Omit<StandardRPCLinkOptions<T>, 'url' | 'headers' | 'method' | 'fallbackMethod' | 'maxUrlLength'>, experimental_LinkWebsocketClientOptions {
|
17
|
+
}
|
18
|
+
/**
|
19
|
+
* The RPC Link communicates with the server using the RPC protocol over WebSocket.
|
20
|
+
*
|
21
|
+
* @see {@link https://orpc.unnoq.com/docs/client/rpc-link RPC Link Docs}
|
22
|
+
* @see {@link https://orpc.unnoq.com/docs/adapters/websocket WebSocket Adapter Docs}
|
23
|
+
*/
|
24
|
+
declare class experimental_RPCLink<T extends ClientContext> extends StandardRPCLink<T> {
|
25
|
+
constructor(options: experimental_RPCLinkOptions<T>);
|
26
|
+
}
|
27
|
+
|
28
|
+
export { experimental_LinkWebsocketClient, experimental_RPCLink };
|
29
|
+
export type { experimental_LinkWebsocketClientOptions, experimental_RPCLinkOptions };
|
@@ -0,0 +1,29 @@
|
|
1
|
+
import { StandardRequest, StandardLazyResponse } from '@orpc/standard-server';
|
2
|
+
import { a as ClientContext, b as ClientOptions } from '../../shared/client.4TS_0JaO.js';
|
3
|
+
import { f as StandardLinkClient } from '../../shared/client.C0KbSWlC.js';
|
4
|
+
import { f as StandardRPCLinkOptions, g as StandardRPCLink } from '../../shared/client.7UM0t5o-.js';
|
5
|
+
import '@orpc/shared';
|
6
|
+
|
7
|
+
interface experimental_LinkWebsocketClientOptions {
|
8
|
+
websocket: Pick<WebSocket, 'addEventListener' | 'send'>;
|
9
|
+
}
|
10
|
+
declare class experimental_LinkWebsocketClient<T extends ClientContext> implements StandardLinkClient<T> {
|
11
|
+
private readonly peer;
|
12
|
+
constructor(options: experimental_LinkWebsocketClientOptions);
|
13
|
+
call(request: StandardRequest, _options: ClientOptions<T>, _path: readonly string[], _input: unknown): Promise<StandardLazyResponse>;
|
14
|
+
}
|
15
|
+
|
16
|
+
interface experimental_RPCLinkOptions<T extends ClientContext> extends Omit<StandardRPCLinkOptions<T>, 'url' | 'headers' | 'method' | 'fallbackMethod' | 'maxUrlLength'>, experimental_LinkWebsocketClientOptions {
|
17
|
+
}
|
18
|
+
/**
|
19
|
+
* The RPC Link communicates with the server using the RPC protocol over WebSocket.
|
20
|
+
*
|
21
|
+
* @see {@link https://orpc.unnoq.com/docs/client/rpc-link RPC Link Docs}
|
22
|
+
* @see {@link https://orpc.unnoq.com/docs/adapters/websocket WebSocket Adapter Docs}
|
23
|
+
*/
|
24
|
+
declare class experimental_RPCLink<T extends ClientContext> extends StandardRPCLink<T> {
|
25
|
+
constructor(options: experimental_RPCLinkOptions<T>);
|
26
|
+
}
|
27
|
+
|
28
|
+
export { experimental_LinkWebsocketClient, experimental_RPCLink };
|
29
|
+
export type { experimental_LinkWebsocketClientOptions, experimental_RPCLinkOptions };
|
@@ -0,0 +1,31 @@
|
|
1
|
+
import { ClientPeer } from '@orpc/standard-server-peer';
|
2
|
+
import '@orpc/shared';
|
3
|
+
import { c as StandardRPCLink } from '../../shared/client.DpICn1BD.mjs';
|
4
|
+
import '@orpc/standard-server';
|
5
|
+
import '../../shared/client.CRWEpqLB.mjs';
|
6
|
+
|
7
|
+
class experimental_LinkWebsocketClient {
|
8
|
+
peer;
|
9
|
+
constructor(options) {
|
10
|
+
this.peer = new ClientPeer(options.websocket.send.bind(options.websocket));
|
11
|
+
options.websocket.addEventListener("message", (event) => {
|
12
|
+
this.peer.message(event.data);
|
13
|
+
});
|
14
|
+
options.websocket.addEventListener("close", () => {
|
15
|
+
this.peer.close();
|
16
|
+
});
|
17
|
+
}
|
18
|
+
async call(request, _options, _path, _input) {
|
19
|
+
const response = await this.peer.request(request);
|
20
|
+
return { ...response, body: () => Promise.resolve(response.body) };
|
21
|
+
}
|
22
|
+
}
|
23
|
+
|
24
|
+
class experimental_RPCLink extends StandardRPCLink {
|
25
|
+
constructor(options) {
|
26
|
+
const linkClient = new experimental_LinkWebsocketClient(options);
|
27
|
+
super(linkClient, { ...options, url: "orpc:/" });
|
28
|
+
}
|
29
|
+
}
|
30
|
+
|
31
|
+
export { experimental_LinkWebsocketClient, experimental_RPCLink };
|
package/dist/index.d.mts
CHANGED
@@ -1,6 +1,7 @@
|
|
1
|
-
import { N as NestedClient,
|
2
|
-
export {
|
3
|
-
import { Promisable, MaybeOptionalOptions } from '@orpc/shared';
|
1
|
+
import { N as NestedClient, C as ClientLink, I as InferClientContext, a as ClientContext, b as ClientOptions, c as ClientPromiseResult, F as FriendlyClientOptions } from './shared/client.4TS_0JaO.mjs';
|
2
|
+
export { f as Client, e as ClientRest, d as HTTPMethod, H as HTTPPath } from './shared/client.4TS_0JaO.mjs';
|
3
|
+
import { Promisable, MaybeOptionalOptions, ThrowableError } from '@orpc/shared';
|
4
|
+
export { Registry, ThrowableError, onError, onFinish, onStart, onSuccess } from '@orpc/shared';
|
4
5
|
export { ErrorEvent } from '@orpc/standard-server';
|
5
6
|
|
6
7
|
interface createORPCClientOptions {
|
@@ -9,16 +10,23 @@ interface createORPCClientOptions {
|
|
9
10
|
*/
|
10
11
|
path?: string[];
|
11
12
|
}
|
13
|
+
/**
|
14
|
+
* Create a oRPC client-side client from a link.
|
15
|
+
*
|
16
|
+
* @see {@link https://orpc.unnoq.com/docs/client/client-side Client-side Client Docs}
|
17
|
+
*/
|
12
18
|
declare function createORPCClient<T extends NestedClient<any>>(link: ClientLink<InferClientContext<T>>, options?: createORPCClientOptions): T;
|
13
19
|
|
14
20
|
/**
|
15
21
|
* DynamicLink provides a way to dynamically resolve and delegate calls to other ClientLinks
|
16
22
|
* based on the request path, input, and context.
|
23
|
+
*
|
24
|
+
* @see {@link https://orpc.unnoq.com/docs/client/dynamic-link Dynamic Link Docs}
|
17
25
|
*/
|
18
26
|
declare class DynamicLink<TClientContext extends ClientContext> implements ClientLink<TClientContext> {
|
19
27
|
private readonly linkResolver;
|
20
|
-
constructor(linkResolver: (options:
|
21
|
-
call(path: readonly string[], input: unknown, options:
|
28
|
+
constructor(linkResolver: (options: ClientOptions<TClientContext>, path: readonly string[], input: unknown) => Promisable<ClientLink<TClientContext>>);
|
29
|
+
call(path: readonly string[], input: unknown, options: ClientOptions<TClientContext>): Promise<unknown>;
|
22
30
|
}
|
23
31
|
|
24
32
|
declare const COMMON_ORPC_ERROR_DEFS: {
|
@@ -119,35 +127,43 @@ declare class ORPCError<TCode extends ORPCErrorCode, TData> extends Error {
|
|
119
127
|
readonly data: TData;
|
120
128
|
constructor(code: TCode, ...[options]: MaybeOptionalOptions<ORPCErrorOptions<TData>>);
|
121
129
|
toJSON(): ORPCErrorJSON<TCode, TData>;
|
122
|
-
static fromJSON<TCode extends ORPCErrorCode, TData>(json: ORPCErrorJSON<TCode, TData>, options?: ErrorOptions): ORPCError<TCode, TData>;
|
123
|
-
static isValidJSON(json: unknown): json is ORPCErrorJSON<ORPCErrorCode, unknown>;
|
124
130
|
}
|
125
131
|
type ORPCErrorJSON<TCode extends string, TData> = Pick<ORPCError<TCode, TData>, 'defined' | 'code' | 'status' | 'message' | 'data'>;
|
126
132
|
declare function isDefinedError<T>(error: T): error is Extract<T, ORPCError<any, any>>;
|
127
133
|
declare function toORPCError(error: unknown): ORPCError<any, any>;
|
134
|
+
declare function isORPCErrorStatus(status: number): boolean;
|
135
|
+
declare function isORPCErrorJson(json: unknown): json is ORPCErrorJSON<ORPCErrorCode, unknown>;
|
136
|
+
declare function createORPCErrorFromJson<TCode extends ORPCErrorCode, TData>(json: ORPCErrorJSON<TCode, TData>, options?: ErrorOptions): ORPCError<TCode, TData>;
|
128
137
|
|
129
|
-
|
130
|
-
|
131
|
-
|
132
|
-
|
133
|
-
}
|
134
|
-
declare function registerEventIteratorState(iterator: AsyncIteratorObject<unknown, unknown, void>, state: EventIteratorState): void;
|
135
|
-
declare function updateEventIteratorStatus(state: EventIteratorState, status: ConnectionStatus): void;
|
136
|
-
declare function onEventIteratorStatusChange(iterator: AsyncIteratorObject<unknown, unknown, void>, callback: (status: ConnectionStatus) => void, notifyImmediately?: boolean): () => void;
|
138
|
+
declare function mapEventIterator<TYield, TReturn, TNext, TMap = TYield | TReturn>(iterator: AsyncIterator<TYield, TReturn, TNext>, maps: {
|
139
|
+
value: (value: NoInfer<TYield | TReturn>, done: boolean | undefined) => Promise<TMap>;
|
140
|
+
error: (error: unknown) => Promise<unknown>;
|
141
|
+
}): AsyncGenerator<TMap, TMap, TNext>;
|
137
142
|
|
138
|
-
type SafeResult<TOutput, TError
|
143
|
+
type SafeResult<TOutput, TError> = [error: null, data: TOutput, isDefined: false, isSuccess: true] & {
|
139
144
|
error: null;
|
140
145
|
data: TOutput;
|
141
146
|
isDefined: false;
|
142
|
-
|
147
|
+
isSuccess: true;
|
148
|
+
} | [error: Exclude<TError, ORPCError<any, any>>, data: undefined, isDefined: false, isSuccess: false] & {
|
143
149
|
error: Exclude<TError, ORPCError<any, any>>;
|
144
150
|
data: undefined;
|
145
151
|
isDefined: false;
|
146
|
-
|
152
|
+
isSuccess: false;
|
153
|
+
} | [error: Extract<TError, ORPCError<any, any>>, data: undefined, isDefined: true, isSuccess: false] & {
|
147
154
|
error: Extract<TError, ORPCError<any, any>>;
|
148
155
|
data: undefined;
|
149
156
|
isDefined: true;
|
157
|
+
isSuccess: false;
|
150
158
|
};
|
151
|
-
|
159
|
+
/**
|
160
|
+
* Works like try/catch, but can infer error types.
|
161
|
+
*
|
162
|
+
* @info support both tuple `[error, data, isDefined, isSuccess]` and object `{ error, data, isDefined, isSuccess }` styles.
|
163
|
+
* @see {@link https://orpc.unnoq.com/docs/client/error-handling Client Error Handling Docs}
|
164
|
+
*/
|
165
|
+
declare function safe<TOutput, TError = ThrowableError>(promise: ClientPromiseResult<TOutput, TError>): Promise<SafeResult<TOutput, TError>>;
|
166
|
+
declare function resolveFriendlyClientOptions<T extends ClientContext>(options: FriendlyClientOptions<T>): ClientOptions<T>;
|
152
167
|
|
153
|
-
export { COMMON_ORPC_ERROR_DEFS, ClientContext, ClientLink,
|
168
|
+
export { COMMON_ORPC_ERROR_DEFS, ClientContext, ClientLink, ClientOptions, ClientPromiseResult, DynamicLink, FriendlyClientOptions, InferClientContext, NestedClient, ORPCError, createORPCClient, createORPCErrorFromJson, fallbackORPCErrorMessage, fallbackORPCErrorStatus, isDefinedError, isORPCErrorJson, isORPCErrorStatus, mapEventIterator, resolveFriendlyClientOptions, safe, toORPCError };
|
169
|
+
export type { CommonORPCErrorCode, ORPCErrorCode, ORPCErrorJSON, ORPCErrorOptions, SafeResult, createORPCClientOptions };
|
package/dist/index.d.ts
CHANGED
@@ -1,6 +1,7 @@
|
|
1
|
-
import { N as NestedClient,
|
2
|
-
export {
|
3
|
-
import { Promisable, MaybeOptionalOptions } from '@orpc/shared';
|
1
|
+
import { N as NestedClient, C as ClientLink, I as InferClientContext, a as ClientContext, b as ClientOptions, c as ClientPromiseResult, F as FriendlyClientOptions } from './shared/client.4TS_0JaO.js';
|
2
|
+
export { f as Client, e as ClientRest, d as HTTPMethod, H as HTTPPath } from './shared/client.4TS_0JaO.js';
|
3
|
+
import { Promisable, MaybeOptionalOptions, ThrowableError } from '@orpc/shared';
|
4
|
+
export { Registry, ThrowableError, onError, onFinish, onStart, onSuccess } from '@orpc/shared';
|
4
5
|
export { ErrorEvent } from '@orpc/standard-server';
|
5
6
|
|
6
7
|
interface createORPCClientOptions {
|
@@ -9,16 +10,23 @@ interface createORPCClientOptions {
|
|
9
10
|
*/
|
10
11
|
path?: string[];
|
11
12
|
}
|
13
|
+
/**
|
14
|
+
* Create a oRPC client-side client from a link.
|
15
|
+
*
|
16
|
+
* @see {@link https://orpc.unnoq.com/docs/client/client-side Client-side Client Docs}
|
17
|
+
*/
|
12
18
|
declare function createORPCClient<T extends NestedClient<any>>(link: ClientLink<InferClientContext<T>>, options?: createORPCClientOptions): T;
|
13
19
|
|
14
20
|
/**
|
15
21
|
* DynamicLink provides a way to dynamically resolve and delegate calls to other ClientLinks
|
16
22
|
* based on the request path, input, and context.
|
23
|
+
*
|
24
|
+
* @see {@link https://orpc.unnoq.com/docs/client/dynamic-link Dynamic Link Docs}
|
17
25
|
*/
|
18
26
|
declare class DynamicLink<TClientContext extends ClientContext> implements ClientLink<TClientContext> {
|
19
27
|
private readonly linkResolver;
|
20
|
-
constructor(linkResolver: (options:
|
21
|
-
call(path: readonly string[], input: unknown, options:
|
28
|
+
constructor(linkResolver: (options: ClientOptions<TClientContext>, path: readonly string[], input: unknown) => Promisable<ClientLink<TClientContext>>);
|
29
|
+
call(path: readonly string[], input: unknown, options: ClientOptions<TClientContext>): Promise<unknown>;
|
22
30
|
}
|
23
31
|
|
24
32
|
declare const COMMON_ORPC_ERROR_DEFS: {
|
@@ -119,35 +127,43 @@ declare class ORPCError<TCode extends ORPCErrorCode, TData> extends Error {
|
|
119
127
|
readonly data: TData;
|
120
128
|
constructor(code: TCode, ...[options]: MaybeOptionalOptions<ORPCErrorOptions<TData>>);
|
121
129
|
toJSON(): ORPCErrorJSON<TCode, TData>;
|
122
|
-
static fromJSON<TCode extends ORPCErrorCode, TData>(json: ORPCErrorJSON<TCode, TData>, options?: ErrorOptions): ORPCError<TCode, TData>;
|
123
|
-
static isValidJSON(json: unknown): json is ORPCErrorJSON<ORPCErrorCode, unknown>;
|
124
130
|
}
|
125
131
|
type ORPCErrorJSON<TCode extends string, TData> = Pick<ORPCError<TCode, TData>, 'defined' | 'code' | 'status' | 'message' | 'data'>;
|
126
132
|
declare function isDefinedError<T>(error: T): error is Extract<T, ORPCError<any, any>>;
|
127
133
|
declare function toORPCError(error: unknown): ORPCError<any, any>;
|
134
|
+
declare function isORPCErrorStatus(status: number): boolean;
|
135
|
+
declare function isORPCErrorJson(json: unknown): json is ORPCErrorJSON<ORPCErrorCode, unknown>;
|
136
|
+
declare function createORPCErrorFromJson<TCode extends ORPCErrorCode, TData>(json: ORPCErrorJSON<TCode, TData>, options?: ErrorOptions): ORPCError<TCode, TData>;
|
128
137
|
|
129
|
-
|
130
|
-
|
131
|
-
|
132
|
-
|
133
|
-
}
|
134
|
-
declare function registerEventIteratorState(iterator: AsyncIteratorObject<unknown, unknown, void>, state: EventIteratorState): void;
|
135
|
-
declare function updateEventIteratorStatus(state: EventIteratorState, status: ConnectionStatus): void;
|
136
|
-
declare function onEventIteratorStatusChange(iterator: AsyncIteratorObject<unknown, unknown, void>, callback: (status: ConnectionStatus) => void, notifyImmediately?: boolean): () => void;
|
138
|
+
declare function mapEventIterator<TYield, TReturn, TNext, TMap = TYield | TReturn>(iterator: AsyncIterator<TYield, TReturn, TNext>, maps: {
|
139
|
+
value: (value: NoInfer<TYield | TReturn>, done: boolean | undefined) => Promise<TMap>;
|
140
|
+
error: (error: unknown) => Promise<unknown>;
|
141
|
+
}): AsyncGenerator<TMap, TMap, TNext>;
|
137
142
|
|
138
|
-
type SafeResult<TOutput, TError
|
143
|
+
type SafeResult<TOutput, TError> = [error: null, data: TOutput, isDefined: false, isSuccess: true] & {
|
139
144
|
error: null;
|
140
145
|
data: TOutput;
|
141
146
|
isDefined: false;
|
142
|
-
|
147
|
+
isSuccess: true;
|
148
|
+
} | [error: Exclude<TError, ORPCError<any, any>>, data: undefined, isDefined: false, isSuccess: false] & {
|
143
149
|
error: Exclude<TError, ORPCError<any, any>>;
|
144
150
|
data: undefined;
|
145
151
|
isDefined: false;
|
146
|
-
|
152
|
+
isSuccess: false;
|
153
|
+
} | [error: Extract<TError, ORPCError<any, any>>, data: undefined, isDefined: true, isSuccess: false] & {
|
147
154
|
error: Extract<TError, ORPCError<any, any>>;
|
148
155
|
data: undefined;
|
149
156
|
isDefined: true;
|
157
|
+
isSuccess: false;
|
150
158
|
};
|
151
|
-
|
159
|
+
/**
|
160
|
+
* Works like try/catch, but can infer error types.
|
161
|
+
*
|
162
|
+
* @info support both tuple `[error, data, isDefined, isSuccess]` and object `{ error, data, isDefined, isSuccess }` styles.
|
163
|
+
* @see {@link https://orpc.unnoq.com/docs/client/error-handling Client Error Handling Docs}
|
164
|
+
*/
|
165
|
+
declare function safe<TOutput, TError = ThrowableError>(promise: ClientPromiseResult<TOutput, TError>): Promise<SafeResult<TOutput, TError>>;
|
166
|
+
declare function resolveFriendlyClientOptions<T extends ClientContext>(options: FriendlyClientOptions<T>): ClientOptions<T>;
|
152
167
|
|
153
|
-
export { COMMON_ORPC_ERROR_DEFS, ClientContext, ClientLink,
|
168
|
+
export { COMMON_ORPC_ERROR_DEFS, ClientContext, ClientLink, ClientOptions, ClientPromiseResult, DynamicLink, FriendlyClientOptions, InferClientContext, NestedClient, ORPCError, createORPCClient, createORPCErrorFromJson, fallbackORPCErrorMessage, fallbackORPCErrorStatus, isDefinedError, isORPCErrorJson, isORPCErrorStatus, mapEventIterator, resolveFriendlyClientOptions, safe, toORPCError };
|
169
|
+
export type { CommonORPCErrorCode, ORPCErrorCode, ORPCErrorJSON, ORPCErrorOptions, SafeResult, createORPCClientOptions };
|
package/dist/index.mjs
CHANGED
@@ -1,17 +1,41 @@
|
|
1
|
-
import { i as isDefinedError } from './shared/client.
|
2
|
-
export { C as COMMON_ORPC_ERROR_DEFS, O as ORPCError,
|
1
|
+
import { i as isDefinedError } from './shared/client.CRWEpqLB.mjs';
|
2
|
+
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.CRWEpqLB.mjs';
|
3
|
+
export { onError, onFinish, onStart, onSuccess } from '@orpc/shared';
|
3
4
|
export { ErrorEvent } from '@orpc/standard-server';
|
4
|
-
|
5
|
+
|
6
|
+
async function safe(promise) {
|
7
|
+
try {
|
8
|
+
const output = await promise;
|
9
|
+
return Object.assign(
|
10
|
+
[null, output, false, true],
|
11
|
+
{ error: null, data: output, isDefined: false, isSuccess: true }
|
12
|
+
);
|
13
|
+
} catch (e) {
|
14
|
+
const error = e;
|
15
|
+
if (isDefinedError(error)) {
|
16
|
+
return Object.assign(
|
17
|
+
[error, void 0, true, false],
|
18
|
+
{ error, data: void 0, isDefined: true, isSuccess: false }
|
19
|
+
);
|
20
|
+
}
|
21
|
+
return Object.assign(
|
22
|
+
[error, void 0, false, false],
|
23
|
+
{ error, data: void 0, isDefined: false, isSuccess: false }
|
24
|
+
);
|
25
|
+
}
|
26
|
+
}
|
27
|
+
function resolveFriendlyClientOptions(options) {
|
28
|
+
return {
|
29
|
+
...options,
|
30
|
+
context: options?.context ?? {}
|
31
|
+
// Context only optional if all fields are optional
|
32
|
+
};
|
33
|
+
}
|
5
34
|
|
6
35
|
function createORPCClient(link, options) {
|
7
36
|
const path = options?.path ?? [];
|
8
|
-
const procedureClient = async (...[input, options2]) => {
|
9
|
-
|
10
|
-
...options2,
|
11
|
-
context: options2?.context ?? {}
|
12
|
-
// options.context can be undefined when all field is optional
|
13
|
-
};
|
14
|
-
return await link.call(path, input, optionsOut);
|
37
|
+
const procedureClient = async (...[input, options2 = {}]) => {
|
38
|
+
return await link.call(path, input, resolveFriendlyClientOptions(options2));
|
15
39
|
};
|
16
40
|
const recursive = new Proxy(procedureClient, {
|
17
41
|
get(target, key) {
|
@@ -38,26 +62,4 @@ class DynamicLink {
|
|
38
62
|
}
|
39
63
|
}
|
40
64
|
|
41
|
-
|
42
|
-
try {
|
43
|
-
const output = await promise;
|
44
|
-
return Object.assign(
|
45
|
-
[null, output, false],
|
46
|
-
{ error: null, data: output, isDefined: false }
|
47
|
-
);
|
48
|
-
} catch (e) {
|
49
|
-
const error = e;
|
50
|
-
if (isDefinedError(error)) {
|
51
|
-
return Object.assign(
|
52
|
-
[error, void 0, true],
|
53
|
-
{ error, data: void 0, isDefined: true }
|
54
|
-
);
|
55
|
-
}
|
56
|
-
return Object.assign(
|
57
|
-
[error, void 0, false],
|
58
|
-
{ error, data: void 0, isDefined: false }
|
59
|
-
);
|
60
|
-
}
|
61
|
-
}
|
62
|
-
|
63
|
-
export { DynamicLink, createORPCClient, isDefinedError, safe };
|
65
|
+
export { DynamicLink, createORPCClient, isDefinedError, resolveFriendlyClientOptions, safe };
|