@orpc/server 1.8.1 → 1.8.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md CHANGED
@@ -31,7 +31,7 @@
31
31
  - **📘 First-Class OpenAPI**: Built-in support that fully adheres to the OpenAPI standard.
32
32
  - **📝 Contract-First Development**: Optionally define your API contract before implementation.
33
33
  - **🔍 First-Class OpenTelemetry**: Seamlessly integrate with OpenTelemetry for observability.
34
- - **⚙️ Framework Integrations**: Seamlessly integrate with TanStack Query (React, Vue, Solid, Svelte, Angular), Pinia Colada, and more.
34
+ - **⚙️ Framework Integrations**: Seamlessly integrate with TanStack Query (React, Vue, Solid, Svelte, Angular), SWR, Pinia Colada, and more.
35
35
  - **🚀 Server Actions**: Fully compatible with React Server Actions on Next.js, TanStack Start, and other platforms.
36
36
  - **🔠 Standard Schema Support**: Works out of the box with Zod, Valibot, ArkType, and other schema validators.
37
37
  - **🗃️ Native Types**: Supports native types like Date, File, Blob, BigInt, URL, and more.
@@ -54,6 +54,7 @@ You can find the full documentation [here](https://orpc.unnoq.com).
54
54
  - [@orpc/nest](https://www.npmjs.com/package/@orpc/nest): Deeply integrate oRPC with [NestJS](https://nestjs.com/).
55
55
  - [@orpc/react](https://www.npmjs.com/package/@orpc/react): Utilities for integrating oRPC with React and React Server Actions.
56
56
  - [@orpc/tanstack-query](https://www.npmjs.com/package/@orpc/tanstack-query): [TanStack Query](https://tanstack.com/query/latest) integration.
57
+ - [@orpc/experimental-react-swr](https://www.npmjs.com/package/@orpc/experimental-react-swr): [SWR](https://swr.vercel.app/) integration.
57
58
  - [@orpc/vue-colada](https://www.npmjs.com/package/@orpc/vue-colada): Integration with [Pinia Colada](https://pinia-colada.esm.dev/).
58
59
  - [@orpc/hey-api](https://www.npmjs.com/package/@orpc/hey-api): [Hey API](https://heyapi.dev/) integration.
59
60
  - [@orpc/zod](https://www.npmjs.com/package/@orpc/zod): More schemas that [Zod](https://zod.dev/) doesn't support yet.
@@ -7,9 +7,9 @@ import '@orpc/standard-server-fetch';
7
7
  import '@orpc/client';
8
8
  import { S as StrictGetMethodPlugin } from '../../shared/server.BW-nUGgA.mjs';
9
9
  import '@orpc/contract';
10
- import { b as StandardRPCHandler } from '../../shared/server.CYRYFTxo.mjs';
10
+ import { b as StandardRPCHandler } from '../../shared/server.BHZCyRuJ.mjs';
11
11
  import '@orpc/client/standard';
12
- import '../../shared/server.B_fj3X5m.mjs';
12
+ import '../../shared/server.7jWaIryJ.mjs';
13
13
 
14
14
  class AwsLambdaHandler {
15
15
  constructor(standardHandler, options = {}) {
@@ -4,10 +4,10 @@ import { c as createServerPeerHandleRequestFn } from '../../shared/server.UVMTOW
4
4
  import '@orpc/client';
5
5
  import '@orpc/standard-server';
6
6
  import '@orpc/contract';
7
- import { b as StandardRPCHandler } from '../../shared/server.CYRYFTxo.mjs';
7
+ import { b as StandardRPCHandler } from '../../shared/server.BHZCyRuJ.mjs';
8
8
  import '@orpc/client/standard';
9
9
  import '../../shared/server.DZ5BIITo.mjs';
10
- import '../../shared/server.B_fj3X5m.mjs';
10
+ import '../../shared/server.7jWaIryJ.mjs';
11
11
 
12
12
  class BunWsHandler {
13
13
  constructor(standardHandler) {
@@ -4,10 +4,10 @@ import { c as createServerPeerHandleRequestFn } from '../../shared/server.UVMTOW
4
4
  import '@orpc/client';
5
5
  import '@orpc/standard-server';
6
6
  import '@orpc/contract';
7
- import { b as StandardRPCHandler } from '../../shared/server.CYRYFTxo.mjs';
7
+ import { b as StandardRPCHandler } from '../../shared/server.BHZCyRuJ.mjs';
8
8
  import '@orpc/client/standard';
9
9
  import '../../shared/server.DZ5BIITo.mjs';
10
- import '../../shared/server.B_fj3X5m.mjs';
10
+ import '../../shared/server.7jWaIryJ.mjs';
11
11
 
12
12
  class experimental_CrosswsHandler {
13
13
  constructor(standardHandler) {
@@ -102,14 +102,14 @@ declare class CompressionPlugin<T extends Context> implements FetchHandlerPlugin
102
102
  initRuntimeAdapter(options: FetchHandlerOptions<T>): void;
103
103
  }
104
104
 
105
- type RPCHandlerOptions<T extends Context> = FetchHandlerOptions<T> & StandardRPCHandlerOptions<T> & {
105
+ interface RPCHandlerOptions<T extends Context> extends FetchHandlerOptions<T>, Omit<StandardRPCHandlerOptions<T>, 'plugins'> {
106
106
  /**
107
107
  * Enables or disables the StrictGetMethodPlugin.
108
108
  *
109
109
  * @default true
110
110
  */
111
111
  strictGetMethodPluginEnabled?: boolean;
112
- };
112
+ }
113
113
  /**
114
114
  * RPC Handler for Fetch Server
115
115
  *
@@ -102,14 +102,14 @@ declare class CompressionPlugin<T extends Context> implements FetchHandlerPlugin
102
102
  initRuntimeAdapter(options: FetchHandlerOptions<T>): void;
103
103
  }
104
104
 
105
- type RPCHandlerOptions<T extends Context> = FetchHandlerOptions<T> & StandardRPCHandlerOptions<T> & {
105
+ interface RPCHandlerOptions<T extends Context> extends FetchHandlerOptions<T>, Omit<StandardRPCHandlerOptions<T>, 'plugins'> {
106
106
  /**
107
107
  * Enables or disables the StrictGetMethodPlugin.
108
108
  *
109
109
  * @default true
110
110
  */
111
111
  strictGetMethodPluginEnabled?: boolean;
112
- };
112
+ }
113
113
  /**
114
114
  * RPC Handler for Fetch Server
115
115
  *
@@ -4,11 +4,11 @@ import { toStandardLazyRequest, toFetchResponse } from '@orpc/standard-server-fe
4
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.CYRYFTxo.mjs';
7
+ import { C as CompositeStandardHandlerPlugin, b as StandardRPCHandler } from '../../shared/server.BHZCyRuJ.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';
11
- import '../../shared/server.B_fj3X5m.mjs';
11
+ import '../../shared/server.7jWaIryJ.mjs';
12
12
 
13
13
  class BodyLimitPlugin {
14
14
  maxBodySize;
@@ -5,10 +5,10 @@ import { c as createServerPeerHandleRequestFn } from '../../shared/server.UVMTOW
5
5
  import '@orpc/client';
6
6
  import '@orpc/standard-server';
7
7
  import '@orpc/contract';
8
- import { b as StandardRPCHandler } from '../../shared/server.CYRYFTxo.mjs';
8
+ import { b as StandardRPCHandler } from '../../shared/server.BHZCyRuJ.mjs';
9
9
  import '@orpc/client/standard';
10
10
  import '../../shared/server.DZ5BIITo.mjs';
11
- import '../../shared/server.B_fj3X5m.mjs';
11
+ import '../../shared/server.7jWaIryJ.mjs';
12
12
 
13
13
  class MessagePortHandler {
14
14
  constructor(standardHandler) {
@@ -77,14 +77,14 @@ declare class CompressionPlugin<T extends Context> implements NodeHttpHandlerPlu
77
77
  initRuntimeAdapter(options: NodeHttpHandlerOptions<T>): void;
78
78
  }
79
79
 
80
- type RPCHandlerOptions<T extends Context> = NodeHttpHandlerOptions<T> & StandardRPCHandlerOptions<T> & {
80
+ interface RPCHandlerOptions<T extends Context> extends NodeHttpHandlerOptions<T>, Omit<StandardRPCHandlerOptions<T>, 'plugins'> {
81
81
  /**
82
82
  * Enables or disables the StrictGetMethodPlugin.
83
83
  *
84
84
  * @default true
85
85
  */
86
86
  strictGetMethodPluginEnabled?: boolean;
87
- };
87
+ }
88
88
  /**
89
89
  * RPC Handler for Node.js HTTP Server
90
90
  *
@@ -77,14 +77,14 @@ declare class CompressionPlugin<T extends Context> implements NodeHttpHandlerPlu
77
77
  initRuntimeAdapter(options: NodeHttpHandlerOptions<T>): void;
78
78
  }
79
79
 
80
- type RPCHandlerOptions<T extends Context> = NodeHttpHandlerOptions<T> & StandardRPCHandlerOptions<T> & {
80
+ interface RPCHandlerOptions<T extends Context> extends NodeHttpHandlerOptions<T>, Omit<StandardRPCHandlerOptions<T>, 'plugins'> {
81
81
  /**
82
82
  * Enables or disables the StrictGetMethodPlugin.
83
83
  *
84
84
  * @default true
85
85
  */
86
86
  strictGetMethodPluginEnabled?: boolean;
87
- };
87
+ }
88
88
  /**
89
89
  * RPC Handler for Node.js HTTP Server
90
90
  *
@@ -5,12 +5,12 @@ import { toStandardLazyRequest, sendStandardResponse } from '@orpc/standard-serv
5
5
  import { r as resolveFriendlyStandardHandleOptions } from '../../shared/server.DZ5BIITo.mjs';
6
6
  import '@orpc/standard-server';
7
7
  import '@orpc/contract';
8
- import { C as CompositeStandardHandlerPlugin, b as StandardRPCHandler } from '../../shared/server.CYRYFTxo.mjs';
8
+ import { C as CompositeStandardHandlerPlugin, b as StandardRPCHandler } from '../../shared/server.BHZCyRuJ.mjs';
9
9
  import '@orpc/client/standard';
10
10
  import '@orpc/standard-server/batch';
11
11
  import '@orpc/standard-server-fetch';
12
12
  import { S as StrictGetMethodPlugin } from '../../shared/server.BW-nUGgA.mjs';
13
- import '../../shared/server.B_fj3X5m.mjs';
13
+ import '../../shared/server.7jWaIryJ.mjs';
14
14
 
15
15
  class BodyLimitPlugin {
16
16
  maxBodySize;
@@ -1,8 +1,8 @@
1
- export { C as CompositeStandardHandlerPlugin, S as StandardHandler, a as StandardRPCCodec, b as StandardRPCHandler, c as StandardRPCMatcher } from '../../shared/server.CYRYFTxo.mjs';
1
+ export { C as CompositeStandardHandlerPlugin, S as StandardHandler, a as StandardRPCCodec, b as StandardRPCHandler, c as StandardRPCMatcher } from '../../shared/server.BHZCyRuJ.mjs';
2
2
  export { r as resolveFriendlyStandardHandleOptions } from '../../shared/server.DZ5BIITo.mjs';
3
3
  import '@orpc/client/standard';
4
4
  import '@orpc/client';
5
5
  import '@orpc/shared';
6
6
  import '@orpc/standard-server';
7
- import '../../shared/server.B_fj3X5m.mjs';
7
+ import '../../shared/server.7jWaIryJ.mjs';
8
8
  import '@orpc/contract';
@@ -4,10 +4,10 @@ import { c as createServerPeerHandleRequestFn } from '../../shared/server.UVMTOW
4
4
  import '@orpc/client';
5
5
  import '@orpc/standard-server';
6
6
  import '@orpc/contract';
7
- import { b as StandardRPCHandler } from '../../shared/server.CYRYFTxo.mjs';
7
+ import { b as StandardRPCHandler } from '../../shared/server.BHZCyRuJ.mjs';
8
8
  import '@orpc/client/standard';
9
9
  import '../../shared/server.DZ5BIITo.mjs';
10
- import '../../shared/server.B_fj3X5m.mjs';
10
+ import '../../shared/server.7jWaIryJ.mjs';
11
11
 
12
12
  class WebsocketHandler {
13
13
  #peers = /* @__PURE__ */ new WeakMap();
@@ -4,10 +4,10 @@ import { c as createServerPeerHandleRequestFn } from '../../shared/server.UVMTOW
4
4
  import '@orpc/client';
5
5
  import '@orpc/standard-server';
6
6
  import '@orpc/contract';
7
- import { b as StandardRPCHandler } from '../../shared/server.CYRYFTxo.mjs';
7
+ import { b as StandardRPCHandler } from '../../shared/server.BHZCyRuJ.mjs';
8
8
  import '@orpc/client/standard';
9
9
  import '../../shared/server.DZ5BIITo.mjs';
10
- import '../../shared/server.B_fj3X5m.mjs';
10
+ import '../../shared/server.7jWaIryJ.mjs';
11
11
 
12
12
  class WsHandler {
13
13
  constructor(standardHandler) {
package/dist/index.mjs CHANGED
@@ -1,7 +1,7 @@
1
1
  import { mergeErrorMap, mergeMeta, mergeRoute, mergePrefix, mergeTags, isContractProcedure, getContractRouter, fallbackContractConfig } 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, u as unlazy, g as getRouter, i as isProcedure, d as isLazy, f as createAssertedLazyProcedure } from './shared/server.B_fj3X5m.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, x as unlazyRouter, v as validateORPCError } from './shared/server.B_fj3X5m.mjs';
3
+ import { P as Procedure, b as addMiddleware, c as createProcedureClient, e as enhanceRouter, l as lazy, s as setHiddenRouterContract, u as unlazy, g as getRouter, i as isProcedure, d as isLazy, f as createAssertedLazyProcedure } from './shared/server.7jWaIryJ.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, x as unlazyRouter, v as validateORPCError } from './shared/server.7jWaIryJ.mjs';
5
5
  import { toORPCError } from '@orpc/client';
6
6
  export { ORPCError, isDefinedError, safe } from '@orpc/client';
7
7
  import { resolveMaybeOptionalOptions } from '@orpc/shared';
@@ -21,7 +21,7 @@ function fallbackConfig(key, value) {
21
21
  }
22
22
 
23
23
  function decorateMiddleware(middleware) {
24
- const decorated = (...args) => middleware(...args);
24
+ const decorated = ((...args) => middleware(...args));
25
25
  decorated.mapInput = (mapInput) => {
26
26
  const mapped = decorateMiddleware(
27
27
  (options, input, ...rest) => middleware(options, mapInput(input), ...rest)
@@ -83,7 +83,7 @@ class BatchHandlerPlugin {
83
83
  status,
84
84
  headers,
85
85
  mode,
86
- body: async function* () {
86
+ body: (async function* () {
87
87
  const promises = [...responses];
88
88
  while (true) {
89
89
  const handling = promises.filter((p) => p !== void 0);
@@ -94,7 +94,7 @@ class BatchHandlerPlugin {
94
94
  promises[result.index] = void 0;
95
95
  yield result;
96
96
  }
97
- }()
97
+ })()
98
98
  });
99
99
  return {
100
100
  matched: true,
@@ -1,6 +1,6 @@
1
1
  import { isContractProcedure, ValidationError, mergePrefix, mergeErrorMap, enhanceRoute } from '@orpc/contract';
2
2
  import { resolveMaybeOptionalOptions, toArray, value, runWithSpan, intercept, isAsyncIteratorObject, asyncIteratorWithSpan } from '@orpc/shared';
3
- import { fallbackORPCErrorStatus, ORPCError } from '@orpc/client';
3
+ import { ORPCError, fallbackORPCErrorStatus, mapEventIterator } from '@orpc/client';
4
4
  import { HibernationEventIterator } from '@orpc/standard-server';
5
5
 
6
6
  const LAZY_SYMBOL = Symbol("ORPC_LAZY_SYMBOL");
@@ -116,6 +116,12 @@ function createProcedureClient(lazyableProcedure, ...rest) {
116
116
  const clientContext = callerOptions?.context ?? {};
117
117
  const context = await value(options.context ?? {}, clientContext);
118
118
  const errors = createORPCErrorConstructorMap(procedure["~orpc"].errorMap);
119
+ const validateError = async (e) => {
120
+ if (e instanceof ORPCError) {
121
+ return await validateORPCError(procedure["~orpc"].errorMap, e);
122
+ }
123
+ return e;
124
+ };
119
125
  try {
120
126
  const output = await runWithSpan(
121
127
  { name: "call_procedure", signal: callerOptions?.signal },
@@ -141,18 +147,20 @@ function createProcedureClient(lazyableProcedure, ...rest) {
141
147
  if (output instanceof HibernationEventIterator) {
142
148
  return output;
143
149
  }
144
- return asyncIteratorWithSpan(
145
- { name: "consume_event_iterator_output", signal: callerOptions?.signal },
146
- output
150
+ return mapEventIterator(
151
+ asyncIteratorWithSpan(
152
+ { name: "consume_event_iterator_output", signal: callerOptions?.signal },
153
+ output
154
+ ),
155
+ {
156
+ value: (v) => v,
157
+ error: (e) => validateError(e)
158
+ }
147
159
  );
148
160
  }
149
161
  return output;
150
162
  } catch (e) {
151
- if (!(e instanceof ORPCError)) {
152
- throw e;
153
- }
154
- const validated = await validateORPCError(procedure["~orpc"].errorMap, e);
155
- throw validated;
163
+ throw await validateError(e);
156
164
  }
157
165
  };
158
166
  }
@@ -2,7 +2,7 @@ import { toHttpPath, StandardRPCJsonSerializer, StandardRPCSerializer } from '@o
2
2
  import { ORPCError, toORPCError } from '@orpc/client';
3
3
  import { toArray, intercept, runWithSpan, ORPC_NAME, isAsyncIteratorObject, asyncIteratorWithSpan, setSpanError, parseEmptyableJSON, NullProtoObj, value } from '@orpc/shared';
4
4
  import { flattenHeader } from '@orpc/standard-server';
5
- import { c as createProcedureClient, t as traverseContractProcedures, i as isProcedure, u as unlazy, g as getRouter, a as createContractedProcedure } from './server.B_fj3X5m.mjs';
5
+ import { c as createProcedureClient, t as traverseContractProcedures, i as isProcedure, u as unlazy, g as getRouter, a as createContractedProcedure } from './server.7jWaIryJ.mjs';
6
6
 
7
7
  class CompositeStandardHandlerPlugin {
8
8
  plugins;
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@orpc/server",
3
3
  "type": "module",
4
- "version": "1.8.1",
4
+ "version": "1.8.3",
5
5
  "license": "MIT",
6
6
  "homepage": "https://orpc.unnoq.com",
7
7
  "repository": {
@@ -102,20 +102,20 @@
102
102
  },
103
103
  "dependencies": {
104
104
  "cookie": "^1.0.2",
105
- "@orpc/client": "1.8.1",
106
- "@orpc/contract": "1.8.1",
107
- "@orpc/interop": "1.8.1",
108
- "@orpc/shared": "1.8.1",
109
- "@orpc/standard-server": "1.8.1",
110
- "@orpc/standard-server-aws-lambda": "1.8.1",
111
- "@orpc/standard-server-fetch": "1.8.1",
112
- "@orpc/standard-server-peer": "1.8.1",
113
- "@orpc/standard-server-node": "1.8.1"
105
+ "@orpc/contract": "1.8.3",
106
+ "@orpc/shared": "1.8.3",
107
+ "@orpc/interop": "1.8.3",
108
+ "@orpc/client": "1.8.3",
109
+ "@orpc/standard-server-aws-lambda": "1.8.3",
110
+ "@orpc/standard-server-fetch": "1.8.3",
111
+ "@orpc/standard-server-node": "1.8.3",
112
+ "@orpc/standard-server": "1.8.3",
113
+ "@orpc/standard-server-peer": "1.8.3"
114
114
  },
115
115
  "devDependencies": {
116
116
  "@types/ws": "^8.18.1",
117
117
  "crossws": "^0.4.1",
118
- "next": "^15.4.5",
118
+ "next": "^15.5.0",
119
119
  "supertest": "^7.1.4",
120
120
  "ws": "^8.18.3"
121
121
  },