phecda-server 7.0.0-alpha.8 → 7.0.0

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 (154) hide show
  1. package/README.md +10 -10
  2. package/assets/schema.json +12 -9
  3. package/bin/cli.mjs +96 -37
  4. package/dist/chunk-5SUY5UVC.js +258 -0
  5. package/dist/chunk-5SUY5UVC.js.map +1 -0
  6. package/dist/chunk-6JAHCTOT.mjs +334 -0
  7. package/dist/chunk-6JAHCTOT.mjs.map +1 -0
  8. package/dist/{chunk-BBNJVYVX.js → chunk-EDAWJVJ4.js} +42 -25
  9. package/dist/chunk-EDAWJVJ4.js.map +1 -0
  10. package/dist/{chunk-7EMAZGYO.js → chunk-H7OCHDZT.js} +65 -95
  11. package/dist/chunk-H7OCHDZT.js.map +1 -0
  12. package/dist/{chunk-QJIAXSLZ.js → chunk-KRUOHWFR.js} +79 -68
  13. package/dist/chunk-KRUOHWFR.js.map +1 -0
  14. package/dist/chunk-KUGU3UGO.js +334 -0
  15. package/dist/chunk-KUGU3UGO.js.map +1 -0
  16. package/dist/{chunk-SGMQZRP6.mjs → chunk-LBH4RXQQ.mjs} +12 -42
  17. package/dist/chunk-LBH4RXQQ.mjs.map +1 -0
  18. package/dist/{chunk-YKP4ODZA.mjs → chunk-MDPW6WGF.mjs} +32 -6
  19. package/dist/chunk-MDPW6WGF.mjs.map +1 -0
  20. package/dist/{chunk-VSGYTGHY.js → chunk-RLFCI3RG.js} +31 -5
  21. package/dist/chunk-RLFCI3RG.js.map +1 -0
  22. package/dist/{chunk-7NWDKK7D.mjs → chunk-TTHYUNOT.mjs} +18 -1
  23. package/dist/chunk-TTHYUNOT.mjs.map +1 -0
  24. package/dist/chunk-VDOICQ2U.mjs +258 -0
  25. package/dist/chunk-VDOICQ2U.mjs.map +1 -0
  26. package/dist/{chunk-B45BN7LY.mjs → chunk-WTJKTICN.mjs} +65 -54
  27. package/dist/chunk-WTJKTICN.mjs.map +1 -0
  28. package/dist/{core-BGEsBtTG.d.ts → core-BOo3uGFX.d.ts} +5 -4
  29. package/dist/{core-BcKywWLd.d.mts → core-CF45G79J.d.mts} +5 -4
  30. package/dist/core-DbqWh47p.d.mts +50 -0
  31. package/dist/core-Rq7BhPHE.d.ts +50 -0
  32. package/dist/helper.d.mts +7 -8
  33. package/dist/helper.d.ts +7 -8
  34. package/dist/helper.js +5 -3
  35. package/dist/helper.js.map +1 -0
  36. package/dist/helper.mjs +9 -7
  37. package/dist/helper.mjs.map +1 -0
  38. package/dist/http/elysia/index.d.mts +4 -4
  39. package/dist/http/elysia/index.d.ts +4 -4
  40. package/dist/http/elysia/index.js +43 -45
  41. package/dist/http/elysia/index.js.map +1 -0
  42. package/dist/http/elysia/index.mjs +6 -8
  43. package/dist/http/elysia/index.mjs.map +1 -0
  44. package/dist/http/express/index.d.mts +3 -3
  45. package/dist/http/express/index.d.ts +3 -3
  46. package/dist/http/express/index.js +40 -42
  47. package/dist/http/express/index.js.map +1 -0
  48. package/dist/http/express/index.mjs +6 -8
  49. package/dist/http/express/index.mjs.map +1 -0
  50. package/dist/http/fastify/index.d.mts +3 -3
  51. package/dist/http/fastify/index.d.ts +3 -3
  52. package/dist/http/fastify/index.js +41 -43
  53. package/dist/http/fastify/index.js.map +1 -0
  54. package/dist/http/fastify/index.mjs +6 -8
  55. package/dist/http/fastify/index.mjs.map +1 -0
  56. package/dist/http/h3/index.d.mts +3 -3
  57. package/dist/http/h3/index.d.ts +3 -3
  58. package/dist/http/h3/index.js +41 -43
  59. package/dist/http/h3/index.js.map +1 -0
  60. package/dist/http/h3/index.mjs +5 -7
  61. package/dist/http/h3/index.mjs.map +1 -0
  62. package/dist/http/hono/index.d.mts +3 -3
  63. package/dist/http/hono/index.d.ts +3 -3
  64. package/dist/http/hono/index.js +37 -39
  65. package/dist/http/hono/index.js.map +1 -0
  66. package/dist/http/hono/index.mjs +5 -7
  67. package/dist/http/hono/index.mjs.map +1 -0
  68. package/dist/http/hyper-express/index.d.mts +3 -3
  69. package/dist/http/hyper-express/index.d.ts +3 -3
  70. package/dist/http/hyper-express/index.js +38 -40
  71. package/dist/http/hyper-express/index.js.map +1 -0
  72. package/dist/http/hyper-express/index.mjs +5 -7
  73. package/dist/http/hyper-express/index.mjs.map +1 -0
  74. package/dist/http/koa/index.d.mts +3 -3
  75. package/dist/http/koa/index.d.ts +3 -3
  76. package/dist/http/koa/index.js +40 -42
  77. package/dist/http/koa/index.js.map +1 -0
  78. package/dist/http/koa/index.mjs +6 -8
  79. package/dist/http/koa/index.mjs.map +1 -0
  80. package/dist/index.d.mts +76 -12
  81. package/dist/index.d.ts +76 -12
  82. package/dist/index.js +103 -49
  83. package/dist/index.js.map +1 -0
  84. package/dist/index.mjs +68 -14
  85. package/dist/index.mjs.map +1 -0
  86. package/dist/{meta-B_HW7cWh.d.ts → meta-BoS1E-Nz.d.mts} +6 -24
  87. package/dist/{meta-B_HW7cWh.d.mts → meta-BoS1E-Nz.d.ts} +6 -24
  88. package/dist/rpc/bullmq/index.d.mts +4 -6
  89. package/dist/rpc/bullmq/index.d.ts +4 -6
  90. package/dist/rpc/bullmq/index.js +13 -80
  91. package/dist/rpc/bullmq/index.js.map +1 -0
  92. package/dist/rpc/bullmq/index.mjs +6 -73
  93. package/dist/rpc/bullmq/index.mjs.map +1 -0
  94. package/dist/rpc/electron/index.d.mts +13 -0
  95. package/dist/rpc/electron/index.d.ts +13 -0
  96. package/dist/rpc/electron/index.js +73 -0
  97. package/dist/rpc/electron/index.js.map +1 -0
  98. package/dist/rpc/electron/index.mjs +73 -0
  99. package/dist/rpc/electron/index.mjs.map +1 -0
  100. package/dist/rpc/kafka/index.d.mts +4 -9
  101. package/dist/rpc/kafka/index.d.ts +4 -9
  102. package/dist/rpc/kafka/index.js +12 -90
  103. package/dist/rpc/kafka/index.js.map +1 -0
  104. package/dist/rpc/kafka/index.mjs +5 -83
  105. package/dist/rpc/kafka/index.mjs.map +1 -0
  106. package/dist/rpc/nats/index.d.mts +4 -6
  107. package/dist/rpc/nats/index.d.ts +4 -6
  108. package/dist/rpc/nats/index.js +13 -72
  109. package/dist/rpc/nats/index.js.map +1 -0
  110. package/dist/rpc/nats/index.mjs +5 -64
  111. package/dist/rpc/nats/index.mjs.map +1 -0
  112. package/dist/rpc/rabbitmq/index.d.mts +4 -6
  113. package/dist/rpc/rabbitmq/index.d.ts +4 -6
  114. package/dist/rpc/rabbitmq/index.js +14 -79
  115. package/dist/rpc/rabbitmq/index.js.map +1 -0
  116. package/dist/rpc/rabbitmq/index.mjs +6 -71
  117. package/dist/rpc/rabbitmq/index.mjs.map +1 -0
  118. package/dist/rpc/redis/index.d.mts +4 -9
  119. package/dist/rpc/redis/index.d.ts +4 -9
  120. package/dist/rpc/redis/index.js +12 -78
  121. package/dist/rpc/redis/index.js.map +1 -0
  122. package/dist/rpc/redis/index.mjs +6 -72
  123. package/dist/rpc/redis/index.mjs.map +1 -0
  124. package/dist/rpc/web-ext/index.d.mts +2 -0
  125. package/dist/rpc/web-ext/index.d.ts +2 -0
  126. package/dist/rpc/web-ext/index.js +1 -0
  127. package/dist/rpc/web-ext/index.js.map +1 -0
  128. package/dist/rpc/web-ext/index.mjs +1 -0
  129. package/dist/rpc/web-ext/index.mjs.map +1 -0
  130. package/dist/rpc/ws/index.d.mts +14 -0
  131. package/dist/rpc/ws/index.d.ts +14 -0
  132. package/dist/rpc/ws/index.js +74 -0
  133. package/dist/rpc/ws/index.js.map +1 -0
  134. package/dist/rpc/ws/index.mjs +74 -0
  135. package/dist/rpc/ws/index.mjs.map +1 -0
  136. package/dist/test.d.mts +8 -4
  137. package/dist/test.d.ts +8 -4
  138. package/dist/test.js +7 -6
  139. package/dist/test.js.map +1 -0
  140. package/dist/test.mjs +3 -2
  141. package/dist/test.mjs.map +1 -0
  142. package/dist/types-CInz3bD0.d.ts +14 -0
  143. package/dist/types-E-rqlg3-.d.mts +14 -0
  144. package/dist/{types-C2SQ9U9V.d.mts → types-SCJZFCYt.d.mts} +1 -1
  145. package/dist/{types-PFPIQWVF.d.ts → types-xruyYmyu.d.ts} +1 -1
  146. package/package.json +24 -8
  147. package/register/export.mjs +30 -0
  148. package/register/index.mjs +20 -12
  149. package/register/loader.mjs +94 -116
  150. package/register/utils.mjs +36 -6
  151. package/assets/ps.json +0 -24
  152. package/assets/tsconfig.json +0 -21
  153. package/dist/types-CYF0vha6.d.ts +0 -19
  154. package/dist/types-DEQb_e59.d.mts +0 -19
@@ -0,0 +1,13 @@
1
+ import Electron from 'electron';
2
+ import { F as Factory } from '../../core-DbqWh47p.mjs';
3
+ import { R as RpcCtx, a as RpcServerOptions } from '../../types-E-rqlg3-.mjs';
4
+ import 'phecda-core';
5
+ import '../../meta-BoS1E-Nz.mjs';
6
+
7
+ interface ElectronCtx extends RpcCtx {
8
+ type: 'electron';
9
+ event: Electron.IpcMainEvent | Electron.IpcMainInvokeEvent;
10
+ }
11
+ declare function bind(IPC: Electron.IpcMain, { moduleMap, meta }: Awaited<ReturnType<typeof Factory>>, opts?: RpcServerOptions): void;
12
+
13
+ export { type ElectronCtx, bind };
@@ -0,0 +1,13 @@
1
+ import Electron from 'electron';
2
+ import { F as Factory } from '../../core-Rq7BhPHE.js';
3
+ import { R as RpcCtx, a as RpcServerOptions } from '../../types-CInz3bD0.js';
4
+ import 'phecda-core';
5
+ import '../../meta-BoS1E-Nz.js';
6
+
7
+ interface ElectronCtx extends RpcCtx {
8
+ type: 'electron';
9
+ event: Electron.IpcMainEvent | Electron.IpcMainInvokeEvent;
10
+ }
11
+ declare function bind(IPC: Electron.IpcMain, { moduleMap, meta }: Awaited<ReturnType<typeof Factory>>, opts?: RpcServerOptions): void;
12
+
13
+ export { type ElectronCtx, bind };
@@ -0,0 +1,73 @@
1
+ "use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } 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
+
3
+
4
+
5
+ var _chunkH7OCHDZTjs = require('../../chunk-H7OCHDZT.js');
6
+
7
+
8
+ var _chunkRLFCI3RGjs = require('../../chunk-RLFCI3RG.js');
9
+
10
+ // src/rpc/electron/bind.ts
11
+ var _debug = require('debug'); var _debug2 = _interopRequireDefault(_debug);
12
+ var debug = _debug2.default.call(void 0, "phecda-server/electron");
13
+ function bind(IPC, { moduleMap, meta }, opts = {}) {
14
+ const { globalGuards, globalFilter, globalPipe, globalAddons = [] } = opts;
15
+ const metaMap = _chunkH7OCHDZTjs.createControllerMetaMap.call(void 0, meta, (meta2) => {
16
+ const { controller, rpc, func, tag } = meta2.data;
17
+ if (controller === "rpc" && _optionalChain([rpc, 'optionalAccess', _ => _.queue]) !== void 0) {
18
+ debug(`register method "${func}" in module "${tag}"`);
19
+ return true;
20
+ }
21
+ });
22
+ _chunkH7OCHDZTjs.detectAopDep.call(void 0, meta, {
23
+ guards: globalGuards,
24
+ addons: globalAddons
25
+ }, "rpc");
26
+ IPC.handle("phecda-server:invoke", callback);
27
+ IPC.on("phecda-server:send", callback);
28
+ async function callback(event, data) {
29
+ const { func, id, tag, _ps, args } = data || {};
30
+ debug(`invoke method "${func}" in module "${tag}"`);
31
+ if (_ps !== 1) return;
32
+ const meta2 = metaMap.get(tag)[func];
33
+ const { data: { rpc: { isEvent } = {} } } = meta2;
34
+ const aop = _chunkH7OCHDZTjs.Context.getAop(meta2, {
35
+ globalFilter,
36
+ globalGuards,
37
+ globalPipe
38
+ });
39
+ const context = new (0, _chunkH7OCHDZTjs.Context)({
40
+ type: "electron",
41
+ category: "rpc",
42
+ moduleMap,
43
+ meta: meta2,
44
+ tag,
45
+ func,
46
+ args,
47
+ id,
48
+ isEvent,
49
+ queue: tag,
50
+ event
51
+ });
52
+ return await context.run(aop, (returnData) => {
53
+ if (!isEvent) return {
54
+ data: returnData,
55
+ id
56
+ };
57
+ }, (err) => {
58
+ if (!isEvent) {
59
+ return {
60
+ data: err,
61
+ error: true,
62
+ id
63
+ };
64
+ }
65
+ });
66
+ }
67
+ _chunkRLFCI3RGjs.__name.call(void 0, callback, "callback");
68
+ }
69
+ _chunkRLFCI3RGjs.__name.call(void 0, bind, "bind");
70
+
71
+
72
+ exports.bind = bind;
73
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["d:\\myproject\\phecda\\packages\\server\\dist\\rpc\\electron\\index.js"],"names":[],"mappings":"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","file":"D:\\myproject\\phecda\\packages\\server\\dist\\rpc\\electron\\index.js","sourcesContent":[null]}
@@ -0,0 +1,73 @@
1
+ import {
2
+ Context,
3
+ createControllerMetaMap,
4
+ detectAopDep
5
+ } from "../../chunk-LBH4RXQQ.mjs";
6
+ import {
7
+ __name
8
+ } from "../../chunk-MDPW6WGF.mjs";
9
+
10
+ // src/rpc/electron/bind.ts
11
+ import Debug from "debug";
12
+ var debug = Debug("phecda-server/electron");
13
+ function bind(IPC, { moduleMap, meta }, opts = {}) {
14
+ const { globalGuards, globalFilter, globalPipe, globalAddons = [] } = opts;
15
+ const metaMap = createControllerMetaMap(meta, (meta2) => {
16
+ const { controller, rpc, func, tag } = meta2.data;
17
+ if (controller === "rpc" && rpc?.queue !== void 0) {
18
+ debug(`register method "${func}" in module "${tag}"`);
19
+ return true;
20
+ }
21
+ });
22
+ detectAopDep(meta, {
23
+ guards: globalGuards,
24
+ addons: globalAddons
25
+ }, "rpc");
26
+ IPC.handle("phecda-server:invoke", callback);
27
+ IPC.on("phecda-server:send", callback);
28
+ async function callback(event, data) {
29
+ const { func, id, tag, _ps, args } = data || {};
30
+ debug(`invoke method "${func}" in module "${tag}"`);
31
+ if (_ps !== 1) return;
32
+ const meta2 = metaMap.get(tag)[func];
33
+ const { data: { rpc: { isEvent } = {} } } = meta2;
34
+ const aop = Context.getAop(meta2, {
35
+ globalFilter,
36
+ globalGuards,
37
+ globalPipe
38
+ });
39
+ const context = new Context({
40
+ type: "electron",
41
+ category: "rpc",
42
+ moduleMap,
43
+ meta: meta2,
44
+ tag,
45
+ func,
46
+ args,
47
+ id,
48
+ isEvent,
49
+ queue: tag,
50
+ event
51
+ });
52
+ return await context.run(aop, (returnData) => {
53
+ if (!isEvent) return {
54
+ data: returnData,
55
+ id
56
+ };
57
+ }, (err) => {
58
+ if (!isEvent) {
59
+ return {
60
+ data: err,
61
+ error: true,
62
+ id
63
+ };
64
+ }
65
+ });
66
+ }
67
+ __name(callback, "callback");
68
+ }
69
+ __name(bind, "bind");
70
+ export {
71
+ bind
72
+ };
73
+ //# sourceMappingURL=index.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/rpc/electron/bind.ts"],"sourcesContent":["import Debug from 'debug'\r\nimport type Electron from 'electron'\r\nimport type { Factory } from '../../core'\r\nimport { Context } from '../../context'\r\nimport type { RpcCtx, RpcServerOptions } from '../types'\r\nimport { createControllerMetaMap, detectAopDep } from '../../helper'\r\nconst debug = Debug('phecda-server/electron')\r\n\r\nexport interface ElectronCtx extends RpcCtx {\r\n type: 'electron'\r\n event: Electron.IpcMainEvent | Electron.IpcMainInvokeEvent\r\n}\r\n\r\nexport function bind(IPC: Electron.IpcMain, { moduleMap, meta }: Awaited<ReturnType<typeof Factory>>, opts: RpcServerOptions = {}) {\r\n const { globalGuards, globalFilter, globalPipe, globalAddons = [] } = opts\r\n const metaMap = createControllerMetaMap(meta, (meta) => {\r\n const { controller, rpc, func, tag } = meta.data\r\n if (controller === 'rpc' && rpc?.queue !== undefined) {\r\n debug(`register method \"${func}\" in module \"${tag}\"`)\r\n return true\r\n }\r\n })\r\n\r\n detectAopDep(meta, {\r\n guards: globalGuards,\r\n addons: globalAddons,\r\n }, 'rpc')\r\n\r\n IPC.handle('phecda-server:invoke', callback)\r\n\r\n IPC.on('phecda-server:send', callback)\r\n\r\n async function callback(event: Electron.IpcMainEvent | Electron.IpcMainInvokeEvent, data: any) {\r\n const { func, id, tag, _ps, args } = data || {}\r\n debug(`invoke method \"${func}\" in module \"${tag}\"`)\r\n\r\n if (_ps !== 1)\r\n return\r\n const meta = metaMap.get(tag)![func]\r\n\r\n const {\r\n data: { rpc: { isEvent } = {} },\r\n } = meta\r\n\r\n const aop = Context.getAop(meta, {\r\n globalFilter,\r\n globalGuards,\r\n globalPipe,\r\n })\r\n const context = new Context(<ElectronCtx>{\r\n type: 'electron',\r\n category: 'rpc',\r\n moduleMap,\r\n meta,\r\n tag,\r\n func,\r\n args,\r\n id,\r\n isEvent,\r\n queue: tag,\r\n event,\r\n })\r\n return await context.run(aop, (returnData) => {\r\n if (!isEvent)\r\n return { data: returnData, id }\r\n }, (err) => {\r\n if (!isEvent) {\r\n return {\r\n data: err,\r\n error: true,\r\n id,\r\n }\r\n }\r\n })\r\n }\r\n}\r\n"],"mappings":";;;;;;;;;;AAAA,OAAOA,WAAW;AAMlB,IAAMC,QAAQC,MAAM,wBAAA;AAOb,SAASC,KAAKC,KAAuB,EAAEC,WAAWC,KAAI,GAAyCC,OAAyB,CAAC,GAAC;AAC/H,QAAM,EAAEC,cAAcC,cAAcC,YAAYC,eAAe,CAAA,EAAE,IAAKJ;AACtE,QAAMK,UAAUC,wBAAwBP,MAAM,CAACA,UAAAA;AAC7C,UAAM,EAAEQ,YAAYC,KAAKC,MAAMC,IAAG,IAAKX,MAAKY;AAC5C,QAAIJ,eAAe,SAASC,KAAKI,UAAUC,QAAW;AACpDnB,YAAM,oBAAoBe,IAAAA,gBAAoBC,GAAAA,GAAM;AACpD,aAAO;IACT;EACF,CAAA;AAEAI,eAAaf,MAAM;IACjBgB,QAAQd;IACRe,QAAQZ;EACV,GAAG,KAAA;AAEHP,MAAIoB,OAAO,wBAAwBC,QAAAA;AAEnCrB,MAAIsB,GAAG,sBAAsBD,QAAAA;AAE7B,iBAAeA,SAASE,OAA4DT,MAAS;AAC3F,UAAM,EAAEF,MAAMY,IAAIX,KAAKY,KAAKC,KAAI,IAAKZ,QAAQ,CAAC;AAC9CjB,UAAM,kBAAkBe,IAAAA,gBAAoBC,GAAAA,GAAM;AAElD,QAAIY,QAAQ,EACV;AACF,UAAMvB,QAAOM,QAAQmB,IAAId,GAAAA,EAAMD,IAAAA;AAE/B,UAAM,EACJE,MAAM,EAAEH,KAAK,EAAEiB,QAAO,IAAK,CAAC,EAAC,EAAE,IAC7B1B;AAEJ,UAAM2B,MAAMC,QAAQC,OAAO7B,OAAM;MAC/BG;MACAD;MACAE;IACF,CAAA;AACA,UAAM0B,UAAU,IAAIF,QAAqB;MACvCG,MAAM;MACNC,UAAU;MACVjC;MACAC,MAAAA;MACAW;MACAD;MACAc;MACAF;MACAI;MACAb,OAAOF;MACPU;IACF,CAAA;AACA,WAAO,MAAMS,QAAQG,IAAIN,KAAK,CAACO,eAAAA;AAC7B,UAAI,CAACR,QACH,QAAO;QAAEd,MAAMsB;QAAYZ;MAAG;IAClC,GAAG,CAACa,QAAAA;AACF,UAAI,CAACT,SAAS;AACZ,eAAO;UACLd,MAAMuB;UACNC,OAAO;UACPd;QACF;MACF;IACF,CAAA;EACF;AA1CeH;AA2CjB;AA9DgBtB;","names":["Debug","debug","Debug","bind","IPC","moduleMap","meta","opts","globalGuards","globalFilter","globalPipe","globalAddons","metaMap","createControllerMetaMap","controller","rpc","func","tag","data","queue","undefined","detectAopDep","guards","addons","handle","callback","on","event","id","_ps","args","get","isEvent","aop","Context","getAop","context","type","category","run","returnData","err","error"]}
@@ -1,8 +1,8 @@
1
1
  import { Consumer, Producer } from 'kafkajs';
2
- import { F as Factory } from '../../core-BcKywWLd.mjs';
3
- import { R as RpcCtx, a as RpcServerOptions, b as RpcClientOptions } from '../../types-DEQb_e59.mjs';
4
- import { T as ToClientMap } from '../../meta-B_HW7cWh.mjs';
2
+ import { F as Factory } from '../../core-DbqWh47p.mjs';
3
+ import { R as RpcCtx, a as RpcServerOptions } from '../../types-E-rqlg3-.mjs';
5
4
  import 'phecda-core';
5
+ import '../../meta-BoS1E-Nz.mjs';
6
6
 
7
7
  interface KafkaCtx extends RpcCtx {
8
8
  type: 'kafka';
@@ -16,9 +16,4 @@ declare function bind({ consumer, producer }: {
16
16
  producer: Producer;
17
17
  }, { moduleMap, meta }: Awaited<ReturnType<typeof Factory>>, opts?: RpcServerOptions): Promise<void>;
18
18
 
19
- declare function createClient<S extends Record<string, any>>({ producer, consumer }: {
20
- producer: Producer;
21
- consumer: Consumer;
22
- }, controllers: S, opts?: RpcClientOptions): Promise<ToClientMap<S>>;
23
-
24
- export { type KafkaCtx, bind, createClient };
19
+ export { type KafkaCtx, bind };
@@ -1,8 +1,8 @@
1
1
  import { Consumer, Producer } from 'kafkajs';
2
- import { F as Factory } from '../../core-BGEsBtTG.js';
3
- import { R as RpcCtx, a as RpcServerOptions, b as RpcClientOptions } from '../../types-CYF0vha6.js';
4
- import { T as ToClientMap } from '../../meta-B_HW7cWh.js';
2
+ import { F as Factory } from '../../core-Rq7BhPHE.js';
3
+ import { R as RpcCtx, a as RpcServerOptions } from '../../types-CInz3bD0.js';
5
4
  import 'phecda-core';
5
+ import '../../meta-BoS1E-Nz.js';
6
6
 
7
7
  interface KafkaCtx extends RpcCtx {
8
8
  type: 'kafka';
@@ -16,9 +16,4 @@ declare function bind({ consumer, producer }: {
16
16
  producer: Producer;
17
17
  }, { moduleMap, meta }: Awaited<ReturnType<typeof Factory>>, opts?: RpcServerOptions): Promise<void>;
18
18
 
19
- declare function createClient<S extends Record<string, any>>({ producer, consumer }: {
20
- producer: Producer;
21
- consumer: Consumer;
22
- }, controllers: S, opts?: RpcClientOptions): Promise<ToClientMap<S>>;
23
-
24
- export { type KafkaCtx, bind, createClient };
19
+ export { type KafkaCtx, bind };
@@ -2,11 +2,10 @@
2
2
 
3
3
 
4
4
 
5
+ var _chunkH7OCHDZTjs = require('../../chunk-H7OCHDZT.js');
5
6
 
6
- var _chunk7EMAZGYOjs = require('../../chunk-7EMAZGYO.js');
7
7
 
8
-
9
- var _chunkVSGYTGHYjs = require('../../chunk-VSGYTGHY.js');
8
+ var _chunkRLFCI3RGjs = require('../../chunk-RLFCI3RG.js');
10
9
 
11
10
  // src/rpc/kafka/bind.ts
12
11
  var _debug = require('debug'); var _debug2 = _interopRequireDefault(_debug);
@@ -14,18 +13,18 @@ var debug = _debug2.default.call(void 0, "phecda-server/kafka");
14
13
  async function bind({ consumer, producer }, { moduleMap, meta }, opts = {}) {
15
14
  const { globalGuards, globalFilter, globalPipe, globalAddons = [], defaultQueue } = opts;
16
15
  const existQueue = /* @__PURE__ */ new Set();
17
- const metaMap = _chunk7EMAZGYOjs.createControllerMetaMap.call(void 0, meta, (meta2) => {
16
+ const metaMap = _chunkH7OCHDZTjs.createControllerMetaMap.call(void 0, meta, (meta2) => {
18
17
  const { controller, rpc, func, tag } = meta2.data;
19
18
  if (controller === "rpc" && _optionalChain([rpc, 'optionalAccess', _ => _.queue]) !== void 0) {
20
19
  debug(`register method "${func}" in module "${tag}"`);
21
20
  return true;
22
21
  }
23
22
  });
24
- _chunk7EMAZGYOjs.detectAopDep.call(void 0, meta, {
23
+ _chunkH7OCHDZTjs.detectAopDep.call(void 0, meta, {
25
24
  guards: globalGuards,
26
25
  addons: globalAddons
27
26
  }, "rpc");
28
- _chunk7EMAZGYOjs.Context.applyAddons(globalAddons, {
27
+ _chunkH7OCHDZTjs.Context.applyAddons(globalAddons, {
29
28
  consumer,
30
29
  producer
31
30
  }, "kafka");
@@ -47,10 +46,10 @@ async function bind({ consumer, producer }, { moduleMap, meta }, opts = {}) {
47
46
  }
48
47
  }
49
48
  }
50
- _chunkVSGYTGHYjs.__name.call(void 0, subscribeQueues, "subscribeQueues");
49
+ _chunkRLFCI3RGjs.__name.call(void 0, subscribeQueues, "subscribeQueues");
51
50
  await subscribeQueues();
52
51
  await consumer.run({
53
- eachMessage: /* @__PURE__ */ _chunkVSGYTGHYjs.__name.call(void 0, async ({ message, partition, topic, heartbeat, pause }) => {
52
+ eachMessage: /* @__PURE__ */ _chunkRLFCI3RGjs.__name.call(void 0, async ({ message, partition, topic, heartbeat, pause }) => {
54
53
  if (!existQueue.has(topic)) return;
55
54
  const data = JSON.parse(message.value.toString());
56
55
  const { tag, func, id, queue: clientQueue, _ps, args } = data;
@@ -59,12 +58,12 @@ async function bind({ consumer, producer }, { moduleMap, meta }, opts = {}) {
59
58
  const meta2 = metaMap.get(tag)[func];
60
59
  const { data: { rpc } } = meta2;
61
60
  const isEvent = rpc.isEvent;
62
- const aop = _chunk7EMAZGYOjs.Context.getAop(meta2, {
61
+ const aop = _chunkH7OCHDZTjs.Context.getAop(meta2, {
63
62
  globalFilter,
64
63
  globalGuards,
65
64
  globalPipe
66
65
  });
67
- const context = new (0, _chunk7EMAZGYOjs.Context)({
66
+ const context = new (0, _chunkH7OCHDZTjs.Context)({
68
67
  type: "kafka",
69
68
  category: "rpc",
70
69
  moduleMap,
@@ -113,85 +112,8 @@ async function bind({ consumer, producer }, { moduleMap, meta }, opts = {}) {
113
112
  }, "eachMessage")
114
113
  });
115
114
  }
116
- _chunkVSGYTGHYjs.__name.call(void 0, bind, "bind");
117
-
118
- // src/rpc/kafka/client.ts
119
- var _events = require('events');
120
- async function createClient({ producer, consumer }, controllers, opts) {
121
- let eventId = 1;
122
- let eventCount = 1;
123
- const ret = {};
124
- const emitter = new (0, _events.EventEmitter)();
125
- const clientQueue = _chunk7EMAZGYOjs.genClientQueue.call(void 0, _optionalChain([opts, 'optionalAccess', _2 => _2.key]));
126
- await consumer.subscribe({
127
- topic: clientQueue,
128
- fromBeginning: true
129
- });
130
- for (const i in controllers) {
131
- ret[i] = new Proxy(new controllers[i](), {
132
- get(target, p) {
133
- if (typeof target[p] !== "function") throw new Error(`"${p}" in "${i}" is not an exposed rpc `);
134
- let { tag, queue, isEvent } = target[p]();
135
- return async (...args) => {
136
- if (!queue) queue = tag;
137
- const id = `${eventId++}`;
138
- producer.send({
139
- topic: queue,
140
- messages: [
141
- {
142
- value: JSON.stringify({
143
- _ps: 1,
144
- id,
145
- tag,
146
- queue: clientQueue,
147
- func: p,
148
- args
149
- })
150
- }
151
- ]
152
- });
153
- if (isEvent) return null;
154
- return new Promise((resolve, reject) => {
155
- if (_optionalChain([opts, 'optionalAccess', _3 => _3.max]) && eventCount >= opts.max) reject({
156
- type: "exceeded"
157
- });
158
- let isEnd = false;
159
- const timer = setTimeout(() => {
160
- if (!isEnd) {
161
- eventCount--;
162
- emitter.off(id, listener);
163
- reject({
164
- type: "timeout"
165
- });
166
- }
167
- }, _optionalChain([opts, 'optionalAccess', _4 => _4.timeout]) || 5e3);
168
- function listener(data, error) {
169
- eventCount--;
170
- isEnd = true;
171
- clearTimeout(timer);
172
- if (error) reject(data);
173
- else resolve(data);
174
- }
175
- _chunkVSGYTGHYjs.__name.call(void 0, listener, "listener");
176
- eventCount++;
177
- emitter.once(id, listener);
178
- });
179
- };
180
- }
181
- });
182
- }
183
- await consumer.run({
184
- eachMessage: /* @__PURE__ */ _chunkVSGYTGHYjs.__name.call(void 0, async ({ message, topic }) => {
185
- if (clientQueue === topic && message.value) {
186
- const { data, id, error } = JSON.parse(message.value.toString());
187
- emitter.emit(id, data, error);
188
- }
189
- }, "eachMessage")
190
- });
191
- return ret;
192
- }
193
- _chunkVSGYTGHYjs.__name.call(void 0, createClient, "createClient");
194
-
115
+ _chunkRLFCI3RGjs.__name.call(void 0, bind, "bind");
195
116
 
196
117
 
197
- exports.bind = bind; exports.createClient = createClient;
118
+ exports.bind = bind;
119
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["d:\\myproject\\phecda\\packages\\server\\dist\\rpc\\kafka\\index.js"],"names":[],"mappings":"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","file":"D:\\myproject\\phecda\\packages\\server\\dist\\rpc\\kafka\\index.js","sourcesContent":[null]}
@@ -1,12 +1,11 @@
1
1
  import {
2
2
  Context,
3
3
  createControllerMetaMap,
4
- detectAopDep,
5
- genClientQueue
6
- } from "../../chunk-SGMQZRP6.mjs";
4
+ detectAopDep
5
+ } from "../../chunk-LBH4RXQQ.mjs";
7
6
  import {
8
7
  __name
9
- } from "../../chunk-YKP4ODZA.mjs";
8
+ } from "../../chunk-MDPW6WGF.mjs";
10
9
 
11
10
  // src/rpc/kafka/bind.ts
12
11
  import Debug from "debug";
@@ -114,84 +113,7 @@ async function bind({ consumer, producer }, { moduleMap, meta }, opts = {}) {
114
113
  });
115
114
  }
116
115
  __name(bind, "bind");
117
-
118
- // src/rpc/kafka/client.ts
119
- import { EventEmitter } from "events";
120
- async function createClient({ producer, consumer }, controllers, opts) {
121
- let eventId = 1;
122
- let eventCount = 1;
123
- const ret = {};
124
- const emitter = new EventEmitter();
125
- const clientQueue = genClientQueue(opts?.key);
126
- await consumer.subscribe({
127
- topic: clientQueue,
128
- fromBeginning: true
129
- });
130
- for (const i in controllers) {
131
- ret[i] = new Proxy(new controllers[i](), {
132
- get(target, p) {
133
- if (typeof target[p] !== "function") throw new Error(`"${p}" in "${i}" is not an exposed rpc `);
134
- let { tag, queue, isEvent } = target[p]();
135
- return async (...args) => {
136
- if (!queue) queue = tag;
137
- const id = `${eventId++}`;
138
- producer.send({
139
- topic: queue,
140
- messages: [
141
- {
142
- value: JSON.stringify({
143
- _ps: 1,
144
- id,
145
- tag,
146
- queue: clientQueue,
147
- func: p,
148
- args
149
- })
150
- }
151
- ]
152
- });
153
- if (isEvent) return null;
154
- return new Promise((resolve, reject) => {
155
- if (opts?.max && eventCount >= opts.max) reject({
156
- type: "exceeded"
157
- });
158
- let isEnd = false;
159
- const timer = setTimeout(() => {
160
- if (!isEnd) {
161
- eventCount--;
162
- emitter.off(id, listener);
163
- reject({
164
- type: "timeout"
165
- });
166
- }
167
- }, opts?.timeout || 5e3);
168
- function listener(data, error) {
169
- eventCount--;
170
- isEnd = true;
171
- clearTimeout(timer);
172
- if (error) reject(data);
173
- else resolve(data);
174
- }
175
- __name(listener, "listener");
176
- eventCount++;
177
- emitter.once(id, listener);
178
- });
179
- };
180
- }
181
- });
182
- }
183
- await consumer.run({
184
- eachMessage: /* @__PURE__ */ __name(async ({ message, topic }) => {
185
- if (clientQueue === topic && message.value) {
186
- const { data, id, error } = JSON.parse(message.value.toString());
187
- emitter.emit(id, data, error);
188
- }
189
- }, "eachMessage")
190
- });
191
- return ret;
192
- }
193
- __name(createClient, "createClient");
194
116
  export {
195
- bind,
196
- createClient
117
+ bind
197
118
  };
119
+ //# sourceMappingURL=index.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/rpc/kafka/bind.ts"],"sourcesContent":["import type { Consumer, Producer } from 'kafkajs'\r\nimport Debug from 'debug'\r\nimport type { Factory } from '../../core'\r\nimport { Context } from '../../context'\r\nimport type { RpcCtx, RpcServerOptions } from '../types'\r\nimport { createControllerMetaMap, detectAopDep } from '../../helper'\r\n\r\nconst debug = Debug('phecda-server/kafka')\r\n\r\nexport interface KafkaCtx extends RpcCtx {\r\n type: 'kafka'\r\n topic: string\r\n partition: number\r\n heartbeat(): Promise<void>\r\n pause(): () => void\r\n\r\n}\r\n// @experiment\r\n\r\nexport async function bind({ consumer, producer }: { consumer: Consumer; producer: Producer }, { moduleMap, meta }: Awaited<ReturnType<typeof Factory>>, opts: RpcServerOptions = {}) {\r\n const { globalGuards, globalFilter, globalPipe, globalAddons = [], defaultQueue } = opts\r\n\r\n const existQueue = new Set<string>()\r\n const metaMap = createControllerMetaMap(meta, (meta) => {\r\n const { controller, rpc, func, tag } = meta.data\r\n if (controller === 'rpc' && rpc?.queue !== undefined) {\r\n debug(`register method \"${func}\" in module \"${tag}\"`)\r\n return true\r\n }\r\n })\r\n\r\n detectAopDep(meta, {\r\n guards: globalGuards,\r\n addons: globalAddons,\r\n }, 'rpc')\r\n\r\n Context.applyAddons(globalAddons, { consumer, producer }, 'kafka')\r\n\r\n async function subscribeQueues() {\r\n existQueue.clear()\r\n for (const [tag, record] of metaMap) {\r\n for (const func in record) {\r\n const meta = metaMap.get(tag)![func]\r\n\r\n const {\r\n data: {\r\n rpc,\r\n },\r\n } = meta\r\n if (rpc) {\r\n const queue = rpc.queue || defaultQueue || tag\r\n if (existQueue.has(queue))\r\n continue\r\n existQueue.add(queue)\r\n await consumer.subscribe({ topic: queue, fromBeginning: true })\r\n }\r\n }\r\n }\r\n }\r\n\r\n await subscribeQueues()\r\n await consumer.run({\r\n eachMessage: async ({ message, partition, topic, heartbeat, pause }) => {\r\n if (!existQueue.has(topic))\r\n return\r\n\r\n const data = JSON.parse(message.value!.toString())\r\n\r\n const { tag, func, id, queue: clientQueue, _ps, args } = data\r\n\r\n if (_ps !== 1)\r\n return\r\n debug(`invoke method \"${func}\" in module \"${tag}\"`)\r\n const meta = metaMap.get(tag)![func]\r\n\r\n const {\r\n data: {\r\n rpc,\r\n },\r\n } = meta\r\n const isEvent = rpc!.isEvent\r\n const aop = Context.getAop(meta, {\r\n globalFilter,\r\n globalGuards,\r\n globalPipe,\r\n })\r\n const context = new Context<KafkaCtx>({\r\n type: 'kafka',\r\n category: 'rpc',\r\n moduleMap,\r\n meta,\r\n args,\r\n id,\r\n tag,\r\n func,\r\n partition,\r\n topic,\r\n heartbeat,\r\n pause,\r\n\r\n isEvent,\r\n queue: topic,\r\n })\r\n\r\n await context.run(aop, (returnData) => {\r\n if (!isEvent) {\r\n producer.send({\r\n topic: clientQueue,\r\n messages: [\r\n { value: JSON.stringify({ data: returnData, id }) },\r\n ],\r\n })\r\n }\r\n }, (err) => {\r\n if (!isEvent) {\r\n producer.send({\r\n topic: clientQueue,\r\n messages: [\r\n {\r\n value: JSON.stringify({\r\n data: err,\r\n error: true,\r\n id,\r\n }),\r\n },\r\n ],\r\n })\r\n }\r\n })\r\n },\r\n })\r\n}\r\n"],"mappings":"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","names":["Debug","debug","Debug","bind","consumer","producer","moduleMap","meta","opts","globalGuards","globalFilter","globalPipe","globalAddons","defaultQueue","existQueue","Set","metaMap","createControllerMetaMap","controller","rpc","func","tag","data","queue","undefined","detectAopDep","guards","addons","Context","applyAddons","subscribeQueues","clear","record","get","has","add","subscribe","topic","fromBeginning","run","eachMessage","message","partition","heartbeat","pause","JSON","parse","value","toString","id","clientQueue","_ps","args","isEvent","aop","getAop","context","type","category","returnData","send","messages","stringify","err","error"]}
@@ -1,8 +1,8 @@
1
1
  import { NatsConnection } from 'nats';
2
- import { F as Factory } from '../../core-BcKywWLd.mjs';
3
- import { R as RpcCtx, a as RpcServerOptions, b as RpcClientOptions } from '../../types-DEQb_e59.mjs';
4
- import { T as ToClientMap } from '../../meta-B_HW7cWh.mjs';
2
+ import { F as Factory } from '../../core-DbqWh47p.mjs';
3
+ import { R as RpcCtx, a as RpcServerOptions } from '../../types-E-rqlg3-.mjs';
5
4
  import 'phecda-core';
5
+ import '../../meta-BoS1E-Nz.mjs';
6
6
 
7
7
  interface NatsCtx extends RpcCtx {
8
8
  type: 'nats';
@@ -10,6 +10,4 @@ interface NatsCtx extends RpcCtx {
10
10
  }
11
11
  declare function bind(nc: NatsConnection, { moduleMap, meta }: Awaited<ReturnType<typeof Factory>>, opts?: RpcServerOptions): Promise<void>;
12
12
 
13
- declare function createClient<S extends Record<string, any>>(nc: NatsConnection, controllers: S, opts?: Omit<RpcClientOptions, 'key'>): Promise<ToClientMap<S>>;
14
-
15
- export { type NatsCtx, bind, createClient };
13
+ export { type NatsCtx, bind };
@@ -1,8 +1,8 @@
1
1
  import { NatsConnection } from 'nats';
2
- import { F as Factory } from '../../core-BGEsBtTG.js';
3
- import { R as RpcCtx, a as RpcServerOptions, b as RpcClientOptions } from '../../types-CYF0vha6.js';
4
- import { T as ToClientMap } from '../../meta-B_HW7cWh.js';
2
+ import { F as Factory } from '../../core-Rq7BhPHE.js';
3
+ import { R as RpcCtx, a as RpcServerOptions } from '../../types-CInz3bD0.js';
5
4
  import 'phecda-core';
5
+ import '../../meta-BoS1E-Nz.js';
6
6
 
7
7
  interface NatsCtx extends RpcCtx {
8
8
  type: 'nats';
@@ -10,6 +10,4 @@ interface NatsCtx extends RpcCtx {
10
10
  }
11
11
  declare function bind(nc: NatsConnection, { moduleMap, meta }: Awaited<ReturnType<typeof Factory>>, opts?: RpcServerOptions): Promise<void>;
12
12
 
13
- declare function createClient<S extends Record<string, any>>(nc: NatsConnection, controllers: S, opts?: Omit<RpcClientOptions, 'key'>): Promise<ToClientMap<S>>;
14
-
15
- export { type NatsCtx, bind, createClient };
13
+ export { type NatsCtx, bind };