@orpc/server 0.0.0-next.eae6003 → 0.0.0-next.eaf61c7

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 (48) hide show
  1. package/README.md +4 -6
  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 +4 -4
  6. package/dist/adapters/bun-ws/index.d.ts +4 -4
  7. package/dist/adapters/bun-ws/index.mjs +4 -9
  8. package/dist/adapters/crossws/index.d.mts +4 -4
  9. package/dist/adapters/crossws/index.d.ts +4 -4
  10. package/dist/adapters/crossws/index.mjs +4 -9
  11. package/dist/adapters/fetch/index.d.mts +6 -6
  12. package/dist/adapters/fetch/index.d.ts +6 -6
  13. package/dist/adapters/fetch/index.mjs +2 -2
  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 +6 -6
  18. package/dist/adapters/node/index.d.ts +6 -6
  19. package/dist/adapters/node/index.mjs +2 -2
  20. package/dist/adapters/standard/index.d.mts +4 -4
  21. package/dist/adapters/standard/index.d.ts +4 -4
  22. package/dist/adapters/standard/index.mjs +1 -1
  23. package/dist/adapters/websocket/index.d.mts +30 -6
  24. package/dist/adapters/websocket/index.d.ts +30 -6
  25. package/dist/adapters/websocket/index.mjs +46 -15
  26. package/dist/adapters/ws/index.d.mts +4 -4
  27. package/dist/adapters/ws/index.d.ts +4 -4
  28. package/dist/adapters/ws/index.mjs +4 -3
  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 +10 -5
  33. package/dist/index.d.ts +10 -5
  34. package/dist/index.mjs +21 -7
  35. package/dist/plugins/index.d.mts +13 -13
  36. package/dist/plugins/index.d.ts +13 -13
  37. package/dist/plugins/index.mjs +5 -3
  38. package/dist/shared/{server.YZzrREz9.d.ts → server.-ACo36I0.d.ts} +6 -6
  39. package/dist/shared/{server.Cy1vfSiG.d.ts → server.BPAWobQg.d.ts} +2 -2
  40. package/dist/shared/{server.BRoxSiSC.d.mts → server.Bd52nNaH.d.mts} +2 -2
  41. package/dist/shared/{server.QUe9N8P4.d.mts → server.BliFSTnG.d.mts} +2 -2
  42. package/dist/shared/{server.4FnxLwwr.mjs → server.CHvOkcM3.mjs} +2 -2
  43. package/dist/shared/{server.DPWk5pjW.d.mts → server.DD2C4ujN.d.mts} +4 -4
  44. package/dist/shared/{server.DPWk5pjW.d.ts → server.DD2C4ujN.d.ts} +4 -4
  45. package/dist/shared/{server.BVwwTHyO.mjs → server.DZ5BIITo.mjs} +1 -1
  46. package/dist/shared/{server.eWLxY3lq.d.mts → server.Dq8xr7PQ.d.mts} +6 -6
  47. package/dist/shared/{server.BjiJH9Vo.d.ts → server.IG2MjhrD.d.ts} +2 -2
  48. package/package.json +25 -9
package/README.md CHANGED
@@ -49,14 +49,12 @@ You can find the full documentation [here](https://orpc.unnoq.com).
49
49
  - [@orpc/contract](https://www.npmjs.com/package/@orpc/contract): Build your API contract.
50
50
  - [@orpc/server](https://www.npmjs.com/package/@orpc/server): Build your API or implement API contract.
51
51
  - [@orpc/client](https://www.npmjs.com/package/@orpc/client): Consume your API on the client with type-safety.
52
- - [@orpc/nest](https://www.npmjs.com/package/@orpc/nest): Deeply integrate oRPC with NestJS.
52
+ - [@orpc/openapi](https://www.npmjs.com/package/@orpc/openapi): Generate OpenAPI specs and handle OpenAPI requests.
53
+ - [@orpc/nest](https://www.npmjs.com/package/@orpc/nest): Deeply integrate oRPC with [NestJS](https://nestjs.com/).
53
54
  - [@orpc/react](https://www.npmjs.com/package/@orpc/react): Utilities for integrating oRPC with React and React Server Actions.
54
- - [@orpc/react-query](https://www.npmjs.com/package/@orpc/react-query): Integration with [React Query](https://tanstack.com/query/latest/docs/framework/react/overview).
55
- - [@orpc/vue-query](https://www.npmjs.com/package/@orpc/vue-query): Integration with [Vue Query](https://tanstack.com/query/latest/docs/framework/vue/overview).
56
- - [@orpc/solid-query](https://www.npmjs.com/package/@orpc/solid-query): Integration with [Solid Query](https://tanstack.com/query/latest/docs/framework/solid/overview).
57
- - [@orpc/svelte-query](https://www.npmjs.com/package/@orpc/svelte-query): Integration with [Svelte Query](https://tanstack.com/query/latest/docs/framework/svelte/overview).
55
+ - [@orpc/tanstack-query](https://www.npmjs.com/package/@orpc/tanstack-query): [TanStack Query](https://tanstack.com/query/latest) integration.
58
56
  - [@orpc/vue-colada](https://www.npmjs.com/package/@orpc/vue-colada): Integration with [Pinia Colada](https://pinia-colada.esm.dev/).
59
- - [@orpc/openapi](https://www.npmjs.com/package/@orpc/openapi): Generate OpenAPI specs and handle OpenAPI requests.
57
+ - [@orpc/hey-api](https://www.npmjs.com/package/@orpc/hey-api): [Hey API](https://heyapi.dev/) integration.
60
58
  - [@orpc/zod](https://www.npmjs.com/package/@orpc/zod): More schemas that [Zod](https://zod.dev/) doesn't support yet.
61
59
  - [@orpc/valibot](https://www.npmjs.com/package/@orpc/valibot): OpenAPI spec generation from [Valibot](https://valibot.dev/).
62
60
  - [@orpc/arktype](https://www.npmjs.com/package/@orpc/arktype): OpenAPI spec generation from [ArkType](https://arktype.io/).
@@ -0,0 +1,45 @@
1
+ import { MaybeOptionalOptions } from '@orpc/shared';
2
+ import { SendStandardResponseOptions, APIGatewayProxyEventV2, ResponseStream } from '@orpc/standard-server-aws-lambda';
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
+ interface AwsLambdaHandlerOptions extends SendStandardResponseOptions {
13
+ }
14
+ type AwsLambdaHandleResult = {
15
+ matched: true;
16
+ } | {
17
+ matched: false;
18
+ };
19
+ declare class AwsLambdaHandler<T extends Context> {
20
+ private readonly standardHandler;
21
+ private readonly sendStandardResponseOptions;
22
+ constructor(standardHandler: StandardHandler<T>, options?: AwsLambdaHandlerOptions);
23
+ handle(event: APIGatewayProxyEventV2, responseStream: ResponseStream, ...rest: MaybeOptionalOptions<FriendlyStandardHandleOptions<T>>): Promise<AwsLambdaHandleResult>;
24
+ }
25
+
26
+ type RPCHandlerOptions<T extends Context> = AwsLambdaHandlerOptions & StandardRPCHandlerOptions<T> & {
27
+ /**
28
+ * Enables or disables the StrictGetMethodPlugin.
29
+ *
30
+ * @default true
31
+ */
32
+ strictGetMethodPluginEnabled?: boolean;
33
+ };
34
+ /**
35
+ * RPC Handler for AWS Lambda.
36
+ *
37
+ * @see {@link https://orpc.unnoq.com/docs/rpc-handler RPC Handler Docs}
38
+ * @see {@link https://orpc.unnoq.com/docs/adapters/http HTTP Adapter Docs}
39
+ */
40
+ declare class experimental_RPCHandler<T extends Context> extends AwsLambdaHandler<T> {
41
+ constructor(router: Router<any, T>, options?: NoInfer<RPCHandlerOptions<T>>);
42
+ }
43
+
44
+ export { AwsLambdaHandler, experimental_RPCHandler };
45
+ export type { AwsLambdaHandleResult, AwsLambdaHandlerOptions, RPCHandlerOptions };
@@ -0,0 +1,45 @@
1
+ import { MaybeOptionalOptions } from '@orpc/shared';
2
+ import { SendStandardResponseOptions, APIGatewayProxyEventV2, ResponseStream } from '@orpc/standard-server-aws-lambda';
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
+ interface AwsLambdaHandlerOptions extends SendStandardResponseOptions {
13
+ }
14
+ type AwsLambdaHandleResult = {
15
+ matched: true;
16
+ } | {
17
+ matched: false;
18
+ };
19
+ declare class AwsLambdaHandler<T extends Context> {
20
+ private readonly standardHandler;
21
+ private readonly sendStandardResponseOptions;
22
+ constructor(standardHandler: StandardHandler<T>, options?: AwsLambdaHandlerOptions);
23
+ handle(event: APIGatewayProxyEventV2, responseStream: ResponseStream, ...rest: MaybeOptionalOptions<FriendlyStandardHandleOptions<T>>): Promise<AwsLambdaHandleResult>;
24
+ }
25
+
26
+ type RPCHandlerOptions<T extends Context> = AwsLambdaHandlerOptions & StandardRPCHandlerOptions<T> & {
27
+ /**
28
+ * Enables or disables the StrictGetMethodPlugin.
29
+ *
30
+ * @default true
31
+ */
32
+ strictGetMethodPluginEnabled?: boolean;
33
+ };
34
+ /**
35
+ * RPC Handler for AWS Lambda.
36
+ *
37
+ * @see {@link https://orpc.unnoq.com/docs/rpc-handler RPC Handler Docs}
38
+ * @see {@link https://orpc.unnoq.com/docs/adapters/http HTTP Adapter Docs}
39
+ */
40
+ declare class experimental_RPCHandler<T extends Context> extends AwsLambdaHandler<T> {
41
+ constructor(router: Router<any, T>, options?: NoInfer<RPCHandlerOptions<T>>);
42
+ }
43
+
44
+ export { AwsLambdaHandler, experimental_RPCHandler };
45
+ export type { AwsLambdaHandleResult, AwsLambdaHandlerOptions, RPCHandlerOptions };
@@ -0,0 +1,41 @@
1
+ import { resolveMaybeOptionalOptions } from '@orpc/shared';
2
+ import { toStandardLazyRequest, sendStandardResponse } from '@orpc/standard-server-aws-lambda';
3
+ import { r as resolveFriendlyStandardHandleOptions } from '../../shared/server.DZ5BIITo.mjs';
4
+ import '@orpc/standard-server';
5
+ import '@orpc/standard-server/batch';
6
+ import '@orpc/client';
7
+ import { S as StrictGetMethodPlugin } from '../../shared/server.BW-nUGgA.mjs';
8
+ import '@orpc/contract';
9
+ import { b as StandardRPCHandler } from '../../shared/server.CHvOkcM3.mjs';
10
+ import '@orpc/client/standard';
11
+ import '../../shared/server.DG7Tamti.mjs';
12
+
13
+ class AwsLambdaHandler {
14
+ constructor(standardHandler, options = {}) {
15
+ this.standardHandler = standardHandler;
16
+ this.sendStandardResponseOptions = options;
17
+ }
18
+ sendStandardResponseOptions;
19
+ async handle(event, responseStream, ...rest) {
20
+ const standardRequest = toStandardLazyRequest(event, responseStream);
21
+ const options = resolveFriendlyStandardHandleOptions(resolveMaybeOptionalOptions(rest));
22
+ const result = await this.standardHandler.handle(standardRequest, options);
23
+ if (!result.matched) {
24
+ return { matched: false };
25
+ }
26
+ await sendStandardResponse(responseStream, result.response, this.sendStandardResponseOptions);
27
+ return { matched: true };
28
+ }
29
+ }
30
+
31
+ class experimental_RPCHandler extends AwsLambdaHandler {
32
+ constructor(router, options = {}) {
33
+ if (options.strictGetMethodPluginEnabled ?? true) {
34
+ options.plugins ??= [];
35
+ options.plugins.push(new StrictGetMethodPlugin());
36
+ }
37
+ super(new StandardRPCHandler(router, options), options);
38
+ }
39
+ }
40
+
41
+ export { AwsLambdaHandler, experimental_RPCHandler };
@@ -1,8 +1,8 @@
1
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';
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
6
  import '@orpc/client';
7
7
  import '@orpc/contract';
8
8
  import '@orpc/standard-server';
@@ -1,8 +1,8 @@
1
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';
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
6
  import '@orpc/client';
7
7
  import '@orpc/contract';
8
8
  import '@orpc/standard-server';
@@ -1,10 +1,10 @@
1
1
  import { resolveMaybeOptionalOptions } from '@orpc/shared';
2
2
  import { ServerPeer } from '@orpc/standard-server-peer';
3
- import { r as resolveFriendlyStandardHandleOptions } from '../../shared/server.BVwwTHyO.mjs';
3
+ import { r as resolveFriendlyStandardHandleOptions } from '../../shared/server.DZ5BIITo.mjs';
4
4
  import '@orpc/client';
5
5
  import '@orpc/standard-server';
6
6
  import '@orpc/contract';
7
- import { b as StandardRPCHandler } from '../../shared/server.4FnxLwwr.mjs';
7
+ import { b as StandardRPCHandler } from '../../shared/server.CHvOkcM3.mjs';
8
8
  import '@orpc/client/standard';
9
9
  import '../../shared/server.DG7Tamti.mjs';
10
10
 
@@ -16,13 +16,8 @@ class experimental_BunWsHandler {
16
16
  async message(ws, message, ...rest) {
17
17
  let peer = this.peers.get(ws);
18
18
  if (!peer) {
19
- this.peers.set(ws, peer = new ServerPeer(async (raw) => {
20
- if (raw instanceof Blob) {
21
- const buffer = await raw.arrayBuffer();
22
- ws.send(buffer);
23
- } else {
24
- ws.send(raw);
25
- }
19
+ this.peers.set(ws, peer = new ServerPeer((message2) => {
20
+ ws.send(message2);
26
21
  }));
27
22
  }
28
23
  const [id, request] = await peer.message(typeof message === "string" ? message : message.buffer);
@@ -1,9 +1,9 @@
1
1
  import { MaybeOptionalOptions } from '@orpc/shared';
2
2
  import { Peer, Message } from 'crossws';
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';
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
7
  import '@orpc/client';
8
8
  import '@orpc/contract';
9
9
  import '@orpc/standard-server';
@@ -1,9 +1,9 @@
1
1
  import { MaybeOptionalOptions } from '@orpc/shared';
2
2
  import { Peer, Message } from 'crossws';
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';
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
7
  import '@orpc/client';
8
8
  import '@orpc/contract';
9
9
  import '@orpc/standard-server';
@@ -1,10 +1,10 @@
1
1
  import { resolveMaybeOptionalOptions } from '@orpc/shared';
2
2
  import { ServerPeer } from '@orpc/standard-server-peer';
3
- import { r as resolveFriendlyStandardHandleOptions } from '../../shared/server.BVwwTHyO.mjs';
3
+ import { r as resolveFriendlyStandardHandleOptions } from '../../shared/server.DZ5BIITo.mjs';
4
4
  import '@orpc/client';
5
5
  import '@orpc/standard-server';
6
6
  import '@orpc/contract';
7
- import { b as StandardRPCHandler } from '../../shared/server.4FnxLwwr.mjs';
7
+ import { b as StandardRPCHandler } from '../../shared/server.CHvOkcM3.mjs';
8
8
  import '@orpc/client/standard';
9
9
  import '../../shared/server.DG7Tamti.mjs';
10
10
 
@@ -16,13 +16,8 @@ class experimental_CrosswsHandler {
16
16
  async message(ws, message, ...rest) {
17
17
  let peer = this.peers.get(ws);
18
18
  if (!peer) {
19
- this.peers.set(ws, peer = new ServerPeer(async (raw) => {
20
- if (raw instanceof Blob) {
21
- const buffer = await raw.arrayBuffer();
22
- ws.send(buffer);
23
- } else {
24
- ws.send(raw);
25
- }
19
+ this.peers.set(ws, peer = new ServerPeer((message2) => {
20
+ ws.send(message2);
26
21
  }));
27
22
  }
28
23
  const [id, request] = await peer.message(typeof message.rawData === "string" ? message.rawData : message.uint8Array());
@@ -1,9 +1,9 @@
1
- import { C as Context, R as Router } from '../../shared/server.DPWk5pjW.mjs';
2
- import { Interceptor, ThrowableError, MaybeOptionalOptions } from '@orpc/shared';
1
+ import { C as Context, R as Router } from '../../shared/server.DD2C4ujN.mjs';
2
+ import { Interceptor, MaybeOptionalOptions } from '@orpc/shared';
3
3
  import { ToFetchResponseOptions } from '@orpc/standard-server-fetch';
4
- import { a as StandardHandlerPlugin, C as CompositeStandardHandlerPlugin, g as StandardHandleOptions, 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';
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
7
  import '@orpc/client';
8
8
  import '@orpc/contract';
9
9
  import '@orpc/standard-server';
@@ -28,7 +28,7 @@ interface FetchHandlerInterceptorOptions<T extends Context> extends StandardHand
28
28
  toFetchResponseOptions: ToFetchResponseOptions;
29
29
  }
30
30
  interface FetchHandlerOptions<T extends Context> extends ToFetchResponseOptions {
31
- adapterInterceptors?: Interceptor<FetchHandlerInterceptorOptions<T>, FetchHandleResult, ThrowableError>[];
31
+ adapterInterceptors?: Interceptor<FetchHandlerInterceptorOptions<T>, Promise<FetchHandleResult>>[];
32
32
  plugins?: FetchHandlerPlugin<T>[];
33
33
  }
34
34
  declare class FetchHandler<T extends Context> {
@@ -1,9 +1,9 @@
1
- import { C as Context, R as Router } from '../../shared/server.DPWk5pjW.js';
2
- import { Interceptor, ThrowableError, MaybeOptionalOptions } from '@orpc/shared';
1
+ import { C as Context, R as Router } from '../../shared/server.DD2C4ujN.js';
2
+ import { Interceptor, MaybeOptionalOptions } from '@orpc/shared';
3
3
  import { ToFetchResponseOptions } from '@orpc/standard-server-fetch';
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';
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
7
  import '@orpc/client';
8
8
  import '@orpc/contract';
9
9
  import '@orpc/standard-server';
@@ -28,7 +28,7 @@ interface FetchHandlerInterceptorOptions<T extends Context> extends StandardHand
28
28
  toFetchResponseOptions: ToFetchResponseOptions;
29
29
  }
30
30
  interface FetchHandlerOptions<T extends Context> extends ToFetchResponseOptions {
31
- adapterInterceptors?: Interceptor<FetchHandlerInterceptorOptions<T>, FetchHandleResult, ThrowableError>[];
31
+ adapterInterceptors?: Interceptor<FetchHandlerInterceptorOptions<T>, Promise<FetchHandleResult>>[];
32
32
  plugins?: FetchHandlerPlugin<T>[];
33
33
  }
34
34
  declare class FetchHandler<T extends Context> {
@@ -1,10 +1,10 @@
1
1
  import { ORPCError } from '@orpc/client';
2
2
  import { toArray, intercept, resolveMaybeOptionalOptions } from '@orpc/shared';
3
3
  import { toStandardLazyRequest, toFetchResponse } from '@orpc/standard-server-fetch';
4
- import { r as resolveFriendlyStandardHandleOptions } from '../../shared/server.BVwwTHyO.mjs';
4
+ import { r as resolveFriendlyStandardHandleOptions } from '../../shared/server.DZ5BIITo.mjs';
5
5
  import '@orpc/standard-server';
6
6
  import '@orpc/contract';
7
- import { C as CompositeStandardHandlerPlugin, b as StandardRPCHandler } from '../../shared/server.4FnxLwwr.mjs';
7
+ import { C as CompositeStandardHandlerPlugin, b as StandardRPCHandler } from '../../shared/server.CHvOkcM3.mjs';
8
8
  import '@orpc/client/standard';
9
9
  import '@orpc/standard-server/batch';
10
10
  import { S as StrictGetMethodPlugin } from '../../shared/server.BW-nUGgA.mjs';
@@ -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 };
@@ -1,9 +1,9 @@
1
- import { C as Context, R as Router } from '../../shared/server.DPWk5pjW.mjs';
2
- import { Interceptor, ThrowableError, MaybeOptionalOptions } from '@orpc/shared';
1
+ import { C as Context, R as Router } from '../../shared/server.DD2C4ujN.mjs';
2
+ import { Interceptor, MaybeOptionalOptions } from '@orpc/shared';
3
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.eWLxY3lq.mjs';
5
- import { F as FriendlyStandardHandleOptions } from '../../shared/server.QUe9N8P4.mjs';
6
- import { S as StandardRPCHandlerOptions } from '../../shared/server.BRoxSiSC.mjs';
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
7
  import '@orpc/client';
8
8
  import '@orpc/contract';
9
9
  import '@orpc/standard-server';
@@ -27,7 +27,7 @@ interface NodeHttpHandlerInterceptorOptions<T extends Context> extends StandardH
27
27
  sendStandardResponseOptions: SendStandardResponseOptions;
28
28
  }
29
29
  interface NodeHttpHandlerOptions<T extends Context> extends SendStandardResponseOptions {
30
- adapterInterceptors?: Interceptor<NodeHttpHandlerInterceptorOptions<T>, NodeHttpHandleResult, ThrowableError>[];
30
+ adapterInterceptors?: Interceptor<NodeHttpHandlerInterceptorOptions<T>, Promise<NodeHttpHandleResult>>[];
31
31
  plugins?: NodeHttpHandlerPlugin<T>[];
32
32
  }
33
33
  declare class NodeHttpHandler<T extends Context> implements NodeHttpHandler<T> {
@@ -1,9 +1,9 @@
1
- import { C as Context, R as Router } from '../../shared/server.DPWk5pjW.js';
2
- import { Interceptor, ThrowableError, MaybeOptionalOptions } from '@orpc/shared';
1
+ import { C as Context, R as Router } from '../../shared/server.DD2C4ujN.js';
2
+ import { Interceptor, MaybeOptionalOptions } from '@orpc/shared';
3
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.YZzrREz9.js';
5
- import { F as FriendlyStandardHandleOptions } from '../../shared/server.BjiJH9Vo.js';
6
- import { S as StandardRPCHandlerOptions } from '../../shared/server.Cy1vfSiG.js';
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
7
  import '@orpc/client';
8
8
  import '@orpc/contract';
9
9
  import '@orpc/standard-server';
@@ -27,7 +27,7 @@ interface NodeHttpHandlerInterceptorOptions<T extends Context> extends StandardH
27
27
  sendStandardResponseOptions: SendStandardResponseOptions;
28
28
  }
29
29
  interface NodeHttpHandlerOptions<T extends Context> extends SendStandardResponseOptions {
30
- adapterInterceptors?: Interceptor<NodeHttpHandlerInterceptorOptions<T>, NodeHttpHandleResult, ThrowableError>[];
30
+ adapterInterceptors?: Interceptor<NodeHttpHandlerInterceptorOptions<T>, Promise<NodeHttpHandleResult>>[];
31
31
  plugins?: NodeHttpHandlerPlugin<T>[];
32
32
  }
33
33
  declare class NodeHttpHandler<T extends Context> implements NodeHttpHandler<T> {
@@ -1,10 +1,10 @@
1
1
  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
- import { r as resolveFriendlyStandardHandleOptions } from '../../shared/server.BVwwTHyO.mjs';
4
+ import { r as resolveFriendlyStandardHandleOptions } from '../../shared/server.DZ5BIITo.mjs';
5
5
  import '@orpc/standard-server';
6
6
  import '@orpc/contract';
7
- import { C as CompositeStandardHandlerPlugin, b as StandardRPCHandler } from '../../shared/server.4FnxLwwr.mjs';
7
+ import { C as CompositeStandardHandlerPlugin, b as StandardRPCHandler } from '../../shared/server.CHvOkcM3.mjs';
8
8
  import '@orpc/client/standard';
9
9
  import '@orpc/standard-server/batch';
10
10
  import { S as StrictGetMethodPlugin } from '../../shared/server.BW-nUGgA.mjs';
@@ -1,10 +1,10 @@
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';
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
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 { h as AnyProcedure, f as AnyRouter } from '../../shared/server.DPWk5pjW.mjs';
7
- export { a as StandardRPCHandler, S as StandardRPCHandlerOptions } from '../../shared/server.BRoxSiSC.mjs';
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
8
  import '@orpc/contract';
9
9
  import '@orpc/shared';
10
10
 
@@ -1,10 +1,10 @@
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';
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
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 { h as AnyProcedure, f as AnyRouter } from '../../shared/server.DPWk5pjW.js';
7
- export { a as StandardRPCHandler, S as StandardRPCHandlerOptions } from '../../shared/server.Cy1vfSiG.js';
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
8
  import '@orpc/contract';
9
9
  import '@orpc/shared';
10
10
 
@@ -1,4 +1,4 @@
1
- export { C as CompositeStandardHandlerPlugin, S as StandardHandler, a as StandardRPCCodec, b as StandardRPCHandler, c as StandardRPCMatcher } from '../../shared/server.4FnxLwwr.mjs';
1
+ export { C as CompositeStandardHandlerPlugin, S as StandardHandler, a as StandardRPCCodec, b as StandardRPCHandler, c as StandardRPCMatcher } from '../../shared/server.CHvOkcM3.mjs';
2
2
  import '@orpc/client/standard';
3
3
  import '@orpc/client';
4
4
  import '@orpc/shared';
@@ -1,17 +1,40 @@
1
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';
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
6
  import '@orpc/client';
7
7
  import '@orpc/contract';
8
8
  import '@orpc/standard-server';
9
9
  import '@orpc/client/standard';
10
10
 
11
+ type experimental_MinimalWebsocket = Pick<WebSocket, 'addEventListener' | 'send'>;
11
12
  declare class experimental_WebsocketHandler<T extends Context> {
12
- private readonly standardHandler;
13
+ #private;
13
14
  constructor(standardHandler: StandardHandler<T>);
14
- upgrade(ws: Pick<WebSocket, 'addEventListener' | 'send'>, ...rest: MaybeOptionalOptions<Omit<FriendlyStandardHandleOptions<T>, 'prefix'>>): void;
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;
15
38
  }
16
39
 
17
40
  /**
@@ -25,3 +48,4 @@ declare class experimental_RPCHandler<T extends Context> extends experimental_We
25
48
  }
26
49
 
27
50
  export { experimental_RPCHandler, experimental_WebsocketHandler };
51
+ export type { experimental_MinimalWebsocket };