phecda-server 4.0.5 → 4.0.7

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.
Files changed (65) hide show
  1. package/dist/{chunk-JQPX546Z.mjs → chunk-43ZXHSVH.mjs} +2 -2
  2. package/dist/{chunk-Q6T7HNEO.mjs → chunk-ATMZNJSE.mjs} +43 -31
  3. package/dist/chunk-ATMZNJSE.mjs.map +1 -0
  4. package/dist/{chunk-AJ2HYENF.mjs → chunk-DQUH5BP6.mjs} +28 -4
  5. package/dist/chunk-DQUH5BP6.mjs.map +1 -0
  6. package/dist/{chunk-NFAA3WFR.mjs → chunk-F5PQVQTY.mjs} +18 -11
  7. package/dist/chunk-F5PQVQTY.mjs.map +1 -0
  8. package/dist/{chunk-FAHHXHL5.js → chunk-FCLWCFQS.js} +3 -3
  9. package/dist/{chunk-YU7ROHTO.js → chunk-JZGLQ4FQ.js} +78 -66
  10. package/dist/chunk-JZGLQ4FQ.js.map +1 -0
  11. package/dist/{chunk-R3N4HR7U.js → chunk-WWYSLFOI.js} +39 -32
  12. package/dist/chunk-WWYSLFOI.js.map +1 -0
  13. package/dist/{chunk-LZAU5FUS.js → chunk-ZZ2QKZ46.js} +27 -3
  14. package/dist/chunk-ZZ2QKZ46.js.map +1 -0
  15. package/dist/{types-ead02c5d.d.ts → core-72951cf9.d.ts} +42 -19
  16. package/dist/index.d.ts +45 -26
  17. package/dist/index.js +123 -54
  18. package/dist/index.js.map +1 -1
  19. package/dist/index.mjs +101 -32
  20. package/dist/index.mjs.map +1 -1
  21. package/dist/rpc/rabbitmq/index.d.ts +2 -3
  22. package/dist/rpc/rabbitmq/index.js +19 -13
  23. package/dist/rpc/rabbitmq/index.js.map +1 -1
  24. package/dist/rpc/rabbitmq/index.mjs +13 -7
  25. package/dist/rpc/rabbitmq/index.mjs.map +1 -1
  26. package/dist/rpc/redis/index.d.ts +2 -3
  27. package/dist/rpc/redis/index.js +19 -13
  28. package/dist/rpc/redis/index.js.map +1 -1
  29. package/dist/rpc/redis/index.mjs +13 -7
  30. package/dist/rpc/redis/index.mjs.map +1 -1
  31. package/dist/server/express/index.d.ts +3 -3
  32. package/dist/server/express/index.js +37 -29
  33. package/dist/server/express/index.js.map +1 -1
  34. package/dist/server/express/index.mjs +19 -11
  35. package/dist/server/express/index.mjs.map +1 -1
  36. package/dist/server/fastify/index.d.ts +4 -4
  37. package/dist/server/fastify/index.js +38 -26
  38. package/dist/server/fastify/index.js.map +1 -1
  39. package/dist/server/fastify/index.mjs +23 -11
  40. package/dist/server/fastify/index.mjs.map +1 -1
  41. package/dist/server/h3/index.d.ts +5 -5
  42. package/dist/server/h3/index.js +34 -28
  43. package/dist/server/h3/index.js.map +1 -1
  44. package/dist/server/h3/index.mjs +16 -10
  45. package/dist/server/h3/index.mjs.map +1 -1
  46. package/dist/server/koa/index.d.ts +2 -2
  47. package/dist/server/koa/index.js +36 -28
  48. package/dist/server/koa/index.js.map +1 -1
  49. package/dist/server/koa/index.mjs +18 -10
  50. package/dist/server/koa/index.mjs.map +1 -1
  51. package/dist/test.d.ts +9 -5
  52. package/dist/test.js +10 -21
  53. package/dist/test.js.map +1 -1
  54. package/dist/test.mjs +7 -18
  55. package/dist/test.mjs.map +1 -1
  56. package/package.json +2 -2
  57. package/dist/chunk-AJ2HYENF.mjs.map +0 -1
  58. package/dist/chunk-LZAU5FUS.js.map +0 -1
  59. package/dist/chunk-NFAA3WFR.mjs.map +0 -1
  60. package/dist/chunk-Q6T7HNEO.mjs.map +0 -1
  61. package/dist/chunk-R3N4HR7U.js.map +0 -1
  62. package/dist/chunk-YU7ROHTO.js.map +0 -1
  63. package/dist/core-ba036c2b.d.ts +0 -23
  64. /package/dist/{chunk-JQPX546Z.mjs.map → chunk-43ZXHSVH.mjs.map} +0 -0
  65. /package/dist/{chunk-FAHHXHL5.js.map → chunk-FCLWCFQS.js.map} +0 -0
@@ -2,11 +2,11 @@
2
2
 
3
3
 
4
4
 
5
- var _chunkYU7ROHTOjs = require('../../chunk-YU7ROHTO.js');
5
+ var _chunkJZGLQ4FQjs = require('../../chunk-JZGLQ4FQ.js');
6
6
 
7
7
 
8
8
 
9
- var _chunkLZAU5FUSjs = require('../../chunk-LZAU5FUS.js');
9
+ var _chunkZZ2QKZ46js = require('../../chunk-ZZ2QKZ46.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
- _chunkYU7ROHTOjs.isAopDepInject.call(void 0, meta, {
17
+ _chunkJZGLQ4FQjs.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
- _chunkLZAU5FUSjs.__name.call(void 0, handleMeta, "handleMeta");
28
+ _chunkZZ2QKZ46js.__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, _chunkYU7ROHTOjs.Context)(tag, {
35
+ const context = new (0, _chunkJZGLQ4FQjs.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, _chunkJZGLQ4FQjs.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: ret.error,
91
+ error: true,
86
92
  id
87
93
  }));
88
94
  }
89
95
  }
90
96
  });
91
- if (_chunkLZAU5FUSjs.IS_DEV) {
97
+ if (_chunkZZ2QKZ46js.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
- _chunkLZAU5FUSjs.__name.call(void 0, bind, "bind");
103
+ _chunkZZ2QKZ46js.__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
- _chunkLZAU5FUSjs.__name.call(void 0, createClient, "createClient");
151
+ _chunkZZ2QKZ46js.__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","publish","stringify","handleArgs","usePipe","map","key","pipe","pipeOpts","index","i","arg","reflect","funcData","res","usePostInterceptor","e","ret","useFilter","error","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\n try {\n if (!metaMap.has(tag))\n throw new BadRequestException(`service \"${tag}\" doesn't exist`)\n\n const {\n data: {\n guards, interceptors, params, name, method,\n },\n paramsType,\n } = metaMap.get(tag)!\n\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)\n queue && pub.publish(queue, JSON.stringify({\n data: ret,\n error: ret.error,\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"]}
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 { ToControllerMap } from '../../types'\n\nexport function createClient<S extends Record<string, any>>(redis: Redis, queue: string, controllers: S): ToControllerMap<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"]}
@@ -2,11 +2,11 @@ import {
2
2
  BadRequestException,
3
3
  Context,
4
4
  isAopDepInject
5
- } from "../../chunk-Q6T7HNEO.mjs";
5
+ } from "../../chunk-ATMZNJSE.mjs";
6
6
  import {
7
7
  IS_DEV,
8
8
  __name
9
- } from "../../chunk-AJ2HYENF.mjs";
9
+ } from "../../chunk-DQUH5BP6.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: ret.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\n try {\n if (!metaMap.has(tag))\n throw new BadRequestException(`service \"${tag}\" doesn't exist`)\n\n const {\n data: {\n guards, interceptors, params, name, method,\n },\n paramsType,\n } = metaMap.get(tag)!\n\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)\n queue && pub.publish(queue, JSON.stringify({\n data: ret,\n error: ret.error,\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","BadRequestException","params","paramsType","useGuard","cache","useInterceptor","undefined","publish","stringify","handleArgs","usePipe","map","key","pipe","pipeOpts","index","i","arg","reflect","funcData","res","usePostInterceptor","e","ret","useFilter","error","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
+ {"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 { ToControllerMap } from '../../types'\n\nexport function createClient<S extends Record<string, any>>(redis: Redis, queue: string, controllers: S): ToControllerMap<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,5 @@
1
- import { Router } from 'express';
2
- import { M as Meta, F as Factory } from '../../core-ba036c2b.js';
3
- import '../../types-ead02c5d.js';
1
+ import { Request, Response, Router } from 'express';
2
+ import { M as Meta, F as Factory } from '../../core-72951cf9.js';
4
3
  import 'phecda-core';
5
4
 
6
5
  interface ExpressCtx {
@@ -9,6 +8,7 @@ interface ExpressCtx {
9
8
  response: Response;
10
9
  meta: Meta;
11
10
  moduleMap: Record<string, any>;
11
+ parallel: boolean;
12
12
  [key: string]: any;
13
13
  }
14
14
  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 _chunkFAHHXHL5js = require('../../chunk-FAHHXHL5.js');
3
+ var _chunkFCLWCFQSjs = require('../../chunk-FCLWCFQS.js');
4
4
 
5
5
 
6
6
 
7
7
 
8
- var _chunkYU7ROHTOjs = require('../../chunk-YU7ROHTO.js');
8
+ var _chunkJZGLQ4FQjs = require('../../chunk-JZGLQ4FQ.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 _chunkLZAU5FUSjs = require('../../chunk-LZAU5FUS.js');
16
+ var _chunkZZ2QKZ46js = require('../../chunk-ZZ2QKZ46.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
- _chunkYU7ROHTOjs.isAopDepInject.call(void 0, meta, {
27
+ _chunkJZGLQ4FQjs.isAopDepInject.call(void 0, meta, {
28
28
  plugins,
29
29
  guards: globalGuards,
30
30
  interceptors: globalInterceptors
31
31
  });
32
- app[_chunkLZAU5FUSjs.APP_SYMBOL] = {
32
+ app[_chunkZZ2QKZ46js.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
- _chunkLZAU5FUSjs.__name.call(void 0, handleMeta, "handleMeta");
47
+ _chunkZZ2QKZ46js.__name.call(void 0, handleMeta, "handleMeta");
48
48
  async function createRoute() {
49
49
  app.post(route, (req, _res, next) => {
50
- req[_chunkLZAU5FUSjs.MERGE_SYMBOL] = true;
51
- req[_chunkLZAU5FUSjs.MODULE_SYMBOL] = moduleMap;
52
- req[_chunkLZAU5FUSjs.META_SYMBOL] = meta;
50
+ req[_chunkZZ2QKZ46js.MERGE_SYMBOL] = true;
51
+ req[_chunkZZ2QKZ46js.MODULE_SYMBOL] = moduleMap;
52
+ req[_chunkZZ2QKZ46js.META_SYMBOL] = meta;
53
53
  next();
54
- }, ..._chunkYU7ROHTOjs.Context.usePlugin(plugins), async (req, res) => {
54
+ }, ..._chunkJZGLQ4FQjs.Context.usePlugin(plugins), async (req, res) => {
55
55
  const { body } = req;
56
56
  async function errorHandler(e) {
57
- const error = await _chunkYU7ROHTOjs.Context.filter(e);
57
+ const error = await _chunkJZGLQ4FQjs.Context.filterRecord.default(e);
58
58
  return res.status(error.status).json(error);
59
59
  }
60
- _chunkLZAU5FUSjs.__name.call(void 0, errorHandler, "errorHandler");
60
+ _chunkZZ2QKZ46js.__name.call(void 0, errorHandler, "errorHandler");
61
61
  if (!Array.isArray(body))
62
- return errorHandler(new (0, _chunkYU7ROHTOjs.BadRequestException)("data format should be an array"));
62
+ return errorHandler(new (0, _chunkJZGLQ4FQjs.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 _chunkYU7ROHTOjs.Context.filter(new (0, _chunkYU7ROHTOjs.BadRequestException)(`"${tag}" doesn't exist`)));
69
+ return resolve(await _chunkJZGLQ4FQjs.Context.filterRecord.default(new (0, _chunkJZGLQ4FQjs.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, _chunkYU7ROHTOjs.Context)(tag, contextData);
78
+ const context = new (0, _chunkJZGLQ4FQjs.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[_chunkLZAU5FUSjs.MODULE_SYMBOL] = moduleMap;
127
- req[_chunkLZAU5FUSjs.META_SYMBOL] = meta;
126
+ req[_chunkZZ2QKZ46js.MODULE_SYMBOL] = moduleMap;
127
+ req[_chunkZZ2QKZ46js.META_SYMBOL] = meta;
128
128
  next();
129
- }, ..._chunkYU7ROHTOjs.Context.usePlugin(plugins2), async (req, res) => {
129
+ }, ..._chunkJZGLQ4FQjs.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, _chunkYU7ROHTOjs.Context)(methodTag, contextData);
139
+ const context = new (0, _chunkJZGLQ4FQjs.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: _chunkFAHHXHL5js.resolveDep.call(void 0, req[type], key),
160
+ arg: _chunkFCLWCFQSjs.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 true;
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
- _chunkLZAU5FUSjs.__name.call(void 0, createRoute, "createRoute");
188
+ _chunkZZ2QKZ46js.__name.call(void 0, createRoute, "createRoute");
186
189
  handleMeta();
187
190
  createRoute();
188
- if (_chunkLZAU5FUSjs.IS_DEV) {
191
+ if (_chunkZZ2QKZ46js.IS_DEV) {
189
192
  _optionalChain([globalThis, 'access', _7 => _7.__PS_HMR__, 'optionalAccess', _8 => _8.push, 'call', _9 => _9(async () => {
193
+ _chunkJZGLQ4FQjs.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
- _chunkLZAU5FUSjs.__name.call(void 0, bindApp, "bindApp");
204
+ _chunkZZ2QKZ46js.__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-JQPX546Z.mjs";
3
+ } from "../../chunk-43ZXHSVH.mjs";
4
4
  import {
5
5
  BadRequestException,
6
6
  Context,
7
7
  isAopDepInject
8
- } from "../../chunk-Q6T7HNEO.mjs";
8
+ } from "../../chunk-ATMZNJSE.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-AJ2HYENF.mjs";
16
+ } from "../../chunk-DQUH5BP6.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.filter(e);
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.filter(new BadRequestException(`"${tag}" doesn't exist`)));
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 true;
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();