phecda-server 7.0.0-alpha.9 → 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-7ZGYJ5OW.mjs → chunk-6JAHCTOT.mjs} +7 -2
  7. package/dist/chunk-6JAHCTOT.mjs.map +1 -0
  8. package/dist/{chunk-V5EYXVJT.js → chunk-EDAWJVJ4.js} +42 -25
  9. package/dist/chunk-EDAWJVJ4.js.map +1 -0
  10. package/dist/{chunk-FX3LDQII.js → chunk-H7OCHDZT.js} +61 -70
  11. package/dist/chunk-H7OCHDZT.js.map +1 -0
  12. package/dist/chunk-KRUOHWFR.js +306 -0
  13. package/dist/chunk-KRUOHWFR.js.map +1 -0
  14. package/dist/{chunk-KJUD2BKE.js → chunk-KUGU3UGO.js} +23 -18
  15. package/dist/chunk-KUGU3UGO.js.map +1 -0
  16. package/dist/{chunk-CVPZWDXU.mjs → chunk-LBH4RXQQ.mjs} +11 -20
  17. package/dist/chunk-LBH4RXQQ.mjs.map +1 -0
  18. package/dist/{chunk-FXTJ3BJ6.mjs → chunk-MDPW6WGF.mjs} +10 -4
  19. package/dist/chunk-MDPW6WGF.mjs.map +1 -0
  20. package/dist/{chunk-5RBTN33A.js → chunk-RLFCI3RG.js} +11 -5
  21. package/dist/chunk-RLFCI3RG.js.map +1 -0
  22. package/dist/{chunk-ODVWOXVB.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-WTJKTICN.mjs +306 -0
  27. package/dist/chunk-WTJKTICN.mjs.map +1 -0
  28. package/dist/{core-D_cz0tKa.d.ts → core-BOo3uGFX.d.ts} +2 -2
  29. package/dist/{core-BDkhrEyf.d.mts → core-CF45G79J.d.mts} +2 -2
  30. package/dist/core-DbqWh47p.d.mts +50 -0
  31. package/dist/core-Rq7BhPHE.d.ts +50 -0
  32. package/dist/helper.d.mts +3 -5
  33. package/dist/helper.d.ts +3 -5
  34. package/dist/helper.js +4 -5
  35. package/dist/helper.js.map +1 -0
  36. package/dist/helper.mjs +3 -4
  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 +42 -40
  41. package/dist/http/elysia/index.js.map +1 -0
  42. package/dist/http/elysia/index.mjs +5 -3
  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 +39 -37
  47. package/dist/http/express/index.js.map +1 -0
  48. package/dist/http/express/index.mjs +4 -2
  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 +40 -38
  53. package/dist/http/fastify/index.js.map +1 -0
  54. package/dist/http/fastify/index.mjs +5 -3
  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 +40 -38
  59. package/dist/http/h3/index.js.map +1 -0
  60. package/dist/http/h3/index.mjs +4 -2
  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 +36 -34
  65. package/dist/http/hono/index.js.map +1 -0
  66. package/dist/http/hono/index.mjs +4 -2
  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 +37 -35
  71. package/dist/http/hyper-express/index.js.map +1 -0
  72. package/dist/http/hyper-express/index.mjs +4 -2
  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 +39 -37
  77. package/dist/http/koa/index.js.map +1 -0
  78. package/dist/http/koa/index.mjs +4 -2
  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 +105 -49
  83. package/dist/index.js.map +1 -0
  84. package/dist/index.mjs +68 -12
  85. package/dist/index.mjs.map +1 -0
  86. package/dist/{meta-BX5jhe4Z.d.mts → meta-BoS1E-Nz.d.mts} +6 -23
  87. package/dist/{meta-BX5jhe4Z.d.ts → meta-BoS1E-Nz.d.ts} +6 -23
  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 +5 -72
  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 +4 -63
  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 +5 -70
  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 +5 -71
  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 +7 -3
  137. package/dist/test.d.ts +7 -3
  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-DKVhyZk_.d.mts → types-SCJZFCYt.d.mts} +1 -1
  145. package/dist/{types-CMeuFoyd.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 +2 -3
  149. package/register/loader.mjs +83 -90
  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-B-rUM9Fm.d.mts +0 -19
  154. package/dist/types-MxxtkZXw.d.ts +0 -19
@@ -1,8 +1,8 @@
1
1
  import { Consumer, Producer } from 'kafkajs';
2
- import { F as Factory } from '../../core-D_cz0tKa.js';
3
- import { R as RpcCtx, a as RpcServerOptions, b as RpcClientOptions } from '../../types-MxxtkZXw.js';
4
- import { T as ToClientMap } from '../../meta-BX5jhe4Z.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 _chunkFX3LDQIIjs = require('../../chunk-FX3LDQII.js');
7
7
 
8
-
9
- var _chunk5RBTN33Ajs = require('../../chunk-5RBTN33A.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 = _chunkFX3LDQIIjs.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
- _chunkFX3LDQIIjs.detectAopDep.call(void 0, meta, {
23
+ _chunkH7OCHDZTjs.detectAopDep.call(void 0, meta, {
25
24
  guards: globalGuards,
26
25
  addons: globalAddons
27
26
  }, "rpc");
28
- _chunkFX3LDQIIjs.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
- _chunk5RBTN33Ajs.__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__ */ _chunk5RBTN33Ajs.__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 = _chunkFX3LDQIIjs.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, _chunkFX3LDQIIjs.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
- _chunk5RBTN33Ajs.__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 = _chunkFX3LDQIIjs.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
- _chunk5RBTN33Ajs.__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__ */ _chunk5RBTN33Ajs.__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
- _chunk5RBTN33Ajs.__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-CVPZWDXU.mjs";
4
+ detectAopDep
5
+ } from "../../chunk-LBH4RXQQ.mjs";
7
6
  import {
8
7
  __name
9
- } from "../../chunk-FXTJ3BJ6.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-BDkhrEyf.mjs';
3
- import { R as RpcCtx, a as RpcServerOptions, b as RpcClientOptions } from '../../types-B-rUM9Fm.mjs';
4
- import { T as ToClientMap } from '../../meta-BX5jhe4Z.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-D_cz0tKa.js';
3
- import { R as RpcCtx, a as RpcServerOptions, b as RpcClientOptions } from '../../types-MxxtkZXw.js';
4
- import { T as ToClientMap } from '../../meta-BX5jhe4Z.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 };
@@ -2,11 +2,11 @@
2
2
 
3
3
 
4
4
 
5
- var _chunkFX3LDQIIjs = require('../../chunk-FX3LDQII.js');
5
+ var _chunkH7OCHDZTjs = require('../../chunk-H7OCHDZT.js');
6
6
 
7
7
 
8
8
 
9
- var _chunk5RBTN33Ajs = require('../../chunk-5RBTN33A.js');
9
+ var _chunkRLFCI3RGjs = require('../../chunk-RLFCI3RG.js');
10
10
 
11
11
  // src/rpc/nats/bind.ts
12
12
  var _nats = require('nats');
@@ -17,18 +17,18 @@ async function bind(nc, { moduleMap, meta }, opts = {}) {
17
17
  const sc = _nats.StringCodec.call(void 0, );
18
18
  const subscriptionMap = {};
19
19
  const existQueue = /* @__PURE__ */ new Set();
20
- const metaMap = _chunkFX3LDQIIjs.createControllerMetaMap.call(void 0, meta, (meta2) => {
20
+ const metaMap = _chunkH7OCHDZTjs.createControllerMetaMap.call(void 0, meta, (meta2) => {
21
21
  const { controller, rpc, func, tag } = meta2.data;
22
22
  if (controller === "rpc" && _optionalChain([rpc, 'optionalAccess', _2 => _2.queue]) !== void 0) {
23
23
  debug(`register method "${func}" in module "${tag}"`);
24
24
  return true;
25
25
  }
26
26
  });
27
- _chunkFX3LDQIIjs.detectAopDep.call(void 0, meta, {
27
+ _chunkH7OCHDZTjs.detectAopDep.call(void 0, meta, {
28
28
  addons: globalAddons,
29
29
  guards: globalGuards
30
30
  }, "rpc");
31
- _chunkFX3LDQIIjs.Context.applyAddons(globalAddons, nc, "nats");
31
+ _chunkH7OCHDZTjs.Context.applyAddons(globalAddons, nc, "nats");
32
32
  async function subscribeQueues() {
33
33
  existQueue.clear();
34
34
  for (const [tag, record] of metaMap) {
@@ -47,7 +47,7 @@ async function bind(nc, { moduleMap, meta }, opts = {}) {
47
47
  }
48
48
  }
49
49
  }
50
- _chunk5RBTN33Ajs.__name.call(void 0, subscribeQueues, "subscribeQueues");
50
+ _chunkRLFCI3RGjs.__name.call(void 0, subscribeQueues, "subscribeQueues");
51
51
  async function handleRequest(_, msg) {
52
52
  const data = JSON.parse(sc.decode(msg.data));
53
53
  const { tag, func, id, _ps, args } = data;
@@ -56,12 +56,12 @@ async function bind(nc, { moduleMap, meta }, opts = {}) {
56
56
  const meta2 = metaMap.get(tag)[func];
57
57
  const { data: { rpc: { isEvent } = {} } } = meta2;
58
58
  if (isEvent) msg.respond("{}");
59
- const aop = _chunkFX3LDQIIjs.Context.getAop(meta2, {
59
+ const aop = _chunkH7OCHDZTjs.Context.getAop(meta2, {
60
60
  globalFilter,
61
61
  globalGuards,
62
62
  globalPipe
63
63
  });
64
- const context = new (0, _chunkFX3LDQIIjs.Context)({
64
+ const context = new (0, _chunkH7OCHDZTjs.Context)({
65
65
  type: "nats",
66
66
  category: "rpc",
67
67
  moduleMap,
@@ -88,74 +88,15 @@ async function bind(nc, { moduleMap, meta }, opts = {}) {
88
88
  })));
89
89
  });
90
90
  }
91
- _chunk5RBTN33Ajs.__name.call(void 0, handleRequest, "handleRequest");
91
+ _chunkRLFCI3RGjs.__name.call(void 0, handleRequest, "handleRequest");
92
92
  subscribeQueues();
93
- _chunk5RBTN33Ajs.HMR.call(void 0, async () => {
93
+ _chunkRLFCI3RGjs.HMR.call(void 0, async () => {
94
94
  for (const i in subscriptionMap) subscriptionMap[i].unsubscribe();
95
95
  await subscribeQueues();
96
96
  });
97
97
  }
98
- _chunk5RBTN33Ajs.__name.call(void 0, bind, "bind");
98
+ _chunkRLFCI3RGjs.__name.call(void 0, bind, "bind");
99
99
 
100
- // src/rpc/nats/client.ts
101
100
 
102
- async function createClient(nc, controllers, opts) {
103
- let eventId = 1;
104
- let eventCount = 0;
105
- const sc = _nats.StringCodec.call(void 0, );
106
- const ret = {};
107
- for (const i in controllers) {
108
- ret[i] = new Proxy(new controllers[i](), {
109
- get(target, p) {
110
- if (typeof target[p] !== "function") throw new Error(`"${p}" in "${i}" is not an exposed rpc `);
111
- let { tag, queue, isEvent } = target[p]();
112
- return async (...args) => {
113
- if (!queue) queue = tag;
114
- const id = `${eventId++}`;
115
- const request = nc.request(queue, sc.encode(JSON.stringify({
116
- _ps: 1,
117
- id,
118
- args,
119
- tag,
120
- func: p
121
- })));
122
- if (isEvent) return null;
123
- return new Promise((resolve, reject) => {
124
- if (_optionalChain([opts, 'optionalAccess', _3 => _3.max]) && eventCount >= opts.max) reject({
125
- type: "exceeded"
126
- });
127
- request.catch(reject);
128
- request.then((msg) => {
129
- const { data, id: id2, error } = msg.json();
130
- if (id2) handler(data, error);
131
- });
132
- let isEnd = false;
133
- const timer = setTimeout(() => {
134
- if (!isEnd) {
135
- eventCount--;
136
- reject({
137
- type: "timeout"
138
- });
139
- }
140
- }, _optionalChain([opts, 'optionalAccess', _4 => _4.timeout]) || 5e3);
141
- function handler(data, error) {
142
- eventCount--;
143
- isEnd = true;
144
- clearTimeout(timer);
145
- if (error) reject(data);
146
- else resolve(data);
147
- }
148
- _chunk5RBTN33Ajs.__name.call(void 0, handler, "handler");
149
- eventCount++;
150
- });
151
- };
152
- }
153
- });
154
- }
155
- return ret;
156
- }
157
- _chunk5RBTN33Ajs.__name.call(void 0, createClient, "createClient");
158
-
159
-
160
-
161
- exports.bind = bind; exports.createClient = createClient;
101
+ exports.bind = bind;
102
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["d:\\myproject\\phecda\\packages\\server\\dist\\rpc\\nats\\index.js"],"names":[],"mappings":"AAAA;AACE;AACA;AACA;AACF,0DAAgC;AAChC;AACE;AACA;AACF,0DAAgC;AAChC;AACA;AACA,4BAAkC;AAClC,4EAAyB;AACzB,IAAI,MAAM,EAAE,6BAAK,oBAAqB,CAAC;AACvC,MAAM,SAAS,IAAI,CAAC,EAAE,EAAE,EAAE,SAAS,EAAE,KAAK,CAAC,EAAE,KAAK,EAAE,CAAC,CAAC,EAAE;AACxD,EAAE,MAAM,EAAE,YAAY,EAAE,YAAY,EAAE,UAAU,EAAE,aAAa,EAAE,CAAC,CAAC,EAAE,aAAa,EAAE,EAAE,IAAI;AAC1F,EAAE,MAAM,GAAG,EAAE,+BAAW,CAAE;AAC1B,EAAE,MAAM,gBAAgB,EAAE,CAAC,CAAC;AAC5B,EAAE,MAAM,WAAW,kBAAkB,IAAI,GAAG,CAAC,CAAC;AAC9C,EAAE,MAAM,QAAQ,EAAE,sDAAuB,IAAK,EAAE,CAAC,KAAK,EAAE,GAAG;AAC3D,IAAI,MAAM,EAAE,UAAU,EAAE,GAAG,EAAE,IAAI,EAAE,IAAI,EAAE,EAAE,KAAK,CAAC,IAAI;AACrD,IAAI,GAAG,CAAC,WAAW,IAAI,MAAM,mBAAG,GAAG,6BAAE,QAAM,IAAI,KAAK,CAAC,EAAE;AACvD,MAAM,KAAK,CAAC,CAAC,iBAAiB,EAAE,IAAI,CAAC,aAAa,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC;AAC3D,MAAM,OAAO,IAAI;AACjB,IAAI;AACJ,EAAE,CAAC,CAAC;AACJ,EAAE,2CAAY,IAAK,EAAE;AACrB,IAAI,MAAM,EAAE,YAAY;AACxB,IAAI,MAAM,EAAE;AACZ,EAAE,CAAC,EAAE,KAAK,CAAC;AACX,EAAE,wBAAO,CAAC,WAAW,CAAC,YAAY,EAAE,EAAE,EAAE,MAAM,CAAC;AAC/C,EAAE,MAAM,SAAS,eAAe,CAAC,EAAE;AACnC,IAAI,UAAU,CAAC,KAAK,CAAC,CAAC;AACtB,IAAI,IAAI,CAAC,MAAM,CAAC,GAAG,EAAE,MAAM,EAAE,GAAG,OAAO,EAAE;AACzC,MAAM,IAAI,CAAC,MAAM,KAAK,GAAG,MAAM,EAAE;AACjC,QAAQ,MAAM,MAAM,EAAE,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC;AAC5C,QAAQ,MAAM,EAAE,IAAI,EAAE,EAAE,IAAI,EAAE,EAAE,EAAE,KAAK;AACvC,QAAQ,GAAG,CAAC,GAAG,EAAE;AACjB,UAAU,MAAM,MAAM,EAAE,GAAG,CAAC,MAAM,GAAG,aAAa,GAAG,GAAG;AACxD,UAAU,GAAG,CAAC,UAAU,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,QAAQ;AAC7C,UAAU,UAAU,CAAC,GAAG,CAAC,KAAK,CAAC;AAC/B,UAAU,eAAe,CAAC,KAAK,EAAE,EAAE,EAAE,CAAC,SAAS,CAAC,KAAK,EAAE;AACvD,YAAY,KAAK;AACjB,YAAY,QAAQ,EAAE;AACtB,UAAU,CAAC,CAAC;AACZ,QAAQ;AACR,MAAM;AACN,IAAI;AACJ,EAAE;AACF,EAAE,qCAAM,eAAgB,EAAE,iBAAiB,CAAC;AAC5C,EAAE,MAAM,SAAS,aAAa,CAAC,CAAC,EAAE,GAAG,EAAE;AACvC,IAAI,MAAM,KAAK,EAAE,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;AAChD,IAAI,MAAM,EAAE,GAAG,EAAE,IAAI,EAAE,EAAE,EAAE,GAAG,EAAE,KAAK,EAAE,EAAE,IAAI;AAC7C,IAAI,GAAG,CAAC,IAAI,IAAI,CAAC,EAAE,MAAM;AACzB,IAAI,KAAK,CAAC,CAAC,eAAe,EAAE,IAAI,CAAC,aAAa,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC;AACvD,IAAI,MAAM,MAAM,EAAE,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC;AACxC,IAAI,MAAM,EAAE,IAAI,EAAE,EAAE,GAAG,EAAE,EAAE,QAAQ,EAAE,EAAE,CAAC,EAAE,EAAE,EAAE,EAAE,KAAK;AACrD,IAAI,GAAG,CAAC,OAAO,EAAE,GAAG,CAAC,OAAO,CAAC,IAAI,CAAC;AAClC,IAAI,MAAM,IAAI,EAAE,wBAAO,CAAC,MAAM,CAAC,KAAK,EAAE;AACtC,MAAM,YAAY;AAClB,MAAM,YAAY;AAClB,MAAM;AACN,IAAI,CAAC,CAAC;AACN,IAAI,MAAM,QAAQ,EAAE,IAAI,6BAAO,CAAC;AAChC,MAAM,IAAI,EAAE,MAAM;AAClB,MAAM,QAAQ,EAAE,KAAK;AACrB,MAAM,SAAS;AACf,MAAM,IAAI,EAAE,KAAK;AACjB,MAAM,GAAG;AACT,MAAM,IAAI;AACV,MAAM,IAAI;AACV,MAAM,EAAE;AACR,MAAM,GAAG;AACT,MAAM,OAAO;AACb;AACA,MAAM,KAAK,EAAE,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC;AACvC,IAAI,CAAC,CAAC;AACN,IAAI,MAAM,OAAO,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,UAAU,EAAE,GAAG;AAC3C,MAAM,GAAG,CAAC,CAAC,OAAO,EAAE,GAAG,CAAC,OAAO,CAAC,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC;AACzD,QAAQ,IAAI,EAAE,UAAU;AACxB,QAAQ;AACR,MAAM,CAAC,CAAC,CAAC,CAAC;AACV,IAAI,CAAC,EAAE,CAAC,GAAG,EAAE,GAAG;AAChB,MAAM,GAAG,CAAC,CAAC,OAAO,EAAE,GAAG,CAAC,OAAO,CAAC,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC;AACzD,QAAQ,IAAI,EAAE,GAAG;AACjB,QAAQ,KAAK,EAAE,IAAI;AACnB,QAAQ;AACR,MAAM,CAAC,CAAC,CAAC,CAAC;AACV,IAAI,CAAC,CAAC;AACN,EAAE;AACF,EAAE,qCAAM,aAAc,EAAE,eAAe,CAAC;AACxC,EAAE,eAAe,CAAC,CAAC;AACnB,EAAE,kCAAG,MAAO,CAAC,EAAE,GAAG;AAClB,IAAI,IAAI,CAAC,MAAM,EAAE,GAAG,eAAe,EAAE,eAAe,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC;AACrE,IAAI,MAAM,eAAe,CAAC,CAAC;AAC3B,EAAE,CAAC,CAAC;AACJ;AACA,qCAAM,IAAK,EAAE,MAAM,CAAC;AACpB;AACE;AACF,oBAAC","file":"D:\\myproject\\phecda\\packages\\server\\dist\\rpc\\nats\\index.js","sourcesContent":[null]}
@@ -2,11 +2,11 @@ import {
2
2
  Context,
3
3
  createControllerMetaMap,
4
4
  detectAopDep
5
- } from "../../chunk-CVPZWDXU.mjs";
5
+ } from "../../chunk-LBH4RXQQ.mjs";
6
6
  import {
7
7
  HMR,
8
8
  __name
9
- } from "../../chunk-FXTJ3BJ6.mjs";
9
+ } from "../../chunk-MDPW6WGF.mjs";
10
10
 
11
11
  // src/rpc/nats/bind.ts
12
12
  import { StringCodec } from "nats";
@@ -96,66 +96,7 @@ async function bind(nc, { moduleMap, meta }, opts = {}) {
96
96
  });
97
97
  }
98
98
  __name(bind, "bind");
99
-
100
- // src/rpc/nats/client.ts
101
- import { StringCodec as StringCodec2 } from "nats";
102
- async function createClient(nc, controllers, opts) {
103
- let eventId = 1;
104
- let eventCount = 0;
105
- const sc = StringCodec2();
106
- const ret = {};
107
- for (const i in controllers) {
108
- ret[i] = new Proxy(new controllers[i](), {
109
- get(target, p) {
110
- if (typeof target[p] !== "function") throw new Error(`"${p}" in "${i}" is not an exposed rpc `);
111
- let { tag, queue, isEvent } = target[p]();
112
- return async (...args) => {
113
- if (!queue) queue = tag;
114
- const id = `${eventId++}`;
115
- const request = nc.request(queue, sc.encode(JSON.stringify({
116
- _ps: 1,
117
- id,
118
- args,
119
- tag,
120
- func: p
121
- })));
122
- if (isEvent) return null;
123
- return new Promise((resolve, reject) => {
124
- if (opts?.max && eventCount >= opts.max) reject({
125
- type: "exceeded"
126
- });
127
- request.catch(reject);
128
- request.then((msg) => {
129
- const { data, id: id2, error } = msg.json();
130
- if (id2) handler(data, error);
131
- });
132
- let isEnd = false;
133
- const timer = setTimeout(() => {
134
- if (!isEnd) {
135
- eventCount--;
136
- reject({
137
- type: "timeout"
138
- });
139
- }
140
- }, opts?.timeout || 5e3);
141
- function handler(data, error) {
142
- eventCount--;
143
- isEnd = true;
144
- clearTimeout(timer);
145
- if (error) reject(data);
146
- else resolve(data);
147
- }
148
- __name(handler, "handler");
149
- eventCount++;
150
- });
151
- };
152
- }
153
- });
154
- }
155
- return ret;
156
- }
157
- __name(createClient, "createClient");
158
99
  export {
159
- bind,
160
- createClient
100
+ bind
161
101
  };
102
+ //# sourceMappingURL=index.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/rpc/nats/bind.ts"],"sourcesContent":["import type { Msg, NatsConnection, NatsError, Subscription } from 'nats'\r\nimport { StringCodec } from 'nats'\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 { HMR } from '../../hmr'\r\n\r\nimport { createControllerMetaMap, detectAopDep } from '../../helper'\r\n\r\nconst debug = Debug('phecda-server/nats')\r\n\r\nexport interface NatsCtx extends RpcCtx {\r\n type: 'nats'\r\n msg: any\r\n}\r\n\r\nexport async function bind(nc: NatsConnection, { moduleMap, meta }: Awaited<ReturnType<typeof Factory>>, opts: RpcServerOptions = {}) {\r\n const { globalGuards, globalFilter, globalPipe, globalAddons = [], defaultQueue } = opts\r\n const sc = StringCodec()\r\n const subscriptionMap: Record<string, Subscription> = {}\r\n const existQueue = new Set<string>()\r\n\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 addons: globalAddons,\r\n guards: globalGuards,\r\n }, 'rpc')\r\n\r\n Context.applyAddons(globalAddons, nc, 'nats')\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 subscriptionMap[queue] = nc.subscribe(queue, {\r\n queue,\r\n callback: handleRequest,\r\n })\r\n }\r\n }\r\n }\r\n }\r\n async function handleRequest(_: NatsError | null, msg: Msg) {\r\n const data = JSON.parse(sc.decode(msg.data))\r\n const { tag, func, id, _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: { rpc: { isEvent } = {} },\r\n } = meta\r\n\r\n if (isEvent)// nats has to have response\r\n msg.respond('{}')\r\n const aop = Context.getAop(meta, {\r\n globalFilter,\r\n globalGuards,\r\n globalPipe,\r\n })\r\n const context = new Context<NatsCtx>({\r\n type: 'nats',\r\n category: 'rpc',\r\n moduleMap,\r\n meta,\r\n tag,\r\n func,\r\n args,\r\n id,\r\n msg,\r\n isEvent,\r\n // @ts-expect-error nats ts problem\r\n queue: msg._msg.subject.toString(),\r\n })\r\n\r\n await context.run(aop, (returnData) => {\r\n if (!isEvent)\r\n msg.respond(sc.encode(JSON.stringify({ data: returnData, id })))\r\n }, (err) => {\r\n if (!isEvent)\r\n msg.respond(sc.encode(JSON.stringify({ data: err, error: true, id })))\r\n })\r\n }\r\n\r\n subscribeQueues()\r\n\r\n HMR(async () => {\r\n for (const i in subscriptionMap)\r\n subscriptionMap[i].unsubscribe()\r\n\r\n await subscribeQueues()\r\n })\r\n}\r\n"],"mappings":"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","names":["StringCodec","Debug","debug","Debug","bind","nc","moduleMap","meta","opts","globalGuards","globalFilter","globalPipe","globalAddons","defaultQueue","sc","StringCodec","subscriptionMap","existQueue","Set","metaMap","createControllerMetaMap","controller","rpc","func","tag","data","queue","undefined","detectAopDep","addons","guards","Context","applyAddons","subscribeQueues","clear","record","get","has","add","subscribe","callback","handleRequest","_","msg","JSON","parse","decode","id","_ps","args","isEvent","respond","aop","getAop","context","type","category","_msg","subject","toString","run","returnData","encode","stringify","err","error","HMR","i","unsubscribe"]}
@@ -1,8 +1,8 @@
1
1
  import amqplib from 'amqplib';
2
- import { F as Factory } from '../../core-BDkhrEyf.mjs';
3
- import { R as RpcCtx, a as RpcServerOptions, b as RpcClientOptions } from '../../types-B-rUM9Fm.mjs';
4
- import { T as ToClientMap } from '../../meta-BX5jhe4Z.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 RabbitmqCtx extends RpcCtx {
8
8
  type: 'rabbitmq';
@@ -11,6 +11,4 @@ interface RabbitmqCtx extends RpcCtx {
11
11
  }
12
12
  declare function bind(ch: amqplib.Channel, { moduleMap, meta }: Awaited<ReturnType<typeof Factory>>, opts?: RpcServerOptions): Promise<void>;
13
13
 
14
- declare function createClient<S extends Record<string, any>>(ch: amqplib.Channel, controllers: S, opts?: RpcClientOptions): Promise<ToClientMap<S>>;
15
-
16
- export { type RabbitmqCtx, bind, createClient };
14
+ export { type RabbitmqCtx, bind };
@@ -1,8 +1,8 @@
1
1
  import amqplib from 'amqplib';
2
- import { F as Factory } from '../../core-D_cz0tKa.js';
3
- import { R as RpcCtx, a as RpcServerOptions, b as RpcClientOptions } from '../../types-MxxtkZXw.js';
4
- import { T as ToClientMap } from '../../meta-BX5jhe4Z.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 RabbitmqCtx extends RpcCtx {
8
8
  type: 'rabbitmq';
@@ -11,6 +11,4 @@ interface RabbitmqCtx extends RpcCtx {
11
11
  }
12
12
  declare function bind(ch: amqplib.Channel, { moduleMap, meta }: Awaited<ReturnType<typeof Factory>>, opts?: RpcServerOptions): Promise<void>;
13
13
 
14
- declare function createClient<S extends Record<string, any>>(ch: amqplib.Channel, controllers: S, opts?: RpcClientOptions): Promise<ToClientMap<S>>;
15
-
16
- export { type RabbitmqCtx, bind, createClient };
14
+ export { type RabbitmqCtx, bind };