@orpc/server 0.52.0 → 0.53.0

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 (34) hide show
  1. package/dist/adapters/fetch/index.d.mts +11 -7
  2. package/dist/adapters/fetch/index.d.ts +11 -7
  3. package/dist/adapters/fetch/index.mjs +6 -4
  4. package/dist/adapters/hono/index.d.mts +5 -5
  5. package/dist/adapters/hono/index.d.ts +5 -5
  6. package/dist/adapters/hono/index.mjs +10 -7
  7. package/dist/adapters/next/index.d.mts +5 -5
  8. package/dist/adapters/next/index.d.ts +5 -5
  9. package/dist/adapters/next/index.mjs +10 -7
  10. package/dist/adapters/node/index.d.mts +11 -7
  11. package/dist/adapters/node/index.d.ts +11 -7
  12. package/dist/adapters/node/index.mjs +17 -12
  13. package/dist/adapters/standard/index.d.mts +3 -3
  14. package/dist/adapters/standard/index.d.ts +3 -3
  15. package/dist/adapters/standard/index.mjs +6 -4
  16. package/dist/index.d.mts +3 -3
  17. package/dist/index.d.ts +3 -3
  18. package/dist/index.mjs +7 -7
  19. package/dist/plugins/index.d.mts +100 -6
  20. package/dist/plugins/index.d.ts +100 -6
  21. package/dist/plugins/index.mjs +138 -1
  22. package/dist/shared/server.BW-nUGgA.mjs +36 -0
  23. package/dist/shared/{server.T5WmDoWQ.mjs → server.Bm0UqHzd.mjs} +16 -11
  24. package/dist/shared/{server.e3W6AG3-.mjs → server.C37gDhSZ.mjs} +16 -22
  25. package/dist/shared/server.C8NkqxHo.d.ts +17 -0
  26. package/dist/shared/{server.DGnN7q3R.d.mts → server.CGCwEAt_.d.mts} +1 -1
  27. package/dist/shared/server.DCQgF_JR.d.mts +17 -0
  28. package/dist/shared/{server.BHlRCrf_.d.ts → server.DFFT_EZo.d.ts} +11 -4
  29. package/dist/shared/{server.Dfx1jV-K.mjs → server.DFuJLDuo.mjs} +43 -14
  30. package/dist/shared/{server.CzxlqYZL.d.mts → server.DOYDVeMX.d.mts} +11 -4
  31. package/dist/shared/{server.Cud5qk0c.d.ts → server._2UufoXA.d.ts} +1 -1
  32. package/package.json +7 -7
  33. package/dist/shared/server.B77ImKAP.d.mts +0 -8
  34. package/dist/shared/server.DUF89eb-.d.ts +0 -8
@@ -1,14 +1,21 @@
1
1
  import { C as Context, R as Router } from '../../shared/server.DLt5njUb.mjs';
2
2
  import { Interceptor, ThrowableError, MaybeOptionalOptions } from '@orpc/shared';
3
- import { c as StandardHandlerPlugin, S as StandardHandleOptions, i as StandardHandler } from '../../shared/server.CzxlqYZL.mjs';
4
- import { F as FriendlyStandardHandleOptions } from '../../shared/server.DGnN7q3R.mjs';
3
+ import { i as StandardHandlerPlugin, C as CompositeStandardHandlerPlugin, S as StandardHandleOptions, b as StandardHandler } from '../../shared/server.DOYDVeMX.mjs';
4
+ import { F as FriendlyStandardHandleOptions } from '../../shared/server.CGCwEAt_.mjs';
5
5
  import { ToFetchResponseOptions } from '@orpc/standard-server-fetch';
6
- import { S as StandardRPCHandlerOptions } from '../../shared/server.B77ImKAP.mjs';
6
+ import { S as StandardRPCHandlerOptions } from '../../shared/server.DCQgF_JR.mjs';
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 FetchHandlerPlugin<T extends Context> extends StandardHandlerPlugin<T> {
13
+ initRuntimeAdapter?(options: FetchHandlerOptions<T>): void;
14
+ }
15
+ declare class CompositeFetchHandlerPlugin<T extends Context, TPlugin extends FetchHandlerPlugin<T>> extends CompositeStandardHandlerPlugin<T, TPlugin> implements FetchHandlerPlugin<T> {
16
+ initRuntimeAdapter(options: FetchHandlerOptions<T>): void;
17
+ }
18
+
12
19
  type FetchHandleResult = {
13
20
  matched: true;
14
21
  response: Response;
@@ -16,9 +23,6 @@ type FetchHandleResult = {
16
23
  matched: false;
17
24
  response: undefined;
18
25
  };
19
- interface FetchHandlerPlugin<T extends Context> extends StandardHandlerPlugin<T> {
20
- initRuntimeAdapter?(options: FetchHandlerOptions<T>): void;
21
- }
22
26
  interface FetchHandlerInterceptorOptions<T extends Context> extends StandardHandleOptions<T> {
23
27
  request: Request;
24
28
  toFetchResponseOptions: ToFetchResponseOptions;
@@ -51,4 +55,4 @@ declare class RPCHandler<T extends Context> extends FetchHandler<T> {
51
55
  constructor(router: Router<any, T>, options?: NoInfer<FetchHandlerOptions<T> & StandardRPCHandlerOptions<T>>);
52
56
  }
53
57
 
54
- export { BodyLimitPlugin, type BodyLimitPluginOptions, type FetchHandleResult, FetchHandler, type FetchHandlerInterceptorOptions, type FetchHandlerOptions, type FetchHandlerPlugin, RPCHandler };
58
+ export { BodyLimitPlugin, type BodyLimitPluginOptions, CompositeFetchHandlerPlugin, type FetchHandleResult, FetchHandler, type FetchHandlerInterceptorOptions, type FetchHandlerOptions, type FetchHandlerPlugin, RPCHandler };
@@ -1,14 +1,21 @@
1
1
  import { C as Context, R as Router } from '../../shared/server.DLt5njUb.js';
2
2
  import { Interceptor, ThrowableError, MaybeOptionalOptions } from '@orpc/shared';
3
- import { c as StandardHandlerPlugin, S as StandardHandleOptions, i as StandardHandler } from '../../shared/server.BHlRCrf_.js';
4
- import { F as FriendlyStandardHandleOptions } from '../../shared/server.Cud5qk0c.js';
3
+ import { i as StandardHandlerPlugin, C as CompositeStandardHandlerPlugin, S as StandardHandleOptions, b as StandardHandler } from '../../shared/server.DFFT_EZo.js';
4
+ import { F as FriendlyStandardHandleOptions } from '../../shared/server._2UufoXA.js';
5
5
  import { ToFetchResponseOptions } from '@orpc/standard-server-fetch';
6
- import { S as StandardRPCHandlerOptions } from '../../shared/server.DUF89eb-.js';
6
+ import { S as StandardRPCHandlerOptions } from '../../shared/server.C8NkqxHo.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 FetchHandlerPlugin<T extends Context> extends StandardHandlerPlugin<T> {
13
+ initRuntimeAdapter?(options: FetchHandlerOptions<T>): void;
14
+ }
15
+ declare class CompositeFetchHandlerPlugin<T extends Context, TPlugin extends FetchHandlerPlugin<T>> extends CompositeStandardHandlerPlugin<T, TPlugin> implements FetchHandlerPlugin<T> {
16
+ initRuntimeAdapter(options: FetchHandlerOptions<T>): void;
17
+ }
18
+
12
19
  type FetchHandleResult = {
13
20
  matched: true;
14
21
  response: Response;
@@ -16,9 +23,6 @@ type FetchHandleResult = {
16
23
  matched: false;
17
24
  response: undefined;
18
25
  };
19
- interface FetchHandlerPlugin<T extends Context> extends StandardHandlerPlugin<T> {
20
- initRuntimeAdapter?(options: FetchHandlerOptions<T>): void;
21
- }
22
26
  interface FetchHandlerInterceptorOptions<T extends Context> extends StandardHandleOptions<T> {
23
27
  request: Request;
24
28
  toFetchResponseOptions: ToFetchResponseOptions;
@@ -51,4 +55,4 @@ declare class RPCHandler<T extends Context> extends FetchHandler<T> {
51
55
  constructor(router: Router<any, T>, options?: NoInfer<FetchHandlerOptions<T> & StandardRPCHandlerOptions<T>>);
52
56
  }
53
57
 
54
- export { BodyLimitPlugin, type BodyLimitPluginOptions, type FetchHandleResult, FetchHandler, type FetchHandlerInterceptorOptions, type FetchHandlerOptions, type FetchHandlerPlugin, RPCHandler };
58
+ export { BodyLimitPlugin, type BodyLimitPluginOptions, CompositeFetchHandlerPlugin, type FetchHandleResult, FetchHandler, type FetchHandlerInterceptorOptions, type FetchHandlerOptions, type FetchHandlerPlugin, RPCHandler };
@@ -1,9 +1,11 @@
1
- export { B as BodyLimitPlugin, F as FetchHandler, R as RPCHandler } from '../../shared/server.T5WmDoWQ.mjs';
1
+ export { B as BodyLimitPlugin, C as CompositeFetchHandlerPlugin, F as FetchHandler, R as RPCHandler } from '../../shared/server.Bm0UqHzd.mjs';
2
2
  import '@orpc/client';
3
- import '@orpc/client/standard';
4
- import '../../shared/server.Dfx1jV-K.mjs';
5
3
  import '@orpc/shared';
6
- import '../../shared/server.e3W6AG3-.mjs';
7
4
  import '@orpc/contract';
5
+ import '../../shared/server.DFuJLDuo.mjs';
6
+ import '@orpc/client/standard';
7
+ import '@orpc/standard-server/batch';
8
+ import '../../shared/server.BW-nUGgA.mjs';
9
+ import '../../shared/server.C37gDhSZ.mjs';
8
10
  import '@orpc/standard-server-fetch';
9
11
  import '../../shared/server.BVwwTHyO.mjs';
@@ -1,12 +1,12 @@
1
1
  import { FetchHandler } from '../fetch/index.mjs';
2
- export { BodyLimitPlugin, BodyLimitPluginOptions, FetchHandleResult, FetchHandlerInterceptorOptions, FetchHandlerOptions, FetchHandlerPlugin, RPCHandler } from '../fetch/index.mjs';
2
+ export { BodyLimitPlugin, BodyLimitPluginOptions, CompositeFetchHandlerPlugin, FetchHandleResult, FetchHandlerInterceptorOptions, FetchHandlerOptions, FetchHandlerPlugin, RPCHandler } from '../fetch/index.mjs';
3
3
  import { Value, MaybeOptionalOptions } from '@orpc/shared';
4
4
  import { Context as Context$1, MiddlewareHandler } from 'hono';
5
5
  import { C as Context } from '../../shared/server.DLt5njUb.mjs';
6
- import { S as StandardHandleOptions } from '../../shared/server.CzxlqYZL.mjs';
7
- import '../../shared/server.DGnN7q3R.mjs';
6
+ import { S as StandardHandleOptions } from '../../shared/server.DOYDVeMX.mjs';
7
+ import '../../shared/server.CGCwEAt_.mjs';
8
8
  import '@orpc/standard-server-fetch';
9
- import '../../shared/server.B77ImKAP.mjs';
9
+ import '../../shared/server.DCQgF_JR.mjs';
10
10
  import '@orpc/client/standard';
11
11
  import '@orpc/client';
12
12
  import '@orpc/contract';
@@ -17,6 +17,6 @@ type CreateMiddlewareOptions<T extends Context> = Omit<StandardHandleOptions<T>,
17
17
  } : {
18
18
  context: Value<T, [Context$1]>;
19
19
  });
20
- declare function createMiddleware<T extends Context>(handler: FetchHandler<T>, ...[options]: MaybeOptionalOptions<CreateMiddlewareOptions<T>>): MiddlewareHandler;
20
+ declare function createMiddleware<T extends Context>(handler: FetchHandler<T>, ...rest: MaybeOptionalOptions<CreateMiddlewareOptions<T>>): MiddlewareHandler;
21
21
 
22
22
  export { type CreateMiddlewareOptions, FetchHandler, createMiddleware };
@@ -1,12 +1,12 @@
1
1
  import { FetchHandler } from '../fetch/index.js';
2
- export { BodyLimitPlugin, BodyLimitPluginOptions, FetchHandleResult, FetchHandlerInterceptorOptions, FetchHandlerOptions, FetchHandlerPlugin, RPCHandler } from '../fetch/index.js';
2
+ export { BodyLimitPlugin, BodyLimitPluginOptions, CompositeFetchHandlerPlugin, FetchHandleResult, FetchHandlerInterceptorOptions, FetchHandlerOptions, FetchHandlerPlugin, RPCHandler } from '../fetch/index.js';
3
3
  import { Value, MaybeOptionalOptions } from '@orpc/shared';
4
4
  import { Context as Context$1, MiddlewareHandler } from 'hono';
5
5
  import { C as Context } from '../../shared/server.DLt5njUb.js';
6
- import { S as StandardHandleOptions } from '../../shared/server.BHlRCrf_.js';
7
- import '../../shared/server.Cud5qk0c.js';
6
+ import { S as StandardHandleOptions } from '../../shared/server.DFFT_EZo.js';
7
+ import '../../shared/server._2UufoXA.js';
8
8
  import '@orpc/standard-server-fetch';
9
- import '../../shared/server.DUF89eb-.js';
9
+ import '../../shared/server.C8NkqxHo.js';
10
10
  import '@orpc/client/standard';
11
11
  import '@orpc/client';
12
12
  import '@orpc/contract';
@@ -17,6 +17,6 @@ type CreateMiddlewareOptions<T extends Context> = Omit<StandardHandleOptions<T>,
17
17
  } : {
18
18
  context: Value<T, [Context$1]>;
19
19
  });
20
- declare function createMiddleware<T extends Context>(handler: FetchHandler<T>, ...[options]: MaybeOptionalOptions<CreateMiddlewareOptions<T>>): MiddlewareHandler;
20
+ declare function createMiddleware<T extends Context>(handler: FetchHandler<T>, ...rest: MaybeOptionalOptions<CreateMiddlewareOptions<T>>): MiddlewareHandler;
21
21
 
22
22
  export { type CreateMiddlewareOptions, FetchHandler, createMiddleware };
@@ -1,14 +1,17 @@
1
- export { B as BodyLimitPlugin, F as FetchHandler, R as RPCHandler } from '../../shared/server.T5WmDoWQ.mjs';
2
- import { value } from '@orpc/shared';
1
+ export { B as BodyLimitPlugin, C as CompositeFetchHandlerPlugin, F as FetchHandler, R as RPCHandler } from '../../shared/server.Bm0UqHzd.mjs';
2
+ import { resolveMaybeOptionalOptions, value } from '@orpc/shared';
3
3
  import '@orpc/client';
4
- import '@orpc/client/standard';
5
- import '../../shared/server.Dfx1jV-K.mjs';
6
- import '../../shared/server.e3W6AG3-.mjs';
7
4
  import '@orpc/contract';
5
+ import '../../shared/server.DFuJLDuo.mjs';
6
+ import '@orpc/client/standard';
7
+ import '@orpc/standard-server/batch';
8
+ import '../../shared/server.BW-nUGgA.mjs';
9
+ import '../../shared/server.C37gDhSZ.mjs';
8
10
  import '@orpc/standard-server-fetch';
9
11
  import '../../shared/server.BVwwTHyO.mjs';
10
12
 
11
- function createMiddleware(handler, ...[options]) {
13
+ function createMiddleware(handler, ...rest) {
14
+ const options = resolveMaybeOptionalOptions(rest);
12
15
  return async (c, next) => {
13
16
  const bodyProps = /* @__PURE__ */ new Set(["arrayBuffer", "blob", "formData", "json", "text"]);
14
17
  const request = c.req.method === "GET" || c.req.method === "HEAD" ? c.req.raw : new Proxy(c.req.raw, {
@@ -20,7 +23,7 @@ function createMiddleware(handler, ...[options]) {
20
23
  return Reflect.get(target, prop, target);
21
24
  }
22
25
  });
23
- const context = await value(options?.context ?? {}, c);
26
+ const context = await value(options.context ?? {}, c);
24
27
  const { matched, response } = await handler.handle(request, { ...options, context });
25
28
  if (matched) {
26
29
  return c.newResponse(response.body, response);
@@ -1,12 +1,12 @@
1
1
  import { FetchHandler } from '../fetch/index.mjs';
2
- export { BodyLimitPlugin, BodyLimitPluginOptions, FetchHandleResult, FetchHandlerInterceptorOptions, FetchHandlerOptions, FetchHandlerPlugin, RPCHandler } from '../fetch/index.mjs';
2
+ export { BodyLimitPlugin, BodyLimitPluginOptions, CompositeFetchHandlerPlugin, FetchHandleResult, FetchHandlerInterceptorOptions, FetchHandlerOptions, FetchHandlerPlugin, RPCHandler } from '../fetch/index.mjs';
3
3
  import { Value, MaybeOptionalOptions } from '@orpc/shared';
4
4
  import { NextRequest } from 'next/server';
5
5
  import { C as Context } from '../../shared/server.DLt5njUb.mjs';
6
- import { S as StandardHandleOptions } from '../../shared/server.CzxlqYZL.mjs';
7
- import '../../shared/server.DGnN7q3R.mjs';
6
+ import { S as StandardHandleOptions } from '../../shared/server.DOYDVeMX.mjs';
7
+ import '../../shared/server.CGCwEAt_.mjs';
8
8
  import '@orpc/standard-server-fetch';
9
- import '../../shared/server.B77ImKAP.mjs';
9
+ import '../../shared/server.DCQgF_JR.mjs';
10
10
  import '@orpc/client/standard';
11
11
  import '@orpc/client';
12
12
  import '@orpc/contract';
@@ -24,6 +24,6 @@ interface ServeResult {
24
24
  PATCH(req: NextRequest): Promise<Response>;
25
25
  DELETE(req: NextRequest): Promise<Response>;
26
26
  }
27
- declare function serve<T extends Context>(handler: FetchHandler<T>, ...[options]: MaybeOptionalOptions<ServeOptions<T>>): ServeResult;
27
+ declare function serve<T extends Context>(handler: FetchHandler<T>, ...rest: MaybeOptionalOptions<ServeOptions<T>>): ServeResult;
28
28
 
29
29
  export { FetchHandler, type ServeOptions, type ServeResult, serve };
@@ -1,12 +1,12 @@
1
1
  import { FetchHandler } from '../fetch/index.js';
2
- export { BodyLimitPlugin, BodyLimitPluginOptions, FetchHandleResult, FetchHandlerInterceptorOptions, FetchHandlerOptions, FetchHandlerPlugin, RPCHandler } from '../fetch/index.js';
2
+ export { BodyLimitPlugin, BodyLimitPluginOptions, CompositeFetchHandlerPlugin, FetchHandleResult, FetchHandlerInterceptorOptions, FetchHandlerOptions, FetchHandlerPlugin, RPCHandler } from '../fetch/index.js';
3
3
  import { Value, MaybeOptionalOptions } from '@orpc/shared';
4
4
  import { NextRequest } from 'next/server';
5
5
  import { C as Context } from '../../shared/server.DLt5njUb.js';
6
- import { S as StandardHandleOptions } from '../../shared/server.BHlRCrf_.js';
7
- import '../../shared/server.Cud5qk0c.js';
6
+ import { S as StandardHandleOptions } from '../../shared/server.DFFT_EZo.js';
7
+ import '../../shared/server._2UufoXA.js';
8
8
  import '@orpc/standard-server-fetch';
9
- import '../../shared/server.DUF89eb-.js';
9
+ import '../../shared/server.C8NkqxHo.js';
10
10
  import '@orpc/client/standard';
11
11
  import '@orpc/client';
12
12
  import '@orpc/contract';
@@ -24,6 +24,6 @@ interface ServeResult {
24
24
  PATCH(req: NextRequest): Promise<Response>;
25
25
  DELETE(req: NextRequest): Promise<Response>;
26
26
  }
27
- declare function serve<T extends Context>(handler: FetchHandler<T>, ...[options]: MaybeOptionalOptions<ServeOptions<T>>): ServeResult;
27
+ declare function serve<T extends Context>(handler: FetchHandler<T>, ...rest: MaybeOptionalOptions<ServeOptions<T>>): ServeResult;
28
28
 
29
29
  export { FetchHandler, type ServeOptions, type ServeResult, serve };
@@ -1,16 +1,19 @@
1
- export { B as BodyLimitPlugin, F as FetchHandler, R as RPCHandler } from '../../shared/server.T5WmDoWQ.mjs';
2
- import { value } from '@orpc/shared';
1
+ export { B as BodyLimitPlugin, C as CompositeFetchHandlerPlugin, F as FetchHandler, R as RPCHandler } from '../../shared/server.Bm0UqHzd.mjs';
2
+ import { resolveMaybeOptionalOptions, value } from '@orpc/shared';
3
3
  import '@orpc/client';
4
- import '@orpc/client/standard';
5
- import '../../shared/server.Dfx1jV-K.mjs';
6
- import '../../shared/server.e3W6AG3-.mjs';
7
4
  import '@orpc/contract';
5
+ import '../../shared/server.DFuJLDuo.mjs';
6
+ import '@orpc/client/standard';
7
+ import '@orpc/standard-server/batch';
8
+ import '../../shared/server.BW-nUGgA.mjs';
9
+ import '../../shared/server.C37gDhSZ.mjs';
8
10
  import '@orpc/standard-server-fetch';
9
11
  import '../../shared/server.BVwwTHyO.mjs';
10
12
 
11
- function serve(handler, ...[options]) {
13
+ function serve(handler, ...rest) {
14
+ const options = resolveMaybeOptionalOptions(rest);
12
15
  const main = async (req) => {
13
- const context = await value(options?.context ?? {}, req);
16
+ const context = await value(options.context ?? {}, req);
14
17
  const { matched, response } = await handler.handle(req, { ...options, context });
15
18
  if (matched) {
16
19
  return response;
@@ -1,22 +1,26 @@
1
1
  import { C as Context, R as Router } from '../../shared/server.DLt5njUb.mjs';
2
2
  import { Interceptor, ThrowableError, MaybeOptionalOptions } from '@orpc/shared';
3
3
  import { SendStandardResponseOptions, NodeHttpRequest, NodeHttpResponse } from '@orpc/standard-server-node';
4
- import { c as StandardHandlerPlugin, S as StandardHandleOptions, i as StandardHandler } from '../../shared/server.CzxlqYZL.mjs';
5
- import { F as FriendlyStandardHandleOptions } from '../../shared/server.DGnN7q3R.mjs';
6
- import { S as StandardRPCHandlerOptions } from '../../shared/server.B77ImKAP.mjs';
4
+ import { i as StandardHandlerPlugin, C as CompositeStandardHandlerPlugin, S as StandardHandleOptions, b as StandardHandler } from '../../shared/server.DOYDVeMX.mjs';
5
+ import { F as FriendlyStandardHandleOptions } from '../../shared/server.CGCwEAt_.mjs';
6
+ import { S as StandardRPCHandlerOptions } from '../../shared/server.DCQgF_JR.mjs';
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;
@@ -50,4 +54,4 @@ declare class RPCHandler<T extends Context> extends NodeHttpHandler<T> {
50
54
  constructor(router: Router<any, T>, options?: NoInfer<StandardRPCHandlerOptions<T> & NodeHttpHandlerOptions<T>>);
51
55
  }
52
56
 
53
- export { BodyLimitPlugin, type BodyLimitPluginOptions, type NodeHttpHandleResult, NodeHttpHandler, type NodeHttpHandlerInterceptorOptions, type NodeHttpHandlerOptions, type NodeHttpHandlerPlugin, RPCHandler };
57
+ export { BodyLimitPlugin, type BodyLimitPluginOptions, CompositeNodeHttpHandlerPlugin, type NodeHttpHandleResult, NodeHttpHandler, type NodeHttpHandlerInterceptorOptions, type NodeHttpHandlerOptions, type NodeHttpHandlerPlugin, RPCHandler };
@@ -1,22 +1,26 @@
1
1
  import { C as Context, R as Router } from '../../shared/server.DLt5njUb.js';
2
2
  import { Interceptor, ThrowableError, MaybeOptionalOptions } from '@orpc/shared';
3
3
  import { SendStandardResponseOptions, NodeHttpRequest, NodeHttpResponse } from '@orpc/standard-server-node';
4
- import { c as StandardHandlerPlugin, S as StandardHandleOptions, i as StandardHandler } from '../../shared/server.BHlRCrf_.js';
5
- import { F as FriendlyStandardHandleOptions } from '../../shared/server.Cud5qk0c.js';
6
- import { S as StandardRPCHandlerOptions } from '../../shared/server.DUF89eb-.js';
4
+ import { i as StandardHandlerPlugin, C as CompositeStandardHandlerPlugin, S as StandardHandleOptions, b as StandardHandler } from '../../shared/server.DFFT_EZo.js';
5
+ import { F as FriendlyStandardHandleOptions } from '../../shared/server._2UufoXA.js';
6
+ import { S as StandardRPCHandlerOptions } from '../../shared/server.C8NkqxHo.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;
@@ -50,4 +54,4 @@ declare class RPCHandler<T extends Context> extends NodeHttpHandler<T> {
50
54
  constructor(router: Router<any, T>, options?: NoInfer<StandardRPCHandlerOptions<T> & NodeHttpHandlerOptions<T>>);
51
55
  }
52
56
 
53
- export { BodyLimitPlugin, type BodyLimitPluginOptions, type NodeHttpHandleResult, NodeHttpHandler, type NodeHttpHandlerInterceptorOptions, type NodeHttpHandlerOptions, type NodeHttpHandlerPlugin, RPCHandler };
57
+ export { BodyLimitPlugin, type BodyLimitPluginOptions, CompositeNodeHttpHandlerPlugin, type NodeHttpHandleResult, NodeHttpHandler, type NodeHttpHandlerInterceptorOptions, type NodeHttpHandlerOptions, type NodeHttpHandlerPlugin, RPCHandler };
@@ -2,10 +2,12 @@ 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.Dfx1jV-K.mjs';
7
- import '../../shared/server.e3W6AG3-.mjs';
8
5
  import '@orpc/contract';
6
+ import { C as CompositeStandardHandlerPlugin, b as StandardRPCHandler } from '../../shared/server.DFuJLDuo.mjs';
7
+ import '@orpc/client/standard';
8
+ import '@orpc/standard-server/batch';
9
+ import '../../shared/server.BW-nUGgA.mjs';
10
+ import '../../shared/server.C37gDhSZ.mjs';
9
11
 
10
12
  class BodyLimitPlugin {
11
13
  maxBodySize;
@@ -39,12 +41,19 @@ class BodyLimitPlugin {
39
41
  }
40
42
  }
41
43
 
44
+ class CompositeNodeHttpHandlerPlugin extends CompositeStandardHandlerPlugin {
45
+ initRuntimeAdapter(options) {
46
+ for (const plugin of this.plugins) {
47
+ plugin.initRuntimeAdapter?.(options);
48
+ }
49
+ }
50
+ }
51
+
42
52
  class NodeHttpHandler {
43
53
  constructor(standardHandler, options = {}) {
44
54
  this.standardHandler = standardHandler;
45
- for (const plugin of toArray(options.plugins)) {
46
- plugin.initRuntimeAdapter?.(options);
47
- }
55
+ const plugin = new CompositeNodeHttpHandlerPlugin(options.plugins);
56
+ plugin.initRuntimeAdapter(options);
48
57
  this.adapterInterceptors = toArray(options.adapterInterceptors);
49
58
  this.sendStandardResponseOptions = options;
50
59
  }
@@ -74,12 +83,8 @@ class NodeHttpHandler {
74
83
 
75
84
  class RPCHandler extends NodeHttpHandler {
76
85
  constructor(router, options = {}) {
77
- const jsonSerializer = new StandardRPCJsonSerializer(options);
78
- const serializer = new StandardRPCSerializer(jsonSerializer);
79
- const matcher = new StandardRPCMatcher();
80
- const codec = new StandardRPCCodec(serializer);
81
- super(new StandardHandler(router, matcher, codec, options), options);
86
+ super(new StandardRPCHandler(router, options), options);
82
87
  }
83
88
  }
84
89
 
85
- export { BodyLimitPlugin, NodeHttpHandler, RPCHandler };
90
+ export { BodyLimitPlugin, CompositeNodeHttpHandlerPlugin, NodeHttpHandler, RPCHandler };
@@ -1,10 +1,10 @@
1
- import { d as StandardCodec, e as StandardParams, f as StandardMatcher, g as StandardMatchResult } from '../../shared/server.CzxlqYZL.mjs';
2
- export { S as StandardHandleOptions, h as StandardHandleResult, i as StandardHandler, b as StandardHandlerInterceptorOptions, a as StandardHandlerOptions, c as StandardHandlerPlugin } from '../../shared/server.CzxlqYZL.mjs';
1
+ import { c as StandardCodec, d as StandardParams, e as StandardMatcher, f as StandardMatchResult } from '../../shared/server.DOYDVeMX.mjs';
2
+ export { C as CompositeStandardHandlerPlugin, S as StandardHandleOptions, g as StandardHandleResult, b as StandardHandler, h as StandardHandlerInterceptorOptions, a as StandardHandlerOptions, i as StandardHandlerPlugin } from '../../shared/server.DOYDVeMX.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
6
  import { A as AnyProcedure, a as AnyRouter } from '../../shared/server.DLt5njUb.mjs';
7
- export { S as StandardRPCHandlerOptions } from '../../shared/server.B77ImKAP.mjs';
7
+ export { a as StandardRPCHandler, S as StandardRPCHandlerOptions } from '../../shared/server.DCQgF_JR.mjs';
8
8
  import '@orpc/contract';
9
9
  import '@orpc/shared';
10
10
 
@@ -1,10 +1,10 @@
1
- import { d as StandardCodec, e as StandardParams, f as StandardMatcher, g as StandardMatchResult } from '../../shared/server.BHlRCrf_.js';
2
- export { S as StandardHandleOptions, h as StandardHandleResult, i as StandardHandler, b as StandardHandlerInterceptorOptions, a as StandardHandlerOptions, c as StandardHandlerPlugin } from '../../shared/server.BHlRCrf_.js';
1
+ import { c as StandardCodec, d as StandardParams, e as StandardMatcher, f as StandardMatchResult } from '../../shared/server.DFFT_EZo.js';
2
+ export { C as CompositeStandardHandlerPlugin, S as StandardHandleOptions, g as StandardHandleResult, b as StandardHandler, h as StandardHandlerInterceptorOptions, a as StandardHandlerOptions, i as StandardHandlerPlugin } from '../../shared/server.DFFT_EZo.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
6
  import { A as AnyProcedure, a as AnyRouter } from '../../shared/server.DLt5njUb.js';
7
- export { S as StandardRPCHandlerOptions } from '../../shared/server.DUF89eb-.js';
7
+ export { a as StandardRPCHandler, S as StandardRPCHandlerOptions } from '../../shared/server.C8NkqxHo.js';
8
8
  import '@orpc/contract';
9
9
  import '@orpc/shared';
10
10
 
@@ -1,6 +1,8 @@
1
- export { S as StandardHandler, a as StandardRPCCodec, b as StandardRPCMatcher } from '../../shared/server.Dfx1jV-K.mjs';
2
- import '@orpc/client';
1
+ export { C as CompositeStandardHandlerPlugin, S as StandardHandler, a as StandardRPCCodec, b as StandardRPCHandler, c as StandardRPCMatcher } from '../../shared/server.DFuJLDuo.mjs';
2
+ import '@orpc/client/standard';
3
3
  import '@orpc/shared';
4
- import '../../shared/server.e3W6AG3-.mjs';
4
+ import '@orpc/standard-server/batch';
5
+ import '@orpc/client';
6
+ import '../../shared/server.BW-nUGgA.mjs';
5
7
  import '@orpc/contract';
6
- import '@orpc/client/standard';
8
+ import '../../shared/server.C37gDhSZ.mjs';
package/dist/index.d.mts CHANGED
@@ -1,9 +1,9 @@
1
1
  import { ORPCErrorJSON, ORPCError, Client, ClientContext, HTTPPath, ClientPromiseResult } from '@orpc/client';
2
- export { HTTPMethod, HTTPPath, ORPCError, isDefinedError, safe } from '@orpc/client';
2
+ export { ClientContext, HTTPMethod, HTTPPath, ORPCError, isDefinedError, safe } from '@orpc/client';
3
3
  import { AnySchema, ErrorMap, InferSchemaInput, InferSchemaOutput, ErrorFromErrorMap, Meta, MergedErrorMap, Route, EnhanceRouteOptions, AnyContractRouter, AnyContractProcedure, Schema, ContractRouter, ContractProcedureDef, ContractProcedure, InferContractRouterErrorMap, InferContractRouterMeta } from '@orpc/contract';
4
4
  export { ContractProcedure, ContractProcedureDef, ContractRouter, ErrorMap, ErrorMapItem, InferSchemaInput, InferSchemaOutput, InputStructure, MergedErrorMap, Meta, OutputStructure, Route, Schema, ValidationError, eventIterator, type } from '@orpc/contract';
5
5
  import { ThrowableError, IntersectPick, MaybeOptionalOptions } from '@orpc/shared';
6
- export { Registry, ThrowableError, onError, onFinish, onStart, onSuccess } from '@orpc/shared';
6
+ export { IntersectPick, Registry, ThrowableError, onError, onFinish, onStart, onSuccess } from '@orpc/shared';
7
7
  import { C as Context, b as Procedure, M as Middleware, O as ORPCErrorConstructorMap, c as MergedInitialContext, d as MergedCurrentContext, e as MapInputMiddleware, f as CreateProcedureClientOptions, g as ProcedureClient, h as AnyMiddleware, L as Lazyable, a as AnyRouter, i as Lazy, A as AnyProcedure, j as ProcedureHandler, R as Router, I as InferRouterInitialContext } from './shared/server.DLt5njUb.mjs';
8
8
  export { J as InferRouterCurrentContexts, H as InferRouterInitialContexts, K as InferRouterInputs, N as InferRouterOutputs, o as LAZY_SYMBOL, p as LazyMeta, x as MiddlewareNextFn, w as MiddlewareNextFnOptions, z as MiddlewareOptions, y as MiddlewareOutputFn, t as MiddlewareResult, l as ORPCErrorConstructorMapItem, k as ORPCErrorConstructorMapItemOptions, P as ProcedureClientInterceptorOptions, E as ProcedureDef, D as ProcedureHandlerOptions, n as createORPCErrorConstructorMap, G as createProcedureClient, s as getLazyMeta, r as isLazy, F as isProcedure, q as lazy, m as mergeCurrentContext, B as middlewareOutputFn, u as unlazy, v as validateORPCError } from './shared/server.DLt5njUb.mjs';
9
9
  export { getEventMeta, withEventMeta } from '@orpc/standard-server';
@@ -283,7 +283,7 @@ declare function call<TInitialContext extends Context, TInputSchema extends AnyS
283
283
  type RouterClient<TRouter extends AnyRouter, TClientContext extends ClientContext = Record<never, never>> = TRouter extends Procedure<any, any, infer UInputSchema, infer UOutputSchema, infer UErrorMap, any> ? ProcedureClient<TClientContext, UInputSchema, UOutputSchema, UErrorMap> : {
284
284
  [K in keyof TRouter]: TRouter[K] extends Lazyable<infer U extends AnyRouter> ? RouterClient<U, TClientContext> : never;
285
285
  };
286
- declare function createRouterClient<T extends AnyRouter, TClientContext extends ClientContext>(router: Lazyable<T | undefined>, ...[options]: MaybeOptionalOptions<CreateProcedureClientOptions<InferRouterInitialContext<T>, Schema<unknown, unknown>, ErrorMap, Meta, TClientContext>>): RouterClient<T, TClientContext>;
286
+ declare function createRouterClient<T extends AnyRouter, TClientContext extends ClientContext>(router: Lazyable<T | undefined>, ...rest: MaybeOptionalOptions<CreateProcedureClientOptions<InferRouterInitialContext<T>, Schema<unknown, unknown>, ErrorMap, Meta, TClientContext>>): RouterClient<T, TClientContext>;
287
287
 
288
288
  declare function setHiddenRouterContract<T extends Lazyable<AnyRouter>>(router: T, contract: AnyContractRouter): T;
289
289
  declare function getHiddenRouterContract(router: Lazyable<AnyRouter | AnyContractRouter>): AnyContractRouter | undefined;
package/dist/index.d.ts CHANGED
@@ -1,9 +1,9 @@
1
1
  import { ORPCErrorJSON, ORPCError, Client, ClientContext, HTTPPath, ClientPromiseResult } from '@orpc/client';
2
- export { HTTPMethod, HTTPPath, ORPCError, isDefinedError, safe } from '@orpc/client';
2
+ export { ClientContext, HTTPMethod, HTTPPath, ORPCError, isDefinedError, safe } from '@orpc/client';
3
3
  import { AnySchema, ErrorMap, InferSchemaInput, InferSchemaOutput, ErrorFromErrorMap, Meta, MergedErrorMap, Route, EnhanceRouteOptions, AnyContractRouter, AnyContractProcedure, Schema, ContractRouter, ContractProcedureDef, ContractProcedure, InferContractRouterErrorMap, InferContractRouterMeta } from '@orpc/contract';
4
4
  export { ContractProcedure, ContractProcedureDef, ContractRouter, ErrorMap, ErrorMapItem, InferSchemaInput, InferSchemaOutput, InputStructure, MergedErrorMap, Meta, OutputStructure, Route, Schema, ValidationError, eventIterator, type } from '@orpc/contract';
5
5
  import { ThrowableError, IntersectPick, MaybeOptionalOptions } from '@orpc/shared';
6
- export { Registry, ThrowableError, onError, onFinish, onStart, onSuccess } from '@orpc/shared';
6
+ export { IntersectPick, Registry, ThrowableError, onError, onFinish, onStart, onSuccess } from '@orpc/shared';
7
7
  import { C as Context, b as Procedure, M as Middleware, O as ORPCErrorConstructorMap, c as MergedInitialContext, d as MergedCurrentContext, e as MapInputMiddleware, f as CreateProcedureClientOptions, g as ProcedureClient, h as AnyMiddleware, L as Lazyable, a as AnyRouter, i as Lazy, A as AnyProcedure, j as ProcedureHandler, R as Router, I as InferRouterInitialContext } from './shared/server.DLt5njUb.js';
8
8
  export { J as InferRouterCurrentContexts, H as InferRouterInitialContexts, K as InferRouterInputs, N as InferRouterOutputs, o as LAZY_SYMBOL, p as LazyMeta, x as MiddlewareNextFn, w as MiddlewareNextFnOptions, z as MiddlewareOptions, y as MiddlewareOutputFn, t as MiddlewareResult, l as ORPCErrorConstructorMapItem, k as ORPCErrorConstructorMapItemOptions, P as ProcedureClientInterceptorOptions, E as ProcedureDef, D as ProcedureHandlerOptions, n as createORPCErrorConstructorMap, G as createProcedureClient, s as getLazyMeta, r as isLazy, F as isProcedure, q as lazy, m as mergeCurrentContext, B as middlewareOutputFn, u as unlazy, v as validateORPCError } from './shared/server.DLt5njUb.js';
9
9
  export { getEventMeta, withEventMeta } from '@orpc/standard-server';
@@ -283,7 +283,7 @@ declare function call<TInitialContext extends Context, TInputSchema extends AnyS
283
283
  type RouterClient<TRouter extends AnyRouter, TClientContext extends ClientContext = Record<never, never>> = TRouter extends Procedure<any, any, infer UInputSchema, infer UOutputSchema, infer UErrorMap, any> ? ProcedureClient<TClientContext, UInputSchema, UOutputSchema, UErrorMap> : {
284
284
  [K in keyof TRouter]: TRouter[K] extends Lazyable<infer U extends AnyRouter> ? RouterClient<U, TClientContext> : never;
285
285
  };
286
- declare function createRouterClient<T extends AnyRouter, TClientContext extends ClientContext>(router: Lazyable<T | undefined>, ...[options]: MaybeOptionalOptions<CreateProcedureClientOptions<InferRouterInitialContext<T>, Schema<unknown, unknown>, ErrorMap, Meta, TClientContext>>): RouterClient<T, TClientContext>;
286
+ declare function createRouterClient<T extends AnyRouter, TClientContext extends ClientContext>(router: Lazyable<T | undefined>, ...rest: MaybeOptionalOptions<CreateProcedureClientOptions<InferRouterInitialContext<T>, Schema<unknown, unknown>, ErrorMap, Meta, TClientContext>>): RouterClient<T, TClientContext>;
287
287
 
288
288
  declare function setHiddenRouterContract<T extends Lazyable<AnyRouter>>(router: T, contract: AnyContractRouter): T;
289
289
  declare function getHiddenRouterContract(router: Lazyable<AnyRouter | AnyContractRouter>): AnyContractRouter | undefined;
package/dist/index.mjs CHANGED
@@ -1,7 +1,7 @@
1
1
  import { mergeErrorMap, mergeMeta, mergeRoute, mergePrefix, mergeTags, isContractProcedure, getContractRouter } from '@orpc/contract';
2
2
  export { ValidationError, eventIterator, type } from '@orpc/contract';
3
- import { P as Procedure, b as addMiddleware, c as createProcedureClient, e as enhanceRouter, l as lazy, s as setHiddenRouterContract, i as isProcedure, d as isLazy, f as createAssertedLazyProcedure, g as getRouter } from './shared/server.e3W6AG3-.mjs';
4
- export { L as LAZY_SYMBOL, p as call, r as createAccessibleLazyRouter, a as createContractedProcedure, h as createORPCErrorConstructorMap, q as getHiddenRouterContract, j as getLazyMeta, n as isStartWithMiddlewares, m as mergeCurrentContext, o as mergeMiddlewares, k as middlewareOutputFn, w as resolveContractProcedures, t as traverseContractProcedures, u as unlazy, x as unlazyRouter, v as validateORPCError } from './shared/server.e3W6AG3-.mjs';
3
+ import { P as Procedure, b as addMiddleware, c as createProcedureClient, e as enhanceRouter, l as lazy, s as setHiddenRouterContract, i as isProcedure, d as isLazy, f as createAssertedLazyProcedure, g as getRouter } from './shared/server.C37gDhSZ.mjs';
4
+ export { L as LAZY_SYMBOL, p as call, r as createAccessibleLazyRouter, a as createContractedProcedure, h as createORPCErrorConstructorMap, q as getHiddenRouterContract, j as getLazyMeta, n as isStartWithMiddlewares, m as mergeCurrentContext, o as mergeMiddlewares, k as middlewareOutputFn, w as resolveContractProcedures, t as traverseContractProcedures, u as unlazy, x as unlazyRouter, v as validateORPCError } from './shared/server.C37gDhSZ.mjs';
5
5
  import { toORPCError } from '@orpc/client';
6
6
  export { ORPCError, isDefinedError, safe } from '@orpc/client';
7
7
  export { onError, onFinish, onStart, onSuccess } from '@orpc/shared';
@@ -336,12 +336,12 @@ function implement(contract, config = {}) {
336
336
  return impl;
337
337
  }
338
338
 
339
- function createRouterClient(router, ...[options]) {
339
+ function createRouterClient(router, ...rest) {
340
340
  if (isProcedure(router)) {
341
- const caller = createProcedureClient(router, options);
341
+ const caller = createProcedureClient(router, ...rest);
342
342
  return caller;
343
343
  }
344
- const procedureCaller = isLazy(router) ? createProcedureClient(createAssertedLazyProcedure(router), options) : {};
344
+ const procedureCaller = isLazy(router) ? createProcedureClient(createAssertedLazyProcedure(router), ...rest) : {};
345
345
  const recursive = new Proxy(procedureCaller, {
346
346
  get(target, key) {
347
347
  if (typeof key !== "string") {
@@ -352,8 +352,8 @@ function createRouterClient(router, ...[options]) {
352
352
  return Reflect.get(target, key);
353
353
  }
354
354
  return createRouterClient(next, {
355
- ...options,
356
- path: [...options?.path ?? [], key]
355
+ ...rest[0],
356
+ path: [...rest[0]?.path ?? [], key]
357
357
  });
358
358
  }
359
359
  });