phecda-server 4.0.4 → 4.0.6
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/dist/{chunk-YU7ROHTO.js → chunk-7OB6K45T.js} +78 -66
- package/dist/chunk-7OB6K45T.js.map +1 -0
- package/dist/{chunk-LZAU5FUS.js → chunk-AAF47ZC6.js} +9 -3
- package/dist/chunk-AAF47ZC6.js.map +1 -0
- package/dist/{chunk-AJ2HYENF.mjs → chunk-AYJWOIAW.mjs} +10 -4
- package/dist/chunk-AYJWOIAW.mjs.map +1 -0
- package/dist/{chunk-Q6T7HNEO.mjs → chunk-GSJ5A2MA.mjs} +43 -31
- package/dist/chunk-GSJ5A2MA.mjs.map +1 -0
- package/dist/{chunk-JUXEUWOU.mjs → chunk-K32VRTXB.mjs} +32 -18
- package/dist/chunk-K32VRTXB.mjs.map +1 -0
- package/dist/{chunk-W64EUEDU.js → chunk-TZ27DHWL.js} +51 -37
- package/dist/chunk-TZ27DHWL.js.map +1 -0
- package/dist/{chunk-JQPX546Z.mjs → chunk-V7SC5EVJ.mjs} +2 -2
- package/dist/{chunk-FAHHXHL5.js → chunk-ZPMAM4LQ.js} +3 -3
- package/dist/{core-7c2dd0c7.d.ts → core-c27b4cf4.d.ts} +3 -2
- package/dist/index.d.ts +45 -26
- package/dist/index.js +119 -54
- package/dist/index.js.map +1 -1
- package/dist/index.mjs +98 -33
- package/dist/index.mjs.map +1 -1
- package/dist/rpc/rabbitmq/index.d.ts +2 -2
- package/dist/rpc/rabbitmq/index.js +19 -13
- package/dist/rpc/rabbitmq/index.js.map +1 -1
- package/dist/rpc/rabbitmq/index.mjs +13 -7
- package/dist/rpc/rabbitmq/index.mjs.map +1 -1
- package/dist/rpc/redis/index.d.ts +2 -2
- package/dist/rpc/redis/index.js +19 -13
- package/dist/rpc/redis/index.js.map +1 -1
- package/dist/rpc/redis/index.mjs +13 -7
- package/dist/rpc/redis/index.mjs.map +1 -1
- package/dist/server/express/index.d.ts +4 -3
- package/dist/server/express/index.js +37 -29
- package/dist/server/express/index.js.map +1 -1
- package/dist/server/express/index.mjs +19 -11
- package/dist/server/express/index.mjs.map +1 -1
- package/dist/server/fastify/index.d.ts +3 -2
- package/dist/server/fastify/index.js +33 -25
- package/dist/server/fastify/index.js.map +1 -1
- package/dist/server/fastify/index.mjs +18 -10
- package/dist/server/fastify/index.mjs.map +1 -1
- package/dist/server/h3/index.d.ts +6 -5
- package/dist/server/h3/index.js +34 -28
- package/dist/server/h3/index.js.map +1 -1
- package/dist/server/h3/index.mjs +16 -10
- package/dist/server/h3/index.mjs.map +1 -1
- package/dist/server/koa/index.d.ts +3 -2
- package/dist/server/koa/index.js +36 -28
- package/dist/server/koa/index.js.map +1 -1
- package/dist/server/koa/index.mjs +18 -10
- package/dist/server/koa/index.mjs.map +1 -1
- package/dist/test.d.ts +1 -1
- package/dist/test.js +6 -6
- package/dist/test.mjs +2 -2
- package/dist/{types-ead02c5d.d.ts → types-8415bd5d.d.ts} +16 -17
- package/package.json +1 -1
- package/register/compile.mjs +3 -7
- package/register/loader.mjs +0 -1
- package/dist/chunk-AJ2HYENF.mjs.map +0 -1
- package/dist/chunk-JUXEUWOU.mjs.map +0 -1
- package/dist/chunk-LZAU5FUS.js.map +0 -1
- package/dist/chunk-Q6T7HNEO.mjs.map +0 -1
- package/dist/chunk-W64EUEDU.js.map +0 -1
- package/dist/chunk-YU7ROHTO.js.map +0 -1
- /package/dist/{chunk-JQPX546Z.mjs.map → chunk-V7SC5EVJ.mjs.map} +0 -0
- /package/dist/{chunk-FAHHXHL5.js.map → chunk-ZPMAM4LQ.js.map} +0 -0
package/dist/rpc/redis/index.js
CHANGED
|
@@ -2,11 +2,11 @@
|
|
|
2
2
|
|
|
3
3
|
|
|
4
4
|
|
|
5
|
-
var
|
|
5
|
+
var _chunk7OB6K45Tjs = require('../../chunk-7OB6K45T.js');
|
|
6
6
|
|
|
7
7
|
|
|
8
8
|
|
|
9
|
-
var
|
|
9
|
+
var _chunkAAF47ZC6js = require('../../chunk-AAF47ZC6.js');
|
|
10
10
|
|
|
11
11
|
// src/rpc/redis/bind.ts
|
|
12
12
|
var _ioredis = require('ioredis'); var _ioredis2 = _interopRequireDefault(_ioredis);
|
|
@@ -14,7 +14,7 @@ function bind(redis, channel, { moduleMap, meta }, opts) {
|
|
|
14
14
|
const metaMap = /* @__PURE__ */ new Map();
|
|
15
15
|
const pub = new (0, _ioredis2.default)(redis.options);
|
|
16
16
|
const { globalGuards = [], globalInterceptors = [] } = opts || {};
|
|
17
|
-
|
|
17
|
+
_chunk7OB6K45Tjs.isAopDepInject.call(void 0, meta, {
|
|
18
18
|
guards: globalGuards,
|
|
19
19
|
interceptors: globalInterceptors
|
|
20
20
|
});
|
|
@@ -25,14 +25,14 @@ function bind(redis, channel, { moduleMap, meta }, opts) {
|
|
|
25
25
|
metaMap.set(`${name}-${method}`, item);
|
|
26
26
|
}
|
|
27
27
|
}
|
|
28
|
-
|
|
28
|
+
_chunkAAF47ZC6js.__name.call(void 0, handleMeta, "handleMeta");
|
|
29
29
|
handleMeta();
|
|
30
30
|
redis.subscribe(channel);
|
|
31
31
|
redis.on("message", async (channel2, msg) => {
|
|
32
32
|
if (msg) {
|
|
33
33
|
const data = JSON.parse(msg);
|
|
34
34
|
const { tag, args, id, queue } = data;
|
|
35
|
-
const context = new (0,
|
|
35
|
+
const context = new (0, _chunk7OB6K45Tjs.Context)(tag, {
|
|
36
36
|
type: "redis",
|
|
37
37
|
moduleMap,
|
|
38
38
|
redis,
|
|
@@ -41,10 +41,16 @@ function bind(redis, channel, { moduleMap, meta }, opts) {
|
|
|
41
41
|
channel: channel2,
|
|
42
42
|
data
|
|
43
43
|
});
|
|
44
|
+
if (!metaMap.has(tag)) {
|
|
45
|
+
queue && pub.publish(queue, JSON.stringify({
|
|
46
|
+
data: new (0, _chunk7OB6K45Tjs.BadRequestException)(`service "${tag}" doesn't exist`).data,
|
|
47
|
+
error: true,
|
|
48
|
+
id
|
|
49
|
+
}));
|
|
50
|
+
return;
|
|
51
|
+
}
|
|
52
|
+
const { data: { guards, interceptors, params, name, method, filter }, paramsType } = metaMap.get(tag);
|
|
44
53
|
try {
|
|
45
|
-
if (!metaMap.has(tag))
|
|
46
|
-
throw new (0, _chunkYU7ROHTOjs.BadRequestException)(`service "${tag}" doesn't exist`);
|
|
47
|
-
const { data: { guards, interceptors, params, name, method }, paramsType } = metaMap.get(tag);
|
|
48
54
|
await context.useGuard([
|
|
49
55
|
...globalGuards,
|
|
50
56
|
...guards
|
|
@@ -79,22 +85,22 @@ function bind(redis, channel, { moduleMap, meta }, opts) {
|
|
|
79
85
|
id
|
|
80
86
|
}));
|
|
81
87
|
} catch (e) {
|
|
82
|
-
const ret = await context.useFilter(e);
|
|
88
|
+
const ret = await context.useFilter(e, filter);
|
|
83
89
|
queue && pub.publish(queue, JSON.stringify({
|
|
84
90
|
data: ret,
|
|
85
|
-
error:
|
|
91
|
+
error: true,
|
|
86
92
|
id
|
|
87
93
|
}));
|
|
88
94
|
}
|
|
89
95
|
}
|
|
90
96
|
});
|
|
91
|
-
if (
|
|
97
|
+
if (_chunkAAF47ZC6js.IS_DEV) {
|
|
92
98
|
_optionalChain([globalThis, 'access', _3 => _3.__PS_HMR__, 'optionalAccess', _4 => _4.push, 'call', _5 => _5(async () => {
|
|
93
99
|
handleMeta();
|
|
94
100
|
})]);
|
|
95
101
|
}
|
|
96
102
|
}
|
|
97
|
-
|
|
103
|
+
_chunkAAF47ZC6js.__name.call(void 0, bind, "bind");
|
|
98
104
|
|
|
99
105
|
// src/rpc/redis/client.ts
|
|
100
106
|
var _crypto = require('crypto');
|
|
@@ -142,7 +148,7 @@ function createClient(redis, queue, controllers) {
|
|
|
142
148
|
}
|
|
143
149
|
return ret;
|
|
144
150
|
}
|
|
145
|
-
|
|
151
|
+
_chunkAAF47ZC6js.__name.call(void 0, createClient, "createClient");
|
|
146
152
|
|
|
147
153
|
|
|
148
154
|
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/rpc/redis/bind.ts","../../../src/rpc/redis/client.ts"],"names":["Redis","bind","redis","channel","moduleMap","meta","opts","metaMap","Map","pub","options","globalGuards","globalInterceptors","isAopDepInject","guards","interceptors","handleMeta","item","data","rpc","method","name","type","includes","set","subscribe","on","msg","JSON","parse","tag","args","id","queue","context","Context","get","has","BadRequestException","params","paramsType","useGuard","cache","useInterceptor","undefined","
|
|
1
|
+
{"version":3,"sources":["../../../src/rpc/redis/bind.ts","../../../src/rpc/redis/client.ts"],"names":["Redis","bind","redis","channel","moduleMap","meta","opts","metaMap","Map","pub","options","globalGuards","globalInterceptors","isAopDepInject","guards","interceptors","handleMeta","item","data","rpc","method","name","type","includes","set","subscribe","on","msg","JSON","parse","tag","args","id","queue","context","Context","get","has","publish","stringify","BadRequestException","error","params","filter","paramsType","useGuard","cache","useInterceptor","undefined","handleArgs","usePipe","map","key","pipe","pipeOpts","index","i","arg","reflect","funcData","res","usePostInterceptor","e","ret","useFilter","IS_DEV","globalThis","__PS_HMR__","push","randomUUID","EventEmitter","createClient","controllers","sub","uniQueue","emitter","_","emit","Proxy","target","p","Error","isEvent","Promise","resolve","reject","once"],"mappings":"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","sourcesContent":["import Redis from 'ioredis'\nimport type { Factory } from '../../core'\nimport type { Meta } from '../../meta'\nimport { BadRequestException } from '../../exception'\nimport { Context, isAopDepInject } from '../../context'\nimport { IS_DEV } from '../../common'\n\nexport interface Options {\n globalGuards?: string[]\n globalInterceptors?: string[]\n\n}\n\nexport interface RedisCtx {\n type: 'redis'\n meta?: Meta\n moduleMap: Record<string, any>\n redis: Redis\n msg: string\n channel: string\n // JSON parse msg\n data: any\n [key: string]: any\n}\n\nexport function bind(redis: Redis, channel: string, { moduleMap, meta }: Awaited<ReturnType<typeof Factory>>, opts?: Options) {\n const metaMap = new Map<string, Meta>()\n\n const pub = new Redis(redis.options)\n const { globalGuards = [], globalInterceptors = [] } = opts || {}\n\n isAopDepInject(meta, {\n guards: globalGuards,\n interceptors: globalInterceptors,\n })\n function handleMeta() {\n for (const item of meta) {\n const { data: { rpc, method, name } } = item\n\n if (rpc?.type && rpc.type.includes('mq'))\n metaMap.set(`${name}-${method}`, item)\n }\n }\n\n handleMeta()\n\n redis.subscribe(channel)\n\n redis.on('message', async (channel, msg) => {\n if (msg) {\n const data = JSON.parse(msg)\n const { tag, args, id, queue } = data\n const context = new Context(tag, {\n type: 'redis',\n moduleMap,\n redis,\n meta: metaMap.get(tag),\n msg,\n channel,\n data,\n })\n if (!metaMap.has(tag)) {\n queue && pub.publish(queue, JSON.stringify({\n data: new BadRequestException(`service \"${tag}\" doesn't exist`).data,\n error: true,\n id,\n }))\n return\n }\n const {\n data: {\n guards, interceptors, params, name, method, filter,\n },\n paramsType,\n } = metaMap.get(tag)!\n try {\n await context.useGuard([...globalGuards, ...guards])\n const cache = await context.useInterceptor([...globalInterceptors, ...interceptors])\n if (cache !== undefined) {\n if (queue)\n pub.publish(queue, JSON.stringify({ data: cache, id }))\n\n return\n }\n\n const handleArgs = await context.usePipe(params.map(({ type, key, pipe, pipeOpts, index }, i) => {\n return { arg: args[i], pipe, pipeOpts, key, type, index, reflect: paramsType[index] }\n }))\n\n const funcData = await moduleMap.get(name)[method](...handleArgs)\n const res = await context.usePostInterceptor(funcData)\n\n queue && pub.publish(queue, JSON.stringify({ data: res, id }))\n }\n catch (e) {\n const ret = await context.useFilter(e, filter)\n queue && pub.publish(queue, JSON.stringify({\n data: ret,\n error: true,\n id,\n }))\n }\n }\n })\n\n if (IS_DEV) {\n globalThis.__PS_HMR__?.push(async () => {\n handleMeta()\n })\n }\n}\n","import { randomUUID } from 'crypto'\nimport EventEmitter from 'events'\nimport Redis from 'ioredis'\nimport type { ToInstance } from '../../types'\n\nexport function createClient<S extends Record<string, any>>(redis: Redis, queue: string, controllers: S): ToInstance<S> {\n const ret = {} as any\n const sub = new Redis(redis.options)\n const uniQueue = randomUUID()\n\n const emitter = new EventEmitter()\n sub.subscribe(uniQueue)\n\n sub.on('message', (_, msg) => {\n const { data, id, error } = JSON.parse(msg)\n emitter.emit(id, data, error)\n })\n\n for (const i in controllers) {\n ret[i] = new Proxy(new controllers[i](), {\n get(target, p: string) {\n return (...args: any) => {\n const id = randomUUID()\n if (typeof target[p] !== 'function')\n throw new Error(`\"${p}\" in \"${i}\" is not an exposed rpc `)\n\n const { tag, rpc, isEvent } = target[p]()\n if (!rpc.includes('redis'))\n throw new Error(`\"${p}\" in \"${i}\" doesn't support redis`)\n\n redis.publish(queue, JSON.stringify({\n args,\n id,\n tag,\n queue: isEvent ? undefined : uniQueue,\n\n }))\n if (isEvent)\n return null\n\n return new Promise((resolve, reject) => {\n emitter.once(id, (data, error) => {\n if (error)\n reject(data)\n\n else\n resolve(data)\n })\n })\n }\n },\n })\n }\n\n return ret\n}\n"]}
|
package/dist/rpc/redis/index.mjs
CHANGED
|
@@ -2,11 +2,11 @@ import {
|
|
|
2
2
|
BadRequestException,
|
|
3
3
|
Context,
|
|
4
4
|
isAopDepInject
|
|
5
|
-
} from "../../chunk-
|
|
5
|
+
} from "../../chunk-GSJ5A2MA.mjs";
|
|
6
6
|
import {
|
|
7
7
|
IS_DEV,
|
|
8
8
|
__name
|
|
9
|
-
} from "../../chunk-
|
|
9
|
+
} from "../../chunk-AYJWOIAW.mjs";
|
|
10
10
|
|
|
11
11
|
// src/rpc/redis/bind.ts
|
|
12
12
|
import Redis from "ioredis";
|
|
@@ -41,10 +41,16 @@ function bind(redis, channel, { moduleMap, meta }, opts) {
|
|
|
41
41
|
channel: channel2,
|
|
42
42
|
data
|
|
43
43
|
});
|
|
44
|
+
if (!metaMap.has(tag)) {
|
|
45
|
+
queue && pub.publish(queue, JSON.stringify({
|
|
46
|
+
data: new BadRequestException(`service "${tag}" doesn't exist`).data,
|
|
47
|
+
error: true,
|
|
48
|
+
id
|
|
49
|
+
}));
|
|
50
|
+
return;
|
|
51
|
+
}
|
|
52
|
+
const { data: { guards, interceptors, params, name, method, filter }, paramsType } = metaMap.get(tag);
|
|
44
53
|
try {
|
|
45
|
-
if (!metaMap.has(tag))
|
|
46
|
-
throw new BadRequestException(`service "${tag}" doesn't exist`);
|
|
47
|
-
const { data: { guards, interceptors, params, name, method }, paramsType } = metaMap.get(tag);
|
|
48
54
|
await context.useGuard([
|
|
49
55
|
...globalGuards,
|
|
50
56
|
...guards
|
|
@@ -79,10 +85,10 @@ function bind(redis, channel, { moduleMap, meta }, opts) {
|
|
|
79
85
|
id
|
|
80
86
|
}));
|
|
81
87
|
} catch (e) {
|
|
82
|
-
const ret = await context.useFilter(e);
|
|
88
|
+
const ret = await context.useFilter(e, filter);
|
|
83
89
|
queue && pub.publish(queue, JSON.stringify({
|
|
84
90
|
data: ret,
|
|
85
|
-
error:
|
|
91
|
+
error: true,
|
|
86
92
|
id
|
|
87
93
|
}));
|
|
88
94
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/rpc/redis/bind.ts","../../../src/rpc/redis/client.ts"],"sourcesContent":["import Redis from 'ioredis'\nimport type { Factory } from '../../core'\nimport type { Meta } from '../../meta'\nimport { BadRequestException } from '../../exception'\nimport { Context, isAopDepInject } from '../../context'\nimport { IS_DEV } from '../../common'\n\nexport interface Options {\n globalGuards?: string[]\n globalInterceptors?: string[]\n\n}\n\nexport interface RedisCtx {\n type: 'redis'\n meta?: Meta\n moduleMap: Record<string, any>\n redis: Redis\n msg: string\n channel: string\n // JSON parse msg\n data: any\n [key: string]: any\n}\n\nexport function bind(redis: Redis, channel: string, { moduleMap, meta }: Awaited<ReturnType<typeof Factory>>, opts?: Options) {\n const metaMap = new Map<string, Meta>()\n\n const pub = new Redis(redis.options)\n const { globalGuards = [], globalInterceptors = [] } = opts || {}\n\n isAopDepInject(meta, {\n guards: globalGuards,\n interceptors: globalInterceptors,\n })\n function handleMeta() {\n for (const item of meta) {\n const { data: { rpc, method, name } } = item\n\n if (rpc?.type && rpc.type.includes('mq'))\n metaMap.set(`${name}-${method}`, item)\n }\n }\n\n handleMeta()\n\n redis.subscribe(channel)\n\n redis.on('message', async (channel, msg) => {\n if (msg) {\n const data = JSON.parse(msg)\n const { tag, args, id, queue } = data\n const context = new Context(tag, {\n type: 'redis',\n moduleMap,\n redis,\n meta: metaMap.get(tag),\n msg,\n channel,\n data,\n })\n
|
|
1
|
+
{"version":3,"sources":["../../../src/rpc/redis/bind.ts","../../../src/rpc/redis/client.ts"],"sourcesContent":["import Redis from 'ioredis'\nimport type { Factory } from '../../core'\nimport type { Meta } from '../../meta'\nimport { BadRequestException } from '../../exception'\nimport { Context, isAopDepInject } from '../../context'\nimport { IS_DEV } from '../../common'\n\nexport interface Options {\n globalGuards?: string[]\n globalInterceptors?: string[]\n\n}\n\nexport interface RedisCtx {\n type: 'redis'\n meta?: Meta\n moduleMap: Record<string, any>\n redis: Redis\n msg: string\n channel: string\n // JSON parse msg\n data: any\n [key: string]: any\n}\n\nexport function bind(redis: Redis, channel: string, { moduleMap, meta }: Awaited<ReturnType<typeof Factory>>, opts?: Options) {\n const metaMap = new Map<string, Meta>()\n\n const pub = new Redis(redis.options)\n const { globalGuards = [], globalInterceptors = [] } = opts || {}\n\n isAopDepInject(meta, {\n guards: globalGuards,\n interceptors: globalInterceptors,\n })\n function handleMeta() {\n for (const item of meta) {\n const { data: { rpc, method, name } } = item\n\n if (rpc?.type && rpc.type.includes('mq'))\n metaMap.set(`${name}-${method}`, item)\n }\n }\n\n handleMeta()\n\n redis.subscribe(channel)\n\n redis.on('message', async (channel, msg) => {\n if (msg) {\n const data = JSON.parse(msg)\n const { tag, args, id, queue } = data\n const context = new Context(tag, {\n type: 'redis',\n moduleMap,\n redis,\n meta: metaMap.get(tag),\n msg,\n channel,\n data,\n })\n if (!metaMap.has(tag)) {\n queue && pub.publish(queue, JSON.stringify({\n data: new BadRequestException(`service \"${tag}\" doesn't exist`).data,\n error: true,\n id,\n }))\n return\n }\n const {\n data: {\n guards, interceptors, params, name, method, filter,\n },\n paramsType,\n } = metaMap.get(tag)!\n try {\n await context.useGuard([...globalGuards, ...guards])\n const cache = await context.useInterceptor([...globalInterceptors, ...interceptors])\n if (cache !== undefined) {\n if (queue)\n pub.publish(queue, JSON.stringify({ data: cache, id }))\n\n return\n }\n\n const handleArgs = await context.usePipe(params.map(({ type, key, pipe, pipeOpts, index }, i) => {\n return { arg: args[i], pipe, pipeOpts, key, type, index, reflect: paramsType[index] }\n }))\n\n const funcData = await moduleMap.get(name)[method](...handleArgs)\n const res = await context.usePostInterceptor(funcData)\n\n queue && pub.publish(queue, JSON.stringify({ data: res, id }))\n }\n catch (e) {\n const ret = await context.useFilter(e, filter)\n queue && pub.publish(queue, JSON.stringify({\n data: ret,\n error: true,\n id,\n }))\n }\n }\n })\n\n if (IS_DEV) {\n globalThis.__PS_HMR__?.push(async () => {\n handleMeta()\n })\n }\n}\n","import { randomUUID } from 'crypto'\nimport EventEmitter from 'events'\nimport Redis from 'ioredis'\nimport type { ToInstance } from '../../types'\n\nexport function createClient<S extends Record<string, any>>(redis: Redis, queue: string, controllers: S): ToInstance<S> {\n const ret = {} as any\n const sub = new Redis(redis.options)\n const uniQueue = randomUUID()\n\n const emitter = new EventEmitter()\n sub.subscribe(uniQueue)\n\n sub.on('message', (_, msg) => {\n const { data, id, error } = JSON.parse(msg)\n emitter.emit(id, data, error)\n })\n\n for (const i in controllers) {\n ret[i] = new Proxy(new controllers[i](), {\n get(target, p: string) {\n return (...args: any) => {\n const id = randomUUID()\n if (typeof target[p] !== 'function')\n throw new Error(`\"${p}\" in \"${i}\" is not an exposed rpc `)\n\n const { tag, rpc, isEvent } = target[p]()\n if (!rpc.includes('redis'))\n throw new Error(`\"${p}\" in \"${i}\" doesn't support redis`)\n\n redis.publish(queue, JSON.stringify({\n args,\n id,\n tag,\n queue: isEvent ? undefined : uniQueue,\n\n }))\n if (isEvent)\n return null\n\n return new Promise((resolve, reject) => {\n emitter.once(id, (data, error) => {\n if (error)\n reject(data)\n\n else\n resolve(data)\n })\n })\n }\n },\n })\n }\n\n return ret\n}\n"],"mappings":"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","names":["Redis","bind","redis","channel","moduleMap","meta","opts","metaMap","Map","pub","Redis","options","globalGuards","globalInterceptors","isAopDepInject","guards","interceptors","handleMeta","item","data","rpc","method","name","type","includes","set","subscribe","on","msg","JSON","parse","tag","args","id","queue","context","Context","get","has","publish","stringify","BadRequestException","error","params","filter","paramsType","useGuard","cache","useInterceptor","undefined","handleArgs","usePipe","map","key","pipe","pipeOpts","index","i","arg","reflect","funcData","res","usePostInterceptor","e","ret","useFilter","IS_DEV","globalThis","__PS_HMR__","push","randomUUID","EventEmitter","Redis","createClient","redis","queue","controllers","ret","sub","Redis","options","uniQueue","randomUUID","emitter","EventEmitter","subscribe","on","_","msg","data","id","error","JSON","parse","emit","i","Proxy","get","target","p","args","Error","tag","rpc","isEvent","includes","publish","stringify","undefined","Promise","resolve","reject","once"]}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import { Router } from 'express';
|
|
2
|
-
import { M as Meta, F as Factory } from '../../core-
|
|
3
|
-
import '../../types-
|
|
1
|
+
import { Request, Response, Router } from 'express';
|
|
2
|
+
import { M as Meta, F as Factory } from '../../core-c27b4cf4.js';
|
|
3
|
+
import '../../types-8415bd5d.js';
|
|
4
4
|
import 'phecda-core';
|
|
5
5
|
|
|
6
6
|
interface ExpressCtx {
|
|
@@ -9,6 +9,7 @@ interface ExpressCtx {
|
|
|
9
9
|
response: Response;
|
|
10
10
|
meta: Meta;
|
|
11
11
|
moduleMap: Record<string, any>;
|
|
12
|
+
parallel: boolean;
|
|
12
13
|
[key: string]: any;
|
|
13
14
|
}
|
|
14
15
|
interface Options {
|
|
@@ -1,11 +1,11 @@
|
|
|
1
1
|
"use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _optionalChain(ops) { let lastAccessLHS = undefined; let value = ops[0]; let i = 1; while (i < ops.length) { const op = ops[i]; const fn = ops[i + 1]; i += 2; if ((op === 'optionalAccess' || op === 'optionalCall') && value == null) { return undefined; } if (op === 'access' || op === 'optionalAccess') { lastAccessLHS = value; value = fn(value); } else if (op === 'call' || op === 'optionalCall') { value = fn((...args) => value.call(lastAccessLHS, ...args)); lastAccessLHS = undefined; } } return value; }
|
|
2
2
|
|
|
3
|
-
var
|
|
3
|
+
var _chunkZPMAM4LQjs = require('../../chunk-ZPMAM4LQ.js');
|
|
4
4
|
|
|
5
5
|
|
|
6
6
|
|
|
7
7
|
|
|
8
|
-
var
|
|
8
|
+
var _chunk7OB6K45Tjs = require('../../chunk-7OB6K45T.js');
|
|
9
9
|
|
|
10
10
|
|
|
11
11
|
|
|
@@ -13,7 +13,7 @@ var _chunkYU7ROHTOjs = require('../../chunk-YU7ROHTO.js');
|
|
|
13
13
|
|
|
14
14
|
|
|
15
15
|
|
|
16
|
-
var
|
|
16
|
+
var _chunkAAF47ZC6js = require('../../chunk-AAF47ZC6.js');
|
|
17
17
|
|
|
18
18
|
// src/server/express/bind.ts
|
|
19
19
|
function bindApp(app, { moduleMap, meta }, options = {}) {
|
|
@@ -24,12 +24,12 @@ function bindApp(app, { moduleMap, meta }, options = {}) {
|
|
|
24
24
|
plugins: [],
|
|
25
25
|
...options
|
|
26
26
|
};
|
|
27
|
-
|
|
27
|
+
_chunk7OB6K45Tjs.isAopDepInject.call(void 0, meta, {
|
|
28
28
|
plugins,
|
|
29
29
|
guards: globalGuards,
|
|
30
30
|
interceptors: globalInterceptors
|
|
31
31
|
});
|
|
32
|
-
app[
|
|
32
|
+
app[_chunkAAF47ZC6js.APP_SYMBOL] = {
|
|
33
33
|
moduleMap,
|
|
34
34
|
meta
|
|
35
35
|
};
|
|
@@ -44,29 +44,29 @@ function bindApp(app, { moduleMap, meta }, options = {}) {
|
|
|
44
44
|
metaMap.set(methodTag, item);
|
|
45
45
|
}
|
|
46
46
|
}
|
|
47
|
-
|
|
47
|
+
_chunkAAF47ZC6js.__name.call(void 0, handleMeta, "handleMeta");
|
|
48
48
|
async function createRoute() {
|
|
49
49
|
app.post(route, (req, _res, next) => {
|
|
50
|
-
req[
|
|
51
|
-
req[
|
|
52
|
-
req[
|
|
50
|
+
req[_chunkAAF47ZC6js.MERGE_SYMBOL] = true;
|
|
51
|
+
req[_chunkAAF47ZC6js.MODULE_SYMBOL] = moduleMap;
|
|
52
|
+
req[_chunkAAF47ZC6js.META_SYMBOL] = meta;
|
|
53
53
|
next();
|
|
54
|
-
}, ...
|
|
54
|
+
}, ..._chunk7OB6K45Tjs.Context.usePlugin(plugins), async (req, res) => {
|
|
55
55
|
const { body } = req;
|
|
56
56
|
async function errorHandler(e) {
|
|
57
|
-
const error = await
|
|
57
|
+
const error = await _chunk7OB6K45Tjs.Context.filterRecord.default(e);
|
|
58
58
|
return res.status(error.status).json(error);
|
|
59
59
|
}
|
|
60
|
-
|
|
60
|
+
_chunkAAF47ZC6js.__name.call(void 0, errorHandler, "errorHandler");
|
|
61
61
|
if (!Array.isArray(body))
|
|
62
|
-
return errorHandler(new (0,
|
|
62
|
+
return errorHandler(new (0, _chunk7OB6K45Tjs.BadRequestException)("data format should be an array"));
|
|
63
63
|
try {
|
|
64
64
|
return Promise.all(body.map((item) => {
|
|
65
65
|
return new Promise(async (resolve) => {
|
|
66
66
|
const { tag } = item;
|
|
67
67
|
const meta2 = metaMap.get(tag);
|
|
68
68
|
if (!meta2)
|
|
69
|
-
return resolve(await
|
|
69
|
+
return resolve(await _chunk7OB6K45Tjs.Context.filterRecord.default(new (0, _chunk7OB6K45Tjs.BadRequestException)(`"${tag}" doesn't exist`)));
|
|
70
70
|
const contextData = {
|
|
71
71
|
type: "express",
|
|
72
72
|
request: req,
|
|
@@ -75,9 +75,9 @@ function bindApp(app, { moduleMap, meta }, options = {}) {
|
|
|
75
75
|
moduleMap,
|
|
76
76
|
parallel: true
|
|
77
77
|
};
|
|
78
|
-
const context = new (0,
|
|
78
|
+
const context = new (0, _chunk7OB6K45Tjs.Context)(tag, contextData);
|
|
79
79
|
const [name, method] = tag.split("-");
|
|
80
|
-
const { paramsType, handlers, data: { params, guards, interceptors } } = meta2;
|
|
80
|
+
const { paramsType, handlers, data: { params, guards, interceptors, filter } } = meta2;
|
|
81
81
|
const instance = moduleMap.get(name);
|
|
82
82
|
try {
|
|
83
83
|
await context.useGuard([
|
|
@@ -106,7 +106,7 @@ function bindApp(app, { moduleMap, meta }, options = {}) {
|
|
|
106
106
|
resolve(await context.usePostInterceptor(funcData));
|
|
107
107
|
} catch (e) {
|
|
108
108
|
handlers.forEach((handler) => _optionalChain([handler, 'access', _2 => _2.error, 'optionalCall', _3 => _3(e)]));
|
|
109
|
-
resolve(await context.useFilter(e));
|
|
109
|
+
resolve(await context.useFilter(e, filter));
|
|
110
110
|
}
|
|
111
111
|
});
|
|
112
112
|
})).then((ret) => {
|
|
@@ -121,21 +121,22 @@ function bindApp(app, { moduleMap, meta }, options = {}) {
|
|
|
121
121
|
if (!_optionalChain([http, 'optionalAccess', _4 => _4.type]))
|
|
122
122
|
continue;
|
|
123
123
|
const methodTag = `${tag}-${method}`;
|
|
124
|
-
const { paramsType, handlers, data: { interceptors, guards, params, plugins: plugins2 } } = metaMap.get(methodTag);
|
|
124
|
+
const { paramsType, handlers, data: { interceptors, guards, params, plugins: plugins2, filter } } = metaMap.get(methodTag);
|
|
125
125
|
app[http.type](http.route, (req, _res, next) => {
|
|
126
|
-
req[
|
|
127
|
-
req[
|
|
126
|
+
req[_chunkAAF47ZC6js.MODULE_SYMBOL] = moduleMap;
|
|
127
|
+
req[_chunkAAF47ZC6js.META_SYMBOL] = meta;
|
|
128
128
|
next();
|
|
129
|
-
}, ...
|
|
129
|
+
}, ..._chunk7OB6K45Tjs.Context.usePlugin(plugins2), async (req, res) => {
|
|
130
130
|
const instance = moduleMap.get(tag);
|
|
131
131
|
const contextData = {
|
|
132
132
|
type: "express",
|
|
133
133
|
request: req,
|
|
134
134
|
meta: i,
|
|
135
135
|
response: res,
|
|
136
|
-
moduleMap
|
|
136
|
+
moduleMap,
|
|
137
|
+
parallel: false
|
|
137
138
|
};
|
|
138
|
-
const context = new (0,
|
|
139
|
+
const context = new (0, _chunk7OB6K45Tjs.Context)(methodTag, contextData);
|
|
139
140
|
try {
|
|
140
141
|
for (const name in header)
|
|
141
142
|
res.set(name, header[name]);
|
|
@@ -156,7 +157,7 @@ function bindApp(app, { moduleMap, meta }, options = {}) {
|
|
|
156
157
|
}
|
|
157
158
|
const args = await context.usePipe(params.map(({ type, key, pipeOpts, index, pipe }) => {
|
|
158
159
|
return {
|
|
159
|
-
arg:
|
|
160
|
+
arg: _chunkZPMAM4LQjs.resolveDep.call(void 0, req[type], key),
|
|
160
161
|
pipeOpts,
|
|
161
162
|
pipe,
|
|
162
163
|
key,
|
|
@@ -169,31 +170,38 @@ function bindApp(app, { moduleMap, meta }, options = {}) {
|
|
|
169
170
|
const funcData = await instance[method](...args);
|
|
170
171
|
const ret = await context.usePostInterceptor(funcData);
|
|
171
172
|
if (res.writableEnded)
|
|
172
|
-
return
|
|
173
|
+
return;
|
|
173
174
|
if (typeof ret === "string")
|
|
174
175
|
res.send(ret);
|
|
175
176
|
else
|
|
176
177
|
res.json(ret);
|
|
177
178
|
} catch (e) {
|
|
178
179
|
handlers.forEach((handler) => _optionalChain([handler, 'access', _5 => _5.error, 'optionalCall', _6 => _6(e)]));
|
|
179
|
-
const err = await context.useFilter(e);
|
|
180
|
+
const err = await context.useFilter(e, filter);
|
|
181
|
+
if (res.writableEnded)
|
|
182
|
+
return;
|
|
180
183
|
res.status(err.status).json(err);
|
|
181
184
|
}
|
|
182
185
|
});
|
|
183
186
|
}
|
|
184
187
|
}
|
|
185
|
-
|
|
188
|
+
_chunkAAF47ZC6js.__name.call(void 0, createRoute, "createRoute");
|
|
186
189
|
handleMeta();
|
|
187
190
|
createRoute();
|
|
188
|
-
if (
|
|
191
|
+
if (_chunkAAF47ZC6js.IS_DEV) {
|
|
189
192
|
_optionalChain([globalThis, 'access', _7 => _7.__PS_HMR__, 'optionalAccess', _8 => _8.push, 'call', _9 => _9(async () => {
|
|
193
|
+
_chunk7OB6K45Tjs.isAopDepInject.call(void 0, meta, {
|
|
194
|
+
plugins,
|
|
195
|
+
guards: globalGuards,
|
|
196
|
+
interceptors: globalInterceptors
|
|
197
|
+
});
|
|
190
198
|
app.stack = [];
|
|
191
199
|
handleMeta();
|
|
192
200
|
createRoute();
|
|
193
201
|
})]);
|
|
194
202
|
}
|
|
195
203
|
}
|
|
196
|
-
|
|
204
|
+
_chunkAAF47ZC6js.__name.call(void 0, bindApp, "bindApp");
|
|
197
205
|
|
|
198
206
|
|
|
199
207
|
exports.bindApp = bindApp;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/server/express/bind.ts"],"names":["bindApp","app","moduleMap","meta","options","globalGuards","globalInterceptors","route","plugins","isAopDepInject","guards","interceptors","APP_SYMBOL","metaMap","Map","handleMeta","clear","item","tag","method","http","data","type","methodTag","set","createRoute","post","req","_res","next","MERGE_SYMBOL","MODULE_SYMBOL","META_SYMBOL","Context","usePlugin","res","body","errorHandler","e","error","filter","status","json","Array","isArray","BadRequestException","Promise","all","map","resolve","get","contextData","request","response","parallel","context","name","split","paramsType","handlers","params","instance","useGuard","cache","useInterceptor","undefined","args","usePipe","key","pipeOpts","pipe","index","arg","reflect","funcData","usePostInterceptor","forEach","handler","useFilter","then","ret","i","header","send","resolveDep","writableEnded","err","IS_DEV","globalThis","__PS_HMR__","push","stack"],"mappings":"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","sourcesContent":["import type { Express, Router } from 'express'\nimport { resolveDep } from '../../helper'\nimport { APP_SYMBOL, IS_DEV, MERGE_SYMBOL, META_SYMBOL, MODULE_SYMBOL } from '../../common'\nimport type { Factory } from '../../core'\nimport { BadRequestException } from '../../exception'\nimport type { Meta } from '../../meta'\nimport { Context, isAopDepInject } from '../../context'\n\nexport interface ExpressCtx {\n type: 'express'\n request: Request\n response: Response\n meta: Meta\n moduleMap: Record<string, any>\n [key: string]: any\n}\nexport interface Options {\n\n /**\n * 专用路由的值,默认为/__PHECDA_SERVER__,处理phecda-client发出的合并请求\n */\n route?: string\n /**\n * 全局守卫\n */\n globalGuards?: string[]\n /**\n * 全局拦截器\n */\n globalInterceptors?: string[]\n /**\n * 专用路由的插件(work for merge request),\n */\n plugins?: string[]\n\n}\n\nexport function bindApp(app: Router, { moduleMap, meta }: Awaited<ReturnType<typeof Factory>>, options: Options = {}) {\n const { globalGuards, globalInterceptors, route, plugins } = { route: '/__PHECDA_SERVER__', globalGuards: [], globalInterceptors: [], plugins: [], ...options } as Required<Options>\n isAopDepInject(meta, {\n plugins,\n guards: globalGuards,\n interceptors: globalInterceptors,\n });\n\n (app as any)[APP_SYMBOL] = { moduleMap, meta }\n\n const metaMap = new Map<string, Meta>()\n function handleMeta() {\n metaMap.clear()\n for (const item of meta) {\n const { tag, method, http } = item.data\n if (!http?.type)\n continue\n const methodTag = `${tag}-${method}`\n metaMap.set(methodTag, item)\n }\n }\n\n async function createRoute() {\n (app as Express).post(route, (req, _res, next) => {\n (req as any)[MERGE_SYMBOL] = true;\n (req as any)[MODULE_SYMBOL] = moduleMap;\n (req as any)[META_SYMBOL] = meta\n\n next()\n }, ...Context.usePlugin(plugins), async (req, res) => {\n const { body } = req\n\n async function errorHandler(e: any) {\n const error = await Context.filter(e)\n return res.status(error.status).json(error)\n }\n\n if (!Array.isArray(body))\n return errorHandler(new BadRequestException('data format should be an array'))\n\n try {\n return Promise.all(body.map((item: any) => {\n // eslint-disable-next-line no-async-promise-executor\n return new Promise(async (resolve) => {\n const { tag } = item\n const meta = metaMap.get(tag)\n if (!meta)\n return resolve(await Context.filter(new BadRequestException(`\"${tag}\" doesn't exist`)))\n\n const contextData = {\n type: 'express' as const,\n request: req,\n meta,\n response: res,\n moduleMap,\n parallel: true,\n }\n const context = new Context(tag, contextData)\n const [name, method] = tag.split('-')\n const {\n paramsType,\n handlers,\n data: {\n params,\n guards, interceptors,\n },\n } = meta\n\n const instance = moduleMap.get(name)\n\n try {\n await context.useGuard([...globalGuards, ...guards])\n const cache = await context.useInterceptor([...globalInterceptors, ...interceptors])\n if (cache !== undefined)\n return resolve(cache)\n const args = await context.usePipe(params.map(({ type, key, pipeOpts, pipe, index }) => {\n return { arg: item.args[index], type, key, pipeOpts, pipe, index, reflect: paramsType[index] }\n })) as any\n instance.context = contextData\n const funcData = await moduleMap.get(name)[method](...args)\n resolve(await context.usePostInterceptor(funcData))\n }\n catch (e: any) {\n handlers.forEach(handler => handler.error?.(e))\n resolve(await context.useFilter(e))\n }\n })\n })).then((ret) => {\n res.json(ret)\n })\n }\n catch (e) {\n return errorHandler(e)\n }\n })\n for (const i of meta) {\n const { method, http, header, tag } = i.data\n\n if (!http?.type)\n continue\n\n const methodTag = `${tag}-${method}`\n\n const {\n paramsType,\n handlers,\n data: {\n interceptors,\n guards,\n params,\n plugins,\n },\n } = metaMap.get(methodTag)!;\n\n (app as Express)[http.type](http.route, (req, _res, next) => {\n (req as any)[MODULE_SYMBOL] = moduleMap;\n (req as any)[META_SYMBOL] = meta\n next()\n }, ...Context.usePlugin(plugins), async (req, res) => {\n const instance = moduleMap.get(tag)!\n const contextData = {\n type: 'express' as const,\n request: req,\n meta: i,\n response: res,\n moduleMap,\n }\n const context = new Context(methodTag, contextData)\n\n try {\n for (const name in header)\n res.set(name, header[name])\n await context.useGuard([...globalGuards, ...guards])\n const cache = await context.useInterceptor([...globalInterceptors, ...interceptors])\n if (cache !== undefined) {\n if (typeof cache === 'string')\n res.send(cache)\n\n else\n res.json(cache)\n\n return\n }\n const args = await context.usePipe(params.map(({ type, key, pipeOpts, index, pipe }) => {\n return { arg: resolveDep((req as any)[type], key), pipeOpts, pipe, key, type, index, reflect: paramsType[index] }\n }))\n\n instance.context = contextData\n const funcData = await instance[method](...args)\n const ret = await context.usePostInterceptor(funcData)\n\n if (res.writableEnded)\n return true\n\n if (typeof ret === 'string')\n res.send(ret)\n\n else\n res.json(ret)\n }\n catch (e: any) {\n handlers.forEach(handler => handler.error?.(e))\n const err = await context.useFilter(e)\n res.status(err.status).json(err)\n }\n })\n }\n }\n\n handleMeta()\n createRoute()\n if (IS_DEV) {\n globalThis.__PS_HMR__?.push(async () => {\n app.stack = []// app.stack.slice(0, 1)\n handleMeta()\n createRoute()\n })\n }\n}\n"]}
|
|
1
|
+
{"version":3,"sources":["../../../src/server/express/bind.ts"],"names":["bindApp","app","moduleMap","meta","options","globalGuards","globalInterceptors","route","plugins","isAopDepInject","guards","interceptors","APP_SYMBOL","metaMap","Map","handleMeta","clear","item","tag","method","http","data","type","methodTag","set","createRoute","post","req","_res","next","MERGE_SYMBOL","MODULE_SYMBOL","META_SYMBOL","Context","usePlugin","res","body","errorHandler","e","error","filterRecord","default","status","json","Array","isArray","BadRequestException","Promise","all","map","resolve","get","contextData","request","response","parallel","context","name","split","paramsType","handlers","params","filter","instance","useGuard","cache","useInterceptor","undefined","args","usePipe","key","pipeOpts","pipe","index","arg","reflect","funcData","usePostInterceptor","forEach","handler","useFilter","then","ret","i","header","send","resolveDep","writableEnded","err","IS_DEV","globalThis","__PS_HMR__","push","stack"],"mappings":"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","sourcesContent":["import type { Express, Request, Response, Router } from 'express'\nimport { resolveDep } from '../../helper'\nimport { APP_SYMBOL, IS_DEV, MERGE_SYMBOL, META_SYMBOL, MODULE_SYMBOL } from '../../common'\nimport type { Factory } from '../../core'\nimport { BadRequestException } from '../../exception'\nimport type { Meta } from '../../meta'\nimport { Context, isAopDepInject } from '../../context'\n\nexport interface ExpressCtx {\n type: 'express'\n request: Request\n response: Response\n meta: Meta\n moduleMap: Record<string, any>\n parallel: boolean\n [key: string]: any\n}\nexport interface Options {\n\n /**\n * 专用路由的值,默认为/__PHECDA_SERVER__,处理phecda-client发出的合并请求\n */\n route?: string\n /**\n * 全局守卫\n */\n globalGuards?: string[]\n /**\n * 全局拦截器\n */\n globalInterceptors?: string[]\n /**\n * 专用路由的插件(work for merge request),\n */\n plugins?: string[]\n\n}\n\nexport function bindApp(app: Router, { moduleMap, meta }: Awaited<ReturnType<typeof Factory>>, options: Options = {}) {\n const { globalGuards, globalInterceptors, route, plugins } = { route: '/__PHECDA_SERVER__', globalGuards: [], globalInterceptors: [], plugins: [], ...options } as Required<Options>\n isAopDepInject(meta, {\n plugins,\n guards: globalGuards,\n interceptors: globalInterceptors,\n });\n\n (app as any)[APP_SYMBOL] = { moduleMap, meta }\n\n const metaMap = new Map<string, Meta>()\n function handleMeta() {\n metaMap.clear()\n for (const item of meta) {\n const { tag, method, http } = item.data\n if (!http?.type)\n continue\n const methodTag = `${tag}-${method}`\n metaMap.set(methodTag, item)\n }\n }\n\n async function createRoute() {\n (app as Express).post(route, (req, _res, next) => {\n (req as any)[MERGE_SYMBOL] = true;\n (req as any)[MODULE_SYMBOL] = moduleMap;\n (req as any)[META_SYMBOL] = meta\n\n next()\n }, ...Context.usePlugin(plugins), async (req, res) => {\n const { body } = req\n\n async function errorHandler(e: any) {\n const error = await Context.filterRecord.default(e)\n return res.status(error.status).json(error)\n }\n\n if (!Array.isArray(body))\n return errorHandler(new BadRequestException('data format should be an array'))\n\n try {\n return Promise.all(body.map((item: any) => {\n // eslint-disable-next-line no-async-promise-executor\n return new Promise(async (resolve) => {\n const { tag } = item\n const meta = metaMap.get(tag)\n if (!meta)\n return resolve(await Context.filterRecord.default(new BadRequestException(`\"${tag}\" doesn't exist`)))\n\n const contextData = {\n type: 'express' as const,\n request: req,\n meta,\n response: res,\n moduleMap,\n parallel: true,\n }\n const context = new Context<ExpressCtx>(tag, contextData)\n const [name, method] = tag.split('-')\n const {\n paramsType,\n handlers,\n data: {\n params,\n guards, interceptors,\n filter,\n },\n } = meta\n\n const instance = moduleMap.get(name)\n\n try {\n await context.useGuard([...globalGuards, ...guards])\n const cache = await context.useInterceptor([...globalInterceptors, ...interceptors])\n if (cache !== undefined)\n return resolve(cache)\n const args = await context.usePipe(params.map(({ type, key, pipeOpts, pipe, index }) => {\n return { arg: item.args[index], type, key, pipeOpts, pipe, index, reflect: paramsType[index] }\n })) as any\n instance.context = contextData\n const funcData = await moduleMap.get(name)[method](...args)\n resolve(await context.usePostInterceptor(funcData))\n }\n catch (e: any) {\n handlers.forEach(handler => handler.error?.(e))\n resolve(await context.useFilter(e, filter))\n }\n })\n })).then((ret) => {\n res.json(ret)\n })\n }\n catch (e) {\n return errorHandler(e)\n }\n })\n for (const i of meta) {\n const { method, http, header, tag } = i.data\n\n if (!http?.type)\n continue\n\n const methodTag = `${tag}-${method}`\n\n const {\n paramsType,\n handlers,\n data: {\n interceptors,\n guards,\n params,\n plugins,\n filter,\n },\n } = metaMap.get(methodTag)!;\n\n (app as Express)[http.type](http.route, (req, _res, next) => {\n (req as any)[MODULE_SYMBOL] = moduleMap;\n (req as any)[META_SYMBOL] = meta\n next()\n }, ...Context.usePlugin(plugins), async (req, res) => {\n const instance = moduleMap.get(tag)!\n const contextData = {\n type: 'express' as const,\n request: req,\n meta: i,\n response: res,\n moduleMap,\n parallel: false,\n }\n const context = new Context<ExpressCtx>(methodTag, contextData)\n\n try {\n for (const name in header)\n res.set(name, header[name])\n await context.useGuard([...globalGuards, ...guards])\n const cache = await context.useInterceptor([...globalInterceptors, ...interceptors])\n if (cache !== undefined) {\n if (typeof cache === 'string')\n res.send(cache)\n\n else\n res.json(cache)\n\n return\n }\n const args = await context.usePipe(params.map(({ type, key, pipeOpts, index, pipe }) => {\n return { arg: resolveDep((req as any)[type], key), pipeOpts, pipe, key, type, index, reflect: paramsType[index] }\n }))\n\n instance.context = contextData\n const funcData = await instance[method](...args)\n const ret = await context.usePostInterceptor(funcData)\n\n if (res.writableEnded)\n return\n\n if (typeof ret === 'string')\n res.send(ret)\n\n else\n res.json(ret)\n }\n catch (e: any) {\n handlers.forEach(handler => handler.error?.(e))\n const err = await context.useFilter(e, filter)\n if (res.writableEnded)\n return\n res.status(err.status).json(err)\n }\n })\n }\n }\n\n handleMeta()\n createRoute()\n if (IS_DEV) {\n globalThis.__PS_HMR__?.push(async () => {\n isAopDepInject(meta, {\n plugins,\n guards: globalGuards,\n interceptors: globalInterceptors,\n })\n app.stack = []// app.stack.slice(0, 1)\n handleMeta()\n createRoute()\n })\n }\n}\n"]}
|
|
@@ -1,11 +1,11 @@
|
|
|
1
1
|
import {
|
|
2
2
|
resolveDep
|
|
3
|
-
} from "../../chunk-
|
|
3
|
+
} from "../../chunk-V7SC5EVJ.mjs";
|
|
4
4
|
import {
|
|
5
5
|
BadRequestException,
|
|
6
6
|
Context,
|
|
7
7
|
isAopDepInject
|
|
8
|
-
} from "../../chunk-
|
|
8
|
+
} from "../../chunk-GSJ5A2MA.mjs";
|
|
9
9
|
import {
|
|
10
10
|
APP_SYMBOL,
|
|
11
11
|
IS_DEV,
|
|
@@ -13,7 +13,7 @@ import {
|
|
|
13
13
|
META_SYMBOL,
|
|
14
14
|
MODULE_SYMBOL,
|
|
15
15
|
__name
|
|
16
|
-
} from "../../chunk-
|
|
16
|
+
} from "../../chunk-AYJWOIAW.mjs";
|
|
17
17
|
|
|
18
18
|
// src/server/express/bind.ts
|
|
19
19
|
function bindApp(app, { moduleMap, meta }, options = {}) {
|
|
@@ -54,7 +54,7 @@ function bindApp(app, { moduleMap, meta }, options = {}) {
|
|
|
54
54
|
}, ...Context.usePlugin(plugins), async (req, res) => {
|
|
55
55
|
const { body } = req;
|
|
56
56
|
async function errorHandler(e) {
|
|
57
|
-
const error = await Context.
|
|
57
|
+
const error = await Context.filterRecord.default(e);
|
|
58
58
|
return res.status(error.status).json(error);
|
|
59
59
|
}
|
|
60
60
|
__name(errorHandler, "errorHandler");
|
|
@@ -66,7 +66,7 @@ function bindApp(app, { moduleMap, meta }, options = {}) {
|
|
|
66
66
|
const { tag } = item;
|
|
67
67
|
const meta2 = metaMap.get(tag);
|
|
68
68
|
if (!meta2)
|
|
69
|
-
return resolve(await Context.
|
|
69
|
+
return resolve(await Context.filterRecord.default(new BadRequestException(`"${tag}" doesn't exist`)));
|
|
70
70
|
const contextData = {
|
|
71
71
|
type: "express",
|
|
72
72
|
request: req,
|
|
@@ -77,7 +77,7 @@ function bindApp(app, { moduleMap, meta }, options = {}) {
|
|
|
77
77
|
};
|
|
78
78
|
const context = new Context(tag, contextData);
|
|
79
79
|
const [name, method] = tag.split("-");
|
|
80
|
-
const { paramsType, handlers, data: { params, guards, interceptors } } = meta2;
|
|
80
|
+
const { paramsType, handlers, data: { params, guards, interceptors, filter } } = meta2;
|
|
81
81
|
const instance = moduleMap.get(name);
|
|
82
82
|
try {
|
|
83
83
|
await context.useGuard([
|
|
@@ -106,7 +106,7 @@ function bindApp(app, { moduleMap, meta }, options = {}) {
|
|
|
106
106
|
resolve(await context.usePostInterceptor(funcData));
|
|
107
107
|
} catch (e) {
|
|
108
108
|
handlers.forEach((handler) => handler.error?.(e));
|
|
109
|
-
resolve(await context.useFilter(e));
|
|
109
|
+
resolve(await context.useFilter(e, filter));
|
|
110
110
|
}
|
|
111
111
|
});
|
|
112
112
|
})).then((ret) => {
|
|
@@ -121,7 +121,7 @@ function bindApp(app, { moduleMap, meta }, options = {}) {
|
|
|
121
121
|
if (!http?.type)
|
|
122
122
|
continue;
|
|
123
123
|
const methodTag = `${tag}-${method}`;
|
|
124
|
-
const { paramsType, handlers, data: { interceptors, guards, params, plugins: plugins2 } } = metaMap.get(methodTag);
|
|
124
|
+
const { paramsType, handlers, data: { interceptors, guards, params, plugins: plugins2, filter } } = metaMap.get(methodTag);
|
|
125
125
|
app[http.type](http.route, (req, _res, next) => {
|
|
126
126
|
req[MODULE_SYMBOL] = moduleMap;
|
|
127
127
|
req[META_SYMBOL] = meta;
|
|
@@ -133,7 +133,8 @@ function bindApp(app, { moduleMap, meta }, options = {}) {
|
|
|
133
133
|
request: req,
|
|
134
134
|
meta: i,
|
|
135
135
|
response: res,
|
|
136
|
-
moduleMap
|
|
136
|
+
moduleMap,
|
|
137
|
+
parallel: false
|
|
137
138
|
};
|
|
138
139
|
const context = new Context(methodTag, contextData);
|
|
139
140
|
try {
|
|
@@ -169,14 +170,16 @@ function bindApp(app, { moduleMap, meta }, options = {}) {
|
|
|
169
170
|
const funcData = await instance[method](...args);
|
|
170
171
|
const ret = await context.usePostInterceptor(funcData);
|
|
171
172
|
if (res.writableEnded)
|
|
172
|
-
return
|
|
173
|
+
return;
|
|
173
174
|
if (typeof ret === "string")
|
|
174
175
|
res.send(ret);
|
|
175
176
|
else
|
|
176
177
|
res.json(ret);
|
|
177
178
|
} catch (e) {
|
|
178
179
|
handlers.forEach((handler) => handler.error?.(e));
|
|
179
|
-
const err = await context.useFilter(e);
|
|
180
|
+
const err = await context.useFilter(e, filter);
|
|
181
|
+
if (res.writableEnded)
|
|
182
|
+
return;
|
|
180
183
|
res.status(err.status).json(err);
|
|
181
184
|
}
|
|
182
185
|
});
|
|
@@ -187,6 +190,11 @@ function bindApp(app, { moduleMap, meta }, options = {}) {
|
|
|
187
190
|
createRoute();
|
|
188
191
|
if (IS_DEV) {
|
|
189
192
|
globalThis.__PS_HMR__?.push(async () => {
|
|
193
|
+
isAopDepInject(meta, {
|
|
194
|
+
plugins,
|
|
195
|
+
guards: globalGuards,
|
|
196
|
+
interceptors: globalInterceptors
|
|
197
|
+
});
|
|
190
198
|
app.stack = [];
|
|
191
199
|
handleMeta();
|
|
192
200
|
createRoute();
|