@orpc/server 0.0.0-next.fa8d145 → 0.0.0-next.fc1ae52
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 +9 -9
- 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 +12 -11
- package/dist/adapters/bun-ws/index.d.ts +12 -11
- package/dist/adapters/bun-ws/index.mjs +16 -20
- package/dist/adapters/crossws/index.d.mts +8 -5
- package/dist/adapters/crossws/index.d.ts +8 -5
- package/dist/adapters/crossws/index.mjs +11 -17
- package/dist/adapters/fetch/index.d.mts +56 -10
- package/dist/adapters/fetch/index.d.ts +56 -10
- package/dist/adapters/fetch/index.mjs +74 -4
- 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 +32 -10
- package/dist/adapters/node/index.d.ts +32 -10
- package/dist/adapters/node/index.mjs +70 -13
- package/dist/adapters/standard/index.d.mts +8 -13
- package/dist/adapters/standard/index.d.ts +8 -13
- package/dist/adapters/standard/index.mjs +3 -2
- 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 +36 -9
- package/dist/adapters/websocket/index.d.ts +36 -9
- package/dist/adapters/websocket/index.mjs +49 -20
- package/dist/adapters/ws/index.d.mts +11 -8
- package/dist/adapters/ws/index.d.ts +11 -8
- package/dist/adapters/ws/index.mjs +13 -14
- 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 +22 -48
- package/dist/index.d.ts +22 -48
- package/dist/index.mjs +25 -10
- package/dist/plugins/index.d.mts +28 -15
- package/dist/plugins/index.d.ts +28 -15
- package/dist/plugins/index.mjs +96 -60
- package/dist/shared/{server.DPWk5pjW.d.mts → server.B4BGqy3Y.d.mts} +10 -9
- package/dist/shared/{server.DPWk5pjW.d.ts → server.B4BGqy3Y.d.ts} +10 -9
- package/dist/shared/server.COL12UTb.d.ts +32 -0
- package/dist/shared/server.CVKCo60T.d.mts +12 -0
- package/dist/shared/{server.DG7Tamti.mjs → server.CaqDCZX1.mjs} +116 -74
- package/dist/shared/server.Cb6yD7DZ.d.ts +42 -0
- package/dist/shared/server.Ck-gOLzq.d.mts +32 -0
- package/dist/shared/{server.YZzrREz9.d.ts → server.DBCUJijK.d.mts} +8 -8
- package/dist/shared/server.DNtJ-p60.d.ts +12 -0
- package/dist/shared/{server.eWLxY3lq.d.mts → server.DPIFWpxG.d.ts} +8 -8
- 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.4FnxLwwr.mjs → server.vzZSq5UM.mjs} +75 -42
- package/package.json +40 -12
- package/dist/shared/server.BRoxSiSC.d.mts +0 -12
- package/dist/shared/server.BjiJH9Vo.d.ts +0 -10
- package/dist/shared/server.Cy1vfSiG.d.ts +0 -12
- package/dist/shared/server.QUe9N8P4.d.mts +0 -10
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
import { toHttpPath, StandardRPCJsonSerializer, StandardRPCSerializer } from '@orpc/client/standard';
|
|
2
2
|
import { ORPCError, toORPCError } from '@orpc/client';
|
|
3
|
-
import { toArray, intercept, parseEmptyableJSON } from '@orpc/shared';
|
|
3
|
+
import { toArray, intercept, runWithSpan, ORPC_NAME, isAsyncIteratorObject, asyncIteratorWithSpan, setSpanError, parseEmptyableJSON, NullProtoObj, value } from '@orpc/shared';
|
|
4
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.
|
|
5
|
+
import { c as createProcedureClient, t as traverseContractProcedures, i as isProcedure, u as unlazy, g as getRouter, a as createContractedProcedure } from './server.CaqDCZX1.mjs';
|
|
6
6
|
|
|
7
7
|
class CompositeStandardHandlerPlugin {
|
|
8
8
|
plugins;
|
|
@@ -39,49 +39,74 @@ class StandardHandler {
|
|
|
39
39
|
this.rootInterceptors,
|
|
40
40
|
{ ...options, request, prefix },
|
|
41
41
|
async (interceptorOptions) => {
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
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);
|
|
54
97
|
}
|
|
55
|
-
const
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
isDecoding = true;
|
|
61
|
-
const input = await this.codec.decode(request2, match.params, match.procedure);
|
|
62
|
-
isDecoding = false;
|
|
63
|
-
const output = await client(input, {
|
|
64
|
-
signal: request2.signal,
|
|
65
|
-
lastEventId: flattenHeader(request2.headers["last-event-id"])
|
|
66
|
-
});
|
|
67
|
-
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);
|
|
68
103
|
return {
|
|
69
104
|
matched: true,
|
|
70
105
|
response
|
|
71
106
|
};
|
|
72
107
|
}
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
const error = isDecoding && !(e instanceof ORPCError) ? new ORPCError("BAD_REQUEST", {
|
|
76
|
-
message: `Malformed request. Ensure the request body is properly formatted and the 'Content-Type' header is set correctly.`,
|
|
77
|
-
cause: e
|
|
78
|
-
}) : toORPCError(e);
|
|
79
|
-
const response = this.codec.encodeError(error);
|
|
80
|
-
return {
|
|
81
|
-
matched: true,
|
|
82
|
-
response
|
|
83
|
-
};
|
|
84
|
-
}
|
|
108
|
+
}
|
|
109
|
+
);
|
|
85
110
|
}
|
|
86
111
|
);
|
|
87
112
|
}
|
|
@@ -112,10 +137,18 @@ class StandardRPCCodec {
|
|
|
112
137
|
}
|
|
113
138
|
|
|
114
139
|
class StandardRPCMatcher {
|
|
115
|
-
|
|
140
|
+
filter;
|
|
141
|
+
tree = new NullProtoObj();
|
|
116
142
|
pendingRouters = [];
|
|
143
|
+
constructor(options = {}) {
|
|
144
|
+
this.filter = options.filter ?? true;
|
|
145
|
+
}
|
|
117
146
|
init(router, path = []) {
|
|
118
|
-
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;
|
|
119
152
|
const httpPath = toHttpPath(path2);
|
|
120
153
|
if (isProcedure(contract)) {
|
|
121
154
|
this.tree[httpPath] = {
|
|
@@ -177,7 +210,7 @@ class StandardRPCHandler extends StandardHandler {
|
|
|
177
210
|
constructor(router, options = {}) {
|
|
178
211
|
const jsonSerializer = new StandardRPCJsonSerializer(options);
|
|
179
212
|
const serializer = new StandardRPCSerializer(jsonSerializer);
|
|
180
|
-
const matcher = new StandardRPCMatcher();
|
|
213
|
+
const matcher = new StandardRPCMatcher(options);
|
|
181
214
|
const codec = new StandardRPCCodec(serializer);
|
|
182
215
|
super(router, matcher, codec, options);
|
|
183
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.fc1ae52",
|
|
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",
|
|
@@ -39,6 +54,11 @@
|
|
|
39
54
|
"import": "./dist/adapters/node/index.mjs",
|
|
40
55
|
"default": "./dist/adapters/node/index.mjs"
|
|
41
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
|
+
},
|
|
42
62
|
"./websocket": {
|
|
43
63
|
"types": "./dist/adapters/websocket/index.d.mts",
|
|
44
64
|
"import": "./dist/adapters/websocket/index.mjs",
|
|
@@ -58,6 +78,11 @@
|
|
|
58
78
|
"types": "./dist/adapters/bun-ws/index.d.mts",
|
|
59
79
|
"import": "./dist/adapters/bun-ws/index.mjs",
|
|
60
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"
|
|
61
86
|
}
|
|
62
87
|
},
|
|
63
88
|
"files": [
|
|
@@ -76,20 +101,23 @@
|
|
|
76
101
|
}
|
|
77
102
|
},
|
|
78
103
|
"dependencies": {
|
|
79
|
-
"
|
|
80
|
-
"@orpc/
|
|
81
|
-
"@orpc/
|
|
82
|
-
"@orpc/
|
|
83
|
-
"@orpc/
|
|
84
|
-
"@orpc/
|
|
85
|
-
"@orpc/standard-server-
|
|
104
|
+
"cookie": "^1.0.2",
|
|
105
|
+
"@orpc/client": "0.0.0-next.fc1ae52",
|
|
106
|
+
"@orpc/interop": "0.0.0-next.fc1ae52",
|
|
107
|
+
"@orpc/shared": "0.0.0-next.fc1ae52",
|
|
108
|
+
"@orpc/standard-server": "0.0.0-next.fc1ae52",
|
|
109
|
+
"@orpc/contract": "0.0.0-next.fc1ae52",
|
|
110
|
+
"@orpc/standard-server-aws-lambda": "0.0.0-next.fc1ae52",
|
|
111
|
+
"@orpc/standard-server-fetch": "0.0.0-next.fc1ae52",
|
|
112
|
+
"@orpc/standard-server-node": "0.0.0-next.fc1ae52",
|
|
113
|
+
"@orpc/standard-server-peer": "0.0.0-next.fc1ae52"
|
|
86
114
|
},
|
|
87
115
|
"devDependencies": {
|
|
88
116
|
"@types/ws": "^8.18.1",
|
|
89
|
-
"crossws": "^0.
|
|
90
|
-
"next": "^15.
|
|
91
|
-
"supertest": "^7.1.
|
|
92
|
-
"ws": "^8.18.
|
|
117
|
+
"crossws": "^0.4.1",
|
|
118
|
+
"next": "^15.5.2",
|
|
119
|
+
"supertest": "^7.1.4",
|
|
120
|
+
"ws": "^8.18.3"
|
|
93
121
|
},
|
|
94
122
|
"scripts": {
|
|
95
123
|
"build": "unbuild",
|
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
import { StandardRPCJsonSerializerOptions } from '@orpc/client/standard';
|
|
2
|
-
import { C as Context, R as Router } from './server.DPWk5pjW.mjs';
|
|
3
|
-
import { b as StandardHandlerOptions, i as StandardHandler } from './server.eWLxY3lq.mjs';
|
|
4
|
-
|
|
5
|
-
interface StandardRPCHandlerOptions<T extends Context> extends StandardHandlerOptions<T>, StandardRPCJsonSerializerOptions {
|
|
6
|
-
}
|
|
7
|
-
declare class StandardRPCHandler<T extends Context> extends StandardHandler<T> {
|
|
8
|
-
constructor(router: Router<any, T>, options?: StandardRPCHandlerOptions<T>);
|
|
9
|
-
}
|
|
10
|
-
|
|
11
|
-
export { StandardRPCHandler as a };
|
|
12
|
-
export type { StandardRPCHandlerOptions as S };
|
|
@@ -1,10 +0,0 @@
|
|
|
1
|
-
import { C as Context } from './server.DPWk5pjW.js';
|
|
2
|
-
import { g as StandardHandleOptions } from './server.YZzrREz9.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 };
|
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
import { StandardRPCJsonSerializerOptions } from '@orpc/client/standard';
|
|
2
|
-
import { C as Context, R as Router } from './server.DPWk5pjW.js';
|
|
3
|
-
import { b as StandardHandlerOptions, i as StandardHandler } from './server.YZzrREz9.js';
|
|
4
|
-
|
|
5
|
-
interface StandardRPCHandlerOptions<T extends Context> extends StandardHandlerOptions<T>, StandardRPCJsonSerializerOptions {
|
|
6
|
-
}
|
|
7
|
-
declare class StandardRPCHandler<T extends Context> extends StandardHandler<T> {
|
|
8
|
-
constructor(router: Router<any, T>, options?: StandardRPCHandlerOptions<T>);
|
|
9
|
-
}
|
|
10
|
-
|
|
11
|
-
export { StandardRPCHandler as a };
|
|
12
|
-
export type { StandardRPCHandlerOptions as S };
|
|
@@ -1,10 +0,0 @@
|
|
|
1
|
-
import { C as Context } from './server.DPWk5pjW.mjs';
|
|
2
|
-
import { g as StandardHandleOptions } from './server.eWLxY3lq.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 };
|