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.
- 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-6JAHCTOT.mjs +334 -0
- package/dist/chunk-6JAHCTOT.mjs.map +1 -0
- package/dist/{chunk-BBNJVYVX.js → chunk-EDAWJVJ4.js} +42 -25
- package/dist/chunk-EDAWJVJ4.js.map +1 -0
- package/dist/{chunk-7EMAZGYO.js → chunk-H7OCHDZT.js} +65 -95
- package/dist/chunk-H7OCHDZT.js.map +1 -0
- package/dist/{chunk-QJIAXSLZ.js → chunk-KRUOHWFR.js} +79 -68
- package/dist/chunk-KRUOHWFR.js.map +1 -0
- package/dist/chunk-KUGU3UGO.js +334 -0
- package/dist/chunk-KUGU3UGO.js.map +1 -0
- package/dist/{chunk-SGMQZRP6.mjs → chunk-LBH4RXQQ.mjs} +12 -42
- package/dist/chunk-LBH4RXQQ.mjs.map +1 -0
- package/dist/{chunk-YKP4ODZA.mjs → chunk-MDPW6WGF.mjs} +32 -6
- package/dist/chunk-MDPW6WGF.mjs.map +1 -0
- package/dist/{chunk-VSGYTGHY.js → chunk-RLFCI3RG.js} +31 -5
- package/dist/chunk-RLFCI3RG.js.map +1 -0
- package/dist/{chunk-7NWDKK7D.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-B45BN7LY.mjs → chunk-WTJKTICN.mjs} +65 -54
- package/dist/chunk-WTJKTICN.mjs.map +1 -0
- package/dist/{core-BGEsBtTG.d.ts → core-BOo3uGFX.d.ts} +5 -4
- package/dist/{core-BcKywWLd.d.mts → core-CF45G79J.d.mts} +5 -4
- package/dist/core-DbqWh47p.d.mts +50 -0
- package/dist/core-Rq7BhPHE.d.ts +50 -0
- package/dist/helper.d.mts +7 -8
- package/dist/helper.d.ts +7 -8
- package/dist/helper.js +5 -3
- package/dist/helper.js.map +1 -0
- package/dist/helper.mjs +9 -7
- 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 +43 -45
- package/dist/http/elysia/index.js.map +1 -0
- package/dist/http/elysia/index.mjs +6 -8
- 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 +40 -42
- package/dist/http/express/index.js.map +1 -0
- package/dist/http/express/index.mjs +6 -8
- 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 +41 -43
- package/dist/http/fastify/index.js.map +1 -0
- package/dist/http/fastify/index.mjs +6 -8
- 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 +41 -43
- package/dist/http/h3/index.js.map +1 -0
- package/dist/http/h3/index.mjs +5 -7
- 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 +37 -39
- package/dist/http/hono/index.js.map +1 -0
- package/dist/http/hono/index.mjs +5 -7
- 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 +38 -40
- package/dist/http/hyper-express/index.js.map +1 -0
- package/dist/http/hyper-express/index.mjs +5 -7
- 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 +40 -42
- package/dist/http/koa/index.js.map +1 -0
- package/dist/http/koa/index.mjs +6 -8
- 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 +103 -49
- package/dist/index.js.map +1 -0
- package/dist/index.mjs +68 -14
- package/dist/index.mjs.map +1 -0
- package/dist/{meta-B_HW7cWh.d.ts → meta-BoS1E-Nz.d.mts} +6 -24
- package/dist/{meta-B_HW7cWh.d.mts → meta-BoS1E-Nz.d.ts} +6 -24
- 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 +6 -73
- 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 +5 -64
- 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 +6 -71
- 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 +6 -72
- 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 +8 -4
- package/dist/test.d.ts +8 -4
- 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-C2SQ9U9V.d.mts → types-SCJZFCYt.d.mts} +1 -1
- package/dist/{types-PFPIQWVF.d.ts → types-xruyYmyu.d.ts} +1 -1
- package/package.json +24 -8
- package/register/export.mjs +30 -0
- package/register/index.mjs +20 -12
- package/register/loader.mjs +94 -116
- package/register/utils.mjs +36 -6
- package/assets/ps.json +0 -24
- package/assets/tsconfig.json +0 -21
- package/dist/types-CYF0vha6.d.ts +0 -19
- package/dist/types-DEQb_e59.d.mts +0 -19
package/dist/rpc/nats/index.js
CHANGED
|
@@ -2,11 +2,11 @@
|
|
|
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
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
|
-
_chunkVSGYTGHYjs.__name.call(void 0, handler, "handler");
|
|
149
|
-
eventCount++;
|
|
150
|
-
});
|
|
151
|
-
};
|
|
152
|
-
}
|
|
153
|
-
});
|
|
154
|
-
}
|
|
155
|
-
return ret;
|
|
156
|
-
}
|
|
157
|
-
_chunkVSGYTGHYjs.__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
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
import {
|
|
2
2
|
Context,
|
|
3
|
-
HMR,
|
|
4
3
|
createControllerMetaMap,
|
|
5
4
|
detectAopDep
|
|
6
|
-
} from "../../chunk-
|
|
5
|
+
} from "../../chunk-LBH4RXQQ.mjs";
|
|
7
6
|
import {
|
|
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-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 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-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 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 };
|
|
@@ -2,31 +2,30 @@
|
|
|
2
2
|
|
|
3
3
|
|
|
4
4
|
|
|
5
|
+
var _chunkH7OCHDZTjs = require('../../chunk-H7OCHDZT.js');
|
|
5
6
|
|
|
6
7
|
|
|
7
|
-
var _chunk7EMAZGYOjs = require('../../chunk-7EMAZGYO.js');
|
|
8
8
|
|
|
9
|
-
|
|
10
|
-
var _chunkVSGYTGHYjs = require('../../chunk-VSGYTGHY.js');
|
|
9
|
+
var _chunkRLFCI3RGjs = require('../../chunk-RLFCI3RG.js');
|
|
11
10
|
|
|
12
11
|
// src/rpc/rabbitmq/bind.ts
|
|
13
12
|
var _debug = require('debug'); var _debug2 = _interopRequireDefault(_debug);
|
|
14
13
|
var debug = _debug2.default.call(void 0, "phecda-server/rabbitmq");
|
|
15
14
|
async function bind(ch, { moduleMap, meta }, opts = {}) {
|
|
16
15
|
const { globalGuards, globalFilter, globalPipe, globalAddons = [], defaultQueue } = opts;
|
|
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
|
const existQueue = /* @__PURE__ */ new Set();
|
|
29
|
-
|
|
28
|
+
_chunkH7OCHDZTjs.Context.applyAddons(globalAddons, ch, "rabbitmq");
|
|
30
29
|
async function subscribeQueues() {
|
|
31
30
|
existQueue.clear();
|
|
32
31
|
for (const [tag, record] of metaMap) {
|
|
@@ -45,12 +44,12 @@ async function bind(ch, { moduleMap, meta }, opts = {}) {
|
|
|
45
44
|
}
|
|
46
45
|
}
|
|
47
46
|
}
|
|
48
|
-
|
|
47
|
+
_chunkRLFCI3RGjs.__name.call(void 0, subscribeQueues, "subscribeQueues");
|
|
49
48
|
async function handleRequest(msg) {
|
|
50
49
|
function send(queue, data) {
|
|
51
50
|
ch.sendToQueue(queue, Buffer.from(JSON.stringify(data)));
|
|
52
51
|
}
|
|
53
|
-
|
|
52
|
+
_chunkRLFCI3RGjs.__name.call(void 0, send, "send");
|
|
54
53
|
if (msg) {
|
|
55
54
|
const data = JSON.parse(msg.content.toString());
|
|
56
55
|
const { tag, func, id, queue: clientQueue, _ps, args } = data;
|
|
@@ -58,12 +57,12 @@ async function bind(ch, { moduleMap, meta }, opts = {}) {
|
|
|
58
57
|
debug(`invoke method "${func}" in module "${tag}"`);
|
|
59
58
|
const meta2 = metaMap.get(tag)[func];
|
|
60
59
|
const { data: { rpc: { isEvent } = {} } } = meta2;
|
|
61
|
-
const aop =
|
|
60
|
+
const aop = _chunkH7OCHDZTjs.Context.getAop(meta2, {
|
|
62
61
|
globalFilter,
|
|
63
62
|
globalGuards,
|
|
64
63
|
globalPipe
|
|
65
64
|
});
|
|
66
|
-
const context = new (0,
|
|
65
|
+
const context = new (0, _chunkH7OCHDZTjs.Context)({
|
|
67
66
|
type: "rabbitmq",
|
|
68
67
|
category: "rpc",
|
|
69
68
|
moduleMap,
|
|
@@ -91,79 +90,15 @@ async function bind(ch, { moduleMap, meta }, opts = {}) {
|
|
|
91
90
|
});
|
|
92
91
|
}
|
|
93
92
|
}
|
|
94
|
-
|
|
93
|
+
_chunkRLFCI3RGjs.__name.call(void 0, handleRequest, "handleRequest");
|
|
95
94
|
subscribeQueues();
|
|
96
|
-
|
|
95
|
+
_chunkRLFCI3RGjs.HMR.call(void 0, async () => {
|
|
97
96
|
for (const queue of existQueue) await ch.deleteQueue(queue);
|
|
98
97
|
await subscribeQueues();
|
|
99
98
|
});
|
|
100
99
|
}
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
// src/rpc/rabbitmq/client.ts
|
|
104
|
-
var _events = require('events');
|
|
105
|
-
async function createClient(ch, controllers, opts) {
|
|
106
|
-
let eventId = 1;
|
|
107
|
-
let eventCount = 0;
|
|
108
|
-
const ret = {};
|
|
109
|
-
const emitter = new (0, _events.EventEmitter)();
|
|
110
|
-
const clientQueue = _chunk7EMAZGYOjs.genClientQueue.call(void 0, _optionalChain([opts, 'optionalAccess', _2 => _2.key]));
|
|
111
|
-
await ch.assertQueue(clientQueue);
|
|
112
|
-
ch.consume(clientQueue, (msg) => {
|
|
113
|
-
if (!msg) return;
|
|
114
|
-
const { data, id, error } = JSON.parse(msg.content.toString());
|
|
115
|
-
emitter.emit(id, data, error);
|
|
116
|
-
});
|
|
117
|
-
for (const i in controllers) {
|
|
118
|
-
ret[i] = new Proxy(new controllers[i](), {
|
|
119
|
-
get(target, p) {
|
|
120
|
-
if (typeof target[p] !== "function") throw new Error(`"${p}" in "${i}" is not an exposed rpc `);
|
|
121
|
-
let { tag, queue, isEvent } = target[p]();
|
|
122
|
-
return async (...args) => {
|
|
123
|
-
if (!queue) queue = tag;
|
|
124
|
-
const id = `${eventId++}`;
|
|
125
|
-
ch.sendToQueue(queue, Buffer.from(JSON.stringify({
|
|
126
|
-
_ps: 1,
|
|
127
|
-
id,
|
|
128
|
-
args,
|
|
129
|
-
tag,
|
|
130
|
-
queue: clientQueue,
|
|
131
|
-
func: p
|
|
132
|
-
})));
|
|
133
|
-
if (isEvent) return null;
|
|
134
|
-
return new Promise((resolve, reject) => {
|
|
135
|
-
if (_optionalChain([opts, 'optionalAccess', _3 => _3.max]) && eventCount >= opts.max) reject({
|
|
136
|
-
type: "exceeded"
|
|
137
|
-
});
|
|
138
|
-
let isEnd = false;
|
|
139
|
-
const timer = setTimeout(() => {
|
|
140
|
-
if (!isEnd) {
|
|
141
|
-
eventCount--;
|
|
142
|
-
emitter.off(id, listener);
|
|
143
|
-
reject({
|
|
144
|
-
type: "timeout"
|
|
145
|
-
});
|
|
146
|
-
}
|
|
147
|
-
}, _optionalChain([opts, 'optionalAccess', _4 => _4.timeout]) || 5e3);
|
|
148
|
-
function listener(data, error) {
|
|
149
|
-
eventCount--;
|
|
150
|
-
isEnd = true;
|
|
151
|
-
clearTimeout(timer);
|
|
152
|
-
if (error) reject(data);
|
|
153
|
-
else resolve(data);
|
|
154
|
-
}
|
|
155
|
-
_chunkVSGYTGHYjs.__name.call(void 0, listener, "listener");
|
|
156
|
-
eventCount++;
|
|
157
|
-
emitter.once(id, listener);
|
|
158
|
-
});
|
|
159
|
-
};
|
|
160
|
-
}
|
|
161
|
-
});
|
|
162
|
-
}
|
|
163
|
-
return ret;
|
|
164
|
-
}
|
|
165
|
-
_chunkVSGYTGHYjs.__name.call(void 0, createClient, "createClient");
|
|
166
|
-
|
|
100
|
+
_chunkRLFCI3RGjs.__name.call(void 0, bind, "bind");
|
|
167
101
|
|
|
168
102
|
|
|
169
|
-
exports.bind = bind;
|
|
103
|
+
exports.bind = bind;
|
|
104
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["d:\\myproject\\phecda\\packages\\server\\dist\\rpc\\rabbitmq\\index.js"],"names":[],"mappings":"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","file":"D:\\myproject\\phecda\\packages\\server\\dist\\rpc\\rabbitmq\\index.js","sourcesContent":[null]}
|
|
@@ -1,13 +1,12 @@
|
|
|
1
1
|
import {
|
|
2
2
|
Context,
|
|
3
|
-
HMR,
|
|
4
3
|
createControllerMetaMap,
|
|
5
|
-
detectAopDep
|
|
6
|
-
|
|
7
|
-
} from "../../chunk-SGMQZRP6.mjs";
|
|
4
|
+
detectAopDep
|
|
5
|
+
} from "../../chunk-LBH4RXQQ.mjs";
|
|
8
6
|
import {
|
|
7
|
+
HMR,
|
|
9
8
|
__name
|
|
10
|
-
} from "../../chunk-
|
|
9
|
+
} from "../../chunk-MDPW6WGF.mjs";
|
|
11
10
|
|
|
12
11
|
// src/rpc/rabbitmq/bind.ts
|
|
13
12
|
import Debug from "debug";
|
|
@@ -99,71 +98,7 @@ async function bind(ch, { moduleMap, meta }, opts = {}) {
|
|
|
99
98
|
});
|
|
100
99
|
}
|
|
101
100
|
__name(bind, "bind");
|
|
102
|
-
|
|
103
|
-
// src/rpc/rabbitmq/client.ts
|
|
104
|
-
import { EventEmitter } from "events";
|
|
105
|
-
async function createClient(ch, controllers, opts) {
|
|
106
|
-
let eventId = 1;
|
|
107
|
-
let eventCount = 0;
|
|
108
|
-
const ret = {};
|
|
109
|
-
const emitter = new EventEmitter();
|
|
110
|
-
const clientQueue = genClientQueue(opts?.key);
|
|
111
|
-
await ch.assertQueue(clientQueue);
|
|
112
|
-
ch.consume(clientQueue, (msg) => {
|
|
113
|
-
if (!msg) return;
|
|
114
|
-
const { data, id, error } = JSON.parse(msg.content.toString());
|
|
115
|
-
emitter.emit(id, data, error);
|
|
116
|
-
});
|
|
117
|
-
for (const i in controllers) {
|
|
118
|
-
ret[i] = new Proxy(new controllers[i](), {
|
|
119
|
-
get(target, p) {
|
|
120
|
-
if (typeof target[p] !== "function") throw new Error(`"${p}" in "${i}" is not an exposed rpc `);
|
|
121
|
-
let { tag, queue, isEvent } = target[p]();
|
|
122
|
-
return async (...args) => {
|
|
123
|
-
if (!queue) queue = tag;
|
|
124
|
-
const id = `${eventId++}`;
|
|
125
|
-
ch.sendToQueue(queue, Buffer.from(JSON.stringify({
|
|
126
|
-
_ps: 1,
|
|
127
|
-
id,
|
|
128
|
-
args,
|
|
129
|
-
tag,
|
|
130
|
-
queue: clientQueue,
|
|
131
|
-
func: p
|
|
132
|
-
})));
|
|
133
|
-
if (isEvent) return null;
|
|
134
|
-
return new Promise((resolve, reject) => {
|
|
135
|
-
if (opts?.max && eventCount >= opts.max) reject({
|
|
136
|
-
type: "exceeded"
|
|
137
|
-
});
|
|
138
|
-
let isEnd = false;
|
|
139
|
-
const timer = setTimeout(() => {
|
|
140
|
-
if (!isEnd) {
|
|
141
|
-
eventCount--;
|
|
142
|
-
emitter.off(id, listener);
|
|
143
|
-
reject({
|
|
144
|
-
type: "timeout"
|
|
145
|
-
});
|
|
146
|
-
}
|
|
147
|
-
}, opts?.timeout || 5e3);
|
|
148
|
-
function listener(data, error) {
|
|
149
|
-
eventCount--;
|
|
150
|
-
isEnd = true;
|
|
151
|
-
clearTimeout(timer);
|
|
152
|
-
if (error) reject(data);
|
|
153
|
-
else resolve(data);
|
|
154
|
-
}
|
|
155
|
-
__name(listener, "listener");
|
|
156
|
-
eventCount++;
|
|
157
|
-
emitter.once(id, listener);
|
|
158
|
-
});
|
|
159
|
-
};
|
|
160
|
-
}
|
|
161
|
-
});
|
|
162
|
-
}
|
|
163
|
-
return ret;
|
|
164
|
-
}
|
|
165
|
-
__name(createClient, "createClient");
|
|
166
101
|
export {
|
|
167
|
-
bind
|
|
168
|
-
createClient
|
|
102
|
+
bind
|
|
169
103
|
};
|
|
104
|
+
//# sourceMappingURL=index.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/rpc/rabbitmq/bind.ts"],"sourcesContent":["import type amqplib from 'amqplib'\r\nimport type { ConsumeMessage } from 'amqplib'\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\nimport { createControllerMetaMap, detectAopDep } from '../../helper'\r\n\r\nconst debug = Debug('phecda-server/rabbitmq')\r\n\r\nexport interface RabbitmqCtx extends RpcCtx {\r\n type: 'rabbitmq'\r\n ch: amqplib.Channel\r\n msg: amqplib.ConsumeMessage\r\n}\r\n\r\nexport async function bind(ch: amqplib.Channel, { moduleMap, meta }: Awaited<ReturnType<typeof Factory>>, opts: RpcServerOptions = {}) {\r\n const { globalGuards, globalFilter, globalPipe, globalAddons = [], defaultQueue } = opts\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 guards: globalGuards,\r\n addons: globalAddons,\r\n }, 'rpc')\r\n const existQueue = new Set<string>()\r\n\r\n Context.applyAddons(globalAddons, ch, 'rabbitmq')\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 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 ch.assertQueue(queue)\r\n\r\n ch.consume(queue, handleRequest, { noAck: true })\r\n }\r\n }\r\n }\r\n }\r\n\r\n async function handleRequest(msg: ConsumeMessage | null) {\r\n function send(queue: string, data: any) {\r\n ch.sendToQueue(queue, Buffer.from(JSON.stringify(data)))\r\n }\r\n\r\n if (msg) {\r\n const data = JSON.parse(msg.content.toString())\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: { rpc: { isEvent } = {} },\r\n } = meta\r\n const aop = Context.getAop(meta, {\r\n globalFilter,\r\n globalGuards,\r\n globalPipe,\r\n })\r\n const context = new Context<RabbitmqCtx>({\r\n type: 'rabbitmq',\r\n category: 'rpc',\r\n moduleMap,\r\n meta,\r\n tag,\r\n func,\r\n args,\r\n id,\r\n ch,\r\n msg,\r\n isEvent,\r\n queue: msg.fields.routingKey,\r\n })\r\n await context.run(aop, (returnData) => {\r\n if (!isEvent)\r\n send(clientQueue, { data: returnData, id })\r\n }, (err) => {\r\n if (!isEvent)\r\n send(clientQueue, { data: err, id, error: true })\r\n })\r\n }\r\n }\r\n\r\n subscribeQueues()\r\n\r\n HMR(async () => {\r\n for (const queue of existQueue)\r\n await ch.deleteQueue(queue)\r\n\r\n await subscribeQueues()\r\n })\r\n}\r\n"],"mappings":";;;;;;;;;;;AAEA,OAAOA,WAAW;AAOlB,IAAMC,QAAQC,MAAM,wBAAA;AAQpB,eAAsBC,KAAKC,IAAqB,EAAEC,WAAWC,KAAI,GAAyCC,OAAyB,CAAC,GAAC;AACnI,QAAM,EAAEC,cAAcC,cAAcC,YAAYC,eAAe,CAAA,GAAIC,aAAY,IAAKL;AAEpF,QAAMM,UAAUC,wBAAwBR,MAAM,CAACA,UAAAA;AAC7C,UAAM,EAAES,YAAYC,KAAKC,MAAMC,IAAG,IAAKZ,MAAKa;AAC5C,QAAIJ,eAAe,SAASC,KAAKI,UAAUC,QAAW;AACpDpB,YAAM,oBAAoBgB,IAAAA,gBAAoBC,GAAAA,GAAM;AACpD,aAAO;IACT;EACF,CAAA;AAEAI,eAAahB,MAAM;IACjBiB,QAAQf;IACRgB,QAAQb;EACV,GAAG,KAAA;AACH,QAAMc,aAAa,oBAAIC,IAAAA;AAEvBC,UAAQC,YAAYjB,cAAcP,IAAI,UAAA;AACtC,iBAAeyB,kBAAAA;AACbJ,eAAWK,MAAK;AAChB,eAAW,CAACZ,KAAKa,MAAAA,KAAWlB,SAAS;AACnC,iBAAWI,QAAQc,QAAQ;AACzB,cAAMzB,QAAOO,QAAQmB,IAAId,GAAAA,EAAMD,IAAAA;AAC/B,cAAM,EACJE,MAAM,EACJH,IAAG,EACJ,IACCV;AACJ,YAAIU,KAAK;AACP,gBAAMI,QAAQJ,IAAII,SAASR,gBAAgBM;AAC3C,cAAIO,WAAWQ,IAAIb,KAAAA,EACjB;AACFK,qBAAWS,IAAId,KAAAA;AACf,gBAAMhB,GAAG+B,YAAYf,KAAAA;AAErBhB,aAAGgC,QAAQhB,OAAOiB,eAAe;YAAEC,OAAO;UAAK,CAAA;QACjD;MACF;IACF;EACF;AArBeT;AAuBf,iBAAeQ,cAAcE,KAA0B;AACrD,aAASC,KAAKpB,OAAeD,MAAS;AACpCf,SAAGqC,YAAYrB,OAAOsB,OAAOC,KAAKC,KAAKC,UAAU1B,IAAAA,CAAAA,CAAAA;IACnD;AAFSqB;AAIT,QAAID,KAAK;AACP,YAAMpB,OAAOyB,KAAKE,MAAMP,IAAIQ,QAAQC,SAAQ,CAAA;AAC5C,YAAM,EAAE9B,KAAKD,MAAMgC,IAAI7B,OAAO8B,aAAaC,KAAKC,KAAI,IAAKjC;AAEzD,UAAIgC,QAAQ,EACV;AACFlD,YAAM,kBAAkBgB,IAAAA,gBAAoBC,GAAAA,GAAM;AAClD,YAAMZ,QAAOO,QAAQmB,IAAId,GAAAA,EAAMD,IAAAA;AAE/B,YAAM,EACJE,MAAM,EAAEH,KAAK,EAAEqC,QAAO,IAAK,CAAC,EAAC,EAAE,IAC7B/C;AACJ,YAAMgD,MAAM3B,QAAQ4B,OAAOjD,OAAM;QAC/BG;QACAD;QACAE;MACF,CAAA;AACA,YAAM8C,UAAU,IAAI7B,QAAqB;QACvC8B,MAAM;QACNC,UAAU;QACVrD;QACAC,MAAAA;QACAY;QACAD;QACAmC;QACAH;QACA7C;QACAmC;QACAc;QACAjC,OAAOmB,IAAIoB,OAAOC;MACpB,CAAA;AACA,YAAMJ,QAAQK,IAAIP,KAAK,CAACQ,eAAAA;AACtB,YAAI,CAACT,QACHb,MAAKU,aAAa;UAAE/B,MAAM2C;UAAYb;QAAG,CAAA;MAC7C,GAAG,CAACc,QAAAA;AACF,YAAI,CAACV,QACHb,MAAKU,aAAa;UAAE/B,MAAM4C;UAAKd;UAAIe,OAAO;QAAK,CAAA;MACnD,CAAA;IACF;EACF;AA5Ce3B;AA8CfR,kBAAAA;AAEAoC,MAAI,YAAA;AACF,eAAW7C,SAASK,WAClB,OAAMrB,GAAG8D,YAAY9C,KAAAA;AAEvB,UAAMS,gBAAAA;EACR,CAAA;AACF;AA/FsB1B;","names":["Debug","debug","Debug","bind","ch","moduleMap","meta","opts","globalGuards","globalFilter","globalPipe","globalAddons","defaultQueue","metaMap","createControllerMetaMap","controller","rpc","func","tag","data","queue","undefined","detectAopDep","guards","addons","existQueue","Set","Context","applyAddons","subscribeQueues","clear","record","get","has","add","assertQueue","consume","handleRequest","noAck","msg","send","sendToQueue","Buffer","from","JSON","stringify","parse","content","toString","id","clientQueue","_ps","args","isEvent","aop","getAop","context","type","category","fields","routingKey","run","returnData","err","error","HMR","deleteQueue"]}
|
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
import Redis from 'ioredis';
|
|
2
|
-
import { F as Factory } from '../../core-
|
|
3
|
-
import { R as RpcCtx, a as RpcServerOptions
|
|
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 RedisCtx extends RpcCtx {
|
|
8
8
|
type: 'redis';
|
|
@@ -15,9 +15,4 @@ declare function bind({ sub, pub }: {
|
|
|
15
15
|
pub: Redis;
|
|
16
16
|
}, { moduleMap, meta }: Awaited<ReturnType<typeof Factory>>, opts?: RpcServerOptions): void;
|
|
17
17
|
|
|
18
|
-
|
|
19
|
-
pub: Redis;
|
|
20
|
-
sub: Redis;
|
|
21
|
-
}, controllers: S, opts?: RpcClientOptions): Promise<ToClientMap<S>>;
|
|
22
|
-
|
|
23
|
-
export { type RedisCtx, bind, createClient };
|
|
18
|
+
export { type RedisCtx, bind };
|
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
import Redis from 'ioredis';
|
|
2
|
-
import { F as Factory } from '../../core-
|
|
3
|
-
import { R as RpcCtx, a as RpcServerOptions
|
|
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 RedisCtx extends RpcCtx {
|
|
8
8
|
type: 'redis';
|
|
@@ -15,9 +15,4 @@ declare function bind({ sub, pub }: {
|
|
|
15
15
|
pub: Redis;
|
|
16
16
|
}, { moduleMap, meta }: Awaited<ReturnType<typeof Factory>>, opts?: RpcServerOptions): void;
|
|
17
17
|
|
|
18
|
-
|
|
19
|
-
pub: Redis;
|
|
20
|
-
sub: Redis;
|
|
21
|
-
}, controllers: S, opts?: RpcClientOptions): Promise<ToClientMap<S>>;
|
|
22
|
-
|
|
23
|
-
export { type RedisCtx, bind, createClient };
|
|
18
|
+
export { type RedisCtx, bind };
|