@orpc/server 0.0.0-next.964aca5 → 0.0.0-next.965aae5
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 +20 -23
- package/dist/adapters/aws-lambda/index.d.mts +46 -0
- package/dist/adapters/aws-lambda/index.d.ts +46 -0
- package/dist/adapters/aws-lambda/index.mjs +42 -0
- package/dist/adapters/bun-ws/index.d.mts +36 -0
- package/dist/adapters/bun-ws/index.d.ts +36 -0
- package/dist/adapters/bun-ws/index.mjs +47 -0
- package/dist/adapters/crossws/index.d.mts +33 -0
- package/dist/adapters/crossws/index.d.ts +33 -0
- package/dist/adapters/crossws/index.mjs +45 -0
- package/dist/adapters/fetch/index.d.mts +74 -8
- package/dist/adapters/fetch/index.d.ts +74 -8
- package/dist/adapters/fetch/index.mjs +80 -5
- package/dist/adapters/message-port/index.d.mts +31 -0
- package/dist/adapters/message-port/index.d.ts +31 -0
- package/dist/adapters/message-port/index.mjs +39 -0
- package/dist/adapters/node/index.d.mts +50 -8
- package/dist/adapters/node/index.d.ts +50 -8
- package/dist/adapters/node/index.mjs +76 -14
- package/dist/adapters/standard/index.d.mts +8 -13
- package/dist/adapters/standard/index.d.ts +8 -13
- package/dist/adapters/standard/index.mjs +5 -5
- package/dist/adapters/standard-peer/index.d.mts +18 -0
- package/dist/adapters/standard-peer/index.d.ts +18 -0
- package/dist/adapters/standard-peer/index.mjs +7 -0
- package/dist/adapters/websocket/index.d.mts +54 -0
- package/dist/adapters/websocket/index.d.ts +54 -0
- package/dist/adapters/websocket/index.mjs +67 -0
- package/dist/adapters/ws/index.d.mts +31 -0
- package/dist/adapters/ws/index.d.ts +31 -0
- package/dist/adapters/ws/index.mjs +37 -0
- package/dist/helpers/index.d.mts +134 -0
- package/dist/helpers/index.d.ts +134 -0
- package/dist/helpers/index.mjs +188 -0
- package/dist/hibernation/index.d.mts +44 -0
- package/dist/hibernation/index.d.ts +44 -0
- package/dist/hibernation/index.mjs +65 -0
- package/dist/index.d.mts +563 -51
- package/dist/index.d.ts +563 -51
- package/dist/index.mjs +139 -13
- package/dist/plugins/index.d.mts +57 -12
- package/dist/plugins/index.d.ts +57 -12
- package/dist/plugins/index.mjs +101 -66
- package/dist/shared/{server.DQJX4Gnf.d.mts → server.B4BGqy3Y.d.mts} +60 -10
- package/dist/shared/{server.DQJX4Gnf.d.ts → server.B4BGqy3Y.d.ts} +60 -10
- package/dist/shared/server.COL12UTb.d.ts +32 -0
- package/dist/shared/server.CVKCo60T.d.mts +12 -0
- package/dist/shared/{server.C37gDhSZ.mjs → server.CaqDCZX1.mjs} +119 -74
- package/dist/shared/server.Cb6yD7DZ.d.ts +42 -0
- package/dist/shared/server.Ck-gOLzq.d.mts +32 -0
- package/dist/shared/{server.DsVSuKTu.d.ts → server.DBCUJijK.d.mts} +18 -17
- package/dist/shared/server.DNtJ-p60.d.ts +12 -0
- package/dist/shared/{server.ClO23hLW.d.mts → server.DPIFWpxG.d.ts} +18 -17
- package/dist/shared/{server.BVwwTHyO.mjs → server.DZ5BIITo.mjs} +1 -1
- package/dist/shared/server.DzV1hr3z.d.mts +42 -0
- package/dist/shared/server.UVMTOWrk.mjs +26 -0
- package/dist/shared/{server.DFuJLDuo.mjs → server.vzZSq5UM.mjs} +80 -51
- package/package.json +73 -8
- package/dist/shared/server.B5yVxwZh.d.mts +0 -17
- package/dist/shared/server.By38lRwX.d.ts +0 -17
- package/dist/shared/server.Cqam9L0P.d.mts +0 -10
- package/dist/shared/server.CuXY46Yy.d.ts +0 -10
|
@@ -1,18 +1,17 @@
|
|
|
1
1
|
import { toHttpPath, StandardRPCJsonSerializer, StandardRPCSerializer } from '@orpc/client/standard';
|
|
2
|
-
import { toArray, intercept, parseEmptyableJSON } from '@orpc/shared';
|
|
3
|
-
import '@orpc/standard-server/batch';
|
|
4
2
|
import { ORPCError, toORPCError } from '@orpc/client';
|
|
5
|
-
import {
|
|
6
|
-
import {
|
|
3
|
+
import { toArray, intercept, runWithSpan, ORPC_NAME, isAsyncIteratorObject, asyncIteratorWithSpan, setSpanError, parseEmptyableJSON, NullProtoObj, value } from '@orpc/shared';
|
|
4
|
+
import { flattenHeader } from '@orpc/standard-server';
|
|
5
|
+
import { c as createProcedureClient, t as traverseContractProcedures, i as isProcedure, u as unlazy, g as getRouter, a as createContractedProcedure } from './server.CaqDCZX1.mjs';
|
|
7
6
|
|
|
8
7
|
class CompositeStandardHandlerPlugin {
|
|
9
8
|
plugins;
|
|
10
9
|
constructor(plugins = []) {
|
|
11
10
|
this.plugins = [...plugins].sort((a, b) => (a.order ?? 0) - (b.order ?? 0));
|
|
12
11
|
}
|
|
13
|
-
init(options) {
|
|
12
|
+
init(options, router) {
|
|
14
13
|
for (const plugin of this.plugins) {
|
|
15
|
-
plugin.init?.(options);
|
|
14
|
+
plugin.init?.(options, router);
|
|
16
15
|
}
|
|
17
16
|
}
|
|
18
17
|
}
|
|
@@ -22,7 +21,7 @@ class StandardHandler {
|
|
|
22
21
|
this.matcher = matcher;
|
|
23
22
|
this.codec = codec;
|
|
24
23
|
const plugins = new CompositeStandardHandlerPlugin(options.plugins);
|
|
25
|
-
plugins.init(options);
|
|
24
|
+
plugins.init(options, router);
|
|
26
25
|
this.interceptors = toArray(options.interceptors);
|
|
27
26
|
this.clientInterceptors = toArray(options.clientInterceptors);
|
|
28
27
|
this.rootInterceptors = toArray(options.rootInterceptors);
|
|
@@ -40,47 +39,74 @@ class StandardHandler {
|
|
|
40
39
|
this.rootInterceptors,
|
|
41
40
|
{ ...options, request, prefix },
|
|
42
41
|
async (interceptorOptions) => {
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
42
|
+
return runWithSpan(
|
|
43
|
+
{ name: `${request.method} ${request.url.pathname}` },
|
|
44
|
+
async (span) => {
|
|
45
|
+
let step;
|
|
46
|
+
try {
|
|
47
|
+
return await intercept(
|
|
48
|
+
this.interceptors,
|
|
49
|
+
interceptorOptions,
|
|
50
|
+
async ({ request: request2, context, prefix: prefix2 }) => {
|
|
51
|
+
const method = request2.method;
|
|
52
|
+
const url = request2.url;
|
|
53
|
+
const pathname = prefix2 ? url.pathname.replace(prefix2, "") : url.pathname;
|
|
54
|
+
const match = await runWithSpan(
|
|
55
|
+
{ name: "find_procedure" },
|
|
56
|
+
() => this.matcher.match(method, `/${pathname.replace(/^\/|\/$/g, "")}`)
|
|
57
|
+
);
|
|
58
|
+
if (!match) {
|
|
59
|
+
return { matched: false, response: void 0 };
|
|
60
|
+
}
|
|
61
|
+
span?.updateName(`${ORPC_NAME}.${match.path.join("/")}`);
|
|
62
|
+
span?.setAttribute("rpc.system", ORPC_NAME);
|
|
63
|
+
span?.setAttribute("rpc.method", match.path.join("."));
|
|
64
|
+
step = "decode_input";
|
|
65
|
+
let input = await runWithSpan(
|
|
66
|
+
{ name: "decode_input" },
|
|
67
|
+
() => this.codec.decode(request2, match.params, match.procedure)
|
|
68
|
+
);
|
|
69
|
+
step = void 0;
|
|
70
|
+
if (isAsyncIteratorObject(input)) {
|
|
71
|
+
input = asyncIteratorWithSpan(
|
|
72
|
+
{ name: "consume_event_iterator_input", signal: request2.signal },
|
|
73
|
+
input
|
|
74
|
+
);
|
|
75
|
+
}
|
|
76
|
+
const client = createProcedureClient(match.procedure, {
|
|
77
|
+
context,
|
|
78
|
+
path: match.path,
|
|
79
|
+
interceptors: this.clientInterceptors
|
|
80
|
+
});
|
|
81
|
+
step = "call_procedure";
|
|
82
|
+
const output = await client(input, {
|
|
83
|
+
signal: request2.signal,
|
|
84
|
+
lastEventId: flattenHeader(request2.headers["last-event-id"])
|
|
85
|
+
});
|
|
86
|
+
step = void 0;
|
|
87
|
+
const response = this.codec.encode(output, match.procedure);
|
|
88
|
+
return {
|
|
89
|
+
matched: true,
|
|
90
|
+
response
|
|
91
|
+
};
|
|
92
|
+
}
|
|
93
|
+
);
|
|
94
|
+
} catch (e) {
|
|
95
|
+
if (step !== "call_procedure") {
|
|
96
|
+
setSpanError(span, e);
|
|
55
97
|
}
|
|
56
|
-
const
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
isDecoding = true;
|
|
62
|
-
const input = await this.codec.decode(request2, match.params, match.procedure);
|
|
63
|
-
isDecoding = false;
|
|
64
|
-
const lastEventId = Array.isArray(request2.headers["last-event-id"]) ? request2.headers["last-event-id"].at(-1) : request2.headers["last-event-id"];
|
|
65
|
-
const output = await client(input, { signal: request2.signal, lastEventId });
|
|
66
|
-
const response = this.codec.encode(output, match.procedure);
|
|
98
|
+
const error = step === "decode_input" && !(e instanceof ORPCError) ? new ORPCError("BAD_REQUEST", {
|
|
99
|
+
message: `Malformed request. Ensure the request body is properly formatted and the 'Content-Type' header is set correctly.`,
|
|
100
|
+
cause: e
|
|
101
|
+
}) : toORPCError(e);
|
|
102
|
+
const response = this.codec.encodeError(error);
|
|
67
103
|
return {
|
|
68
104
|
matched: true,
|
|
69
105
|
response
|
|
70
106
|
};
|
|
71
107
|
}
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
const error = isDecoding && !(e instanceof ORPCError) ? new ORPCError("BAD_REQUEST", {
|
|
75
|
-
message: `Malformed request. Ensure the request body is properly formatted and the 'Content-Type' header is set correctly.`,
|
|
76
|
-
cause: e
|
|
77
|
-
}) : toORPCError(e);
|
|
78
|
-
const response = this.codec.encodeError(error);
|
|
79
|
-
return {
|
|
80
|
-
matched: true,
|
|
81
|
-
response
|
|
82
|
-
};
|
|
83
|
-
}
|
|
108
|
+
}
|
|
109
|
+
);
|
|
84
110
|
}
|
|
85
111
|
);
|
|
86
112
|
}
|
|
@@ -111,10 +137,18 @@ class StandardRPCCodec {
|
|
|
111
137
|
}
|
|
112
138
|
|
|
113
139
|
class StandardRPCMatcher {
|
|
114
|
-
|
|
140
|
+
filter;
|
|
141
|
+
tree = new NullProtoObj();
|
|
115
142
|
pendingRouters = [];
|
|
143
|
+
constructor(options = {}) {
|
|
144
|
+
this.filter = options.filter ?? true;
|
|
145
|
+
}
|
|
116
146
|
init(router, path = []) {
|
|
117
|
-
const laziedOptions = traverseContractProcedures({ router, path }, (
|
|
147
|
+
const laziedOptions = traverseContractProcedures({ router, path }, (traverseOptions) => {
|
|
148
|
+
if (!value(this.filter, traverseOptions)) {
|
|
149
|
+
return;
|
|
150
|
+
}
|
|
151
|
+
const { path: path2, contract } = traverseOptions;
|
|
118
152
|
const httpPath = toHttpPath(path2);
|
|
119
153
|
if (isProcedure(contract)) {
|
|
120
154
|
this.tree[httpPath] = {
|
|
@@ -173,15 +207,10 @@ class StandardRPCMatcher {
|
|
|
173
207
|
}
|
|
174
208
|
|
|
175
209
|
class StandardRPCHandler extends StandardHandler {
|
|
176
|
-
constructor(router, options) {
|
|
177
|
-
options.plugins ??= [];
|
|
178
|
-
const strictGetMethodPluginEnabled = options.strictGetMethodPluginEnabled ?? true;
|
|
179
|
-
if (strictGetMethodPluginEnabled) {
|
|
180
|
-
options.plugins.push(new StrictGetMethodPlugin());
|
|
181
|
-
}
|
|
210
|
+
constructor(router, options = {}) {
|
|
182
211
|
const jsonSerializer = new StandardRPCJsonSerializer(options);
|
|
183
212
|
const serializer = new StandardRPCSerializer(jsonSerializer);
|
|
184
|
-
const matcher = new StandardRPCMatcher();
|
|
213
|
+
const matcher = new StandardRPCMatcher(options);
|
|
185
214
|
const codec = new StandardRPCCodec(serializer);
|
|
186
215
|
super(router, matcher, codec, options);
|
|
187
216
|
}
|
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@orpc/server",
|
|
3
3
|
"type": "module",
|
|
4
|
-
"version": "0.0.0-next.
|
|
4
|
+
"version": "0.0.0-next.965aae5",
|
|
5
5
|
"license": "MIT",
|
|
6
6
|
"homepage": "https://orpc.unnoq.com",
|
|
7
7
|
"repository": {
|
|
@@ -19,16 +19,31 @@
|
|
|
19
19
|
"import": "./dist/index.mjs",
|
|
20
20
|
"default": "./dist/index.mjs"
|
|
21
21
|
},
|
|
22
|
+
"./helpers": {
|
|
23
|
+
"types": "./dist/helpers/index.d.mts",
|
|
24
|
+
"import": "./dist/helpers/index.mjs",
|
|
25
|
+
"default": "./dist/helpers/index.mjs"
|
|
26
|
+
},
|
|
22
27
|
"./plugins": {
|
|
23
28
|
"types": "./dist/plugins/index.d.mts",
|
|
24
29
|
"import": "./dist/plugins/index.mjs",
|
|
25
30
|
"default": "./dist/plugins/index.mjs"
|
|
26
31
|
},
|
|
32
|
+
"./hibernation": {
|
|
33
|
+
"types": "./dist/hibernation/index.d.mts",
|
|
34
|
+
"import": "./dist/hibernation/index.mjs",
|
|
35
|
+
"default": "./dist/hibernation/index.mjs"
|
|
36
|
+
},
|
|
27
37
|
"./standard": {
|
|
28
38
|
"types": "./dist/adapters/standard/index.d.mts",
|
|
29
39
|
"import": "./dist/adapters/standard/index.mjs",
|
|
30
40
|
"default": "./dist/adapters/standard/index.mjs"
|
|
31
41
|
},
|
|
42
|
+
"./standard-peer": {
|
|
43
|
+
"types": "./dist/adapters/standard-peer/index.d.mts",
|
|
44
|
+
"import": "./dist/adapters/standard-peer/index.mjs",
|
|
45
|
+
"default": "./dist/adapters/standard-peer/index.mjs"
|
|
46
|
+
},
|
|
32
47
|
"./fetch": {
|
|
33
48
|
"types": "./dist/adapters/fetch/index.d.mts",
|
|
34
49
|
"import": "./dist/adapters/fetch/index.mjs",
|
|
@@ -38,21 +53,71 @@
|
|
|
38
53
|
"types": "./dist/adapters/node/index.d.mts",
|
|
39
54
|
"import": "./dist/adapters/node/index.mjs",
|
|
40
55
|
"default": "./dist/adapters/node/index.mjs"
|
|
56
|
+
},
|
|
57
|
+
"./aws-lambda": {
|
|
58
|
+
"types": "./dist/adapters/aws-lambda/index.d.mts",
|
|
59
|
+
"import": "./dist/adapters/aws-lambda/index.mjs",
|
|
60
|
+
"default": "./dist/adapters/aws-lambda/index.mjs"
|
|
61
|
+
},
|
|
62
|
+
"./websocket": {
|
|
63
|
+
"types": "./dist/adapters/websocket/index.d.mts",
|
|
64
|
+
"import": "./dist/adapters/websocket/index.mjs",
|
|
65
|
+
"default": "./dist/adapters/websocket/index.mjs"
|
|
66
|
+
},
|
|
67
|
+
"./crossws": {
|
|
68
|
+
"types": "./dist/adapters/crossws/index.d.mts",
|
|
69
|
+
"import": "./dist/adapters/crossws/index.mjs",
|
|
70
|
+
"default": "./dist/adapters/crossws/index.mjs"
|
|
71
|
+
},
|
|
72
|
+
"./ws": {
|
|
73
|
+
"types": "./dist/adapters/ws/index.d.mts",
|
|
74
|
+
"import": "./dist/adapters/ws/index.mjs",
|
|
75
|
+
"default": "./dist/adapters/ws/index.mjs"
|
|
76
|
+
},
|
|
77
|
+
"./bun-ws": {
|
|
78
|
+
"types": "./dist/adapters/bun-ws/index.d.mts",
|
|
79
|
+
"import": "./dist/adapters/bun-ws/index.mjs",
|
|
80
|
+
"default": "./dist/adapters/bun-ws/index.mjs"
|
|
81
|
+
},
|
|
82
|
+
"./message-port": {
|
|
83
|
+
"types": "./dist/adapters/message-port/index.d.mts",
|
|
84
|
+
"import": "./dist/adapters/message-port/index.mjs",
|
|
85
|
+
"default": "./dist/adapters/message-port/index.mjs"
|
|
41
86
|
}
|
|
42
87
|
},
|
|
43
88
|
"files": [
|
|
44
89
|
"dist"
|
|
45
90
|
],
|
|
91
|
+
"peerDependencies": {
|
|
92
|
+
"crossws": ">=0.3.4",
|
|
93
|
+
"ws": ">=8.18.1"
|
|
94
|
+
},
|
|
95
|
+
"peerDependenciesMeta": {
|
|
96
|
+
"crossws": {
|
|
97
|
+
"optional": true
|
|
98
|
+
},
|
|
99
|
+
"ws": {
|
|
100
|
+
"optional": true
|
|
101
|
+
}
|
|
102
|
+
},
|
|
46
103
|
"dependencies": {
|
|
47
|
-
"
|
|
48
|
-
"@orpc/
|
|
49
|
-
"@orpc/
|
|
50
|
-
"@orpc/
|
|
51
|
-
"@orpc/
|
|
52
|
-
"@orpc/
|
|
104
|
+
"cookie": "^1.0.2",
|
|
105
|
+
"@orpc/client": "0.0.0-next.965aae5",
|
|
106
|
+
"@orpc/contract": "0.0.0-next.965aae5",
|
|
107
|
+
"@orpc/interop": "0.0.0-next.965aae5",
|
|
108
|
+
"@orpc/shared": "0.0.0-next.965aae5",
|
|
109
|
+
"@orpc/standard-server-aws-lambda": "0.0.0-next.965aae5",
|
|
110
|
+
"@orpc/standard-server": "0.0.0-next.965aae5",
|
|
111
|
+
"@orpc/standard-server-fetch": "0.0.0-next.965aae5",
|
|
112
|
+
"@orpc/standard-server-peer": "0.0.0-next.965aae5",
|
|
113
|
+
"@orpc/standard-server-node": "0.0.0-next.965aae5"
|
|
53
114
|
},
|
|
54
115
|
"devDependencies": {
|
|
55
|
-
"
|
|
116
|
+
"@types/ws": "^8.18.1",
|
|
117
|
+
"crossws": "^0.4.1",
|
|
118
|
+
"next": "^15.5.2",
|
|
119
|
+
"supertest": "^7.1.4",
|
|
120
|
+
"ws": "^8.18.3"
|
|
56
121
|
},
|
|
57
122
|
"scripts": {
|
|
58
123
|
"build": "unbuild",
|
|
@@ -1,17 +0,0 @@
|
|
|
1
|
-
import { C as Context, R as Router } from './server.DQJX4Gnf.mjs';
|
|
2
|
-
import { StandardRPCJsonSerializerOptions } from '@orpc/client/standard';
|
|
3
|
-
import { b as StandardHandlerOptions, i as StandardHandler } from './server.ClO23hLW.mjs';
|
|
4
|
-
|
|
5
|
-
interface StandardRPCHandlerOptions<T extends Context> extends StandardHandlerOptions<T>, StandardRPCJsonSerializerOptions {
|
|
6
|
-
/**
|
|
7
|
-
* Enables or disables the StrictGetMethodPlugin.
|
|
8
|
-
*
|
|
9
|
-
* @default true
|
|
10
|
-
*/
|
|
11
|
-
strictGetMethodPluginEnabled?: boolean;
|
|
12
|
-
}
|
|
13
|
-
declare class StandardRPCHandler<T extends Context> extends StandardHandler<T> {
|
|
14
|
-
constructor(router: Router<any, T>, options: StandardRPCHandlerOptions<T>);
|
|
15
|
-
}
|
|
16
|
-
|
|
17
|
-
export { type StandardRPCHandlerOptions as S, StandardRPCHandler as a };
|
|
@@ -1,17 +0,0 @@
|
|
|
1
|
-
import { C as Context, R as Router } from './server.DQJX4Gnf.js';
|
|
2
|
-
import { StandardRPCJsonSerializerOptions } from '@orpc/client/standard';
|
|
3
|
-
import { b as StandardHandlerOptions, i as StandardHandler } from './server.DsVSuKTu.js';
|
|
4
|
-
|
|
5
|
-
interface StandardRPCHandlerOptions<T extends Context> extends StandardHandlerOptions<T>, StandardRPCJsonSerializerOptions {
|
|
6
|
-
/**
|
|
7
|
-
* Enables or disables the StrictGetMethodPlugin.
|
|
8
|
-
*
|
|
9
|
-
* @default true
|
|
10
|
-
*/
|
|
11
|
-
strictGetMethodPluginEnabled?: boolean;
|
|
12
|
-
}
|
|
13
|
-
declare class StandardRPCHandler<T extends Context> extends StandardHandler<T> {
|
|
14
|
-
constructor(router: Router<any, T>, options: StandardRPCHandlerOptions<T>);
|
|
15
|
-
}
|
|
16
|
-
|
|
17
|
-
export { type StandardRPCHandlerOptions as S, StandardRPCHandler as a };
|
|
@@ -1,10 +0,0 @@
|
|
|
1
|
-
import { C as Context } from './server.DQJX4Gnf.mjs';
|
|
2
|
-
import { g as StandardHandleOptions } from './server.ClO23hLW.mjs';
|
|
3
|
-
|
|
4
|
-
type FriendlyStandardHandleOptions<T extends Context> = Omit<StandardHandleOptions<T>, 'context'> & (Record<never, never> extends T ? {
|
|
5
|
-
context?: T;
|
|
6
|
-
} : {
|
|
7
|
-
context: T;
|
|
8
|
-
});
|
|
9
|
-
|
|
10
|
-
export type { FriendlyStandardHandleOptions as F };
|
|
@@ -1,10 +0,0 @@
|
|
|
1
|
-
import { C as Context } from './server.DQJX4Gnf.js';
|
|
2
|
-
import { g as StandardHandleOptions } from './server.DsVSuKTu.js';
|
|
3
|
-
|
|
4
|
-
type FriendlyStandardHandleOptions<T extends Context> = Omit<StandardHandleOptions<T>, 'context'> & (Record<never, never> extends T ? {
|
|
5
|
-
context?: T;
|
|
6
|
-
} : {
|
|
7
|
-
context: T;
|
|
8
|
-
});
|
|
9
|
-
|
|
10
|
-
export type { FriendlyStandardHandleOptions as F };
|