@orpc/server 0.0.0-next.19fea10 → 0.0.0-next.1a17b94
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 +128 -0
- package/dist/adapters/aws-lambda/index.d.mts +46 -0
- package/dist/adapters/aws-lambda/index.d.ts +46 -0
- package/dist/adapters/aws-lambda/index.mjs +42 -0
- package/dist/adapters/bun-ws/index.d.mts +36 -0
- package/dist/adapters/bun-ws/index.d.ts +36 -0
- package/dist/adapters/bun-ws/index.mjs +47 -0
- package/dist/adapters/crossws/index.d.mts +33 -0
- package/dist/adapters/crossws/index.d.ts +33 -0
- package/dist/adapters/crossws/index.mjs +45 -0
- package/dist/adapters/fetch/index.d.mts +124 -0
- package/dist/adapters/fetch/index.d.ts +124 -0
- package/dist/adapters/fetch/index.mjs +179 -0
- package/dist/adapters/message-port/index.d.mts +31 -0
- package/dist/adapters/message-port/index.d.ts +31 -0
- package/dist/adapters/message-port/index.mjs +39 -0
- package/dist/adapters/node/index.d.mts +99 -0
- package/dist/adapters/node/index.d.ts +99 -0
- package/dist/adapters/node/index.mjs +152 -0
- package/dist/adapters/standard/index.d.mts +21 -0
- package/dist/adapters/standard/index.d.ts +21 -0
- package/dist/adapters/standard/index.mjs +8 -0
- package/dist/adapters/standard-peer/index.d.mts +18 -0
- package/dist/adapters/standard-peer/index.d.ts +18 -0
- package/dist/adapters/standard-peer/index.mjs +7 -0
- package/dist/adapters/websocket/index.d.mts +54 -0
- package/dist/adapters/websocket/index.d.ts +54 -0
- package/dist/adapters/websocket/index.mjs +67 -0
- package/dist/adapters/ws/index.d.mts +31 -0
- package/dist/adapters/ws/index.d.ts +31 -0
- package/dist/adapters/ws/index.mjs +37 -0
- package/dist/helpers/index.d.mts +134 -0
- package/dist/helpers/index.d.ts +134 -0
- package/dist/helpers/index.mjs +188 -0
- package/dist/hibernation/index.d.mts +44 -0
- package/dist/hibernation/index.d.ts +44 -0
- package/dist/hibernation/index.mjs +65 -0
- package/dist/index.d.mts +803 -0
- package/dist/index.d.ts +803 -0
- package/dist/index.mjs +489 -0
- package/dist/plugins/index.d.mts +169 -0
- package/dist/plugins/index.d.ts +169 -0
- package/dist/plugins/index.mjs +285 -0
- package/dist/shared/server.7jWaIryJ.mjs +416 -0
- package/dist/shared/server.B7b2w3_i.d.ts +12 -0
- package/dist/shared/server.BEFBl-Cb.d.mts +12 -0
- package/dist/shared/server.BHZCyRuJ.mjs +219 -0
- package/dist/shared/server.BU4WI18A.d.mts +32 -0
- package/dist/shared/server.BW-nUGgA.mjs +36 -0
- package/dist/shared/server.Bmh5xd4n.d.ts +74 -0
- package/dist/shared/server.CYNGeoCm.d.mts +194 -0
- package/dist/shared/server.CYNGeoCm.d.ts +194 -0
- package/dist/shared/server.D0H-iaY3.d.ts +32 -0
- package/dist/shared/server.DZ5BIITo.mjs +9 -0
- package/dist/shared/server.DhJj-1X9.d.mts +42 -0
- package/dist/shared/server.UVMTOWrk.mjs +26 -0
- package/dist/shared/server.gqRxT-yN.d.mts +74 -0
- package/dist/shared/server.jMTkVNIb.d.ts +42 -0
- package/package.json +92 -18
- package/dist/chunk-MZXEMHFS.js +0 -272
- package/dist/fetch.js +0 -110
- package/dist/index.js +0 -467
- package/dist/src/builder.d.ts +0 -53
- package/dist/src/fetch/handle.d.ts +0 -7
- package/dist/src/fetch/handler.d.ts +0 -3
- package/dist/src/fetch/index.d.ts +0 -4
- package/dist/src/fetch/types.d.ts +0 -27
- package/dist/src/index.d.ts +0 -17
- package/dist/src/lazy.d.ts +0 -23
- package/dist/src/middleware.d.ts +0 -26
- package/dist/src/procedure-builder.d.ts +0 -31
- package/dist/src/procedure-caller.d.ts +0 -25
- package/dist/src/procedure-implementer.d.ts +0 -22
- package/dist/src/procedure.d.ts +0 -32
- package/dist/src/router-builder.d.ts +0 -27
- package/dist/src/router-caller.d.ts +0 -25
- package/dist/src/router-implementer.d.ts +0 -24
- package/dist/src/router.d.ts +0 -21
- package/dist/src/types.d.ts +0 -8
- package/dist/src/utils.d.ts +0 -3
@@ -0,0 +1,74 @@
|
|
1
|
+
import { HTTPPath, ORPCError } from '@orpc/client';
|
2
|
+
import { Meta } from '@orpc/contract';
|
3
|
+
import { Interceptor } from '@orpc/shared';
|
4
|
+
import { StandardResponse, StandardLazyRequest } from '@orpc/standard-server';
|
5
|
+
import { C as Context, R as Router, b as AnyRouter, A as AnyProcedure, d as ProcedureClientInterceptorOptions } from './server.CYNGeoCm.mjs';
|
6
|
+
|
7
|
+
interface StandardHandlerPlugin<T extends Context> {
|
8
|
+
order?: number;
|
9
|
+
init?(options: StandardHandlerOptions<T>, router: Router<any, T>): void;
|
10
|
+
}
|
11
|
+
declare class CompositeStandardHandlerPlugin<T extends Context, TPlugin extends StandardHandlerPlugin<T>> implements StandardHandlerPlugin<T> {
|
12
|
+
protected readonly plugins: TPlugin[];
|
13
|
+
constructor(plugins?: readonly TPlugin[]);
|
14
|
+
init(options: StandardHandlerOptions<T>, router: Router<any, T>): void;
|
15
|
+
}
|
16
|
+
|
17
|
+
type StandardParams = Record<string, string>;
|
18
|
+
type StandardMatchResult = {
|
19
|
+
path: readonly string[];
|
20
|
+
procedure: AnyProcedure;
|
21
|
+
params?: StandardParams;
|
22
|
+
} | undefined;
|
23
|
+
interface StandardMatcher {
|
24
|
+
init(router: AnyRouter): void;
|
25
|
+
match(method: string, pathname: HTTPPath): Promise<StandardMatchResult>;
|
26
|
+
}
|
27
|
+
interface StandardCodec {
|
28
|
+
encode(output: unknown, procedure: AnyProcedure): StandardResponse;
|
29
|
+
encodeError(error: ORPCError<any, any>): StandardResponse;
|
30
|
+
decode(request: StandardLazyRequest, params: StandardParams | undefined, procedure: AnyProcedure): Promise<unknown>;
|
31
|
+
}
|
32
|
+
|
33
|
+
interface StandardHandleOptions<T extends Context> {
|
34
|
+
prefix?: HTTPPath;
|
35
|
+
context: T;
|
36
|
+
}
|
37
|
+
type StandardHandleResult = {
|
38
|
+
matched: true;
|
39
|
+
response: StandardResponse;
|
40
|
+
} | {
|
41
|
+
matched: false;
|
42
|
+
response: undefined;
|
43
|
+
};
|
44
|
+
interface StandardHandlerInterceptorOptions<T extends Context> extends StandardHandleOptions<T> {
|
45
|
+
request: StandardLazyRequest;
|
46
|
+
}
|
47
|
+
interface StandardHandlerOptions<TContext extends Context> {
|
48
|
+
plugins?: StandardHandlerPlugin<TContext>[];
|
49
|
+
/**
|
50
|
+
* Interceptors at the request level, helpful when you want catch errors
|
51
|
+
*/
|
52
|
+
interceptors?: Interceptor<StandardHandlerInterceptorOptions<TContext>, Promise<StandardHandleResult>>[];
|
53
|
+
/**
|
54
|
+
* Interceptors at the root level, helpful when you want override the request/response
|
55
|
+
*/
|
56
|
+
rootInterceptors?: Interceptor<StandardHandlerInterceptorOptions<TContext>, Promise<StandardHandleResult>>[];
|
57
|
+
/**
|
58
|
+
*
|
59
|
+
* Interceptors for procedure client.
|
60
|
+
*/
|
61
|
+
clientInterceptors?: Interceptor<ProcedureClientInterceptorOptions<TContext, Record<never, never>, Meta>, Promise<unknown>>[];
|
62
|
+
}
|
63
|
+
declare class StandardHandler<T extends Context> {
|
64
|
+
private readonly matcher;
|
65
|
+
private readonly codec;
|
66
|
+
private readonly interceptors;
|
67
|
+
private readonly clientInterceptors;
|
68
|
+
private readonly rootInterceptors;
|
69
|
+
constructor(router: Router<any, T>, matcher: StandardMatcher, codec: StandardCodec, options: NoInfer<StandardHandlerOptions<T>>);
|
70
|
+
handle(request: StandardLazyRequest, options: StandardHandleOptions<T>): Promise<StandardHandleResult>;
|
71
|
+
}
|
72
|
+
|
73
|
+
export { CompositeStandardHandlerPlugin as C, StandardHandler as f };
|
74
|
+
export type { StandardCodec as S, StandardParams as a, StandardHandleOptions as b, StandardHandleResult as c, StandardHandlerInterceptorOptions as d, StandardHandlerOptions as e, StandardHandlerPlugin as g, StandardMatchResult as h, StandardMatcher as i };
|
@@ -0,0 +1,42 @@
|
|
1
|
+
import { ErrorMap, EnhanceRouteOptions, MergedErrorMap, AnyContractRouter, AnyContractProcedure } from '@orpc/contract';
|
2
|
+
import { a as AnyMiddleware, L as Lazyable, b as AnyRouter, C as Context, c as Lazy, A as AnyProcedure, P as Procedure, M as MergedInitialContext } from './server.CYNGeoCm.js';
|
3
|
+
|
4
|
+
declare function getRouter<T extends Lazyable<AnyRouter | undefined>>(router: T, path: readonly string[]): T extends Lazy<any> ? Lazy<AnyRouter | undefined> : Lazyable<AnyRouter | undefined>;
|
5
|
+
type AccessibleLazyRouter<T extends Lazyable<AnyRouter | undefined>> = T extends Lazy<infer U extends AnyRouter | undefined | Lazy<AnyRouter | undefined>> ? AccessibleLazyRouter<U> : T extends AnyProcedure | undefined ? Lazy<T> : Lazy<T> & {
|
6
|
+
[K in keyof T]: T[K] extends Lazyable<AnyRouter> ? AccessibleLazyRouter<T[K]> : never;
|
7
|
+
};
|
8
|
+
declare function createAccessibleLazyRouter<T extends Lazy<AnyRouter | undefined>>(lazied: T): AccessibleLazyRouter<T>;
|
9
|
+
type EnhancedRouter<T extends Lazyable<AnyRouter>, TInitialContext extends Context, TCurrentContext extends Context, TErrorMap extends ErrorMap> = T extends Lazy<infer U extends AnyRouter> ? AccessibleLazyRouter<EnhancedRouter<U, TInitialContext, TCurrentContext, TErrorMap>> : T extends Procedure<infer UInitialContext, infer UCurrentContext, infer UInputSchema, infer UOutputSchema, infer UErrorMap, infer UMeta> ? Procedure<MergedInitialContext<TInitialContext, UInitialContext, TCurrentContext>, UCurrentContext, UInputSchema, UOutputSchema, MergedErrorMap<TErrorMap, UErrorMap>, UMeta> : {
|
10
|
+
[K in keyof T]: T[K] extends Lazyable<AnyRouter> ? EnhancedRouter<T[K], TInitialContext, TCurrentContext, TErrorMap> : never;
|
11
|
+
};
|
12
|
+
interface EnhanceRouterOptions<TErrorMap extends ErrorMap> extends EnhanceRouteOptions {
|
13
|
+
middlewares: readonly AnyMiddleware[];
|
14
|
+
errorMap: TErrorMap;
|
15
|
+
dedupeLeadingMiddlewares: boolean;
|
16
|
+
}
|
17
|
+
declare function enhanceRouter<T extends Lazyable<AnyRouter>, TInitialContext extends Context, TCurrentContext extends Context, TErrorMap extends ErrorMap>(router: T, options: EnhanceRouterOptions<TErrorMap>): EnhancedRouter<T, TInitialContext, TCurrentContext, TErrorMap>;
|
18
|
+
interface TraverseContractProceduresOptions {
|
19
|
+
router: AnyContractRouter | AnyRouter;
|
20
|
+
path: readonly string[];
|
21
|
+
}
|
22
|
+
interface TraverseContractProcedureCallbackOptions {
|
23
|
+
contract: AnyContractProcedure | AnyProcedure;
|
24
|
+
path: readonly string[];
|
25
|
+
}
|
26
|
+
/**
|
27
|
+
* @deprecated Use `TraverseContractProcedureCallbackOptions` instead.
|
28
|
+
*/
|
29
|
+
type ContractProcedureCallbackOptions = TraverseContractProcedureCallbackOptions;
|
30
|
+
interface LazyTraverseContractProceduresOptions {
|
31
|
+
router: Lazy<AnyRouter>;
|
32
|
+
path: readonly string[];
|
33
|
+
}
|
34
|
+
declare function traverseContractProcedures(options: TraverseContractProceduresOptions, callback: (options: TraverseContractProcedureCallbackOptions) => void, lazyOptions?: LazyTraverseContractProceduresOptions[]): LazyTraverseContractProceduresOptions[];
|
35
|
+
declare function resolveContractProcedures(options: TraverseContractProceduresOptions, callback: (options: TraverseContractProcedureCallbackOptions) => void): Promise<void>;
|
36
|
+
type UnlaziedRouter<T extends AnyRouter> = T extends AnyProcedure ? T : {
|
37
|
+
[K in keyof T]: T[K] extends Lazyable<infer U extends AnyRouter> ? UnlaziedRouter<U> : never;
|
38
|
+
};
|
39
|
+
declare function unlazyRouter<T extends AnyRouter>(router: T): Promise<UnlaziedRouter<T>>;
|
40
|
+
|
41
|
+
export { createAccessibleLazyRouter as c, enhanceRouter as e, getRouter as g, resolveContractProcedures as r, traverseContractProcedures as t, unlazyRouter as u };
|
42
|
+
export type { AccessibleLazyRouter as A, ContractProcedureCallbackOptions as C, EnhanceRouterOptions as E, LazyTraverseContractProceduresOptions as L, TraverseContractProcedureCallbackOptions as T, UnlaziedRouter as U, EnhancedRouter as a, TraverseContractProceduresOptions as b };
|
package/package.json
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
{
|
2
2
|
"name": "@orpc/server",
|
3
3
|
"type": "module",
|
4
|
-
"version": "0.0.0-next.
|
4
|
+
"version": "0.0.0-next.1a17b94",
|
5
5
|
"license": "MIT",
|
6
6
|
"homepage": "https://orpc.unnoq.com",
|
7
7
|
"repository": {
|
@@ -15,38 +15,112 @@
|
|
15
15
|
],
|
16
16
|
"exports": {
|
17
17
|
".": {
|
18
|
-
"types": "./dist/
|
19
|
-
"import": "./dist/index.
|
20
|
-
"default": "./dist/index.
|
18
|
+
"types": "./dist/index.d.mts",
|
19
|
+
"import": "./dist/index.mjs",
|
20
|
+
"default": "./dist/index.mjs"
|
21
|
+
},
|
22
|
+
"./helpers": {
|
23
|
+
"types": "./dist/helpers/index.d.mts",
|
24
|
+
"import": "./dist/helpers/index.mjs",
|
25
|
+
"default": "./dist/helpers/index.mjs"
|
26
|
+
},
|
27
|
+
"./plugins": {
|
28
|
+
"types": "./dist/plugins/index.d.mts",
|
29
|
+
"import": "./dist/plugins/index.mjs",
|
30
|
+
"default": "./dist/plugins/index.mjs"
|
31
|
+
},
|
32
|
+
"./hibernation": {
|
33
|
+
"types": "./dist/hibernation/index.d.mts",
|
34
|
+
"import": "./dist/hibernation/index.mjs",
|
35
|
+
"default": "./dist/hibernation/index.mjs"
|
36
|
+
},
|
37
|
+
"./standard": {
|
38
|
+
"types": "./dist/adapters/standard/index.d.mts",
|
39
|
+
"import": "./dist/adapters/standard/index.mjs",
|
40
|
+
"default": "./dist/adapters/standard/index.mjs"
|
41
|
+
},
|
42
|
+
"./standard-peer": {
|
43
|
+
"types": "./dist/adapters/standard-peer/index.d.mts",
|
44
|
+
"import": "./dist/adapters/standard-peer/index.mjs",
|
45
|
+
"default": "./dist/adapters/standard-peer/index.mjs"
|
21
46
|
},
|
22
47
|
"./fetch": {
|
23
|
-
"types": "./dist/
|
24
|
-
"import": "./dist/fetch.
|
25
|
-
"default": "./dist/fetch.
|
48
|
+
"types": "./dist/adapters/fetch/index.d.mts",
|
49
|
+
"import": "./dist/adapters/fetch/index.mjs",
|
50
|
+
"default": "./dist/adapters/fetch/index.mjs"
|
51
|
+
},
|
52
|
+
"./node": {
|
53
|
+
"types": "./dist/adapters/node/index.d.mts",
|
54
|
+
"import": "./dist/adapters/node/index.mjs",
|
55
|
+
"default": "./dist/adapters/node/index.mjs"
|
56
|
+
},
|
57
|
+
"./aws-lambda": {
|
58
|
+
"types": "./dist/adapters/aws-lambda/index.d.mts",
|
59
|
+
"import": "./dist/adapters/aws-lambda/index.mjs",
|
60
|
+
"default": "./dist/adapters/aws-lambda/index.mjs"
|
26
61
|
},
|
27
|
-
"
|
28
|
-
"types": "./dist/
|
62
|
+
"./websocket": {
|
63
|
+
"types": "./dist/adapters/websocket/index.d.mts",
|
64
|
+
"import": "./dist/adapters/websocket/index.mjs",
|
65
|
+
"default": "./dist/adapters/websocket/index.mjs"
|
66
|
+
},
|
67
|
+
"./crossws": {
|
68
|
+
"types": "./dist/adapters/crossws/index.d.mts",
|
69
|
+
"import": "./dist/adapters/crossws/index.mjs",
|
70
|
+
"default": "./dist/adapters/crossws/index.mjs"
|
71
|
+
},
|
72
|
+
"./ws": {
|
73
|
+
"types": "./dist/adapters/ws/index.d.mts",
|
74
|
+
"import": "./dist/adapters/ws/index.mjs",
|
75
|
+
"default": "./dist/adapters/ws/index.mjs"
|
76
|
+
},
|
77
|
+
"./bun-ws": {
|
78
|
+
"types": "./dist/adapters/bun-ws/index.d.mts",
|
79
|
+
"import": "./dist/adapters/bun-ws/index.mjs",
|
80
|
+
"default": "./dist/adapters/bun-ws/index.mjs"
|
81
|
+
},
|
82
|
+
"./message-port": {
|
83
|
+
"types": "./dist/adapters/message-port/index.d.mts",
|
84
|
+
"import": "./dist/adapters/message-port/index.mjs",
|
85
|
+
"default": "./dist/adapters/message-port/index.mjs"
|
29
86
|
}
|
30
87
|
},
|
31
88
|
"files": [
|
32
|
-
"!**/*.map",
|
33
|
-
"!**/*.tsbuildinfo",
|
34
89
|
"dist"
|
35
90
|
],
|
36
91
|
"peerDependencies": {
|
37
|
-
"
|
38
|
-
"
|
92
|
+
"crossws": ">=0.3.4",
|
93
|
+
"ws": ">=8.18.1"
|
94
|
+
},
|
95
|
+
"peerDependenciesMeta": {
|
96
|
+
"crossws": {
|
97
|
+
"optional": true
|
98
|
+
},
|
99
|
+
"ws": {
|
100
|
+
"optional": true
|
101
|
+
}
|
39
102
|
},
|
40
103
|
"dependencies": {
|
41
|
-
"
|
42
|
-
"@orpc/
|
43
|
-
"@orpc/
|
104
|
+
"cookie": "^1.0.2",
|
105
|
+
"@orpc/client": "0.0.0-next.1a17b94",
|
106
|
+
"@orpc/interop": "0.0.0-next.1a17b94",
|
107
|
+
"@orpc/shared": "0.0.0-next.1a17b94",
|
108
|
+
"@orpc/standard-server": "0.0.0-next.1a17b94",
|
109
|
+
"@orpc/contract": "0.0.0-next.1a17b94",
|
110
|
+
"@orpc/standard-server-aws-lambda": "0.0.0-next.1a17b94",
|
111
|
+
"@orpc/standard-server-node": "0.0.0-next.1a17b94",
|
112
|
+
"@orpc/standard-server-fetch": "0.0.0-next.1a17b94",
|
113
|
+
"@orpc/standard-server-peer": "0.0.0-next.1a17b94"
|
44
114
|
},
|
45
115
|
"devDependencies": {
|
46
|
-
"@
|
116
|
+
"@types/ws": "^8.18.1",
|
117
|
+
"crossws": "^0.4.1",
|
118
|
+
"next": "^15.5.0",
|
119
|
+
"supertest": "^7.1.4",
|
120
|
+
"ws": "^8.18.3"
|
47
121
|
},
|
48
122
|
"scripts": {
|
49
|
-
"build": "
|
123
|
+
"build": "unbuild",
|
50
124
|
"build:watch": "pnpm run build --watch",
|
51
125
|
"type:check": "tsc -b"
|
52
126
|
}
|
package/dist/chunk-MZXEMHFS.js
DELETED
@@ -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
|
package/dist/fetch.js
DELETED
@@ -1,110 +0,0 @@
|
|
1
|
-
import {
|
2
|
-
createProcedureCaller,
|
3
|
-
isLazy,
|
4
|
-
isProcedure
|
5
|
-
} from "./chunk-MZXEMHFS.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 { ORPC_HEADER, ORPC_HEADER_VALUE } from "@orpc/contract";
|
27
|
-
import { executeWithHooks, trim, value } from "@orpc/shared";
|
28
|
-
import { ORPCError as ORPCError2 } from "@orpc/shared/error";
|
29
|
-
import { ORPCDeserializer, ORPCSerializer } from "@orpc/transformer";
|
30
|
-
var serializer = new ORPCSerializer();
|
31
|
-
var deserializer = new ORPCDeserializer();
|
32
|
-
function createORPCHandler() {
|
33
|
-
return async (options) => {
|
34
|
-
if (options.request.headers.get(ORPC_HEADER) !== ORPC_HEADER_VALUE) {
|
35
|
-
return void 0;
|
36
|
-
}
|
37
|
-
const context = await value(options.context);
|
38
|
-
const handler = async () => {
|
39
|
-
const url = new URL(options.request.url);
|
40
|
-
const pathname = `/${trim(url.pathname.replace(options.prefix ?? "", ""), "/")}`;
|
41
|
-
const match = resolveORPCRouter(options.router, pathname);
|
42
|
-
if (!match) {
|
43
|
-
throw new ORPCError2({ code: "NOT_FOUND", message: "Not found" });
|
44
|
-
}
|
45
|
-
const input = await deserializeRequest(options.request);
|
46
|
-
const caller = createProcedureCaller({
|
47
|
-
context,
|
48
|
-
procedure: match.procedure,
|
49
|
-
path: match.path
|
50
|
-
});
|
51
|
-
const output = await caller(input);
|
52
|
-
const { body, headers } = serializer.serialize(output);
|
53
|
-
return new Response(body, {
|
54
|
-
status: 200,
|
55
|
-
headers
|
56
|
-
});
|
57
|
-
};
|
58
|
-
try {
|
59
|
-
return await executeWithHooks({
|
60
|
-
hooks: options,
|
61
|
-
context,
|
62
|
-
execute: handler,
|
63
|
-
input: options.request,
|
64
|
-
meta: void 0
|
65
|
-
});
|
66
|
-
} catch (e) {
|
67
|
-
const error = e instanceof ORPCError2 ? e : new ORPCError2({
|
68
|
-
code: "INTERNAL_SERVER_ERROR",
|
69
|
-
message: "Internal server error",
|
70
|
-
cause: e
|
71
|
-
});
|
72
|
-
const { body, headers } = serializer.serialize(error.toJSON());
|
73
|
-
return new Response(body, {
|
74
|
-
status: error.status,
|
75
|
-
headers
|
76
|
-
});
|
77
|
-
}
|
78
|
-
};
|
79
|
-
}
|
80
|
-
function resolveORPCRouter(router, pathname) {
|
81
|
-
const path = trim(pathname, "/").split("/").map(decodeURIComponent);
|
82
|
-
let current = router;
|
83
|
-
for (const segment of path) {
|
84
|
-
if (typeof current !== "object" && typeof current !== "function" || !current) {
|
85
|
-
current = void 0;
|
86
|
-
break;
|
87
|
-
}
|
88
|
-
current = current[segment];
|
89
|
-
}
|
90
|
-
return isProcedure(current) || isLazy(current) ? {
|
91
|
-
procedure: current,
|
92
|
-
path
|
93
|
-
} : void 0;
|
94
|
-
}
|
95
|
-
async function deserializeRequest(request) {
|
96
|
-
try {
|
97
|
-
return await deserializer.deserialize(request);
|
98
|
-
} catch (e) {
|
99
|
-
throw new ORPCError2({
|
100
|
-
code: "BAD_REQUEST",
|
101
|
-
message: "Cannot parse request. Please check the request body and Content-Type header.",
|
102
|
-
cause: e
|
103
|
-
});
|
104
|
-
}
|
105
|
-
}
|
106
|
-
export {
|
107
|
-
createORPCHandler,
|
108
|
-
handleFetchRequest
|
109
|
-
};
|
110
|
-
//# sourceMappingURL=fetch.js.map
|