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.
- package/README.md +10 -10
- package/assets/schema.json +12 -9
- package/bin/cli.mjs +96 -37
- package/dist/chunk-5SUY5UVC.js +258 -0
- package/dist/chunk-5SUY5UVC.js.map +1 -0
- package/dist/{chunk-7ZGYJ5OW.mjs → chunk-6JAHCTOT.mjs} +7 -2
- package/dist/chunk-6JAHCTOT.mjs.map +1 -0
- package/dist/{chunk-V5EYXVJT.js → chunk-EDAWJVJ4.js} +42 -25
- package/dist/chunk-EDAWJVJ4.js.map +1 -0
- package/dist/{chunk-FX3LDQII.js → chunk-H7OCHDZT.js} +61 -70
- package/dist/chunk-H7OCHDZT.js.map +1 -0
- package/dist/chunk-KRUOHWFR.js +306 -0
- package/dist/chunk-KRUOHWFR.js.map +1 -0
- package/dist/{chunk-KJUD2BKE.js → chunk-KUGU3UGO.js} +23 -18
- package/dist/chunk-KUGU3UGO.js.map +1 -0
- package/dist/{chunk-CVPZWDXU.mjs → chunk-LBH4RXQQ.mjs} +11 -20
- package/dist/chunk-LBH4RXQQ.mjs.map +1 -0
- package/dist/{chunk-FXTJ3BJ6.mjs → chunk-MDPW6WGF.mjs} +10 -4
- package/dist/chunk-MDPW6WGF.mjs.map +1 -0
- package/dist/{chunk-5RBTN33A.js → chunk-RLFCI3RG.js} +11 -5
- package/dist/chunk-RLFCI3RG.js.map +1 -0
- package/dist/{chunk-ODVWOXVB.mjs → chunk-TTHYUNOT.mjs} +18 -1
- package/dist/chunk-TTHYUNOT.mjs.map +1 -0
- package/dist/chunk-VDOICQ2U.mjs +258 -0
- package/dist/chunk-VDOICQ2U.mjs.map +1 -0
- package/dist/chunk-WTJKTICN.mjs +306 -0
- package/dist/chunk-WTJKTICN.mjs.map +1 -0
- package/dist/{core-D_cz0tKa.d.ts → core-BOo3uGFX.d.ts} +2 -2
- package/dist/{core-BDkhrEyf.d.mts → core-CF45G79J.d.mts} +2 -2
- package/dist/core-DbqWh47p.d.mts +50 -0
- package/dist/core-Rq7BhPHE.d.ts +50 -0
- package/dist/helper.d.mts +3 -5
- package/dist/helper.d.ts +3 -5
- package/dist/helper.js +4 -5
- package/dist/helper.js.map +1 -0
- package/dist/helper.mjs +3 -4
- package/dist/helper.mjs.map +1 -0
- package/dist/http/elysia/index.d.mts +4 -4
- package/dist/http/elysia/index.d.ts +4 -4
- package/dist/http/elysia/index.js +42 -40
- package/dist/http/elysia/index.js.map +1 -0
- package/dist/http/elysia/index.mjs +5 -3
- package/dist/http/elysia/index.mjs.map +1 -0
- package/dist/http/express/index.d.mts +3 -3
- package/dist/http/express/index.d.ts +3 -3
- package/dist/http/express/index.js +39 -37
- package/dist/http/express/index.js.map +1 -0
- package/dist/http/express/index.mjs +4 -2
- package/dist/http/express/index.mjs.map +1 -0
- package/dist/http/fastify/index.d.mts +3 -3
- package/dist/http/fastify/index.d.ts +3 -3
- package/dist/http/fastify/index.js +40 -38
- package/dist/http/fastify/index.js.map +1 -0
- package/dist/http/fastify/index.mjs +5 -3
- package/dist/http/fastify/index.mjs.map +1 -0
- package/dist/http/h3/index.d.mts +3 -3
- package/dist/http/h3/index.d.ts +3 -3
- package/dist/http/h3/index.js +40 -38
- package/dist/http/h3/index.js.map +1 -0
- package/dist/http/h3/index.mjs +4 -2
- package/dist/http/h3/index.mjs.map +1 -0
- package/dist/http/hono/index.d.mts +3 -3
- package/dist/http/hono/index.d.ts +3 -3
- package/dist/http/hono/index.js +36 -34
- package/dist/http/hono/index.js.map +1 -0
- package/dist/http/hono/index.mjs +4 -2
- package/dist/http/hono/index.mjs.map +1 -0
- package/dist/http/hyper-express/index.d.mts +3 -3
- package/dist/http/hyper-express/index.d.ts +3 -3
- package/dist/http/hyper-express/index.js +37 -35
- package/dist/http/hyper-express/index.js.map +1 -0
- package/dist/http/hyper-express/index.mjs +4 -2
- package/dist/http/hyper-express/index.mjs.map +1 -0
- package/dist/http/koa/index.d.mts +3 -3
- package/dist/http/koa/index.d.ts +3 -3
- package/dist/http/koa/index.js +39 -37
- package/dist/http/koa/index.js.map +1 -0
- package/dist/http/koa/index.mjs +4 -2
- package/dist/http/koa/index.mjs.map +1 -0
- package/dist/index.d.mts +76 -12
- package/dist/index.d.ts +76 -12
- package/dist/index.js +105 -49
- package/dist/index.js.map +1 -0
- package/dist/index.mjs +68 -12
- package/dist/index.mjs.map +1 -0
- package/dist/{meta-BX5jhe4Z.d.mts → meta-BoS1E-Nz.d.mts} +6 -23
- package/dist/{meta-BX5jhe4Z.d.ts → meta-BoS1E-Nz.d.ts} +6 -23
- package/dist/rpc/bullmq/index.d.mts +4 -6
- package/dist/rpc/bullmq/index.d.ts +4 -6
- package/dist/rpc/bullmq/index.js +13 -80
- package/dist/rpc/bullmq/index.js.map +1 -0
- package/dist/rpc/bullmq/index.mjs +5 -72
- package/dist/rpc/bullmq/index.mjs.map +1 -0
- package/dist/rpc/electron/index.d.mts +13 -0
- package/dist/rpc/electron/index.d.ts +13 -0
- package/dist/rpc/electron/index.js +73 -0
- package/dist/rpc/electron/index.js.map +1 -0
- package/dist/rpc/electron/index.mjs +73 -0
- package/dist/rpc/electron/index.mjs.map +1 -0
- package/dist/rpc/kafka/index.d.mts +4 -9
- package/dist/rpc/kafka/index.d.ts +4 -9
- package/dist/rpc/kafka/index.js +12 -90
- package/dist/rpc/kafka/index.js.map +1 -0
- package/dist/rpc/kafka/index.mjs +5 -83
- package/dist/rpc/kafka/index.mjs.map +1 -0
- package/dist/rpc/nats/index.d.mts +4 -6
- package/dist/rpc/nats/index.d.ts +4 -6
- package/dist/rpc/nats/index.js +13 -72
- package/dist/rpc/nats/index.js.map +1 -0
- package/dist/rpc/nats/index.mjs +4 -63
- package/dist/rpc/nats/index.mjs.map +1 -0
- package/dist/rpc/rabbitmq/index.d.mts +4 -6
- package/dist/rpc/rabbitmq/index.d.ts +4 -6
- package/dist/rpc/rabbitmq/index.js +14 -79
- package/dist/rpc/rabbitmq/index.js.map +1 -0
- package/dist/rpc/rabbitmq/index.mjs +5 -70
- package/dist/rpc/rabbitmq/index.mjs.map +1 -0
- package/dist/rpc/redis/index.d.mts +4 -9
- package/dist/rpc/redis/index.d.ts +4 -9
- package/dist/rpc/redis/index.js +12 -78
- package/dist/rpc/redis/index.js.map +1 -0
- package/dist/rpc/redis/index.mjs +5 -71
- package/dist/rpc/redis/index.mjs.map +1 -0
- package/dist/rpc/web-ext/index.d.mts +2 -0
- package/dist/rpc/web-ext/index.d.ts +2 -0
- package/dist/rpc/web-ext/index.js +1 -0
- package/dist/rpc/web-ext/index.js.map +1 -0
- package/dist/rpc/web-ext/index.mjs +1 -0
- package/dist/rpc/web-ext/index.mjs.map +1 -0
- package/dist/rpc/ws/index.d.mts +14 -0
- package/dist/rpc/ws/index.d.ts +14 -0
- package/dist/rpc/ws/index.js +74 -0
- package/dist/rpc/ws/index.js.map +1 -0
- package/dist/rpc/ws/index.mjs +74 -0
- package/dist/rpc/ws/index.mjs.map +1 -0
- package/dist/test.d.mts +7 -3
- package/dist/test.d.ts +7 -3
- package/dist/test.js +7 -6
- package/dist/test.js.map +1 -0
- package/dist/test.mjs +3 -2
- package/dist/test.mjs.map +1 -0
- package/dist/types-CInz3bD0.d.ts +14 -0
- package/dist/types-E-rqlg3-.d.mts +14 -0
- package/dist/{types-DKVhyZk_.d.mts → types-SCJZFCYt.d.mts} +1 -1
- package/dist/{types-CMeuFoyd.d.ts → types-xruyYmyu.d.ts} +1 -1
- package/package.json +24 -8
- package/register/export.mjs +30 -0
- package/register/index.mjs +2 -3
- package/register/loader.mjs +83 -90
- package/register/utils.mjs +36 -6
- package/assets/ps.json +0 -24
- package/assets/tsconfig.json +0 -21
- package/dist/types-B-rUM9Fm.d.mts +0 -19
- 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-
|
|
3
|
-
import { R as RpcCtx, a as RpcServerOptions
|
|
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
|
-
|
|
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 };
|
package/dist/rpc/kafka/index.js
CHANGED
|
@@ -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 =
|
|
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
|
-
|
|
23
|
+
_chunkH7OCHDZTjs.detectAopDep.call(void 0, meta, {
|
|
25
24
|
guards: globalGuards,
|
|
26
25
|
addons: globalAddons
|
|
27
26
|
}, "rpc");
|
|
28
|
-
|
|
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
|
-
|
|
49
|
+
_chunkRLFCI3RGjs.__name.call(void 0, subscribeQueues, "subscribeQueues");
|
|
51
50
|
await subscribeQueues();
|
|
52
51
|
await consumer.run({
|
|
53
|
-
eachMessage: /* @__PURE__ */
|
|
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 =
|
|
61
|
+
const aop = _chunkH7OCHDZTjs.Context.getAop(meta2, {
|
|
63
62
|
globalFilter,
|
|
64
63
|
globalGuards,
|
|
65
64
|
globalPipe
|
|
66
65
|
});
|
|
67
|
-
const context = new (0,
|
|
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
|
-
|
|
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;
|
|
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]}
|
package/dist/rpc/kafka/index.mjs
CHANGED
|
@@ -1,12 +1,11 @@
|
|
|
1
1
|
import {
|
|
2
2
|
Context,
|
|
3
3
|
createControllerMetaMap,
|
|
4
|
-
detectAopDep
|
|
5
|
-
|
|
6
|
-
} from "../../chunk-CVPZWDXU.mjs";
|
|
4
|
+
detectAopDep
|
|
5
|
+
} from "../../chunk-LBH4RXQQ.mjs";
|
|
7
6
|
import {
|
|
8
7
|
__name
|
|
9
|
-
} from "../../chunk-
|
|
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-
|
|
3
|
-
import { R as RpcCtx, a as RpcServerOptions
|
|
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
|
-
|
|
14
|
-
|
|
15
|
-
export { type NatsCtx, bind, createClient };
|
|
13
|
+
export { type NatsCtx, bind };
|
package/dist/rpc/nats/index.d.ts
CHANGED
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
import { NatsConnection } from 'nats';
|
|
2
|
-
import { F as Factory } from '../../core-
|
|
3
|
-
import { R as RpcCtx, a as RpcServerOptions
|
|
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
|
-
|
|
14
|
-
|
|
15
|
-
export { type NatsCtx, bind, createClient };
|
|
13
|
+
export { type NatsCtx, bind };
|
package/dist/rpc/nats/index.js
CHANGED
|
@@ -2,11 +2,11 @@
|
|
|
2
2
|
|
|
3
3
|
|
|
4
4
|
|
|
5
|
-
var
|
|
5
|
+
var _chunkH7OCHDZTjs = require('../../chunk-H7OCHDZT.js');
|
|
6
6
|
|
|
7
7
|
|
|
8
8
|
|
|
9
|
-
var
|
|
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 =
|
|
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
|
-
|
|
27
|
+
_chunkH7OCHDZTjs.detectAopDep.call(void 0, meta, {
|
|
28
28
|
addons: globalAddons,
|
|
29
29
|
guards: globalGuards
|
|
30
30
|
}, "rpc");
|
|
31
|
-
|
|
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
|
-
|
|
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 =
|
|
59
|
+
const aop = _chunkH7OCHDZTjs.Context.getAop(meta2, {
|
|
60
60
|
globalFilter,
|
|
61
61
|
globalGuards,
|
|
62
62
|
globalPipe
|
|
63
63
|
});
|
|
64
|
-
const context = new (0,
|
|
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
|
-
|
|
91
|
+
_chunkRLFCI3RGjs.__name.call(void 0, handleRequest, "handleRequest");
|
|
92
92
|
subscribeQueues();
|
|
93
|
-
|
|
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
|
-
|
|
98
|
+
_chunkRLFCI3RGjs.__name.call(void 0, bind, "bind");
|
|
99
99
|
|
|
100
|
-
// src/rpc/nats/client.ts
|
|
101
100
|
|
|
102
|
-
|
|
103
|
-
|
|
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":"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","file":"D:\\myproject\\phecda\\packages\\server\\dist\\rpc\\nats\\index.js","sourcesContent":[null]}
|
package/dist/rpc/nats/index.mjs
CHANGED
|
@@ -2,11 +2,11 @@ import {
|
|
|
2
2
|
Context,
|
|
3
3
|
createControllerMetaMap,
|
|
4
4
|
detectAopDep
|
|
5
|
-
} from "../../chunk-
|
|
5
|
+
} from "../../chunk-LBH4RXQQ.mjs";
|
|
6
6
|
import {
|
|
7
7
|
HMR,
|
|
8
8
|
__name
|
|
9
|
-
} from "../../chunk-
|
|
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-
|
|
3
|
-
import { R as RpcCtx, a as RpcServerOptions
|
|
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
|
-
|
|
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-
|
|
3
|
-
import { R as RpcCtx, a as RpcServerOptions
|
|
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
|
-
|
|
15
|
-
|
|
16
|
-
export { type RabbitmqCtx, bind, createClient };
|
|
14
|
+
export { type RabbitmqCtx, bind };
|