@orpc/server 0.0.0-next.93e7a4c → 0.0.0-next.93fa264

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.
Files changed (80) hide show
  1. package/README.md +126 -0
  2. package/dist/adapters/aws-lambda/index.d.mts +45 -0
  3. package/dist/adapters/aws-lambda/index.d.ts +45 -0
  4. package/dist/adapters/aws-lambda/index.mjs +41 -0
  5. package/dist/adapters/bun-ws/index.d.mts +35 -0
  6. package/dist/adapters/bun-ws/index.d.ts +35 -0
  7. package/dist/adapters/bun-ws/index.mjs +46 -0
  8. package/dist/adapters/crossws/index.d.mts +30 -0
  9. package/dist/adapters/crossws/index.d.ts +30 -0
  10. package/dist/adapters/crossws/index.mjs +46 -0
  11. package/dist/adapters/fetch/index.d.mts +78 -0
  12. package/dist/adapters/fetch/index.d.ts +78 -0
  13. package/dist/adapters/fetch/index.mjs +110 -0
  14. package/dist/adapters/message-port/index.d.mts +28 -0
  15. package/dist/adapters/message-port/index.d.ts +28 -0
  16. package/dist/adapters/message-port/index.mjs +41 -0
  17. package/dist/adapters/node/index.d.mts +77 -0
  18. package/dist/adapters/node/index.d.ts +77 -0
  19. package/dist/adapters/node/index.mjs +95 -0
  20. package/dist/adapters/standard/index.d.mts +26 -0
  21. package/dist/adapters/standard/index.d.ts +26 -0
  22. package/dist/adapters/standard/index.mjs +7 -0
  23. package/dist/adapters/websocket/index.d.mts +51 -0
  24. package/dist/adapters/websocket/index.d.ts +51 -0
  25. package/dist/adapters/websocket/index.mjs +69 -0
  26. package/dist/adapters/ws/index.d.mts +28 -0
  27. package/dist/adapters/ws/index.d.ts +28 -0
  28. package/dist/adapters/ws/index.mjs +39 -0
  29. package/dist/hibernation/index.d.mts +44 -0
  30. package/dist/hibernation/index.d.ts +44 -0
  31. package/dist/hibernation/index.mjs +65 -0
  32. package/dist/index.d.mts +834 -0
  33. package/dist/index.d.ts +834 -0
  34. package/dist/index.mjs +488 -0
  35. package/dist/plugins/index.d.mts +156 -0
  36. package/dist/plugins/index.d.ts +156 -0
  37. package/dist/plugins/index.mjs +253 -0
  38. package/dist/shared/server.-ACo36I0.d.ts +74 -0
  39. package/dist/shared/server.BPAWobQg.d.ts +12 -0
  40. package/dist/shared/server.BW-nUGgA.mjs +36 -0
  41. package/dist/shared/server.Bd52nNaH.d.mts +12 -0
  42. package/dist/shared/server.BliFSTnG.d.mts +10 -0
  43. package/dist/shared/server.CHvOkcM3.mjs +186 -0
  44. package/dist/shared/server.DD2C4ujN.d.mts +192 -0
  45. package/dist/shared/server.DD2C4ujN.d.ts +192 -0
  46. package/dist/shared/server.DG7Tamti.mjs +367 -0
  47. package/dist/shared/server.DZ5BIITo.mjs +9 -0
  48. package/dist/shared/server.Dq8xr7PQ.d.mts +74 -0
  49. package/dist/shared/server.IG2MjhrD.d.ts +10 -0
  50. package/package.json +82 -15
  51. package/dist/chunk-FN62GL22.js +0 -182
  52. package/dist/fetch.js +0 -286
  53. package/dist/index.js +0 -518
  54. package/dist/src/builder.d.ts +0 -35
  55. package/dist/src/fetch/composite-handler.d.ts +0 -8
  56. package/dist/src/fetch/index.d.ts +0 -6
  57. package/dist/src/fetch/orpc-handler.d.ts +0 -20
  58. package/dist/src/fetch/orpc-payload-codec.d.ts +0 -9
  59. package/dist/src/fetch/orpc-procedure-matcher.d.ts +0 -12
  60. package/dist/src/fetch/super-json.d.ts +0 -12
  61. package/dist/src/fetch/types.d.ts +0 -16
  62. package/dist/src/hidden.d.ts +0 -6
  63. package/dist/src/implementer-chainable.d.ts +0 -10
  64. package/dist/src/index.d.ts +0 -23
  65. package/dist/src/lazy-decorated.d.ts +0 -10
  66. package/dist/src/lazy-utils.d.ts +0 -4
  67. package/dist/src/lazy.d.ts +0 -18
  68. package/dist/src/middleware-decorated.d.ts +0 -8
  69. package/dist/src/middleware.d.ts +0 -23
  70. package/dist/src/procedure-builder.d.ts +0 -22
  71. package/dist/src/procedure-client.d.ts +0 -29
  72. package/dist/src/procedure-decorated.d.ts +0 -14
  73. package/dist/src/procedure-implementer.d.ts +0 -18
  74. package/dist/src/procedure.d.ts +0 -23
  75. package/dist/src/router-builder.d.ts +0 -29
  76. package/dist/src/router-client.d.ts +0 -25
  77. package/dist/src/router-implementer.d.ts +0 -21
  78. package/dist/src/router.d.ts +0 -16
  79. package/dist/src/types.d.ts +0 -12
  80. package/dist/src/utils.d.ts +0 -3
@@ -0,0 +1,110 @@
1
+ import { ORPCError } from '@orpc/client';
2
+ import { toArray, intercept, resolveMaybeOptionalOptions } from '@orpc/shared';
3
+ import { toStandardLazyRequest, toFetchResponse } from '@orpc/standard-server-fetch';
4
+ import { r as resolveFriendlyStandardHandleOptions } from '../../shared/server.DZ5BIITo.mjs';
5
+ import '@orpc/standard-server';
6
+ import '@orpc/contract';
7
+ import { C as CompositeStandardHandlerPlugin, b as StandardRPCHandler } from '../../shared/server.CHvOkcM3.mjs';
8
+ import '@orpc/client/standard';
9
+ import '@orpc/standard-server/batch';
10
+ import { S as StrictGetMethodPlugin } from '../../shared/server.BW-nUGgA.mjs';
11
+ import '../../shared/server.DG7Tamti.mjs';
12
+
13
+ class BodyLimitPlugin {
14
+ maxBodySize;
15
+ constructor(options) {
16
+ this.maxBodySize = options.maxBodySize;
17
+ }
18
+ initRuntimeAdapter(options) {
19
+ options.adapterInterceptors ??= [];
20
+ options.adapterInterceptors.push(async (options2) => {
21
+ if (!options2.request.body) {
22
+ return options2.next();
23
+ }
24
+ let currentBodySize = 0;
25
+ const rawReader = options2.request.body.getReader();
26
+ const reader = new ReadableStream({
27
+ start: async (controller) => {
28
+ try {
29
+ if (Number(options2.request.headers.get("content-length")) > this.maxBodySize) {
30
+ controller.error(new ORPCError("PAYLOAD_TOO_LARGE"));
31
+ return;
32
+ }
33
+ while (true) {
34
+ const { done, value } = await rawReader.read();
35
+ if (done) {
36
+ break;
37
+ }
38
+ currentBodySize += value.length;
39
+ if (currentBodySize > this.maxBodySize) {
40
+ controller.error(new ORPCError("PAYLOAD_TOO_LARGE"));
41
+ break;
42
+ }
43
+ controller.enqueue(value);
44
+ }
45
+ } finally {
46
+ controller.close();
47
+ }
48
+ }
49
+ });
50
+ const requestInit = { body: reader, duplex: "half" };
51
+ return options2.next({
52
+ ...options2,
53
+ request: new Request(options2.request, requestInit)
54
+ });
55
+ });
56
+ }
57
+ }
58
+
59
+ class CompositeFetchHandlerPlugin extends CompositeStandardHandlerPlugin {
60
+ initRuntimeAdapter(options) {
61
+ for (const plugin of this.plugins) {
62
+ plugin.initRuntimeAdapter?.(options);
63
+ }
64
+ }
65
+ }
66
+
67
+ class FetchHandler {
68
+ constructor(standardHandler, options = {}) {
69
+ this.standardHandler = standardHandler;
70
+ const plugin = new CompositeFetchHandlerPlugin(options.plugins);
71
+ plugin.initRuntimeAdapter(options);
72
+ this.adapterInterceptors = toArray(options.adapterInterceptors);
73
+ this.toFetchResponseOptions = options;
74
+ }
75
+ toFetchResponseOptions;
76
+ adapterInterceptors;
77
+ async handle(request, ...rest) {
78
+ return intercept(
79
+ this.adapterInterceptors,
80
+ {
81
+ ...resolveFriendlyStandardHandleOptions(resolveMaybeOptionalOptions(rest)),
82
+ request,
83
+ toFetchResponseOptions: this.toFetchResponseOptions
84
+ },
85
+ async ({ request: request2, toFetchResponseOptions, ...options }) => {
86
+ const standardRequest = toStandardLazyRequest(request2);
87
+ const result = await this.standardHandler.handle(standardRequest, options);
88
+ if (!result.matched) {
89
+ return result;
90
+ }
91
+ return {
92
+ matched: true,
93
+ response: toFetchResponse(result.response, toFetchResponseOptions)
94
+ };
95
+ }
96
+ );
97
+ }
98
+ }
99
+
100
+ class RPCHandler extends FetchHandler {
101
+ constructor(router, options = {}) {
102
+ if (options.strictGetMethodPluginEnabled ?? true) {
103
+ options.plugins ??= [];
104
+ options.plugins.push(new StrictGetMethodPlugin());
105
+ }
106
+ super(new StandardRPCHandler(router, options), options);
107
+ }
108
+ }
109
+
110
+ export { BodyLimitPlugin, CompositeFetchHandlerPlugin, FetchHandler, RPCHandler };
@@ -0,0 +1,28 @@
1
+ import { SupportedMessagePort } from '@orpc/client/message-port';
2
+ import { MaybeOptionalOptions } from '@orpc/shared';
3
+ import { C as Context, R as Router } from '../../shared/server.DD2C4ujN.mjs';
4
+ import { i as StandardHandler } from '../../shared/server.Dq8xr7PQ.mjs';
5
+ import { F as FriendlyStandardHandleOptions } from '../../shared/server.BliFSTnG.mjs';
6
+ import { S as StandardRPCHandlerOptions } from '../../shared/server.Bd52nNaH.mjs';
7
+ import '@orpc/client';
8
+ import '@orpc/contract';
9
+ import '@orpc/standard-server';
10
+ import '@orpc/client/standard';
11
+
12
+ declare class experimental_MessagePortHandler<T extends Context> {
13
+ private readonly standardHandler;
14
+ constructor(standardHandler: StandardHandler<T>);
15
+ upgrade(port: SupportedMessagePort, ...rest: MaybeOptionalOptions<Omit<FriendlyStandardHandleOptions<T>, 'prefix'>>): void;
16
+ }
17
+
18
+ /**
19
+ * RPC Handler for common message port implementations.
20
+ *
21
+ * @see {@link https://orpc.unnoq.com/docs/rpc-handler RPC Handler Docs}
22
+ * @see {@link https://orpc.unnoq.com/docs/adapters/message-port Message Port Adapter Docs}
23
+ */
24
+ declare class experimental_RPCHandler<T extends Context> extends experimental_MessagePortHandler<T> {
25
+ constructor(router: Router<any, T>, options?: NoInfer<StandardRPCHandlerOptions<T>>);
26
+ }
27
+
28
+ export { experimental_MessagePortHandler, experimental_RPCHandler };
@@ -0,0 +1,28 @@
1
+ import { SupportedMessagePort } from '@orpc/client/message-port';
2
+ import { MaybeOptionalOptions } from '@orpc/shared';
3
+ import { C as Context, R as Router } from '../../shared/server.DD2C4ujN.js';
4
+ import { i as StandardHandler } from '../../shared/server.-ACo36I0.js';
5
+ import { F as FriendlyStandardHandleOptions } from '../../shared/server.IG2MjhrD.js';
6
+ import { S as StandardRPCHandlerOptions } from '../../shared/server.BPAWobQg.js';
7
+ import '@orpc/client';
8
+ import '@orpc/contract';
9
+ import '@orpc/standard-server';
10
+ import '@orpc/client/standard';
11
+
12
+ declare class experimental_MessagePortHandler<T extends Context> {
13
+ private readonly standardHandler;
14
+ constructor(standardHandler: StandardHandler<T>);
15
+ upgrade(port: SupportedMessagePort, ...rest: MaybeOptionalOptions<Omit<FriendlyStandardHandleOptions<T>, 'prefix'>>): void;
16
+ }
17
+
18
+ /**
19
+ * RPC Handler for common message port implementations.
20
+ *
21
+ * @see {@link https://orpc.unnoq.com/docs/rpc-handler RPC Handler Docs}
22
+ * @see {@link https://orpc.unnoq.com/docs/adapters/message-port Message Port Adapter Docs}
23
+ */
24
+ declare class experimental_RPCHandler<T extends Context> extends experimental_MessagePortHandler<T> {
25
+ constructor(router: Router<any, T>, options?: NoInfer<StandardRPCHandlerOptions<T>>);
26
+ }
27
+
28
+ export { experimental_MessagePortHandler, experimental_RPCHandler };
@@ -0,0 +1,41 @@
1
+ import { postMessagePortMessage, onMessagePortMessage, onMessagePortClose } from '@orpc/client/message-port';
2
+ import { resolveMaybeOptionalOptions } from '@orpc/shared';
3
+ import { ServerPeer } from '@orpc/standard-server-peer';
4
+ import { r as resolveFriendlyStandardHandleOptions } from '../../shared/server.DZ5BIITo.mjs';
5
+ import '@orpc/client';
6
+ import '@orpc/standard-server';
7
+ import '@orpc/contract';
8
+ import { b as StandardRPCHandler } from '../../shared/server.CHvOkcM3.mjs';
9
+ import '@orpc/client/standard';
10
+ import '../../shared/server.DG7Tamti.mjs';
11
+
12
+ class experimental_MessagePortHandler {
13
+ constructor(standardHandler) {
14
+ this.standardHandler = standardHandler;
15
+ }
16
+ upgrade(port, ...rest) {
17
+ const peer = new ServerPeer((message) => {
18
+ return postMessagePortMessage(port, message);
19
+ });
20
+ onMessagePortMessage(port, async (message) => {
21
+ const [id, request] = await peer.message(message);
22
+ if (!request) {
23
+ return;
24
+ }
25
+ const options = resolveFriendlyStandardHandleOptions(resolveMaybeOptionalOptions(rest));
26
+ const { response } = await this.standardHandler.handle({ ...request, body: () => Promise.resolve(request.body) }, options);
27
+ await peer.response(id, response ?? { status: 404, headers: {}, body: "No procedure matched" });
28
+ });
29
+ onMessagePortClose(port, () => {
30
+ peer.close();
31
+ });
32
+ }
33
+ }
34
+
35
+ class experimental_RPCHandler extends experimental_MessagePortHandler {
36
+ constructor(router, options = {}) {
37
+ super(new StandardRPCHandler(router, options));
38
+ }
39
+ }
40
+
41
+ export { experimental_MessagePortHandler, experimental_RPCHandler };
@@ -0,0 +1,77 @@
1
+ import { C as Context, R as Router } from '../../shared/server.DD2C4ujN.mjs';
2
+ import { Interceptor, MaybeOptionalOptions } from '@orpc/shared';
3
+ import { SendStandardResponseOptions, NodeHttpRequest, NodeHttpResponse } from '@orpc/standard-server-node';
4
+ import { a as StandardHandlerPlugin, C as CompositeStandardHandlerPlugin, g as StandardHandleOptions, i as StandardHandler } from '../../shared/server.Dq8xr7PQ.mjs';
5
+ import { F as FriendlyStandardHandleOptions } from '../../shared/server.BliFSTnG.mjs';
6
+ import { S as StandardRPCHandlerOptions } from '../../shared/server.Bd52nNaH.mjs';
7
+ import '@orpc/client';
8
+ import '@orpc/contract';
9
+ import '@orpc/standard-server';
10
+ import '@orpc/client/standard';
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
+
19
+ type NodeHttpHandleResult = {
20
+ matched: true;
21
+ } | {
22
+ matched: false;
23
+ };
24
+ interface NodeHttpHandlerInterceptorOptions<T extends Context> extends StandardHandleOptions<T> {
25
+ request: NodeHttpRequest;
26
+ response: NodeHttpResponse;
27
+ sendStandardResponseOptions: SendStandardResponseOptions;
28
+ }
29
+ interface NodeHttpHandlerOptions<T extends Context> extends SendStandardResponseOptions {
30
+ adapterInterceptors?: Interceptor<NodeHttpHandlerInterceptorOptions<T>, Promise<NodeHttpHandleResult>>[];
31
+ plugins?: NodeHttpHandlerPlugin<T>[];
32
+ }
33
+ declare class NodeHttpHandler<T extends Context> implements NodeHttpHandler<T> {
34
+ private readonly standardHandler;
35
+ private readonly sendStandardResponseOptions;
36
+ private readonly adapterInterceptors;
37
+ constructor(standardHandler: StandardHandler<T>, options?: NoInfer<NodeHttpHandlerOptions<T>>);
38
+ handle(request: NodeHttpRequest, response: NodeHttpResponse, ...rest: MaybeOptionalOptions<FriendlyStandardHandleOptions<T>>): Promise<NodeHttpHandleResult>;
39
+ }
40
+
41
+ interface BodyLimitPluginOptions {
42
+ /**
43
+ * The maximum size of the body in bytes.
44
+ */
45
+ maxBodySize: number;
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
+ */
52
+ declare class BodyLimitPlugin<T extends Context> implements NodeHttpHandlerPlugin<T> {
53
+ private readonly maxBodySize;
54
+ constructor(options: BodyLimitPluginOptions);
55
+ initRuntimeAdapter(options: NodeHttpHandlerOptions<T>): void;
56
+ }
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
+ */
72
+ declare class RPCHandler<T extends Context> extends NodeHttpHandler<T> {
73
+ constructor(router: Router<any, T>, options?: NoInfer<RPCHandlerOptions<T>>);
74
+ }
75
+
76
+ export { BodyLimitPlugin, CompositeNodeHttpHandlerPlugin, NodeHttpHandler, RPCHandler };
77
+ export type { BodyLimitPluginOptions, NodeHttpHandleResult, NodeHttpHandlerInterceptorOptions, NodeHttpHandlerOptions, NodeHttpHandlerPlugin, RPCHandlerOptions };
@@ -0,0 +1,77 @@
1
+ import { C as Context, R as Router } from '../../shared/server.DD2C4ujN.js';
2
+ import { Interceptor, MaybeOptionalOptions } from '@orpc/shared';
3
+ import { SendStandardResponseOptions, NodeHttpRequest, NodeHttpResponse } from '@orpc/standard-server-node';
4
+ import { a as StandardHandlerPlugin, C as CompositeStandardHandlerPlugin, g as StandardHandleOptions, i as StandardHandler } from '../../shared/server.-ACo36I0.js';
5
+ import { F as FriendlyStandardHandleOptions } from '../../shared/server.IG2MjhrD.js';
6
+ import { S as StandardRPCHandlerOptions } from '../../shared/server.BPAWobQg.js';
7
+ import '@orpc/client';
8
+ import '@orpc/contract';
9
+ import '@orpc/standard-server';
10
+ import '@orpc/client/standard';
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
+
19
+ type NodeHttpHandleResult = {
20
+ matched: true;
21
+ } | {
22
+ matched: false;
23
+ };
24
+ interface NodeHttpHandlerInterceptorOptions<T extends Context> extends StandardHandleOptions<T> {
25
+ request: NodeHttpRequest;
26
+ response: NodeHttpResponse;
27
+ sendStandardResponseOptions: SendStandardResponseOptions;
28
+ }
29
+ interface NodeHttpHandlerOptions<T extends Context> extends SendStandardResponseOptions {
30
+ adapterInterceptors?: Interceptor<NodeHttpHandlerInterceptorOptions<T>, Promise<NodeHttpHandleResult>>[];
31
+ plugins?: NodeHttpHandlerPlugin<T>[];
32
+ }
33
+ declare class NodeHttpHandler<T extends Context> implements NodeHttpHandler<T> {
34
+ private readonly standardHandler;
35
+ private readonly sendStandardResponseOptions;
36
+ private readonly adapterInterceptors;
37
+ constructor(standardHandler: StandardHandler<T>, options?: NoInfer<NodeHttpHandlerOptions<T>>);
38
+ handle(request: NodeHttpRequest, response: NodeHttpResponse, ...rest: MaybeOptionalOptions<FriendlyStandardHandleOptions<T>>): Promise<NodeHttpHandleResult>;
39
+ }
40
+
41
+ interface BodyLimitPluginOptions {
42
+ /**
43
+ * The maximum size of the body in bytes.
44
+ */
45
+ maxBodySize: number;
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
+ */
52
+ declare class BodyLimitPlugin<T extends Context> implements NodeHttpHandlerPlugin<T> {
53
+ private readonly maxBodySize;
54
+ constructor(options: BodyLimitPluginOptions);
55
+ initRuntimeAdapter(options: NodeHttpHandlerOptions<T>): void;
56
+ }
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
+ */
72
+ declare class RPCHandler<T extends Context> extends NodeHttpHandler<T> {
73
+ constructor(router: Router<any, T>, options?: NoInfer<RPCHandlerOptions<T>>);
74
+ }
75
+
76
+ export { BodyLimitPlugin, CompositeNodeHttpHandlerPlugin, NodeHttpHandler, RPCHandler };
77
+ export type { BodyLimitPluginOptions, NodeHttpHandleResult, NodeHttpHandlerInterceptorOptions, NodeHttpHandlerOptions, NodeHttpHandlerPlugin, RPCHandlerOptions };
@@ -0,0 +1,95 @@
1
+ import { ORPCError } from '@orpc/client';
2
+ import { toArray, intercept, resolveMaybeOptionalOptions } from '@orpc/shared';
3
+ import { toStandardLazyRequest, sendStandardResponse } from '@orpc/standard-server-node';
4
+ import { r as resolveFriendlyStandardHandleOptions } from '../../shared/server.DZ5BIITo.mjs';
5
+ import '@orpc/standard-server';
6
+ import '@orpc/contract';
7
+ import { C as CompositeStandardHandlerPlugin, b as StandardRPCHandler } from '../../shared/server.CHvOkcM3.mjs';
8
+ import '@orpc/client/standard';
9
+ import '@orpc/standard-server/batch';
10
+ import { S as StrictGetMethodPlugin } from '../../shared/server.BW-nUGgA.mjs';
11
+ import '../../shared/server.DG7Tamti.mjs';
12
+
13
+ class BodyLimitPlugin {
14
+ maxBodySize;
15
+ constructor(options) {
16
+ this.maxBodySize = options.maxBodySize;
17
+ }
18
+ initRuntimeAdapter(options) {
19
+ options.adapterInterceptors ??= [];
20
+ options.adapterInterceptors.push(async (options2) => {
21
+ let isHeaderChecked = false;
22
+ const checkHeader = () => {
23
+ if (!isHeaderChecked && Number(options2.request.headers["content-length"]) > this.maxBodySize) {
24
+ throw new ORPCError("PAYLOAD_TOO_LARGE");
25
+ }
26
+ isHeaderChecked = true;
27
+ };
28
+ const originalEmit = options2.request.emit.bind(options2.request);
29
+ let currentBodySize = 0;
30
+ options2.request.emit = (event, ...args) => {
31
+ if (event === "data") {
32
+ checkHeader();
33
+ currentBodySize += args[0].length;
34
+ if (currentBodySize > this.maxBodySize) {
35
+ throw new ORPCError("PAYLOAD_TOO_LARGE");
36
+ }
37
+ }
38
+ return originalEmit(event, ...args);
39
+ };
40
+ return options2.next();
41
+ });
42
+ }
43
+ }
44
+
45
+ class CompositeNodeHttpHandlerPlugin extends CompositeStandardHandlerPlugin {
46
+ initRuntimeAdapter(options) {
47
+ for (const plugin of this.plugins) {
48
+ plugin.initRuntimeAdapter?.(options);
49
+ }
50
+ }
51
+ }
52
+
53
+ class NodeHttpHandler {
54
+ constructor(standardHandler, options = {}) {
55
+ this.standardHandler = standardHandler;
56
+ const plugin = new CompositeNodeHttpHandlerPlugin(options.plugins);
57
+ plugin.initRuntimeAdapter(options);
58
+ this.adapterInterceptors = toArray(options.adapterInterceptors);
59
+ this.sendStandardResponseOptions = options;
60
+ }
61
+ sendStandardResponseOptions;
62
+ adapterInterceptors;
63
+ async handle(request, response, ...rest) {
64
+ return intercept(
65
+ this.adapterInterceptors,
66
+ {
67
+ ...resolveFriendlyStandardHandleOptions(resolveMaybeOptionalOptions(rest)),
68
+ request,
69
+ response,
70
+ sendStandardResponseOptions: this.sendStandardResponseOptions
71
+ },
72
+ async ({ request: request2, response: response2, sendStandardResponseOptions, ...options }) => {
73
+ const standardRequest = toStandardLazyRequest(request2, response2);
74
+ const result = await this.standardHandler.handle(standardRequest, options);
75
+ if (!result.matched) {
76
+ return { matched: false };
77
+ }
78
+ await sendStandardResponse(response2, result.response, sendStandardResponseOptions);
79
+ return { matched: true };
80
+ }
81
+ );
82
+ }
83
+ }
84
+
85
+ class RPCHandler extends NodeHttpHandler {
86
+ constructor(router, options = {}) {
87
+ if (options.strictGetMethodPluginEnabled ?? true) {
88
+ options.plugins ??= [];
89
+ options.plugins.push(new StrictGetMethodPlugin());
90
+ }
91
+ super(new StandardRPCHandler(router, options), options);
92
+ }
93
+ }
94
+
95
+ export { BodyLimitPlugin, CompositeNodeHttpHandlerPlugin, NodeHttpHandler, RPCHandler };
@@ -0,0 +1,26 @@
1
+ import { c as StandardCodec, d as StandardParams, e as StandardMatcher, f as StandardMatchResult } from '../../shared/server.Dq8xr7PQ.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.Dq8xr7PQ.mjs';
3
+ import { ORPCError, HTTPPath } from '@orpc/client';
4
+ import { StandardRPCSerializer } from '@orpc/client/standard';
5
+ import { StandardLazyRequest, StandardResponse } from '@orpc/standard-server';
6
+ import { h as AnyProcedure, f as AnyRouter } from '../../shared/server.DD2C4ujN.mjs';
7
+ export { a as StandardRPCHandler, S as StandardRPCHandlerOptions } from '../../shared/server.Bd52nNaH.mjs';
8
+ import '@orpc/contract';
9
+ import '@orpc/shared';
10
+
11
+ declare class StandardRPCCodec implements StandardCodec {
12
+ private readonly serializer;
13
+ constructor(serializer: StandardRPCSerializer);
14
+ decode(request: StandardLazyRequest, _params: StandardParams | undefined, _procedure: AnyProcedure): Promise<unknown>;
15
+ encode(output: unknown, _procedure: AnyProcedure): StandardResponse;
16
+ encodeError(error: ORPCError<any, any>): StandardResponse;
17
+ }
18
+
19
+ declare class StandardRPCMatcher implements StandardMatcher {
20
+ private readonly tree;
21
+ private pendingRouters;
22
+ init(router: AnyRouter, path?: readonly string[]): void;
23
+ match(_method: string, pathname: HTTPPath): Promise<StandardMatchResult>;
24
+ }
25
+
26
+ export { StandardCodec, StandardMatchResult, StandardMatcher, StandardParams, StandardRPCCodec, StandardRPCMatcher };
@@ -0,0 +1,26 @@
1
+ import { c as StandardCodec, d as StandardParams, e as StandardMatcher, f as StandardMatchResult } from '../../shared/server.-ACo36I0.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.-ACo36I0.js';
3
+ import { ORPCError, HTTPPath } from '@orpc/client';
4
+ import { StandardRPCSerializer } from '@orpc/client/standard';
5
+ import { StandardLazyRequest, StandardResponse } from '@orpc/standard-server';
6
+ import { h as AnyProcedure, f as AnyRouter } from '../../shared/server.DD2C4ujN.js';
7
+ export { a as StandardRPCHandler, S as StandardRPCHandlerOptions } from '../../shared/server.BPAWobQg.js';
8
+ import '@orpc/contract';
9
+ import '@orpc/shared';
10
+
11
+ declare class StandardRPCCodec implements StandardCodec {
12
+ private readonly serializer;
13
+ constructor(serializer: StandardRPCSerializer);
14
+ decode(request: StandardLazyRequest, _params: StandardParams | undefined, _procedure: AnyProcedure): Promise<unknown>;
15
+ encode(output: unknown, _procedure: AnyProcedure): StandardResponse;
16
+ encodeError(error: ORPCError<any, any>): StandardResponse;
17
+ }
18
+
19
+ declare class StandardRPCMatcher implements StandardMatcher {
20
+ private readonly tree;
21
+ private pendingRouters;
22
+ init(router: AnyRouter, path?: readonly string[]): void;
23
+ match(_method: string, pathname: HTTPPath): Promise<StandardMatchResult>;
24
+ }
25
+
26
+ export { StandardCodec, StandardMatchResult, StandardMatcher, StandardParams, StandardRPCCodec, StandardRPCMatcher };
@@ -0,0 +1,7 @@
1
+ export { C as CompositeStandardHandlerPlugin, S as StandardHandler, a as StandardRPCCodec, b as StandardRPCHandler, c as StandardRPCMatcher } from '../../shared/server.CHvOkcM3.mjs';
2
+ import '@orpc/client/standard';
3
+ import '@orpc/client';
4
+ import '@orpc/shared';
5
+ import '@orpc/standard-server';
6
+ import '../../shared/server.DG7Tamti.mjs';
7
+ import '@orpc/contract';
@@ -0,0 +1,51 @@
1
+ import { MaybeOptionalOptions } from '@orpc/shared';
2
+ import { C as Context, R as Router } from '../../shared/server.DD2C4ujN.mjs';
3
+ import { i as StandardHandler } from '../../shared/server.Dq8xr7PQ.mjs';
4
+ import { F as FriendlyStandardHandleOptions } from '../../shared/server.BliFSTnG.mjs';
5
+ import { S as StandardRPCHandlerOptions } from '../../shared/server.Bd52nNaH.mjs';
6
+ import '@orpc/client';
7
+ import '@orpc/contract';
8
+ import '@orpc/standard-server';
9
+ import '@orpc/client/standard';
10
+
11
+ type experimental_MinimalWebsocket = Pick<WebSocket, 'addEventListener' | 'send'>;
12
+ declare class experimental_WebsocketHandler<T extends Context> {
13
+ #private;
14
+ constructor(standardHandler: StandardHandler<T>);
15
+ /**
16
+ * Upgrades a WebSocket to enable handling
17
+ *
18
+ * This attaches the necessary 'message' and 'close' listeners to the WebSocket
19
+ *
20
+ * @warning Do not use this method if you're using `.message()` or `.close()`
21
+ */
22
+ upgrade(ws: experimental_MinimalWebsocket, ...rest: MaybeOptionalOptions<Omit<FriendlyStandardHandleOptions<T>, 'prefix'>>): void;
23
+ /**
24
+ * Handles a single message received from a WebSocket.
25
+ *
26
+ * @warning Avoid calling this directly if `.upgrade()` is used.
27
+ *
28
+ * @param ws The WebSocket instance
29
+ * @param data The message payload, usually place in `event.data`
30
+ */
31
+ message(ws: experimental_MinimalWebsocket, data: string | ArrayBuffer | Blob, ...rest: MaybeOptionalOptions<Omit<FriendlyStandardHandleOptions<T>, 'prefix'>>): Promise<void>;
32
+ /**
33
+ * Closes the WebSocket peer and cleans up.
34
+ *
35
+ * @warning Avoid calling this directly if `.upgrade()` is used.
36
+ */
37
+ close(ws: experimental_MinimalWebsocket): void;
38
+ }
39
+
40
+ /**
41
+ * RPC Handler for Websocket adapter
42
+ *
43
+ * @see {@link https://orpc.unnoq.com/docs/rpc-handler RPC Handler Docs}
44
+ * @see {@link https://orpc.unnoq.com/docs/adapters/websocket Websocket Adapter Docs}
45
+ */
46
+ declare class experimental_RPCHandler<T extends Context> extends experimental_WebsocketHandler<T> {
47
+ constructor(router: Router<any, T>, options?: NoInfer<StandardRPCHandlerOptions<T>>);
48
+ }
49
+
50
+ export { experimental_RPCHandler, experimental_WebsocketHandler };
51
+ export type { experimental_MinimalWebsocket };
@@ -0,0 +1,51 @@
1
+ import { MaybeOptionalOptions } from '@orpc/shared';
2
+ import { C as Context, R as Router } from '../../shared/server.DD2C4ujN.js';
3
+ import { i as StandardHandler } from '../../shared/server.-ACo36I0.js';
4
+ import { F as FriendlyStandardHandleOptions } from '../../shared/server.IG2MjhrD.js';
5
+ import { S as StandardRPCHandlerOptions } from '../../shared/server.BPAWobQg.js';
6
+ import '@orpc/client';
7
+ import '@orpc/contract';
8
+ import '@orpc/standard-server';
9
+ import '@orpc/client/standard';
10
+
11
+ type experimental_MinimalWebsocket = Pick<WebSocket, 'addEventListener' | 'send'>;
12
+ declare class experimental_WebsocketHandler<T extends Context> {
13
+ #private;
14
+ constructor(standardHandler: StandardHandler<T>);
15
+ /**
16
+ * Upgrades a WebSocket to enable handling
17
+ *
18
+ * This attaches the necessary 'message' and 'close' listeners to the WebSocket
19
+ *
20
+ * @warning Do not use this method if you're using `.message()` or `.close()`
21
+ */
22
+ upgrade(ws: experimental_MinimalWebsocket, ...rest: MaybeOptionalOptions<Omit<FriendlyStandardHandleOptions<T>, 'prefix'>>): void;
23
+ /**
24
+ * Handles a single message received from a WebSocket.
25
+ *
26
+ * @warning Avoid calling this directly if `.upgrade()` is used.
27
+ *
28
+ * @param ws The WebSocket instance
29
+ * @param data The message payload, usually place in `event.data`
30
+ */
31
+ message(ws: experimental_MinimalWebsocket, data: string | ArrayBuffer | Blob, ...rest: MaybeOptionalOptions<Omit<FriendlyStandardHandleOptions<T>, 'prefix'>>): Promise<void>;
32
+ /**
33
+ * Closes the WebSocket peer and cleans up.
34
+ *
35
+ * @warning Avoid calling this directly if `.upgrade()` is used.
36
+ */
37
+ close(ws: experimental_MinimalWebsocket): void;
38
+ }
39
+
40
+ /**
41
+ * RPC Handler for Websocket adapter
42
+ *
43
+ * @see {@link https://orpc.unnoq.com/docs/rpc-handler RPC Handler Docs}
44
+ * @see {@link https://orpc.unnoq.com/docs/adapters/websocket Websocket Adapter Docs}
45
+ */
46
+ declare class experimental_RPCHandler<T extends Context> extends experimental_WebsocketHandler<T> {
47
+ constructor(router: Router<any, T>, options?: NoInfer<StandardRPCHandlerOptions<T>>);
48
+ }
49
+
50
+ export { experimental_RPCHandler, experimental_WebsocketHandler };
51
+ export type { experimental_MinimalWebsocket };