@orpc/server 0.0.0-next.ee0aeaf → 0.0.0-next.f22c7ec

Sign up to get free protection for your applications and to get access to all the features.
Files changed (51) hide show
  1. package/dist/chunk-2HRHHZJD.js +301 -0
  2. package/dist/chunk-SA7HGGVY.js +242 -0
  3. package/dist/chunk-WUOGVGWG.js +1 -0
  4. package/dist/fetch.js +11 -107
  5. package/dist/hono.js +30 -0
  6. package/dist/index.js +435 -291
  7. package/dist/next.js +36 -0
  8. package/dist/node.js +87 -0
  9. package/dist/src/adapters/fetch/index.d.ts +6 -0
  10. package/dist/src/adapters/fetch/orpc-handler.d.ts +20 -0
  11. package/dist/src/adapters/fetch/orpc-payload-codec.d.ts +16 -0
  12. package/dist/src/adapters/fetch/orpc-procedure-matcher.d.ts +12 -0
  13. package/dist/src/adapters/fetch/super-json.d.ts +12 -0
  14. package/dist/src/adapters/fetch/types.d.ts +21 -0
  15. package/dist/src/adapters/hono/index.d.ts +3 -0
  16. package/dist/src/adapters/hono/middleware.d.ts +12 -0
  17. package/dist/src/adapters/next/index.d.ts +3 -0
  18. package/dist/src/adapters/next/serve.d.ts +19 -0
  19. package/dist/src/adapters/node/index.d.ts +5 -0
  20. package/dist/src/adapters/node/orpc-handler.d.ts +12 -0
  21. package/dist/src/adapters/node/request-listener.d.ts +28 -0
  22. package/dist/src/adapters/node/types.d.ts +22 -0
  23. package/dist/src/builder.d.ts +33 -49
  24. package/dist/src/error.d.ts +10 -0
  25. package/dist/src/hidden.d.ts +6 -0
  26. package/dist/src/implementer-chainable.d.ts +10 -0
  27. package/dist/src/index.d.ts +12 -4
  28. package/dist/src/lazy-decorated.d.ts +7 -0
  29. package/dist/src/lazy-utils.d.ts +4 -0
  30. package/dist/src/lazy.d.ts +6 -11
  31. package/dist/src/middleware-decorated.d.ts +9 -0
  32. package/dist/src/middleware.d.ts +22 -12
  33. package/dist/src/procedure-builder.d.ts +19 -26
  34. package/dist/src/procedure-client.d.ts +22 -0
  35. package/dist/src/procedure-decorated.d.ts +25 -0
  36. package/dist/src/procedure-implementer.d.ts +17 -19
  37. package/dist/src/procedure-utils.d.ts +17 -0
  38. package/dist/src/procedure.d.ts +38 -26
  39. package/dist/src/router-builder.d.ts +27 -23
  40. package/dist/src/router-client.d.ts +26 -0
  41. package/dist/src/router-implementer.d.ts +17 -20
  42. package/dist/src/router.d.ts +11 -15
  43. package/dist/src/types.d.ts +8 -8
  44. package/package.json +22 -10
  45. package/dist/chunk-VARUID7X.js +0 -273
  46. package/dist/src/fetch/handle.d.ts +0 -7
  47. package/dist/src/fetch/handler.d.ts +0 -3
  48. package/dist/src/fetch/index.d.ts +0 -4
  49. package/dist/src/fetch/types.d.ts +0 -28
  50. package/dist/src/procedure-caller.d.ts +0 -26
  51. package/dist/src/router-caller.d.ts +0 -25
@@ -0,0 +1,301 @@
1
+ import {
2
+ __export,
3
+ createProcedureClient,
4
+ getRouterChild,
5
+ isProcedure,
6
+ unlazy
7
+ } from "./chunk-SA7HGGVY.js";
8
+
9
+ // src/adapters/fetch/super-json.ts
10
+ var super_json_exports = {};
11
+ __export(super_json_exports, {
12
+ deserialize: () => deserialize,
13
+ serialize: () => serialize
14
+ });
15
+
16
+ // ../../node_modules/.pnpm/is-what@5.0.2/node_modules/is-what/dist/getType.js
17
+ function getType(payload) {
18
+ return Object.prototype.toString.call(payload).slice(8, -1);
19
+ }
20
+
21
+ // ../../node_modules/.pnpm/is-what@5.0.2/node_modules/is-what/dist/isPlainObject.js
22
+ function isPlainObject(payload) {
23
+ if (getType(payload) !== "Object")
24
+ return false;
25
+ const prototype = Object.getPrototypeOf(payload);
26
+ return !!prototype && prototype.constructor === Object && prototype === Object.prototype;
27
+ }
28
+
29
+ // src/adapters/fetch/super-json.ts
30
+ function serialize(value, segments = [], meta = []) {
31
+ if (typeof value === "bigint") {
32
+ meta.push(["bigint", segments]);
33
+ return { data: value.toString(), meta };
34
+ }
35
+ if (value instanceof Date) {
36
+ meta.push(["date", segments]);
37
+ const data = Number.isNaN(value.getTime()) ? "Invalid Date" : value.toISOString();
38
+ return { data, meta };
39
+ }
40
+ if (Number.isNaN(value)) {
41
+ meta.push(["nan", segments]);
42
+ return { data: "NaN", meta };
43
+ }
44
+ if (value instanceof RegExp) {
45
+ meta.push(["regexp", segments]);
46
+ return { data: value.toString(), meta };
47
+ }
48
+ if (value instanceof URL) {
49
+ meta.push(["url", segments]);
50
+ return { data: value.toString(), meta };
51
+ }
52
+ if (isPlainObject(value)) {
53
+ const data = {};
54
+ for (const k in value) {
55
+ data[k] = serialize(value[k], [...segments, k], meta).data;
56
+ }
57
+ return { data, meta };
58
+ }
59
+ if (Array.isArray(value)) {
60
+ const data = value.map((v, i) => {
61
+ if (v === void 0) {
62
+ meta.push(["undefined", [...segments, i]]);
63
+ return null;
64
+ }
65
+ return serialize(v, [...segments, i], meta).data;
66
+ });
67
+ return { data, meta };
68
+ }
69
+ if (value instanceof Set) {
70
+ const result = serialize(Array.from(value), segments, meta);
71
+ meta.push(["set", segments]);
72
+ return result;
73
+ }
74
+ if (value instanceof Map) {
75
+ const result = serialize(Array.from(value.entries()), segments, meta);
76
+ meta.push(["map", segments]);
77
+ return result;
78
+ }
79
+ return { data: value, meta };
80
+ }
81
+ function deserialize({
82
+ data,
83
+ meta
84
+ }) {
85
+ if (meta.length === 0) {
86
+ return data;
87
+ }
88
+ const ref = { data };
89
+ for (const [type, segments] of meta) {
90
+ let currentRef = ref;
91
+ let preSegment = "data";
92
+ for (let i = 0; i < segments.length; i++) {
93
+ currentRef = currentRef[preSegment];
94
+ preSegment = segments[i];
95
+ }
96
+ switch (type) {
97
+ case "nan":
98
+ currentRef[preSegment] = Number.NaN;
99
+ break;
100
+ case "bigint":
101
+ currentRef[preSegment] = BigInt(currentRef[preSegment]);
102
+ break;
103
+ case "date":
104
+ currentRef[preSegment] = new Date(currentRef[preSegment]);
105
+ break;
106
+ case "regexp": {
107
+ const [, pattern, flags] = currentRef[preSegment].match(/^\/(.*)\/([a-z]*)$/);
108
+ currentRef[preSegment] = new RegExp(pattern, flags);
109
+ break;
110
+ }
111
+ case "url":
112
+ currentRef[preSegment] = new URL(currentRef[preSegment]);
113
+ break;
114
+ case "undefined":
115
+ currentRef[preSegment] = void 0;
116
+ break;
117
+ case "map":
118
+ currentRef[preSegment] = new Map(currentRef[preSegment]);
119
+ break;
120
+ case "set":
121
+ currentRef[preSegment] = new Set(currentRef[preSegment]);
122
+ break;
123
+ /* v8 ignore next 3 */
124
+ default: {
125
+ const _expected = type;
126
+ }
127
+ }
128
+ }
129
+ return ref.data;
130
+ }
131
+
132
+ // src/adapters/fetch/orpc-payload-codec.ts
133
+ import { ORPCError } from "@orpc/contract";
134
+ import { findDeepMatches, set } from "@orpc/shared";
135
+ var ORPCPayloadCodec = class {
136
+ /**
137
+ * If method is GET, the payload will be encoded as query string.
138
+ * If method is GET and payload contain file, the method will be fallback to fallbackMethod. (fallbackMethod = GET will force to use GET method)
139
+ */
140
+ encode(payload, method = "POST", fallbackMethod = "POST") {
141
+ const { data, meta } = serialize(payload);
142
+ const { maps, values } = findDeepMatches((v) => v instanceof Blob, data);
143
+ if (method === "GET" && (values.length === 0 || fallbackMethod === "GET")) {
144
+ const query = new URLSearchParams({
145
+ data: JSON.stringify(data),
146
+ meta: JSON.stringify(meta)
147
+ });
148
+ return {
149
+ query,
150
+ method: "GET"
151
+ };
152
+ }
153
+ const nonGETMethod = method === "GET" ? fallbackMethod : method;
154
+ if (values.length > 0) {
155
+ const form = new FormData();
156
+ if (data !== void 0) {
157
+ form.append("data", JSON.stringify(data));
158
+ }
159
+ form.append("meta", JSON.stringify(meta));
160
+ form.append("maps", JSON.stringify(maps));
161
+ for (const i in values) {
162
+ const value = values[i];
163
+ form.append(i, value);
164
+ }
165
+ return {
166
+ body: form,
167
+ method: nonGETMethod
168
+ };
169
+ }
170
+ return {
171
+ body: JSON.stringify({ data, meta }),
172
+ headers: new Headers({
173
+ "content-type": "application/json"
174
+ }),
175
+ method: nonGETMethod
176
+ };
177
+ }
178
+ async decode(re) {
179
+ try {
180
+ if ("method" in re && re.method === "GET") {
181
+ const url = new URL(re.url);
182
+ const query = url.searchParams;
183
+ const data = JSON.parse(query.getAll("data").at(-1));
184
+ const meta = JSON.parse(query.getAll("meta").at(-1));
185
+ return deserialize({
186
+ data,
187
+ meta
188
+ });
189
+ }
190
+ if (re.headers.get("content-type")?.startsWith("multipart/form-data")) {
191
+ const form = await re.formData();
192
+ const rawData = form.get("data");
193
+ const rawMeta = form.get("meta");
194
+ const rawMaps = form.get("maps");
195
+ let data = JSON.parse(rawData);
196
+ const meta = JSON.parse(rawMeta);
197
+ const maps = JSON.parse(rawMaps);
198
+ for (const i in maps) {
199
+ data = set(data, maps[i], form.get(i));
200
+ }
201
+ return deserialize({
202
+ data,
203
+ meta
204
+ });
205
+ }
206
+ const json = await re.json();
207
+ return deserialize(json);
208
+ } catch (e) {
209
+ throw new ORPCError({
210
+ code: "BAD_REQUEST",
211
+ message: "Cannot parse request/response. Please check the request/response body and Content-Type header.",
212
+ cause: e
213
+ });
214
+ }
215
+ }
216
+ };
217
+
218
+ // src/adapters/fetch/orpc-procedure-matcher.ts
219
+ import { trim } from "@orpc/shared";
220
+ var ORPCProcedureMatcher = class {
221
+ constructor(router) {
222
+ this.router = router;
223
+ }
224
+ async match(pathname) {
225
+ const path = trim(pathname, "/").split("/").map(decodeURIComponent);
226
+ const match = getRouterChild(this.router, ...path);
227
+ const { default: maybeProcedure } = await unlazy(match);
228
+ if (!isProcedure(maybeProcedure)) {
229
+ return void 0;
230
+ }
231
+ return {
232
+ procedure: maybeProcedure,
233
+ path
234
+ };
235
+ }
236
+ };
237
+
238
+ // src/adapters/fetch/orpc-handler.ts
239
+ import { ORPCError as ORPCError2 } from "@orpc/contract";
240
+ import { executeWithHooks, trim as trim2 } from "@orpc/shared";
241
+ var RPCHandler = class {
242
+ constructor(router, options) {
243
+ this.options = options;
244
+ this.procedureMatcher = options?.procedureMatcher ?? new ORPCProcedureMatcher(router);
245
+ this.payloadCodec = options?.payloadCodec ?? new ORPCPayloadCodec();
246
+ }
247
+ procedureMatcher;
248
+ payloadCodec;
249
+ async handle(request, ...[options]) {
250
+ const context = options?.context;
251
+ const execute = async () => {
252
+ const url = new URL(request.url);
253
+ const pathname = `/${trim2(url.pathname.replace(options?.prefix ?? "", ""), "/")}`;
254
+ const match = await this.procedureMatcher.match(pathname);
255
+ if (!match) {
256
+ return { matched: false, response: void 0 };
257
+ }
258
+ const input = await this.payloadCodec.decode(request);
259
+ const client = createProcedureClient(match.procedure, {
260
+ context,
261
+ path: match.path
262
+ });
263
+ const output = await client(input, { signal: request.signal });
264
+ const { body, headers } = this.payloadCodec.encode(output);
265
+ const response = new Response(body, { headers });
266
+ return { matched: true, response };
267
+ };
268
+ try {
269
+ const result = await executeWithHooks({
270
+ context,
271
+ execute,
272
+ input: request,
273
+ hooks: this.options,
274
+ meta: {
275
+ signal: request.signal
276
+ }
277
+ });
278
+ return result;
279
+ } catch (e) {
280
+ const error = e instanceof ORPCError2 ? e : new ORPCError2({
281
+ code: "INTERNAL_SERVER_ERROR",
282
+ message: "Internal server error",
283
+ cause: e
284
+ });
285
+ const { body, headers } = this.payloadCodec.encode(error.toJSON());
286
+ const response = new Response(body, {
287
+ headers,
288
+ status: error.status
289
+ });
290
+ return { matched: true, response };
291
+ }
292
+ }
293
+ };
294
+
295
+ export {
296
+ super_json_exports,
297
+ ORPCPayloadCodec,
298
+ ORPCProcedureMatcher,
299
+ RPCHandler
300
+ };
301
+ //# sourceMappingURL=chunk-2HRHHZJD.js.map
@@ -0,0 +1,242 @@
1
+ var __defProp = Object.defineProperty;
2
+ var __export = (target, all) => {
3
+ for (var name in all)
4
+ __defProp(target, name, { get: all[name], enumerable: true });
5
+ };
6
+
7
+ // src/utils.ts
8
+ function mergeContext(a, b) {
9
+ if (!a)
10
+ return b;
11
+ if (!b)
12
+ return a;
13
+ return {
14
+ ...a,
15
+ ...b
16
+ };
17
+ }
18
+
19
+ // src/procedure.ts
20
+ import { isContractProcedure } from "@orpc/contract";
21
+ var Procedure = class {
22
+ "~type" = "Procedure";
23
+ "~orpc";
24
+ constructor(def) {
25
+ this["~orpc"] = def;
26
+ }
27
+ };
28
+ function isProcedure(item) {
29
+ if (item instanceof Procedure) {
30
+ return true;
31
+ }
32
+ return (typeof item === "object" || typeof item === "function") && item !== null && "~type" in item && item["~type"] === "Procedure" && "~orpc" in item && typeof item["~orpc"] === "object" && item["~orpc"] !== null && "contract" in item["~orpc"] && isContractProcedure(item["~orpc"].contract) && "handler" in item["~orpc"] && typeof item["~orpc"].handler === "function";
33
+ }
34
+
35
+ // src/error.ts
36
+ import { ORPCError } from "@orpc/contract";
37
+ function createORPCErrorConstructorMap(errors) {
38
+ const constructors = {};
39
+ for (const code in errors) {
40
+ const config = errors[code];
41
+ if (!config) {
42
+ continue;
43
+ }
44
+ const constructor = (...[options]) => {
45
+ return new ORPCError({
46
+ code,
47
+ defined: true,
48
+ status: config.status,
49
+ message: options?.message ?? config.message,
50
+ data: options?.data,
51
+ cause: options?.cause
52
+ });
53
+ };
54
+ constructors[code] = constructor;
55
+ }
56
+ return constructors;
57
+ }
58
+
59
+ // src/lazy.ts
60
+ var LAZY_LOADER_SYMBOL = Symbol("ORPC_LAZY_LOADER");
61
+ function lazy(loader) {
62
+ return {
63
+ [LAZY_LOADER_SYMBOL]: loader
64
+ };
65
+ }
66
+ function isLazy(item) {
67
+ return (typeof item === "object" || typeof item === "function") && item !== null && LAZY_LOADER_SYMBOL in item && typeof item[LAZY_LOADER_SYMBOL] === "function";
68
+ }
69
+ function unlazy(lazied) {
70
+ return isLazy(lazied) ? lazied[LAZY_LOADER_SYMBOL]() : Promise.resolve({ default: lazied });
71
+ }
72
+ function flatLazy(lazied) {
73
+ const flattenLoader = async () => {
74
+ let current = await unlazy(lazied);
75
+ while (true) {
76
+ if (!isLazy(current.default)) {
77
+ break;
78
+ }
79
+ current = await unlazy(current.default);
80
+ }
81
+ return current;
82
+ };
83
+ return lazy(flattenLoader);
84
+ }
85
+
86
+ // src/middleware.ts
87
+ function middlewareOutputFn(output) {
88
+ return { output, context: void 0 };
89
+ }
90
+
91
+ // src/procedure-client.ts
92
+ import { ORPCError as ORPCError2, validateORPCError, ValidationError } from "@orpc/contract";
93
+ import { executeWithHooks, toError, value } from "@orpc/shared";
94
+ function createProcedureClient(lazyableProcedure, ...[options]) {
95
+ return async (...[input, callerOptions]) => {
96
+ const path = options?.path ?? [];
97
+ const { default: procedure } = await unlazy(lazyableProcedure);
98
+ const context = await value(options?.context, callerOptions?.context);
99
+ const errors = createORPCErrorConstructorMap(procedure["~orpc"].contract["~orpc"].errorMap);
100
+ const executeOptions = {
101
+ input,
102
+ context,
103
+ errors,
104
+ path,
105
+ procedure,
106
+ signal: callerOptions?.signal
107
+ };
108
+ try {
109
+ const output = await executeWithHooks({
110
+ hooks: options,
111
+ input,
112
+ context,
113
+ meta: executeOptions,
114
+ execute: () => executeProcedureInternal(procedure, executeOptions)
115
+ });
116
+ return output;
117
+ } catch (e) {
118
+ if (!(e instanceof ORPCError2)) {
119
+ throw toError(e);
120
+ }
121
+ const validated = await validateORPCError(procedure["~orpc"].contract["~orpc"].errorMap, e);
122
+ throw validated;
123
+ }
124
+ };
125
+ }
126
+ async function validateInput(procedure, input) {
127
+ const schema = procedure["~orpc"].contract["~orpc"].InputSchema;
128
+ if (!schema)
129
+ return input;
130
+ const result = await schema["~standard"].validate(input);
131
+ if (result.issues) {
132
+ throw new ORPCError2({
133
+ message: "Input validation failed",
134
+ code: "BAD_REQUEST",
135
+ data: {
136
+ issues: result.issues
137
+ },
138
+ cause: new ValidationError({ message: "Input validation failed", issues: result.issues })
139
+ });
140
+ }
141
+ return result.value;
142
+ }
143
+ async function validateOutput(procedure, output) {
144
+ const schema = procedure["~orpc"].contract["~orpc"].OutputSchema;
145
+ if (!schema)
146
+ return output;
147
+ const result = await schema["~standard"].validate(output);
148
+ if (result.issues) {
149
+ throw new ORPCError2({
150
+ message: "Output validation failed",
151
+ code: "INTERNAL_SERVER_ERROR",
152
+ cause: new ValidationError({ message: "Output validation failed", issues: result.issues })
153
+ });
154
+ }
155
+ return result.value;
156
+ }
157
+ function executeMiddlewareChain(middlewares, opt, input) {
158
+ let currentIndex = 0;
159
+ let currentContext = opt.context;
160
+ const executeMiddlewareChain2 = async (nextOptions) => {
161
+ const mid = middlewares[currentIndex];
162
+ currentIndex += 1;
163
+ currentContext = mergeContext(currentContext, nextOptions.context);
164
+ if (mid) {
165
+ return await mid({ ...opt, context: currentContext, next: executeMiddlewareChain2 }, input, middlewareOutputFn);
166
+ }
167
+ return opt.next({ context: currentContext });
168
+ };
169
+ return executeMiddlewareChain2({});
170
+ }
171
+ async function executeProcedureInternal(procedure, options) {
172
+ const executeHandler = async (context, input) => {
173
+ return await procedure["~orpc"].handler({ ...options, context, input });
174
+ };
175
+ const executePostMiddlewares = async (context, input) => {
176
+ const validatedInput = await validateInput(procedure, input);
177
+ const result2 = await executeMiddlewareChain(procedure["~orpc"].postMiddlewares, {
178
+ ...options,
179
+ context,
180
+ next: async ({ context: context2 }) => {
181
+ return middlewareOutputFn(
182
+ await executeHandler(context2, validatedInput)
183
+ );
184
+ }
185
+ }, validatedInput);
186
+ const validatedOutput = await validateOutput(procedure, result2.output);
187
+ return { ...result2, output: validatedOutput };
188
+ };
189
+ const result = await executeMiddlewareChain(procedure["~orpc"].preMiddlewares, {
190
+ ...options,
191
+ context: options.context,
192
+ next: ({ context }) => executePostMiddlewares(context, options.input)
193
+ }, options.input);
194
+ return result.output;
195
+ }
196
+
197
+ // src/router.ts
198
+ function getRouterChild(router, ...path) {
199
+ let current = router;
200
+ for (let i = 0; i < path.length; i++) {
201
+ const segment = path[i];
202
+ if (!current) {
203
+ return void 0;
204
+ }
205
+ if (isProcedure(current)) {
206
+ return void 0;
207
+ }
208
+ if (!isLazy(current)) {
209
+ current = current[segment];
210
+ continue;
211
+ }
212
+ const lazied = current;
213
+ const rest = path.slice(i);
214
+ const newLazy = lazy(async () => {
215
+ const unwrapped = await unlazy(lazied);
216
+ if (!unwrapped.default) {
217
+ return unwrapped;
218
+ }
219
+ const next = getRouterChild(unwrapped.default, ...rest);
220
+ return { default: next };
221
+ });
222
+ return flatLazy(newLazy);
223
+ }
224
+ return current;
225
+ }
226
+
227
+ export {
228
+ __export,
229
+ mergeContext,
230
+ Procedure,
231
+ isProcedure,
232
+ createORPCErrorConstructorMap,
233
+ LAZY_LOADER_SYMBOL,
234
+ lazy,
235
+ isLazy,
236
+ unlazy,
237
+ flatLazy,
238
+ middlewareOutputFn,
239
+ createProcedureClient,
240
+ getRouterChild
241
+ };
242
+ //# sourceMappingURL=chunk-SA7HGGVY.js.map
@@ -0,0 +1 @@
1
+ //# sourceMappingURL=chunk-WUOGVGWG.js.map
package/dist/fetch.js CHANGED
@@ -1,111 +1,15 @@
1
+ import "./chunk-WUOGVGWG.js";
1
2
  import {
2
- createProcedureCaller,
3
- isLazy,
4
- isProcedure
5
- } from "./chunk-VARUID7X.js";
6
-
7
- // src/fetch/handle.ts
8
- import { ORPCError } from "@orpc/shared/error";
9
- async function handleFetchRequest(options) {
10
- for (const handler of options.handlers) {
11
- const response = await handler(options);
12
- if (response) {
13
- return response;
14
- }
15
- }
16
- const error = new ORPCError({ code: "NOT_FOUND", message: "Not found" });
17
- return new Response(JSON.stringify(error.toJSON()), {
18
- status: error.status,
19
- headers: {
20
- "Content-Type": "application/json"
21
- }
22
- });
23
- }
24
-
25
- // src/fetch/handler.ts
26
- import { executeWithHooks, ORPC_PROTOCOL_HEADER, ORPC_PROTOCOL_VALUE, trim, value } from "@orpc/shared";
27
- import { ORPCError as ORPCError2 } from "@orpc/shared/error";
28
- import { ORPCDeserializer, ORPCSerializer } from "@orpc/transformer";
29
- var serializer = new ORPCSerializer();
30
- var deserializer = new ORPCDeserializer();
31
- function createORPCHandler() {
32
- return async (options) => {
33
- if (!options.request.headers.get(ORPC_PROTOCOL_HEADER)?.includes(ORPC_PROTOCOL_VALUE)) {
34
- return void 0;
35
- }
36
- const context = await value(options.context);
37
- const handler = async () => {
38
- const url = new URL(options.request.url);
39
- const pathname = `/${trim(url.pathname.replace(options.prefix ?? "", ""), "/")}`;
40
- const match = resolveORPCRouter(options.router, pathname);
41
- if (!match) {
42
- throw new ORPCError2({ code: "NOT_FOUND", message: "Not found" });
43
- }
44
- const input = await deserializeRequest(options.request);
45
- const caller = createProcedureCaller({
46
- context,
47
- procedure: match.procedure,
48
- path: match.path
49
- });
50
- const output = await caller(input, { signal: options.signal });
51
- const { body, headers } = serializer.serialize(output);
52
- return new Response(body, {
53
- status: 200,
54
- headers
55
- });
56
- };
57
- try {
58
- return await executeWithHooks({
59
- hooks: options,
60
- context,
61
- execute: handler,
62
- input: options.request,
63
- meta: {
64
- signal: options.signal
65
- }
66
- });
67
- } catch (e) {
68
- const error = e instanceof ORPCError2 ? e : new ORPCError2({
69
- code: "INTERNAL_SERVER_ERROR",
70
- message: "Internal server error",
71
- cause: e
72
- });
73
- const { body, headers } = serializer.serialize(error.toJSON());
74
- return new Response(body, {
75
- status: error.status,
76
- headers
77
- });
78
- }
79
- };
80
- }
81
- function resolveORPCRouter(router, pathname) {
82
- const path = trim(pathname, "/").split("/").map(decodeURIComponent);
83
- let current = router;
84
- for (const segment of path) {
85
- if (typeof current !== "object" && typeof current !== "function" || !current) {
86
- current = void 0;
87
- break;
88
- }
89
- current = current[segment];
90
- }
91
- return isProcedure(current) || isLazy(current) ? {
92
- procedure: current,
93
- path
94
- } : void 0;
95
- }
96
- async function deserializeRequest(request) {
97
- try {
98
- return await deserializer.deserialize(request);
99
- } catch (e) {
100
- throw new ORPCError2({
101
- code: "BAD_REQUEST",
102
- message: "Cannot parse request. Please check the request body and Content-Type header.",
103
- cause: e
104
- });
105
- }
106
- }
3
+ ORPCPayloadCodec,
4
+ ORPCProcedureMatcher,
5
+ RPCHandler,
6
+ super_json_exports
7
+ } from "./chunk-2HRHHZJD.js";
8
+ import "./chunk-SA7HGGVY.js";
107
9
  export {
108
- createORPCHandler,
109
- handleFetchRequest
10
+ ORPCPayloadCodec,
11
+ ORPCProcedureMatcher,
12
+ RPCHandler,
13
+ super_json_exports as SuperJSON
110
14
  };
111
15
  //# sourceMappingURL=fetch.js.map
package/dist/hono.js ADDED
@@ -0,0 +1,30 @@
1
+ import "./chunk-WUOGVGWG.js";
2
+ import {
3
+ ORPCPayloadCodec,
4
+ ORPCProcedureMatcher,
5
+ RPCHandler,
6
+ super_json_exports
7
+ } from "./chunk-2HRHHZJD.js";
8
+ import "./chunk-SA7HGGVY.js";
9
+
10
+ // src/adapters/hono/middleware.ts
11
+ import { value } from "@orpc/shared";
12
+ function createMiddleware(handler, ...[options]) {
13
+ return async (c, next) => {
14
+ const context = await value(options?.context, c);
15
+ const { matched, response } = await handler.handle(c.req.raw, { ...options, context });
16
+ if (matched) {
17
+ c.res = response;
18
+ return;
19
+ }
20
+ await next();
21
+ };
22
+ }
23
+ export {
24
+ ORPCPayloadCodec,
25
+ ORPCProcedureMatcher,
26
+ RPCHandler,
27
+ super_json_exports as SuperJSON,
28
+ createMiddleware
29
+ };
30
+ //# sourceMappingURL=hono.js.map