phecda-server 4.1.0 → 4.1.1

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.
@@ -5,7 +5,7 @@ import {
5
5
  BadRequestException,
6
6
  Context,
7
7
  isAopDepInject
8
- } from "../../chunk-Z6LSJTOF.mjs";
8
+ } from "../../chunk-MIIYJMMM.mjs";
9
9
  import {
10
10
  APP_SYMBOL,
11
11
  IS_DEV,
@@ -5,8 +5,7 @@ var _chunk63KBHOSBjs = require('../../chunk-63KBHOSB.js');
5
5
 
6
6
 
7
7
 
8
- var _chunk32E425F6js = require('../../chunk-32E425F6.js');
9
-
8
+ var _chunkWBHZCJSNjs = require('../../chunk-WBHZCJSN.js');
10
9
 
11
10
 
12
11
 
@@ -25,7 +24,7 @@ function bindApp(router, { moduleMap, meta }, options = {}) {
25
24
  plugins: [],
26
25
  ...options
27
26
  };
28
- _chunk32E425F6js.isAopDepInject.call(void 0, meta, {
27
+ _chunkWBHZCJSNjs.isAopDepInject.call(void 0, meta, {
29
28
  plugins,
30
29
  guards: globalGuards,
31
30
  interceptors: globalInterceptors
@@ -34,6 +33,10 @@ function bindApp(router, { moduleMap, meta }, options = {}) {
34
33
  moduleMap,
35
34
  meta
36
35
  };
36
+ const prePlugin = _h3.defineRequestMiddleware.call(void 0, (event) => {
37
+ event[_chunkBDIQWWHNjs.MODULE_SYMBOL] = moduleMap;
38
+ event[_chunkBDIQWWHNjs.META_SYMBOL] = meta;
39
+ });
37
40
  const metaMap = /* @__PURE__ */ new Map();
38
41
  function handleMeta() {
39
42
  metaMap.clear();
@@ -47,84 +50,76 @@ function bindApp(router, { moduleMap, meta }, options = {}) {
47
50
  }
48
51
  _chunkBDIQWWHNjs.__name.call(void 0, handleMeta, "handleMeta");
49
52
  async function createRoute() {
50
- router.post(route, _h3.fromNodeMiddleware.call(void 0, (req, _res, next) => {
51
- req[_chunkBDIQWWHNjs.MERGE_SYMBOL] = true;
52
- req[_chunkBDIQWWHNjs.MODULE_SYMBOL] = moduleMap;
53
- req[_chunkBDIQWWHNjs.META_SYMBOL] = meta;
54
- next();
55
- }));
56
- plugins.forEach((p) => {
57
- const middleware = _chunk32E425F6js.Context.usePlugin([
58
- p
59
- ])[0];
60
- if (!middleware)
61
- return;
62
- router.post(route, _h3.fromNodeMiddleware.call(void 0, middleware));
63
- });
64
- router.post(route, _h3.eventHandler.call(void 0, async (event) => {
65
- const body = await _h3.readBody.call(void 0, event, {
66
- strict: true
67
- });
68
- async function errorHandler(e) {
69
- const error = await _chunk32E425F6js.Context.filterRecord.default(e);
70
- _h3.setResponseStatus.call(void 0, event, error.status);
71
- return error;
72
- }
73
- _chunkBDIQWWHNjs.__name.call(void 0, errorHandler, "errorHandler");
74
- if (!Array.isArray(body))
75
- return errorHandler(new (0, _chunk32E425F6js.BadRequestException)("data format should be an array"));
76
- try {
77
- return Promise.all(body.map((item) => {
78
- return new Promise(async (resolve) => {
79
- const { tag } = item;
80
- const meta2 = metaMap.get(tag);
81
- if (!meta2)
82
- return resolve(await _chunk32E425F6js.Context.filterRecord.default(new (0, _chunk32E425F6js.BadRequestException)(`"${tag}" doesn't exist`)));
83
- const contextData = {
84
- type: "h3",
85
- event,
86
- meta: meta2,
87
- moduleMap,
88
- parallel: true,
89
- tag
90
- };
91
- const context = new (0, _chunk32E425F6js.Context)(contextData);
92
- const [name, method] = tag.split("-");
93
- const { paramsType, handlers, data: { params, guards, interceptors, filter } } = metaMap.get(tag);
94
- const instance = moduleMap.get(name);
95
- try {
96
- await context.useGuard([
97
- ...globalGuards,
98
- ...guards
99
- ]);
100
- const cache = await context.useInterceptor([
101
- ...globalInterceptors,
102
- ...interceptors
103
- ]);
104
- if (cache !== void 0)
105
- return resolve(cache);
106
- const args = await context.usePipe(params.map(({ type, key, pipe, pipeOpts, index }) => {
107
- return {
108
- arg: item.args[index],
109
- type,
110
- key,
111
- pipe,
112
- pipeOpts,
113
- index,
114
- reflect: paramsType[index]
115
- };
116
- }));
117
- instance.context = contextData;
118
- const funcData = await moduleMap.get(name)[method](...args);
119
- resolve(await context.usePostInterceptor(funcData));
120
- } catch (e) {
121
- handlers.forEach((handler) => _optionalChain([handler, 'access', _2 => _2.error, 'optionalCall', _3 => _3(e)]));
122
- resolve(await context.useFilter(e, filter));
123
- }
124
- });
125
- }));
126
- } catch (e) {
127
- return errorHandler(e);
53
+ router.post(route, _h3.eventHandler.call(void 0, {
54
+ onRequest: [
55
+ prePlugin,
56
+ ..._chunkWBHZCJSNjs.Context.usePlugin(plugins).map((p) => _h3.defineRequestMiddleware.call(void 0, p))
57
+ ],
58
+ handler: async (event) => {
59
+ const body = await _h3.readBody.call(void 0, event, {
60
+ strict: true
61
+ });
62
+ async function errorHandler(e) {
63
+ const error = await _chunkWBHZCJSNjs.Context.filterRecord.default(e);
64
+ _h3.setResponseStatus.call(void 0, event, error.status);
65
+ return error;
66
+ }
67
+ _chunkBDIQWWHNjs.__name.call(void 0, errorHandler, "errorHandler");
68
+ if (!Array.isArray(body))
69
+ return errorHandler(new (0, _chunkWBHZCJSNjs.BadRequestException)("data format should be an array"));
70
+ try {
71
+ return Promise.all(body.map((item) => {
72
+ return new Promise(async (resolve) => {
73
+ const { tag } = item;
74
+ const meta2 = metaMap.get(tag);
75
+ if (!meta2)
76
+ return resolve(await _chunkWBHZCJSNjs.Context.filterRecord.default(new (0, _chunkWBHZCJSNjs.BadRequestException)(`"${tag}" doesn't exist`)));
77
+ const contextData = {
78
+ type: "h3",
79
+ event,
80
+ meta: meta2,
81
+ moduleMap,
82
+ parallel: true,
83
+ tag
84
+ };
85
+ const context = new (0, _chunkWBHZCJSNjs.Context)(contextData);
86
+ const [name, method] = tag.split("-");
87
+ const { paramsType, handlers, data: { params, guards, interceptors, filter } } = metaMap.get(tag);
88
+ const instance = moduleMap.get(name);
89
+ try {
90
+ await context.useGuard([
91
+ ...globalGuards,
92
+ ...guards
93
+ ]);
94
+ const cache = await context.useInterceptor([
95
+ ...globalInterceptors,
96
+ ...interceptors
97
+ ]);
98
+ if (cache !== void 0)
99
+ return resolve(cache);
100
+ const args = await context.usePipe(params.map(({ type, key, pipe, pipeOpts, index }) => {
101
+ return {
102
+ arg: item.args[index],
103
+ type,
104
+ key,
105
+ pipe,
106
+ pipeOpts,
107
+ index,
108
+ reflect: paramsType[index]
109
+ };
110
+ }));
111
+ instance.context = contextData;
112
+ const funcData = await moduleMap.get(name)[method](...args);
113
+ resolve(await context.usePostInterceptor(funcData));
114
+ } catch (e) {
115
+ handlers.forEach((handler) => _optionalChain([handler, 'access', _2 => _2.error, 'optionalCall', _3 => _3(e)]));
116
+ resolve(await context.useFilter(e, filter));
117
+ }
118
+ });
119
+ }));
120
+ } catch (e) {
121
+ return errorHandler(e);
122
+ }
128
123
  }
129
124
  }));
130
125
  for (const i of meta) {
@@ -133,79 +128,72 @@ function bindApp(router, { moduleMap, meta }, options = {}) {
133
128
  continue;
134
129
  const methodTag = `${tag}-${method}`;
135
130
  const { paramsType, handlers, data: { interceptors, guards, params, plugins: plugins2, filter } } = metaMap.get(methodTag);
136
- router[http.type](http.route, _h3.fromNodeMiddleware.call(void 0, (req, _res, next) => {
137
- req[_chunkBDIQWWHNjs.MODULE_SYMBOL] = moduleMap;
138
- req[_chunkBDIQWWHNjs.META_SYMBOL] = meta;
139
- next();
140
- }));
141
- for (const p of plugins2) {
142
- const middleware = _chunk32E425F6js.Context.usePlugin([
143
- p
144
- ])[0];
145
- if (!middleware)
146
- continue;
147
- router[http.type](http.route, _h3.fromNodeMiddleware.call(void 0, middleware));
148
- }
149
- router[http.type](http.route, _h3.eventHandler.call(void 0, async (event) => {
150
- const instance = moduleMap.get(tag);
151
- const contextData = {
152
- type: "h3",
153
- meta: i,
154
- event,
155
- moduleMap,
156
- parallel: false,
157
- tag: methodTag
158
- };
159
- const context = new (0, _chunk32E425F6js.Context)(contextData);
160
- try {
161
- _h3.setHeaders.call(void 0, event, header);
162
- await context.useGuard([
163
- ...globalGuards,
164
- ...guards
165
- ]);
166
- const cache = await context.useInterceptor([
167
- ...globalInterceptors,
168
- ...interceptors
169
- ]);
170
- if (cache !== void 0)
171
- return cache;
172
- const body = params.some((item) => item.type === "body") ? await _h3.readBody.call(void 0, event, {
173
- strict: true
174
- }) : void 0;
175
- const args = await context.usePipe(params.map(({ type, key, pipe, pipeOpts, index }) => {
176
- let arg;
177
- switch (type) {
178
- case "params":
179
- arg = _h3.getRouterParams.call(void 0, event);
180
- break;
181
- case "query":
182
- arg = _h3.getQuery.call(void 0, event);
183
- break;
184
- case "header":
185
- arg = _h3.getRequestHeaders.call(void 0, event);
186
- break;
187
- default:
188
- arg = body;
189
- }
190
- return {
191
- arg: _chunk63KBHOSBjs.resolveDep.call(void 0, arg, key),
192
- pipe,
193
- pipeOpts,
194
- key,
195
- type,
196
- index,
197
- reflect: paramsType[index]
198
- };
199
- }));
200
- instance.context = contextData;
201
- const funcData = await instance[method](...args);
202
- const ret = await context.usePostInterceptor(funcData);
203
- return ret;
204
- } catch (e) {
205
- handlers.forEach((handler) => _optionalChain([handler, 'access', _5 => _5.error, 'optionalCall', _6 => _6(e)]));
206
- const err = await context.useFilter(e, filter);
207
- _h3.setResponseStatus.call(void 0, event, err.status);
208
- return err;
131
+ router[http.type](http.route, _h3.eventHandler.call(void 0, {
132
+ onRequest: [
133
+ prePlugin,
134
+ ..._chunkWBHZCJSNjs.Context.usePlugin(plugins2).map((p) => _h3.defineRequestMiddleware.call(void 0, p))
135
+ ],
136
+ handler: async (event) => {
137
+ const instance = moduleMap.get(tag);
138
+ const contextData = {
139
+ type: "h3",
140
+ meta: i,
141
+ event,
142
+ moduleMap,
143
+ parallel: false,
144
+ tag: methodTag
145
+ };
146
+ const context = new (0, _chunkWBHZCJSNjs.Context)(contextData);
147
+ try {
148
+ _h3.setHeaders.call(void 0, event, header);
149
+ await context.useGuard([
150
+ ...globalGuards,
151
+ ...guards
152
+ ]);
153
+ const cache = await context.useInterceptor([
154
+ ...globalInterceptors,
155
+ ...interceptors
156
+ ]);
157
+ if (cache !== void 0)
158
+ return cache;
159
+ const body = params.some((item) => item.type === "body") ? await _h3.readBody.call(void 0, event, {
160
+ strict: true
161
+ }) : void 0;
162
+ const args = await context.usePipe(params.map(({ type, key, pipe, pipeOpts, index }) => {
163
+ let arg;
164
+ switch (type) {
165
+ case "params":
166
+ arg = _h3.getRouterParams.call(void 0, event);
167
+ break;
168
+ case "query":
169
+ arg = _h3.getQuery.call(void 0, event);
170
+ break;
171
+ case "header":
172
+ arg = _h3.getRequestHeaders.call(void 0, event);
173
+ break;
174
+ default:
175
+ arg = body;
176
+ }
177
+ return {
178
+ arg: _chunk63KBHOSBjs.resolveDep.call(void 0, arg, key),
179
+ pipe,
180
+ pipeOpts,
181
+ key,
182
+ type,
183
+ index,
184
+ reflect: paramsType[index]
185
+ };
186
+ }));
187
+ instance.context = contextData;
188
+ const funcData = await instance[method](...args);
189
+ const ret = await context.usePostInterceptor(funcData);
190
+ return ret;
191
+ } catch (e) {
192
+ handlers.forEach((handler) => _optionalChain([handler, 'access', _5 => _5.error, 'optionalCall', _6 => _6(e)]));
193
+ const err = await context.useFilter(e, filter);
194
+ _h3.setResponseStatus.call(void 0, event, err.status);
195
+ return err;
196
+ }
209
197
  }
210
198
  }));
211
199
  }
@@ -215,7 +203,7 @@ function bindApp(router, { moduleMap, meta }, options = {}) {
215
203
  createRoute();
216
204
  if (_chunkBDIQWWHNjs.IS_DEV) {
217
205
  _optionalChain([globalThis, 'access', _7 => _7.__PS_HMR__, 'optionalAccess', _8 => _8.push, 'call', _9 => _9(async () => {
218
- _chunk32E425F6js.isAopDepInject.call(void 0, meta, {
206
+ _chunkWBHZCJSNjs.isAopDepInject.call(void 0, meta, {
219
207
  plugins,
220
208
  guards: globalGuards,
221
209
  interceptors: globalInterceptors
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/server/h3/bind.ts"],"names":["eventHandler","fromNodeMiddleware","getQuery","getRequestHeaders","getRouterParams","readBody","setHeaders","setResponseStatus","bindApp","router","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","forEach","p","middleware","Context","usePlugin","event","body","strict","errorHandler","e","error","filterRecord","default","status","Array","isArray","BadRequestException","Promise","all","map","resolve","get","contextData","parallel","context","name","split","paramsType","handlers","params","filter","instance","useGuard","cache","useInterceptor","undefined","args","usePipe","key","pipe","pipeOpts","index","arg","reflect","funcData","usePostInterceptor","handler","useFilter","i","header","some","resolveDep","ret","err","IS_DEV","globalThis","__PS_HMR__","push"],"mappings":"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","sourcesContent":["import { eventHandler, fromNodeMiddleware, getQuery, getRequestHeaders, getRouterParams, readBody, setHeaders, setResponseStatus } from 'h3'\nimport type { H3Event, NodeMiddleware, Router } from 'h3'\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'\nimport { P } from '../../types'\n\nexport interface H3Ctx extends P.BaseContext{\n type: 'h3'\n event: H3Event\n\n parallel: boolean\n\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),全局中间件请在bindApp以外设置\n */\n plugins?: string[]\n\n}\n\nexport function bindApp(router: 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\n isAopDepInject(meta, {\n plugins,\n guards: globalGuards,\n interceptors: globalInterceptors,\n });\n\n (router 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 router.post(route, fromNodeMiddleware((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 }))\n plugins.forEach((p) => {\n const middleware = Context.usePlugin([p])[0] as NodeMiddleware\n if (!middleware)\n return\n router.post(route, fromNodeMiddleware(middleware))\n })\n\n router.post(route, eventHandler(async (event) => {\n const body = await readBody(event, { strict: true })\n async function errorHandler(e: any) {\n const error = await Context.filterRecord.default(e)\n setResponseStatus(event, error.status)\n return 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: 'h3' as const,\n event,\n meta,\n moduleMap,\n parallel: true,\n tag\n }\n const context = new Context<H3Ctx>(contextData)\n const [name, method] = tag.split('-')\n const {\n paramsType,\n handlers,\n data: {\n params,\n guards,\n interceptors, filter,\n },\n } = metaMap.get(tag)!\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, pipe, pipeOpts, index }) => {\n return { arg: item.args[index], type, key, pipe, pipeOpts, 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 }))\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 router[http.type](http.route, fromNodeMiddleware((req, _res, next) => {\n (req as any)[MODULE_SYMBOL] = moduleMap;\n (req as any)[META_SYMBOL] = meta\n next()\n }))\n\n for (const p of plugins) {\n const middleware = Context.usePlugin([p])[0]\n if (!middleware)\n continue\n\n router[http.type](http.route, fromNodeMiddleware(middleware))\n }\n\n router[http.type](http.route, eventHandler(async (event) => {\n const instance = moduleMap.get(tag)!\n\n const contextData = {\n type: 'h3' as const,\n meta: i,\n event,\n moduleMap,\n parallel: false,\n tag:methodTag\n }\n const context = new Context<H3Ctx>( contextData)\n\n try {\n setHeaders(event, header)\n await context.useGuard([...globalGuards, ...guards])\n const cache = await context.useInterceptor([...globalInterceptors, ...interceptors])\n if (cache !== undefined)\n return cache\n\n const body = params.some(item => item.type === 'body') ? await readBody(event, { strict: true }) : undefined\n const args = await context.usePipe(params.map(({ type, key, pipe, pipeOpts, index }) => {\n let arg: any\n\n switch (type) {\n case 'params':\n arg = getRouterParams(event)\n break\n case 'query':\n arg = getQuery(event)\n break\n case 'header':\n arg = getRequestHeaders(event)\n break\n default:\n arg = body\n }\n\n return { arg: resolveDep(arg, key), pipe, pipeOpts, 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 return ret\n }\n catch (e: any) {\n handlers.forEach(handler => handler.error?.(e))\n const err = await context.useFilter(e, filter)\n setResponseStatus(event, err.status)\n return 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 handleMeta()\n })\n }\n}\n"]}
1
+ {"version":3,"sources":["../../../src/server/h3/bind.ts"],"names":["defineRequestMiddleware","eventHandler","getQuery","getRequestHeaders","getRouterParams","readBody","setHeaders","setResponseStatus","bindApp","router","moduleMap","meta","options","globalGuards","globalInterceptors","route","plugins","isAopDepInject","guards","interceptors","APP_SYMBOL","prePlugin","event","MODULE_SYMBOL","META_SYMBOL","metaMap","Map","handleMeta","clear","item","tag","method","http","data","type","methodTag","set","createRoute","post","onRequest","Context","usePlugin","map","p","handler","body","strict","errorHandler","e","error","filterRecord","default","status","Array","isArray","BadRequestException","Promise","all","resolve","get","contextData","parallel","context","name","split","paramsType","handlers","params","filter","instance","useGuard","cache","useInterceptor","undefined","args","usePipe","key","pipe","pipeOpts","index","arg","reflect","funcData","usePostInterceptor","forEach","useFilter","i","header","some","resolveDep","ret","err","IS_DEV","globalThis","__PS_HMR__","push"],"mappings":";;;;;;;;;;;;;;;;;AAAA,SAASA,yBAAyBC,cAAcC,UAAUC,mBAAmBC,iBAAiBC,UAAUC,YAAYC,yBAAyB;AAsCtI,SAASC,QAAQC,QAAgB,EAAEC,WAAWC,KAAI,GAAyCC,UAAmB,CAAC,GAAG;AACvH,QAAM,EAAEC,cAAcC,oBAAoBC,OAAOC,QAAO,IAAK;IAAED,OAAO;IAAsBF,cAAc,CAAA;IAAIC,oBAAoB,CAAA;IAAIE,SAAS,CAAA;IAAI,GAAGJ;EAAQ;AAI9JK,iBAAeN,MAAM;IACnBK;IACAE,QAAQL;IACRM,cAAcL;EAChB,CAAA;AAICL,SAAeW,cAAc;IAAEV;IAAWC;EAAK;AAGhD,QAAMU,YAAUrB,wBAAwB,CAACsB,UAAU;AAChDA,UAAcC,iBAAiBb;AAC/BY,UAAcE,eAAeb;EAChC,CAAA;AACA,QAAMc,UAAU,oBAAIC,IAAAA;AACpB,WAASC,aAAa;AACpBF,YAAQG,MAAK;AACb,eAAWC,QAAQlB,MAAM;AACvB,YAAM,EAAEmB,KAAKC,QAAQC,KAAI,IAAKH,KAAKI;AACnC,UAAI,CAACD,MAAME;AACT;AACF,YAAMC,YAAY,GAAGL,OAAOC;AAC5BN,cAAQW,IAAID,WAAWN,IAAAA;IACzB;EACF;AATSF;AAWT,iBAAeU,cAAc;AAG3B5B,WAAO6B,KAAKvB,OAAOd,aAAa;MAC9BsC,WAAU;QAAClB;WAAamB,QAAQC,UAAUzB,OAAAA,EAAS0B,IAAI,CAACC,MAAI3C,wBAAwB2C,CAAAA,CAAAA;;MACpFC,SAAQ,OAAOtB,UAAU;AACvB,cAAMuB,OAAO,MAAMxC,SAASiB,OAAO;UAAEwB,QAAQ;QAAK,CAAA;AAClD,uBAAeC,aAAaC,GAAQ;AAClC,gBAAMC,QAAQ,MAAMT,QAAQU,aAAaC,QAAQH,CAAAA;AACjDzC,4BAAkBe,OAAO2B,MAAMG,MAAM;AACrC,iBAAOH;QACT;AAJeF;AAMf,YAAI,CAACM,MAAMC,QAAQT,IAAAA;AACjB,iBAAOE,aAAa,IAAIQ,oBAAoB,gCAAA,CAAA;AAE9C,YAAI;AACF,iBAAOC,QAAQC,IAAIZ,KAAKH,IAAI,CAACb,SAAc;AAEzC,mBAAO,IAAI2B,QAAQ,OAAOE,YAAY;AACpC,oBAAM,EAAE5B,IAAG,IAAKD;AAChB,oBAAMlB,QAAOc,QAAQkC,IAAI7B,GAAAA;AACzB,kBAAI,CAACnB;AACH,uBAAO+C,QAAQ,MAAMlB,QAAQU,aAAaC,QAAQ,IAAII,oBAAoB,IAAIzB,oBAAoB,CAAA,CAAA;AAEpG,oBAAM8B,cAAc;gBAClB1B,MAAM;gBACNZ;gBACAX,MAAAA;gBACAD;gBACAmD,UAAU;gBACV/B;cACF;AACA,oBAAMgC,UAAU,IAAItB,QAAeoB,WAAAA;AACnC,oBAAM,CAACG,MAAMhC,MAAAA,IAAUD,IAAIkC,MAAM,GAAA;AACjC,oBAAM,EACJC,YACAC,UACAjC,MAAM,EACJkC,QACAjD,QACAC,cAAciD,OAAM,EACrB,IACC3C,QAAQkC,IAAI7B,GAAAA;AAEhB,oBAAMuC,WAAW3D,UAAUiD,IAAII,IAAAA;AAE/B,kBAAI;AACF,sBAAMD,QAAQQ,SAAS;qBAAIzD;qBAAiBK;iBAAO;AACnD,sBAAMqD,QAAQ,MAAMT,QAAQU,eAAe;qBAAI1D;qBAAuBK;iBAAa;AACnF,oBAAIoD,UAAUE;AACZ,yBAAOf,QAAQa,KAAAA;AACjB,sBAAMG,OAAO,MAAMZ,QAAQa,QAAQR,OAAOzB,IAAI,CAAC,EAAER,MAAM0C,KAAKC,MAAMC,UAAUC,MAAK,MAAO;AACtF,yBAAO;oBAAEC,KAAKnD,KAAK6C,KAAKK;oBAAQ7C;oBAAM0C;oBAAKC;oBAAMC;oBAAUC;oBAAOE,SAAShB,WAAWc;kBAAO;gBAC/F,CAAA,CAAA;AACAV,yBAASP,UAAUF;AACnB,sBAAMsB,WAAW,MAAMxE,UAAUiD,IAAII,IAAAA,EAAMhC,QAAO,GAAI2C,IAAAA;AACtDhB,wBAAQ,MAAMI,QAAQqB,mBAAmBD,QAAAA,CAAAA;cAC3C,SACOlC,GAAP;AACEkB,yBAASkB,QAAQxC,CAAAA,YAAWA,QAAQK,QAAQD,CAAAA,CAAAA;AAC5CU,wBAAQ,MAAMI,QAAQuB,UAAUrC,GAAGoB,MAAAA,CAAAA;cACrC;YACF,CAAA;UACF,CAAA,CAAA;QACF,SAEOpB,GAAP;AACE,iBAAOD,aAAaC,CAAAA;QACtB;MACF;IACF,CAAA,CAAA;AAIA,eAAWsC,KAAK3E,MAAM;AACpB,YAAM,EAAEoB,QAAQC,MAAMuD,QAAQzD,IAAG,IAAKwD,EAAErD;AAExC,UAAI,CAACD,MAAME;AACT;AAEF,YAAMC,YAAY,GAAGL,OAAOC;AAE5B,YAAM,EACJkC,YACAC,UACAjC,MAAM,EACJd,cACAD,QACAiD,QACAnD,SAAAA,UACAoD,OAAM,EACP,IACC3C,QAAQkC,IAAIxB,SAAAA;AAIhB1B,aAAOuB,KAAKE,MAAMF,KAAKjB,OAAOd,aAAa;QACzCsC,WAAU;UAAClB;aAAamB,QAAQC,UAAUzB,QAAAA,EAAS0B,IAAI,CAACC,MAAI3C,wBAAwB2C,CAAAA,CAAAA;;QACpFC,SAAQ,OAAOtB,UAAU;AACvB,gBAAM+C,WAAW3D,UAAUiD,IAAI7B,GAAAA;AAE/B,gBAAM8B,cAAc;YAClB1B,MAAM;YACNvB,MAAM2E;YACNhE;YACAZ;YACAmD,UAAU;YACV/B,KAAKK;UACP;AACA,gBAAM2B,UAAU,IAAItB,QAAeoB,WAAAA;AAEnC,cAAI;AACFtD,uBAAWgB,OAAOiE,MAAAA;AAClB,kBAAMzB,QAAQQ,SAAS;iBAAIzD;iBAAiBK;aAAO;AACnD,kBAAMqD,QAAQ,MAAMT,QAAQU,eAAe;iBAAI1D;iBAAuBK;aAAa;AACnF,gBAAIoD,UAAUE;AACZ,qBAAOF;AAET,kBAAM1B,OAAOsB,OAAOqB,KAAK3D,CAAAA,SAAQA,KAAKK,SAAS,MAAA,IAAU,MAAM7B,SAASiB,OAAO;cAAEwB,QAAQ;YAAK,CAAA,IAAK2B;AACnG,kBAAMC,OAAO,MAAMZ,QAAQa,QAAQR,OAAOzB,IAAI,CAAC,EAAER,MAAM0C,KAAKC,MAAMC,UAAUC,MAAK,MAAO;AACtF,kBAAIC;AAEJ,sBAAQ9C,MAAAA;gBACN,KAAK;AACH8C,wBAAM5E,gBAAgBkB,KAAAA;AACtB;gBACF,KAAK;AACH0D,wBAAM9E,SAASoB,KAAAA;AACf;gBACF,KAAK;AACH0D,wBAAM7E,kBAAkBmB,KAAAA;AACxB;gBACF;AACE0D,wBAAMnC;cACV;AAEA,qBAAO;gBAAEmC,KAAKS,WAAWT,KAAKJ,GAAAA;gBAAMC;gBAAMC;gBAAUF;gBAAK1C;gBAAM6C;gBAAOE,SAAShB,WAAWc;cAAO;YACnG,CAAA,CAAA;AAEAV,qBAASP,UAAUF;AACnB,kBAAMsB,WAAW,MAAMb,SAAStC,QAAO,GAAI2C,IAAAA;AAC3C,kBAAMgB,MAAM,MAAM5B,QAAQqB,mBAAmBD,QAAAA;AAE7C,mBAAOQ;UACT,SACO1C,GAAP;AACEkB,qBAASkB,QAAQxC,CAAAA,YAAWA,QAAQK,QAAQD,CAAAA,CAAAA;AAC5C,kBAAM2C,MAAM,MAAM7B,QAAQuB,UAAUrC,GAAGoB,MAAAA;AACvC7D,8BAAkBe,OAAOqE,IAAIvC,MAAM;AACnC,mBAAOuC;UACT;QACF;MACF,CAAA,CAAA;IACF;EACF;AA3JetD;AA6JfV,aAAAA;AACAU,cAAAA;AACA,MAAIuD,QAAQ;AACVC,eAAWC,YAAYC,KAAK,YAAY;AACtC9E,qBAAeN,MAAM;QACnBK;QACAE,QAAQL;QACRM,cAAcL;MAChB,CAAA;AACAa,iBAAAA;IACF,CAAA;EACF;AACF;AAzMgBnB","sourcesContent":["import { defineRequestMiddleware, eventHandler, getQuery, getRequestHeaders, getRouterParams, readBody, setHeaders, setResponseStatus } from 'h3'\nimport type { H3Event, Router } from 'h3'\nimport { resolveDep } from '../../helper'\nimport { APP_SYMBOL, IS_DEV, 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'\nimport { P } from '../../types'\n\nexport interface H3Ctx extends P.BaseContext {\n type: 'h3'\n event: H3Event\n\n parallel: boolean\n\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),全局中间件请在bindApp以外设置\n */\n plugins?: string[]\n\n}\n\nexport function bindApp(router: 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\n\n\n isAopDepInject(meta, {\n plugins,\n guards: globalGuards,\n interceptors: globalInterceptors,\n });\n\n\n\n (router as any)[APP_SYMBOL] = { moduleMap, meta }\n\n\n const prePlugin=defineRequestMiddleware((event) => {\n (event as any)[MODULE_SYMBOL] = moduleMap;\n (event as any)[META_SYMBOL] = 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\n\n router.post(route, eventHandler({\n onRequest:[prePlugin,...Context.usePlugin(plugins).map((p)=>defineRequestMiddleware(p))],\n handler:async (event) => {\n const body = await readBody(event, { strict: true })\n async function errorHandler(e: any) {\n const error = await Context.filterRecord.default(e)\n setResponseStatus(event, error.status)\n return 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: 'h3' as const,\n event,\n meta,\n moduleMap,\n parallel: true,\n tag\n }\n const context = new Context<H3Ctx>(contextData)\n const [name, method] = tag.split('-')\n const {\n paramsType,\n handlers,\n data: {\n params,\n guards,\n interceptors, filter,\n },\n } = metaMap.get(tag)!\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, pipe, pipeOpts, index }) => {\n return { arg: item.args[index], type, key, pipe, pipeOpts, 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 }))\n }\n \n catch (e) {\n return errorHandler(e)\n }\n }\n }))\n\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\n \n router[http.type](http.route, eventHandler({\n onRequest:[prePlugin,...Context.usePlugin(plugins).map((p)=>defineRequestMiddleware(p))],\n handler:async (event) => {\n const instance = moduleMap.get(tag)!\n \n const contextData = {\n type: 'h3' as const,\n meta: i,\n event,\n moduleMap,\n parallel: false,\n tag: methodTag\n }\n const context = new Context<H3Ctx>(contextData)\n \n try {\n setHeaders(event, header)\n await context.useGuard([...globalGuards, ...guards])\n const cache = await context.useInterceptor([...globalInterceptors, ...interceptors])\n if (cache !== undefined)\n return cache\n \n const body = params.some(item => item.type === 'body') ? await readBody(event, { strict: true }) : undefined\n const args = await context.usePipe(params.map(({ type, key, pipe, pipeOpts, index }) => {\n let arg: any\n \n switch (type) {\n case 'params':\n arg = getRouterParams(event)\n break\n case 'query':\n arg = getQuery(event)\n break\n case 'header':\n arg = getRequestHeaders(event)\n break\n default:\n arg = body\n }\n \n return { arg: resolveDep(arg, key), pipe, pipeOpts, 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 return ret\n }\n catch (e: any) {\n handlers.forEach(handler => handler.error?.(e))\n const err = await context.useFilter(e, filter)\n setResponseStatus(event, err.status)\n return err\n }\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 handleMeta()\n })\n }\n}\n"]}