@orpc/server 0.0.0-next.6a8bf13 → 0.0.0-next.748dfd9

Sign up to get free protection for your applications and to get access to all the features.
Files changed (49) hide show
  1. package/dist/chunk-3BAPJGK6.js +302 -0
  2. package/dist/chunk-E7GUWVR4.js +186 -0
  3. package/dist/chunk-WUOGVGWG.js +1 -0
  4. package/dist/fetch.js +11 -106
  5. package/dist/hono.js +30 -0
  6. package/dist/index.js +371 -317
  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 +26 -44
  24. package/dist/src/hidden.d.ts +6 -0
  25. package/dist/src/implementer-chainable.d.ts +10 -0
  26. package/dist/src/index.d.ts +10 -3
  27. package/dist/src/lazy-decorated.d.ts +10 -0
  28. package/dist/src/lazy-utils.d.ts +4 -0
  29. package/dist/src/lazy.d.ts +6 -11
  30. package/dist/src/middleware-decorated.d.ts +8 -0
  31. package/dist/src/middleware.d.ts +18 -11
  32. package/dist/src/procedure-builder.d.ts +15 -24
  33. package/dist/src/procedure-client.d.ts +34 -0
  34. package/dist/src/procedure-decorated.d.ts +14 -0
  35. package/dist/src/procedure-implementer.d.ts +13 -17
  36. package/dist/src/procedure.d.ts +23 -25
  37. package/dist/src/router-builder.d.ts +23 -21
  38. package/dist/src/router-client.d.ts +25 -0
  39. package/dist/src/router-implementer.d.ts +18 -21
  40. package/dist/src/router.d.ts +11 -16
  41. package/dist/src/types.d.ts +10 -4
  42. package/package.json +22 -11
  43. package/dist/chunk-MZXEMHFS.js +0 -272
  44. package/dist/src/fetch/handle.d.ts +0 -7
  45. package/dist/src/fetch/handler.d.ts +0 -3
  46. package/dist/src/fetch/index.d.ts +0 -4
  47. package/dist/src/fetch/types.d.ts +0 -27
  48. package/dist/src/procedure-caller.d.ts +0 -25
  49. package/dist/src/router-caller.d.ts +0 -25
@@ -1,272 +0,0 @@
1
- // src/utils.ts
2
- function mergeContext(a, b) {
3
- if (!a)
4
- return b;
5
- if (!b)
6
- return a;
7
- return {
8
- ...a,
9
- ...b
10
- };
11
- }
12
-
13
- // src/middleware.ts
14
- var decoratedMiddlewareSymbol = Symbol("\u{1F512}decoratedMiddleware");
15
- function decorateMiddleware(middleware) {
16
- if (Reflect.get(middleware, decoratedMiddlewareSymbol)) {
17
- return middleware;
18
- }
19
- const concat = (concatMiddleware, mapInput2) => {
20
- const concatMiddleware_ = mapInput2 ? decorateMiddleware(concatMiddleware).mapInput(mapInput2) : concatMiddleware;
21
- return decorateMiddleware(async (input, context, meta, ...rest) => {
22
- const input_ = input;
23
- const context_ = context;
24
- const meta_ = meta;
25
- const next = async (options) => {
26
- return concatMiddleware_(input_, mergeContext(context_, options.context), meta_, ...rest);
27
- };
28
- const m1 = await middleware(input_, context_, {
29
- ...meta_,
30
- next
31
- }, ...rest);
32
- return m1;
33
- });
34
- };
35
- const mapInput = (map) => {
36
- return decorateMiddleware(
37
- (input, ...rest) => middleware(map(input), ...rest)
38
- );
39
- };
40
- return Object.assign(middleware, {
41
- [decoratedMiddlewareSymbol]: true,
42
- concat,
43
- mapInput
44
- });
45
- }
46
-
47
- // src/procedure-caller.ts
48
- import { executeWithHooks, trim, value } from "@orpc/shared";
49
- import { ORPCError } from "@orpc/shared/error";
50
-
51
- // src/procedure.ts
52
- import {
53
- DecoratedContractProcedure,
54
- isContractProcedure
55
- } from "@orpc/contract";
56
- var Procedure = class {
57
- constructor(zz$p) {
58
- this.zz$p = zz$p;
59
- }
60
- };
61
- var DECORATED_PROCEDURE_SYMBOL = Symbol("DECORATED_PROCEDURE");
62
- function decorateProcedure(procedure) {
63
- if (DECORATED_PROCEDURE_SYMBOL in procedure) {
64
- return procedure;
65
- }
66
- return Object.assign(createProcedureCaller({
67
- procedure,
68
- context: void 0
69
- }), {
70
- [DECORATED_PROCEDURE_SYMBOL]: true,
71
- zz$p: procedure.zz$p,
72
- prefix(prefix) {
73
- return decorateProcedure({
74
- zz$p: {
75
- ...procedure.zz$p,
76
- contract: DecoratedContractProcedure.decorate(
77
- procedure.zz$p.contract
78
- ).prefix(prefix)
79
- }
80
- });
81
- },
82
- route(opts) {
83
- return decorateProcedure({
84
- zz$p: {
85
- ...procedure.zz$p,
86
- contract: DecoratedContractProcedure.decorate(
87
- procedure.zz$p.contract
88
- ).route(opts)
89
- }
90
- });
91
- },
92
- use(middleware, mapInput) {
93
- const middleware_ = mapInput ? decorateMiddleware(middleware).mapInput(mapInput) : middleware;
94
- return decorateProcedure({
95
- zz$p: {
96
- ...procedure.zz$p,
97
- middlewares: [middleware_, ...procedure.zz$p.middlewares ?? []]
98
- }
99
- });
100
- }
101
- });
102
- }
103
- function isProcedure(item) {
104
- if (item instanceof Procedure)
105
- return true;
106
- return (typeof item === "object" || typeof item === "function") && item !== null && "zz$p" in item && typeof item.zz$p === "object" && item.zz$p !== null && "contract" in item.zz$p && isContractProcedure(item.zz$p.contract) && "func" in item.zz$p && typeof item.zz$p.func === "function";
107
- }
108
-
109
- // src/procedure-caller.ts
110
- function createProcedureCaller(options) {
111
- const caller = async (input) => {
112
- const path = options.path ?? [];
113
- const procedure = await loadProcedure(options.procedure);
114
- const context = await value(options.context);
115
- const execute = async () => {
116
- const validInput = (() => {
117
- const schema = procedure.zz$p.contract.zz$cp.InputSchema;
118
- if (!schema) {
119
- return input;
120
- }
121
- try {
122
- return schema.parse(input);
123
- } catch (e) {
124
- throw new ORPCError({
125
- message: "Validation input failed",
126
- code: "BAD_REQUEST",
127
- cause: e
128
- });
129
- }
130
- })();
131
- const middlewares = procedure.zz$p.middlewares ?? [];
132
- let currentMidIndex = 0;
133
- let currentContext = context;
134
- const next = async (nextOptions) => {
135
- const mid = middlewares[currentMidIndex];
136
- currentMidIndex += 1;
137
- currentContext = mergeContext(currentContext, nextOptions.context);
138
- if (mid) {
139
- return await mid(validInput, currentContext, {
140
- path,
141
- procedure,
142
- next,
143
- output: (output3) => ({ output: output3, context: void 0 })
144
- });
145
- } else {
146
- return {
147
- output: await await procedure.zz$p.func(validInput, currentContext, {
148
- path,
149
- procedure
150
- }),
151
- context: currentContext
152
- };
153
- }
154
- };
155
- const output2 = (await next({})).output;
156
- const validOutput = await (async () => {
157
- const schema = procedure.zz$p.contract.zz$cp.OutputSchema;
158
- if (!schema) {
159
- return output2;
160
- }
161
- const result = await schema.safeParseAsync(output2);
162
- if (result.error) {
163
- throw new ORPCError({
164
- message: "Validation output failed",
165
- code: "INTERNAL_SERVER_ERROR",
166
- cause: result.error
167
- });
168
- }
169
- return result.data;
170
- })();
171
- return validOutput;
172
- };
173
- const output = await executeWithHooks({
174
- hooks: options,
175
- input,
176
- context,
177
- meta: {
178
- path,
179
- procedure
180
- },
181
- execute
182
- });
183
- return output;
184
- };
185
- return caller;
186
- }
187
- async function loadProcedure(procedure) {
188
- let loadedProcedure;
189
- if (isLazy(procedure)) {
190
- loadedProcedure = (await loadLazy(procedure)).default;
191
- } else {
192
- loadedProcedure = procedure;
193
- }
194
- if (!isProcedure(loadedProcedure)) {
195
- throw new ORPCError({
196
- code: "NOT_FOUND",
197
- message: "Not found",
198
- cause: new Error(trim(`
199
- This error should be caught by the typescript compiler.
200
- But if you still see this error, it means that you trying to call a lazy router (expected to be a lazy procedure).
201
- `))
202
- });
203
- }
204
- return loadedProcedure;
205
- }
206
-
207
- // src/lazy.ts
208
- var LAZY_LOADER_SYMBOL = Symbol("ORPC_LAZY_LOADER");
209
- function createLazy(loader) {
210
- return {
211
- [LAZY_LOADER_SYMBOL]: loader
212
- };
213
- }
214
- function loadLazy(lazy) {
215
- return lazy[LAZY_LOADER_SYMBOL]();
216
- }
217
- function isLazy(item) {
218
- return (typeof item === "object" || typeof item === "function") && item !== null && LAZY_LOADER_SYMBOL in item && typeof item[LAZY_LOADER_SYMBOL] === "function";
219
- }
220
- function createFlattenLazy(lazy) {
221
- const flattenLoader = async () => {
222
- let current = await loadLazy(lazy);
223
- while (true) {
224
- if (!isLazy(current.default)) {
225
- break;
226
- }
227
- current = await loadLazy(current.default);
228
- }
229
- return current;
230
- };
231
- const flattenLazy = {
232
- [LAZY_LOADER_SYMBOL]: flattenLoader
233
- };
234
- return flattenLazy;
235
- }
236
- function decorateLazy(lazy) {
237
- const flattenLazy = createFlattenLazy(lazy);
238
- const procedureCaller = createProcedureCaller({
239
- procedure: flattenLazy,
240
- context: void 0
241
- });
242
- Object.assign(procedureCaller, flattenLazy);
243
- const recursive = new Proxy(procedureCaller, {
244
- get(target, key) {
245
- if (typeof key !== "string") {
246
- return Reflect.get(target, key);
247
- }
248
- return decorateLazy(createLazy(async () => {
249
- const current = await loadLazy(flattenLazy);
250
- return { default: current.default[key] };
251
- }));
252
- }
253
- });
254
- return recursive;
255
- }
256
-
257
- export {
258
- mergeContext,
259
- decorateMiddleware,
260
- LAZY_LOADER_SYMBOL,
261
- createLazy,
262
- loadLazy,
263
- isLazy,
264
- createFlattenLazy,
265
- decorateLazy,
266
- createProcedureCaller,
267
- loadProcedure,
268
- Procedure,
269
- decorateProcedure,
270
- isProcedure
271
- };
272
- //# sourceMappingURL=chunk-MZXEMHFS.js.map
@@ -1,7 +0,0 @@
1
- import type { Router } from '../router';
2
- import type { FetchHandler, FetchHandlerOptions } from './types';
3
- export type HandleFetchRequestOptions<TRouter extends Router<any>> = FetchHandlerOptions<TRouter> & {
4
- handlers: readonly [FetchHandler, ...FetchHandler[]];
5
- };
6
- export declare function handleFetchRequest<TRouter extends Router<any>>(options: HandleFetchRequestOptions<TRouter>): Promise<Response>;
7
- //# sourceMappingURL=handle.d.ts.map
@@ -1,3 +0,0 @@
1
- import type { FetchHandler } from './types';
2
- export declare function createORPCHandler(): FetchHandler;
3
- //# sourceMappingURL=handler.d.ts.map
@@ -1,4 +0,0 @@
1
- export * from './handle';
2
- export * from './handler';
3
- export * from './types';
4
- //# sourceMappingURL=index.d.ts.map
@@ -1,27 +0,0 @@
1
- import type { Hooks, PartialOnUndefinedDeep, Value } from '@orpc/shared';
2
- import type { Router } from '../router';
3
- export type FetchHandlerOptions<TRouter extends Router<any>> = {
4
- /**
5
- * The `router` used for handling the request and routing,
6
- *
7
- */
8
- router: TRouter;
9
- /**
10
- * The request need to be handled.
11
- */
12
- request: Request;
13
- /**
14
- * Remove the prefix from the request path.
15
- *
16
- * @example /orpc
17
- * @example /api
18
- */
19
- prefix?: string;
20
- } & PartialOnUndefinedDeep<{
21
- /**
22
- * The context used to handle the request.
23
- */
24
- context: Value<TRouter extends Router<infer UContext> ? UContext : never>;
25
- }> & Hooks<Request, Response, TRouter extends Router<infer UContext> ? UContext : never, undefined>;
26
- export type FetchHandler = <TRouter extends Router<any>>(options: FetchHandlerOptions<TRouter>) => Promise<Response | undefined>;
27
- //# sourceMappingURL=types.d.ts.map
@@ -1,25 +0,0 @@
1
- import type { SchemaInput, SchemaOutput } from '@orpc/contract';
2
- import type { Hooks, PartialOnUndefinedDeep, Value } from '@orpc/shared';
3
- import type { Lazy } from './lazy';
4
- import type { ANY_LAZY_PROCEDURE, ANY_PROCEDURE, Procedure } from './procedure';
5
- export type CreateProcedureCallerOptions<T extends ANY_PROCEDURE | ANY_LAZY_PROCEDURE> = T extends Procedure<infer UContext, any, any, infer UOutputSchema, infer UFuncOutput> | Lazy<Procedure<infer UContext, any, any, infer UOutputSchema, infer UFuncOutput>> ? {
6
- procedure: T;
7
- /**
8
- * This is helpful for logging and analytics.
9
- *
10
- * @internal
11
- */
12
- path?: string[];
13
- } & PartialOnUndefinedDeep<{
14
- /**
15
- * The context used when calling the procedure.
16
- */
17
- context: Value<UContext>;
18
- }> & Hooks<unknown, SchemaOutput<UOutputSchema, UFuncOutput>, UContext, {
19
- path: string[];
20
- procedure: ANY_PROCEDURE;
21
- }> : never;
22
- export type ProcedureCaller<TProcedure extends ANY_PROCEDURE | ANY_LAZY_PROCEDURE> = TProcedure extends Procedure<any, any, infer UInputSchema, infer UOutputSchema, infer UFuncOutput> | Lazy<Procedure<any, any, infer UInputSchema, infer UOutputSchema, infer UFuncOutput>> ? (...input: [input: SchemaInput<UInputSchema>] | (undefined extends SchemaInput<UInputSchema> ? [] : never)) => Promise<SchemaOutput<UOutputSchema, UFuncOutput>> : never;
23
- export declare function createProcedureCaller<TProcedure extends ANY_PROCEDURE | ANY_LAZY_PROCEDURE>(options: CreateProcedureCallerOptions<TProcedure>): ProcedureCaller<TProcedure>;
24
- export declare function loadProcedure(procedure: ANY_PROCEDURE | ANY_LAZY_PROCEDURE): Promise<ANY_PROCEDURE>;
25
- //# sourceMappingURL=procedure-caller.d.ts.map
@@ -1,25 +0,0 @@
1
- import type { Hooks, Value } from '@orpc/shared';
2
- import type { ANY_LAZY_PROCEDURE, ANY_PROCEDURE } from './procedure';
3
- import type { Router } from './router';
4
- import { type ProcedureCaller } from './procedure-caller';
5
- export interface CreateRouterCallerOptions<TRouter extends Router<any>> extends Hooks<unknown, unknown, TRouter extends Router<infer UContext> ? UContext : never, {
6
- path: string[];
7
- procedure: ANY_PROCEDURE;
8
- }> {
9
- router: TRouter;
10
- /**
11
- * The context used when calling the procedure.
12
- */
13
- context: Value<TRouter extends Router<infer UContext> ? UContext : never>;
14
- /**
15
- * This is helpful for logging and analytics.
16
- *
17
- * @internal
18
- */
19
- basePath?: string[];
20
- }
21
- export type RouterCaller<TRouter extends Router<any>> = {
22
- [K in keyof TRouter]: TRouter[K] extends ANY_PROCEDURE | ANY_LAZY_PROCEDURE ? ProcedureCaller<TRouter[K]> : TRouter[K] extends Router<any> ? RouterCaller<TRouter[K]> : never;
23
- };
24
- export declare function createRouterCaller<TRouter extends Router<any>>(options: CreateRouterCallerOptions<TRouter>): RouterCaller<TRouter>;
25
- //# sourceMappingURL=router-caller.d.ts.map