@orpc/server 0.0.0-next.c40d0c9 → 0.0.0-next.c4671e3
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 +13 -17
- package/dist/adapters/bun-ws/index.d.mts +35 -0
- package/dist/adapters/bun-ws/index.d.ts +35 -0
- package/dist/adapters/bun-ws/index.mjs +50 -0
- package/dist/adapters/crossws/index.d.mts +30 -0
- package/dist/adapters/crossws/index.d.ts +30 -0
- package/dist/adapters/crossws/index.mjs +50 -0
- package/dist/adapters/fetch/index.d.mts +33 -9
- package/dist/adapters/fetch/index.d.ts +33 -9
- package/dist/adapters/fetch/index.mjs +109 -8
- package/dist/adapters/node/index.d.mts +33 -9
- package/dist/adapters/node/index.d.ts +33 -9
- package/dist/adapters/node/index.mjs +22 -12
- package/dist/adapters/standard/index.d.mts +4 -4
- package/dist/adapters/standard/index.d.ts +4 -4
- package/dist/adapters/standard/index.mjs +3 -3
- package/dist/adapters/websocket/index.d.mts +27 -0
- package/dist/adapters/websocket/index.d.ts +27 -0
- package/dist/adapters/websocket/index.mjs +37 -0
- package/dist/adapters/ws/index.d.mts +28 -0
- package/dist/adapters/ws/index.d.ts +28 -0
- package/dist/adapters/ws/index.mjs +37 -0
- package/dist/index.d.mts +548 -10
- package/dist/index.d.ts +548 -10
- package/dist/index.mjs +122 -11
- package/dist/plugins/index.d.mts +132 -6
- package/dist/plugins/index.d.ts +132 -6
- package/dist/plugins/index.mjs +153 -9
- package/dist/shared/server.BRoxSiSC.d.mts +12 -0
- package/dist/shared/server.BW-nUGgA.mjs +36 -0
- package/dist/shared/{server.Cud5qk0c.d.ts → server.BjiJH9Vo.d.ts} +2 -2
- package/dist/shared/server.Cy1vfSiG.d.ts +12 -0
- package/dist/shared/{server.e3W6AG3-.mjs → server.DG7Tamti.mjs} +19 -22
- package/dist/shared/{server.DLt5njUb.d.mts → server.DPWk5pjW.d.mts} +54 -5
- package/dist/shared/{server.DLt5njUb.d.ts → server.DPWk5pjW.d.ts} +54 -5
- package/dist/shared/{server.DGnN7q3R.d.mts → server.QUe9N8P4.d.mts} +2 -2
- package/dist/shared/{server.DCCkTG29.mjs → server.SxlTJfG2.mjs} +27 -6
- package/dist/shared/{server.BHlRCrf_.d.ts → server.YZzrREz9.d.ts} +13 -5
- package/dist/shared/{server.CzxlqYZL.d.mts → server.eWLxY3lq.d.mts} +13 -5
- package/package.json +43 -20
- package/dist/adapters/hono/index.d.mts +0 -22
- package/dist/adapters/hono/index.d.ts +0 -22
- package/dist/adapters/hono/index.mjs +0 -32
- package/dist/adapters/next/index.d.mts +0 -29
- package/dist/adapters/next/index.d.ts +0 -29
- package/dist/adapters/next/index.mjs +0 -29
- package/dist/shared/server.B77ImKAP.d.mts +0 -8
- package/dist/shared/server.DUF89eb-.d.ts +0 -8
- package/dist/shared/server.Prfzu_zf.mjs +0 -98
@@ -1,22 +1,26 @@
|
|
1
|
-
import { C as Context, R as Router } from '../../shared/server.
|
1
|
+
import { C as Context, R as Router } from '../../shared/server.DPWk5pjW.js';
|
2
2
|
import { Interceptor, ThrowableError, MaybeOptionalOptions } from '@orpc/shared';
|
3
3
|
import { SendStandardResponseOptions, NodeHttpRequest, NodeHttpResponse } from '@orpc/standard-server-node';
|
4
|
-
import {
|
5
|
-
import { F as FriendlyStandardHandleOptions } from '../../shared/server.
|
6
|
-
import { S as StandardRPCHandlerOptions } from '../../shared/server.
|
4
|
+
import { a as StandardHandlerPlugin, C as CompositeStandardHandlerPlugin, g as StandardHandleOptions, i as StandardHandler } from '../../shared/server.YZzrREz9.js';
|
5
|
+
import { F as FriendlyStandardHandleOptions } from '../../shared/server.BjiJH9Vo.js';
|
6
|
+
import { S as StandardRPCHandlerOptions } from '../../shared/server.Cy1vfSiG.js';
|
7
7
|
import '@orpc/client';
|
8
8
|
import '@orpc/contract';
|
9
9
|
import '@orpc/standard-server';
|
10
10
|
import '@orpc/client/standard';
|
11
11
|
|
12
|
+
interface NodeHttpHandlerPlugin<T extends Context> extends StandardHandlerPlugin<T> {
|
13
|
+
initRuntimeAdapter?(options: NodeHttpHandlerOptions<T>): void;
|
14
|
+
}
|
15
|
+
declare class CompositeNodeHttpHandlerPlugin<T extends Context, TPlugin extends NodeHttpHandlerPlugin<T>> extends CompositeStandardHandlerPlugin<T, TPlugin> implements NodeHttpHandlerPlugin<T> {
|
16
|
+
initRuntimeAdapter(options: NodeHttpHandlerOptions<T>): void;
|
17
|
+
}
|
18
|
+
|
12
19
|
type NodeHttpHandleResult = {
|
13
20
|
matched: true;
|
14
21
|
} | {
|
15
22
|
matched: false;
|
16
23
|
};
|
17
|
-
interface NodeHttpHandlerPlugin<T extends Context> extends StandardHandlerPlugin<T> {
|
18
|
-
initRuntimeAdapter?(options: NodeHttpHandlerOptions<T>): void;
|
19
|
-
}
|
20
24
|
interface NodeHttpHandlerInterceptorOptions<T extends Context> extends StandardHandleOptions<T> {
|
21
25
|
request: NodeHttpRequest;
|
22
26
|
response: NodeHttpResponse;
|
@@ -40,14 +44,34 @@ interface BodyLimitPluginOptions {
|
|
40
44
|
*/
|
41
45
|
maxBodySize: number;
|
42
46
|
}
|
47
|
+
/**
|
48
|
+
* The Body Limit Plugin restricts the size of the request body for the Node.js HTTP Server.
|
49
|
+
*
|
50
|
+
* @see {@link https://orpc.unnoq.com/docs/plugins/body-limit Body Limit Plugin Docs}
|
51
|
+
*/
|
43
52
|
declare class BodyLimitPlugin<T extends Context> implements NodeHttpHandlerPlugin<T> {
|
44
53
|
private readonly maxBodySize;
|
45
54
|
constructor(options: BodyLimitPluginOptions);
|
46
55
|
initRuntimeAdapter(options: NodeHttpHandlerOptions<T>): void;
|
47
56
|
}
|
48
57
|
|
58
|
+
type RPCHandlerOptions<T extends Context> = NodeHttpHandlerOptions<T> & StandardRPCHandlerOptions<T> & {
|
59
|
+
/**
|
60
|
+
* Enables or disables the StrictGetMethodPlugin.
|
61
|
+
*
|
62
|
+
* @default true
|
63
|
+
*/
|
64
|
+
strictGetMethodPluginEnabled?: boolean;
|
65
|
+
};
|
66
|
+
/**
|
67
|
+
* RPC Handler for Node.js HTTP Server
|
68
|
+
*
|
69
|
+
* @see {@link https://orpc.unnoq.com/docs/rpc-handler RPC Handler Docs}
|
70
|
+
* @see {@link https://orpc.unnoq.com/docs/adapters/http HTTP Adapter Docs}
|
71
|
+
*/
|
49
72
|
declare class RPCHandler<T extends Context> extends NodeHttpHandler<T> {
|
50
|
-
constructor(router: Router<any, T>, options?: NoInfer<
|
73
|
+
constructor(router: Router<any, T>, options?: NoInfer<RPCHandlerOptions<T>>);
|
51
74
|
}
|
52
75
|
|
53
|
-
export { BodyLimitPlugin,
|
76
|
+
export { BodyLimitPlugin, CompositeNodeHttpHandlerPlugin, NodeHttpHandler, RPCHandler };
|
77
|
+
export type { BodyLimitPluginOptions, NodeHttpHandleResult, NodeHttpHandlerInterceptorOptions, NodeHttpHandlerOptions, NodeHttpHandlerPlugin, RPCHandlerOptions };
|
@@ -2,10 +2,13 @@ import { ORPCError } from '@orpc/client';
|
|
2
2
|
import { toArray, intercept, resolveMaybeOptionalOptions } from '@orpc/shared';
|
3
3
|
import { toStandardLazyRequest, sendStandardResponse } from '@orpc/standard-server-node';
|
4
4
|
import { r as resolveFriendlyStandardHandleOptions } from '../../shared/server.BVwwTHyO.mjs';
|
5
|
-
import { StandardRPCJsonSerializer, StandardRPCSerializer } from '@orpc/client/standard';
|
6
|
-
import { S as StandardHandler, b as StandardRPCMatcher, a as StandardRPCCodec } from '../../shared/server.DCCkTG29.mjs';
|
7
|
-
import '../../shared/server.e3W6AG3-.mjs';
|
8
5
|
import '@orpc/contract';
|
6
|
+
import { C as CompositeStandardHandlerPlugin, b as StandardRPCHandler } from '../../shared/server.SxlTJfG2.mjs';
|
7
|
+
import '@orpc/client/standard';
|
8
|
+
import '@orpc/standard-server/batch';
|
9
|
+
import '@orpc/standard-server';
|
10
|
+
import { S as StrictGetMethodPlugin } from '../../shared/server.BW-nUGgA.mjs';
|
11
|
+
import '../../shared/server.DG7Tamti.mjs';
|
9
12
|
|
10
13
|
class BodyLimitPlugin {
|
11
14
|
maxBodySize;
|
@@ -39,12 +42,19 @@ class BodyLimitPlugin {
|
|
39
42
|
}
|
40
43
|
}
|
41
44
|
|
45
|
+
class CompositeNodeHttpHandlerPlugin extends CompositeStandardHandlerPlugin {
|
46
|
+
initRuntimeAdapter(options) {
|
47
|
+
for (const plugin of this.plugins) {
|
48
|
+
plugin.initRuntimeAdapter?.(options);
|
49
|
+
}
|
50
|
+
}
|
51
|
+
}
|
52
|
+
|
42
53
|
class NodeHttpHandler {
|
43
54
|
constructor(standardHandler, options = {}) {
|
44
55
|
this.standardHandler = standardHandler;
|
45
|
-
|
46
|
-
|
47
|
-
}
|
56
|
+
const plugin = new CompositeNodeHttpHandlerPlugin(options.plugins);
|
57
|
+
plugin.initRuntimeAdapter(options);
|
48
58
|
this.adapterInterceptors = toArray(options.adapterInterceptors);
|
49
59
|
this.sendStandardResponseOptions = options;
|
50
60
|
}
|
@@ -74,12 +84,12 @@ class NodeHttpHandler {
|
|
74
84
|
|
75
85
|
class RPCHandler extends NodeHttpHandler {
|
76
86
|
constructor(router, options = {}) {
|
77
|
-
|
78
|
-
|
79
|
-
|
80
|
-
|
81
|
-
super(new
|
87
|
+
if (options.strictGetMethodPluginEnabled ?? true) {
|
88
|
+
options.plugins ??= [];
|
89
|
+
options.plugins.push(new StrictGetMethodPlugin());
|
90
|
+
}
|
91
|
+
super(new StandardRPCHandler(router, options), options);
|
82
92
|
}
|
83
93
|
}
|
84
94
|
|
85
|
-
export { BodyLimitPlugin, NodeHttpHandler, RPCHandler };
|
95
|
+
export { BodyLimitPlugin, CompositeNodeHttpHandlerPlugin, NodeHttpHandler, RPCHandler };
|
@@ -1,10 +1,10 @@
|
|
1
|
-
import {
|
2
|
-
export {
|
1
|
+
import { c as StandardCodec, d as StandardParams, e as StandardMatcher, f as StandardMatchResult } from '../../shared/server.eWLxY3lq.mjs';
|
2
|
+
export { C as CompositeStandardHandlerPlugin, g as StandardHandleOptions, h as StandardHandleResult, i as StandardHandler, S as StandardHandlerInterceptorOptions, b as StandardHandlerOptions, a as StandardHandlerPlugin } from '../../shared/server.eWLxY3lq.mjs';
|
3
3
|
import { ORPCError, HTTPPath } from '@orpc/client';
|
4
4
|
import { StandardRPCSerializer } from '@orpc/client/standard';
|
5
5
|
import { StandardLazyRequest, StandardResponse } from '@orpc/standard-server';
|
6
|
-
import {
|
7
|
-
export { S as StandardRPCHandlerOptions } from '../../shared/server.
|
6
|
+
import { h as AnyProcedure, f as AnyRouter } from '../../shared/server.DPWk5pjW.mjs';
|
7
|
+
export { a as StandardRPCHandler, S as StandardRPCHandlerOptions } from '../../shared/server.BRoxSiSC.mjs';
|
8
8
|
import '@orpc/contract';
|
9
9
|
import '@orpc/shared';
|
10
10
|
|
@@ -1,10 +1,10 @@
|
|
1
|
-
import {
|
2
|
-
export {
|
1
|
+
import { c as StandardCodec, d as StandardParams, e as StandardMatcher, f as StandardMatchResult } from '../../shared/server.YZzrREz9.js';
|
2
|
+
export { C as CompositeStandardHandlerPlugin, g as StandardHandleOptions, h as StandardHandleResult, i as StandardHandler, S as StandardHandlerInterceptorOptions, b as StandardHandlerOptions, a as StandardHandlerPlugin } from '../../shared/server.YZzrREz9.js';
|
3
3
|
import { ORPCError, HTTPPath } from '@orpc/client';
|
4
4
|
import { StandardRPCSerializer } from '@orpc/client/standard';
|
5
5
|
import { StandardLazyRequest, StandardResponse } from '@orpc/standard-server';
|
6
|
-
import {
|
7
|
-
export { S as StandardRPCHandlerOptions } from '../../shared/server.
|
6
|
+
import { h as AnyProcedure, f as AnyRouter } from '../../shared/server.DPWk5pjW.js';
|
7
|
+
export { a as StandardRPCHandler, S as StandardRPCHandlerOptions } from '../../shared/server.Cy1vfSiG.js';
|
8
8
|
import '@orpc/contract';
|
9
9
|
import '@orpc/shared';
|
10
10
|
|
@@ -1,6 +1,6 @@
|
|
1
|
-
export { S as StandardHandler, a as StandardRPCCodec, b as StandardRPCMatcher } from '../../shared/server.
|
1
|
+
export { C as CompositeStandardHandlerPlugin, S as StandardHandler, a as StandardRPCCodec, b as StandardRPCHandler, c as StandardRPCMatcher } from '../../shared/server.SxlTJfG2.mjs';
|
2
|
+
import '@orpc/client/standard';
|
2
3
|
import '@orpc/client';
|
3
4
|
import '@orpc/shared';
|
4
|
-
import '../../shared/server.
|
5
|
+
import '../../shared/server.DG7Tamti.mjs';
|
5
6
|
import '@orpc/contract';
|
6
|
-
import '@orpc/client/standard';
|
@@ -0,0 +1,27 @@
|
|
1
|
+
import { MaybeOptionalOptions } from '@orpc/shared';
|
2
|
+
import { C as Context, R as Router } from '../../shared/server.DPWk5pjW.mjs';
|
3
|
+
import { i as StandardHandler } from '../../shared/server.eWLxY3lq.mjs';
|
4
|
+
import { F as FriendlyStandardHandleOptions } from '../../shared/server.QUe9N8P4.mjs';
|
5
|
+
import { S as StandardRPCHandlerOptions } from '../../shared/server.BRoxSiSC.mjs';
|
6
|
+
import '@orpc/client';
|
7
|
+
import '@orpc/contract';
|
8
|
+
import '@orpc/standard-server';
|
9
|
+
import '@orpc/client/standard';
|
10
|
+
|
11
|
+
declare class experimental_WebsocketHandler<T extends Context> {
|
12
|
+
private readonly standardHandler;
|
13
|
+
constructor(standardHandler: StandardHandler<T>);
|
14
|
+
upgrade(ws: Pick<WebSocket, 'addEventListener' | 'send'>, ...rest: MaybeOptionalOptions<Omit<FriendlyStandardHandleOptions<T>, 'prefix'>>): void;
|
15
|
+
}
|
16
|
+
|
17
|
+
/**
|
18
|
+
* RPC Handler for Websocket adapter
|
19
|
+
*
|
20
|
+
* @see {@link https://orpc.unnoq.com/docs/rpc-handler RPC Handler Docs}
|
21
|
+
* @see {@link https://orpc.unnoq.com/docs/adapters/websocket Websocket Adapter Docs}
|
22
|
+
*/
|
23
|
+
declare class experimental_RPCHandler<T extends Context> extends experimental_WebsocketHandler<T> {
|
24
|
+
constructor(router: Router<any, T>, options?: NoInfer<StandardRPCHandlerOptions<T>>);
|
25
|
+
}
|
26
|
+
|
27
|
+
export { experimental_RPCHandler, experimental_WebsocketHandler };
|
@@ -0,0 +1,27 @@
|
|
1
|
+
import { MaybeOptionalOptions } from '@orpc/shared';
|
2
|
+
import { C as Context, R as Router } from '../../shared/server.DPWk5pjW.js';
|
3
|
+
import { i as StandardHandler } from '../../shared/server.YZzrREz9.js';
|
4
|
+
import { F as FriendlyStandardHandleOptions } from '../../shared/server.BjiJH9Vo.js';
|
5
|
+
import { S as StandardRPCHandlerOptions } from '../../shared/server.Cy1vfSiG.js';
|
6
|
+
import '@orpc/client';
|
7
|
+
import '@orpc/contract';
|
8
|
+
import '@orpc/standard-server';
|
9
|
+
import '@orpc/client/standard';
|
10
|
+
|
11
|
+
declare class experimental_WebsocketHandler<T extends Context> {
|
12
|
+
private readonly standardHandler;
|
13
|
+
constructor(standardHandler: StandardHandler<T>);
|
14
|
+
upgrade(ws: Pick<WebSocket, 'addEventListener' | 'send'>, ...rest: MaybeOptionalOptions<Omit<FriendlyStandardHandleOptions<T>, 'prefix'>>): void;
|
15
|
+
}
|
16
|
+
|
17
|
+
/**
|
18
|
+
* RPC Handler for Websocket adapter
|
19
|
+
*
|
20
|
+
* @see {@link https://orpc.unnoq.com/docs/rpc-handler RPC Handler Docs}
|
21
|
+
* @see {@link https://orpc.unnoq.com/docs/adapters/websocket Websocket Adapter Docs}
|
22
|
+
*/
|
23
|
+
declare class experimental_RPCHandler<T extends Context> extends experimental_WebsocketHandler<T> {
|
24
|
+
constructor(router: Router<any, T>, options?: NoInfer<StandardRPCHandlerOptions<T>>);
|
25
|
+
}
|
26
|
+
|
27
|
+
export { experimental_RPCHandler, experimental_WebsocketHandler };
|
@@ -0,0 +1,37 @@
|
|
1
|
+
import { resolveMaybeOptionalOptions } from '@orpc/shared';
|
2
|
+
import { ServerPeer } from '@orpc/standard-server-peer';
|
3
|
+
import { r as resolveFriendlyStandardHandleOptions } from '../../shared/server.BVwwTHyO.mjs';
|
4
|
+
import '@orpc/client';
|
5
|
+
import '@orpc/contract';
|
6
|
+
import { b as StandardRPCHandler } from '../../shared/server.SxlTJfG2.mjs';
|
7
|
+
import '@orpc/client/standard';
|
8
|
+
import '../../shared/server.DG7Tamti.mjs';
|
9
|
+
|
10
|
+
class experimental_WebsocketHandler {
|
11
|
+
constructor(standardHandler) {
|
12
|
+
this.standardHandler = standardHandler;
|
13
|
+
}
|
14
|
+
upgrade(ws, ...rest) {
|
15
|
+
const peer = new ServerPeer(ws.send.bind(ws));
|
16
|
+
ws.addEventListener("message", async (event) => {
|
17
|
+
const [id, request] = await peer.message(event.data);
|
18
|
+
if (!request) {
|
19
|
+
return;
|
20
|
+
}
|
21
|
+
const options = resolveFriendlyStandardHandleOptions(resolveMaybeOptionalOptions(rest));
|
22
|
+
const { response } = await this.standardHandler.handle({ ...request, body: () => Promise.resolve(request.body) }, options);
|
23
|
+
await peer.response(id, response ?? { status: 404, headers: {}, body: "No procedure matched" });
|
24
|
+
});
|
25
|
+
ws.addEventListener("close", () => {
|
26
|
+
peer.close();
|
27
|
+
});
|
28
|
+
}
|
29
|
+
}
|
30
|
+
|
31
|
+
class experimental_RPCHandler extends experimental_WebsocketHandler {
|
32
|
+
constructor(router, options = {}) {
|
33
|
+
super(new StandardRPCHandler(router, options));
|
34
|
+
}
|
35
|
+
}
|
36
|
+
|
37
|
+
export { experimental_RPCHandler, experimental_WebsocketHandler };
|
@@ -0,0 +1,28 @@
|
|
1
|
+
import { MaybeOptionalOptions } from '@orpc/shared';
|
2
|
+
import { WebSocket } from 'ws';
|
3
|
+
import { C as Context, R as Router } from '../../shared/server.DPWk5pjW.mjs';
|
4
|
+
import { i as StandardHandler } from '../../shared/server.eWLxY3lq.mjs';
|
5
|
+
import { F as FriendlyStandardHandleOptions } from '../../shared/server.QUe9N8P4.mjs';
|
6
|
+
import { S as StandardRPCHandlerOptions } from '../../shared/server.BRoxSiSC.mjs';
|
7
|
+
import '@orpc/client';
|
8
|
+
import '@orpc/contract';
|
9
|
+
import '@orpc/standard-server';
|
10
|
+
import '@orpc/client/standard';
|
11
|
+
|
12
|
+
declare class experimental_WsHandler<T extends Context> {
|
13
|
+
private readonly standardHandler;
|
14
|
+
constructor(standardHandler: StandardHandler<T>);
|
15
|
+
upgrade(ws: Pick<WebSocket, 'addEventListener' | 'send'>, ...rest: MaybeOptionalOptions<Omit<FriendlyStandardHandleOptions<T>, 'prefix'>>): Promise<void>;
|
16
|
+
}
|
17
|
+
|
18
|
+
/**
|
19
|
+
* RPC Handler for ws (node ws) adapter
|
20
|
+
*
|
21
|
+
* @see {@link https://orpc.unnoq.com/docs/rpc-handler RPC Handler Docs}
|
22
|
+
* @see {@link https://orpc.unnoq.com/docs/adapters/websocket Websocket Adapter Docs}
|
23
|
+
*/
|
24
|
+
declare class experimental_RPCHandler<T extends Context> extends experimental_WsHandler<T> {
|
25
|
+
constructor(router: Router<any, T>, options?: NoInfer<StandardRPCHandlerOptions<T>>);
|
26
|
+
}
|
27
|
+
|
28
|
+
export { experimental_RPCHandler, experimental_WsHandler };
|
@@ -0,0 +1,28 @@
|
|
1
|
+
import { MaybeOptionalOptions } from '@orpc/shared';
|
2
|
+
import { WebSocket } from 'ws';
|
3
|
+
import { C as Context, R as Router } from '../../shared/server.DPWk5pjW.js';
|
4
|
+
import { i as StandardHandler } from '../../shared/server.YZzrREz9.js';
|
5
|
+
import { F as FriendlyStandardHandleOptions } from '../../shared/server.BjiJH9Vo.js';
|
6
|
+
import { S as StandardRPCHandlerOptions } from '../../shared/server.Cy1vfSiG.js';
|
7
|
+
import '@orpc/client';
|
8
|
+
import '@orpc/contract';
|
9
|
+
import '@orpc/standard-server';
|
10
|
+
import '@orpc/client/standard';
|
11
|
+
|
12
|
+
declare class experimental_WsHandler<T extends Context> {
|
13
|
+
private readonly standardHandler;
|
14
|
+
constructor(standardHandler: StandardHandler<T>);
|
15
|
+
upgrade(ws: Pick<WebSocket, 'addEventListener' | 'send'>, ...rest: MaybeOptionalOptions<Omit<FriendlyStandardHandleOptions<T>, 'prefix'>>): Promise<void>;
|
16
|
+
}
|
17
|
+
|
18
|
+
/**
|
19
|
+
* RPC Handler for ws (node ws) adapter
|
20
|
+
*
|
21
|
+
* @see {@link https://orpc.unnoq.com/docs/rpc-handler RPC Handler Docs}
|
22
|
+
* @see {@link https://orpc.unnoq.com/docs/adapters/websocket Websocket Adapter Docs}
|
23
|
+
*/
|
24
|
+
declare class experimental_RPCHandler<T extends Context> extends experimental_WsHandler<T> {
|
25
|
+
constructor(router: Router<any, T>, options?: NoInfer<StandardRPCHandlerOptions<T>>);
|
26
|
+
}
|
27
|
+
|
28
|
+
export { experimental_RPCHandler, experimental_WsHandler };
|
@@ -0,0 +1,37 @@
|
|
1
|
+
import { resolveMaybeOptionalOptions } from '@orpc/shared';
|
2
|
+
import { ServerPeer } from '@orpc/standard-server-peer';
|
3
|
+
import { r as resolveFriendlyStandardHandleOptions } from '../../shared/server.BVwwTHyO.mjs';
|
4
|
+
import '@orpc/client';
|
5
|
+
import '@orpc/contract';
|
6
|
+
import { b as StandardRPCHandler } from '../../shared/server.SxlTJfG2.mjs';
|
7
|
+
import '@orpc/client/standard';
|
8
|
+
import '../../shared/server.DG7Tamti.mjs';
|
9
|
+
|
10
|
+
class experimental_WsHandler {
|
11
|
+
constructor(standardHandler) {
|
12
|
+
this.standardHandler = standardHandler;
|
13
|
+
}
|
14
|
+
async upgrade(ws, ...rest) {
|
15
|
+
const peer = new ServerPeer(ws.send.bind(ws));
|
16
|
+
ws.addEventListener("message", async (event) => {
|
17
|
+
const [id, request] = await peer.message(new Blob(Array.isArray(event.data) ? event.data : [event.data]));
|
18
|
+
if (!request) {
|
19
|
+
return;
|
20
|
+
}
|
21
|
+
const options = resolveFriendlyStandardHandleOptions(resolveMaybeOptionalOptions(rest));
|
22
|
+
const { response } = await this.standardHandler.handle({ ...request, body: () => Promise.resolve(request.body) }, options);
|
23
|
+
await peer.response(id, response ?? { status: 404, headers: {}, body: "No procedure matched" });
|
24
|
+
});
|
25
|
+
ws.addEventListener("close", () => {
|
26
|
+
peer.close();
|
27
|
+
});
|
28
|
+
}
|
29
|
+
}
|
30
|
+
|
31
|
+
class experimental_RPCHandler extends experimental_WsHandler {
|
32
|
+
constructor(router, options = {}) {
|
33
|
+
super(new StandardRPCHandler(router, options));
|
34
|
+
}
|
35
|
+
}
|
36
|
+
|
37
|
+
export { experimental_RPCHandler, experimental_WsHandler };
|