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