oox 0.2.0 → 0.3.0-beta10

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (57) hide show
  1. package/LICENSE +21 -21
  2. package/README.md +32 -29
  3. package/app.js +143 -0
  4. package/bin/argv.js +70 -95
  5. package/bin/cli.js +49 -58
  6. package/bin/configurer.js +64 -78
  7. package/bin/loader.mjs +449 -0
  8. package/bin/proxyer.js +66 -95
  9. package/bin/register.js +55 -105
  10. package/bin/starter.js +71 -144
  11. package/index.js +168 -6
  12. package/index.mjs +5 -0
  13. package/logger.js +40 -0
  14. package/modules/http/index.js +192 -0
  15. package/modules/http/utils.js +73 -0
  16. package/modules/index.js +88 -0
  17. package/modules/module.js +16 -0
  18. package/modules/socketio/client.js +101 -0
  19. package/modules/socketio/index.js +168 -0
  20. package/modules/socketio/server.js +136 -0
  21. package/modules/socketio/socket.js +4 -0
  22. package/package.json +39 -16
  23. package/types/app.d.ts +51 -0
  24. package/types/bin/argv.d.ts +8 -0
  25. package/types/bin/cli.d.ts +4 -0
  26. package/types/bin/configurer.d.ts +3 -0
  27. package/types/bin/proxyer.d.ts +1 -0
  28. package/types/bin/register.d.ts +1 -0
  29. package/types/bin/starter.d.ts +3 -0
  30. package/types/index.d.ts +76 -0
  31. package/types/logger.d.ts +4 -0
  32. package/types/modules/http/index.d.ts +47 -0
  33. package/types/modules/http/utils.d.ts +17 -0
  34. package/types/modules/index.d.ts +24 -0
  35. package/types/modules/module.d.ts +13 -0
  36. package/types/modules/socketio/client.d.ts +23 -0
  37. package/types/modules/socketio/index.d.ts +37 -0
  38. package/types/modules/socketio/server.d.ts +35 -0
  39. package/types/modules/socketio/socket.d.ts +11 -0
  40. package/types/utils.d.ts +6 -0
  41. package/utils.js +63 -0
  42. package/.gitattributes +0 -2
  43. package/global.js +0 -118
  44. package/middleware.js +0 -167
  45. package/rpc/config.class.js +0 -48
  46. package/rpc/context.class.js +0 -15
  47. package/rpc/http.class.js +0 -312
  48. package/rpc/rpc.class.js +0 -231
  49. package/rpc/rpc.interface.class.js +0 -119
  50. package/rpc/socketio.class.js +0 -223
  51. package/service/service.class.js +0 -74
  52. package/service/socketio.class.js +0 -145
  53. package/setMap.class.js +0 -67
  54. package/socketio/client.class.js +0 -190
  55. package/socketio/server.class.js +0 -222
  56. package/socketio/socket.class.js +0 -23
  57. package/util.js +0 -224
@@ -0,0 +1,168 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.sockets = void 0;
4
+ const path = require("node:path");
5
+ const client_1 = require("./client");
6
+ const oox = require("../../index");
7
+ const index_1 = require("../../index");
8
+ const socket_1 = require("./socket");
9
+ Object.defineProperty(exports, "sockets", { enumerable: true, get: function () { return socket_1.sockets; } });
10
+ class SocketIOModule extends client_1.default {
11
+ sockets = socket_1.sockets;
12
+ async serve() {
13
+ await this.stop();
14
+ const _http = oox.modules.builtins.http;
15
+ const httpConfig = _http.getConfig(), config = this.getConfig();
16
+ let isShareServer = false;
17
+ // 都没设置端口
18
+ isShareServer = !httpConfig.port && !config.port;
19
+ // 都设置相同端口
20
+ isShareServer = isShareServer || httpConfig.port === config.port;
21
+ // http 模块未被禁用
22
+ isShareServer = isShareServer && !httpConfig.disabled;
23
+ if (isShareServer) {
24
+ config.path = path.posix.join(httpConfig.path, config.path);
25
+ this.server = _http.server;
26
+ }
27
+ await super.serve();
28
+ }
29
+ onSyncConnection(socket) {
30
+ const mSockets = Array.from(socket_1.sockets.values())
31
+ .filter(s => s !== socket &&
32
+ s.data.name !== socket.data.name &&
33
+ s.data.id.startsWith('ws://'));
34
+ return mSockets.map(s => s.data);
35
+ }
36
+ serverOnDisconnect(socket, reason) {
37
+ super.serverOnDisconnect(socket, reason);
38
+ (0, index_1.removeKeepAliveConnection)(socket.data.name, socket.data.id);
39
+ }
40
+ clientOnDisconnect(socket, reason) {
41
+ super.clientOnDisconnect(socket, reason);
42
+ (0, index_1.removeKeepAliveConnection)(socket.data.name, socket.data.id);
43
+ }
44
+ /**
45
+ *
46
+ * @param socket 是由哪个通道发送过来的
47
+ * @param connectionDatas
48
+ */
49
+ clientOnSyncConnection(socket, connectionDatas) {
50
+ for (const data of connectionDatas)
51
+ if (!socket_1.sockets.has(data.id))
52
+ this.connect(data.id).catch((error) => console.error(error));
53
+ }
54
+ onFetchActions(socket, search) {
55
+ const data = [];
56
+ for (const key of oox.kvMethods.keys())
57
+ if (!key.endsWith('_proxy') && key.includes(search))
58
+ data.push(key);
59
+ return data;
60
+ }
61
+ fetchActions(id, search = '') {
62
+ let socket = socket_1.sockets.get(id);
63
+ if (!socket) {
64
+ const connections = (0, index_1.getKeepAliveConnections)(id);
65
+ if (!connections || !connections.size)
66
+ throw new Error(`Unknown service identify<${id}>`);
67
+ id = connections.keys().next().value;
68
+ socket = socket_1.sockets.get(id);
69
+ }
70
+ if (!socket)
71
+ throw new Error(`Unknown service identify<${id}>`);
72
+ return this.emit(socket.data.id, 'fetchActions', [search]);
73
+ }
74
+ onConnection(socket) {
75
+ const { id, name, host } = socket.data;
76
+ const connection = new index_1.RPCKeepAliveConnection(this, id, socket.data);
77
+ (0, index_1.addKeepAliveConnection)(connection);
78
+ const connectionContext = {
79
+ sourceIP: '',
80
+ ip: host,
81
+ caller: name,
82
+ callerId: id,
83
+ connection
84
+ };
85
+ socket.on('fetchActions', async (search, fn) => {
86
+ if ('function' !== typeof fn)
87
+ return;
88
+ const data = await this.onFetchActions(socket, search);
89
+ fn(data);
90
+ });
91
+ socket.on('call', async (action, params, context, callback) => {
92
+ if ('object' !== typeof context)
93
+ context = oox.genContext(connectionContext);
94
+ else
95
+ context = oox.genContext(Object.assign(context, connectionContext));
96
+ this.call(action, params, context, callback);
97
+ });
98
+ }
99
+ /**
100
+ *
101
+ * @param {Socket} socket
102
+ */
103
+ serverOnConnection(socket) {
104
+ super.serverOnConnection(socket);
105
+ socket.setMaxListeners(0);
106
+ socket.on('syncConnection', async (fn) => {
107
+ if ('function' !== typeof fn)
108
+ return;
109
+ const data = this.onSyncConnection(socket);
110
+ fn(data);
111
+ });
112
+ this.onConnection(socket);
113
+ }
114
+ async call(action, params, context, callback) {
115
+ const returns = await oox.call(action, params, context);
116
+ 'function' === typeof callback && callback(returns);
117
+ return returns;
118
+ }
119
+ clientOnConnection(socket) {
120
+ super.clientOnConnection(socket);
121
+ socket.emit('syncConnection', (socketDatas) => this.clientOnSyncConnection(socket, socketDatas));
122
+ this.onConnection(socket);
123
+ }
124
+ /**
125
+ * socketio emit
126
+ */
127
+ async emit(url, action, params) {
128
+ let socket = null;
129
+ try {
130
+ socket = await this.connect(url);
131
+ }
132
+ catch (error) {
133
+ // try again
134
+ socket = await this.connect(url);
135
+ }
136
+ try {
137
+ return await new Promise((resolve, reject) => {
138
+ const onError = (reason) => {
139
+ const message = 'string' === typeof reason ? reason : reason instanceof Error ? reason.message : 'connect error';
140
+ reject(new Error(message));
141
+ };
142
+ // RPC 执行时中断连接
143
+ socket.once('disconnect', onError);
144
+ socket.emit(action, ...params, (returns) => {
145
+ socket.off('disconnect', onError);
146
+ resolve(returns);
147
+ });
148
+ });
149
+ }
150
+ catch (error) {
151
+ throw new Error(error.message);
152
+ }
153
+ }
154
+ /**
155
+ * RPC
156
+ */
157
+ async rpc(url, action, params, context) {
158
+ if (!context || !context.traceId) {
159
+ context = oox.getContext();
160
+ }
161
+ const { error, body } = await this.emit(url, 'call', [action, params, context]);
162
+ if (error)
163
+ throw new Error(error.message);
164
+ else
165
+ return body;
166
+ }
167
+ }
168
+ exports.default = SocketIOModule;
@@ -0,0 +1,136 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.SocketIOConfig = void 0;
4
+ const http = require("node:http");
5
+ const socket_io_1 = require("socket.io");
6
+ const oox = require("../../index");
7
+ const index_1 = require("../../index");
8
+ const socket_1 = require("./socket");
9
+ class SocketIOConfig extends index_1.ModuleConfig {
10
+ // listen port
11
+ port = 0;
12
+ // service path
13
+ path = '/socket.io';
14
+ // browser cross origin
15
+ origin = '';
16
+ }
17
+ exports.SocketIOConfig = SocketIOConfig;
18
+ class SocketIOServer extends index_1.Module {
19
+ name = 'socketio';
20
+ config = new SocketIOConfig;
21
+ /**
22
+ * means this.server created by myself<SocketIOServer>
23
+ */
24
+ #isSelfServer = false;
25
+ server = null;
26
+ socketServer = null;
27
+ setConfig(config) {
28
+ Object.assign(this.config, config);
29
+ if (!config.hasOwnProperty('port')) {
30
+ this.config.port = oox.config.port;
31
+ }
32
+ if (!config.hasOwnProperty('origin')) {
33
+ this.config.origin = oox.config.origin;
34
+ }
35
+ }
36
+ getConfig() {
37
+ return this.config;
38
+ }
39
+ async serve() {
40
+ await this.stop();
41
+ const port = this.config.port;
42
+ const isSelfServer = this.#isSelfServer = this.server ? true : false;
43
+ const server = this.server = isSelfServer ? this.server :
44
+ http.createServer((request, response) => response.end('No HTTP Gateway'));
45
+ if (!server.listening)
46
+ server.listen(port);
47
+ const address = server.address();
48
+ if (!address || 'object' !== typeof address)
49
+ throw new Error('Cannot read socket.io server port');
50
+ this.config.port = address.port;
51
+ this.createSocketIOServer();
52
+ }
53
+ async stop() {
54
+ if (this.socketServer)
55
+ await new Promise((resolve, reject) => this.socketServer.close(error => error ? reject(error) : resolve()));
56
+ if (this.#isSelfServer)
57
+ await new Promise((resolve, reject) => this.server.listening && this.server.close(error => error ? reject(error) : resolve()));
58
+ }
59
+ genSocketIOServerOptions() {
60
+ const options = {
61
+ /**
62
+ * name of the path to capture
63
+ * @default "/socket.io"
64
+ */
65
+ path: this.config.path,
66
+ /**
67
+ * how many ms before a client without namespace is closed
68
+ * @default 45000
69
+ */
70
+ connectTimeout: 5000,
71
+ /**
72
+ * how many ms without a pong packet to consider the connection closed
73
+ * @default 5000
74
+ */
75
+ pingTimeout: 2000,
76
+ /**
77
+ * how many ms before sending a new ping packet
78
+ * @default 25000
79
+ */
80
+ pingInterval: 10000,
81
+ /**
82
+ * how many bytes or characters a message can be, before closing the session (to avoid DoS).
83
+ * @default 1e5 (100 KB)
84
+ */
85
+ maxHttpBufferSize: 1e5
86
+ };
87
+ const { origin } = this.config;
88
+ if (origin)
89
+ options.cors = { origin };
90
+ return options;
91
+ }
92
+ createSocketIOServer() {
93
+ const socketServer = this.socketServer = new socket_io_1.Server(this.server, this.genSocketIOServerOptions());
94
+ socketServer.on('connection', async (socket) => {
95
+ try {
96
+ this.serverOnSocketConnection(socket);
97
+ }
98
+ catch (error) {
99
+ socket.send(error.message).disconnect(true);
100
+ }
101
+ });
102
+ }
103
+ /**
104
+ * 服务端Socket连接事件
105
+ */
106
+ serverOnSocketConnection(socket) {
107
+ const headers = socket.handshake.headers;
108
+ const callerId = String(headers['x-caller-id'] || '') || socket.id;
109
+ // 已经存在相同的连接
110
+ if (socket_1.sockets.has(callerId))
111
+ throw new Error('Connection Exists');
112
+ // client ip or caller service ip
113
+ const ip = String(headers['x-real-ip'] || headers['x-ip'] || socket.handshake.address);
114
+ // service name
115
+ const caller = String(headers['x-caller'] || 'anonymous');
116
+ socket.data = { connected: true, host: ip, name: caller, id: callerId };
117
+ // 保存 callerId 与 socket 对应关系
118
+ socket_1.sockets.set(callerId, socket);
119
+ socket.on('disconnect', reason => this.serverOnSocketDisconnect(socket, reason));
120
+ socket.emit('oox_connected', { name: oox.config.name });
121
+ this.serverOnConnection(socket);
122
+ }
123
+ serverOnConnection(socket) { }
124
+ /**
125
+ * 服务端Socket断开事件
126
+ * @param {Socket} socket
127
+ * @param {Error} reason
128
+ */
129
+ serverOnSocketDisconnect(socket, reason) {
130
+ socket.data.connected = false;
131
+ socket_1.sockets.delete(socket.data.id);
132
+ this.serverOnDisconnect(socket, reason);
133
+ }
134
+ serverOnDisconnect(socket, reason) { }
135
+ }
136
+ exports.default = SocketIOServer;
@@ -0,0 +1,4 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.sockets = void 0;
4
+ exports.sockets = new Map();
package/package.json CHANGED
@@ -1,17 +1,40 @@
1
1
  {
2
- "name": "oox",
3
- "version": "0.2.0",
4
- "description": "distributed api service",
5
- "main": "index.js",
6
- "bin": {
7
- "oox": "bin/cli.js"
8
- },
9
- "author": "lipingruan",
10
- "homepage": "https://github.com/lipingruan/oox",
11
- "license": "MIT",
12
- "dependencies": {
13
- "chalk": "^4.1.0",
14
- "socket.io": "^4.4.0",
15
- "socket.io-client": "^4.4.0"
16
- }
17
- }
2
+ "name": "oox",
3
+ "version": "0.3.0-beta10",
4
+ "description": "Graceful NodeJS distributed application solution",
5
+ "keywords": [
6
+ "http",
7
+ "websocket",
8
+ "socket.io",
9
+ "rpc",
10
+ "framework",
11
+ "microservice",
12
+ "distributed",
13
+ "tracing"
14
+ ],
15
+ "type": "commonjs",
16
+ "main": "index.js",
17
+ "types": "types/index.d.ts",
18
+ "exports": {
19
+ ".": {
20
+ "import": "./index.mjs",
21
+ "require": "./index.js"
22
+ },
23
+ "./loader": "./bin/loader.mjs",
24
+ "./cli": "./bin/cli.js"
25
+ },
26
+ "bin": {
27
+ "oox": "bin/cli.js"
28
+ },
29
+ "author": "lipingruan",
30
+ "homepage": "https://github.com/lipingruan/oox",
31
+ "license": "MIT",
32
+ "dependencies": {
33
+ "chalk": "^4.1.0",
34
+ "socket.io": "^4.4.0",
35
+ "socket.io-client": "^4.4.0"
36
+ },
37
+ "engines": {
38
+ "node": ">=14.17.0"
39
+ }
40
+ }
package/types/app.d.ts ADDED
@@ -0,0 +1,51 @@
1
+ /// <reference types="node" />
2
+ /// <reference types="node" />
3
+ import { EventEmitter } from 'node:events';
4
+ import { AsyncLocalStorage } from 'node:async_hooks';
5
+ export * as logger from './logger';
6
+ export interface ReturnsBody {
7
+ traceId: string;
8
+ success: boolean;
9
+ body?: any;
10
+ error?: {
11
+ message: string;
12
+ stack: string;
13
+ };
14
+ }
15
+ export declare class Context {
16
+ [x: string]: any;
17
+ traceId?: string;
18
+ }
19
+ export declare const asyncStore: AsyncLocalStorage<Context>;
20
+ export declare const eventHub: EventEmitter;
21
+ /**
22
+ * the kvMethods is all actions refs [has bind this]
23
+ */
24
+ export declare const kvMethods: Map<string, Function>;
25
+ export declare const sourceKVMethods: Map<string, Function>;
26
+ export declare function setMethods(methods: any): void;
27
+ export declare function getMethods(): any;
28
+ export declare function on(event: 'app:configured' | 'app:served' | 'app:stopped', listener: () => void): void;
29
+ export declare function on(event: 'request', listener: (action: string, params: any[], context: Context) => void): void;
30
+ export declare function on(event: 'success', listener: (action: string, params: any[], context: Context, result: ReturnsBody) => void): void;
31
+ export declare function on(event: 'fail', listener: (action: string, params: any[], context: Context, error: Error) => void): void;
32
+ export declare function on(event: 'log', listener: (context: Context, tag: string, msgs: any[]) => void): void;
33
+ export declare function on(event: string, listener: (...args: any[]) => void): void;
34
+ export declare function once(event: 'app:configured' | 'app:served' | 'app:stopped', listener: (...args: any[]) => void): void;
35
+ export declare function once(event: 'request', listener: (action: string, params: any[], context: Context) => void): void;
36
+ export declare function once(event: 'success', listener: (action: string, params: any[], context: Context, result: ReturnsBody) => void): void;
37
+ export declare function once(event: 'fail', listener: (action: string, params: any[], context: Context, error: Error) => void): void;
38
+ export declare function once(event: 'log', listener: (context: Context, tag: string, msgs: any[]) => void): void;
39
+ export declare function once(event: string, listener: (...args: any[]) => void): void;
40
+ export declare function off(event: 'app:configured' | 'app:served' | 'app:stopped' | 'request' | 'success' | 'fail' | 'log', listener: (...args: any[]) => void): void;
41
+ export declare function off(event: string, listener: (...args: any[]) => void): void;
42
+ export declare function emit(event: string, ...args: any[]): boolean;
43
+ /**
44
+ * Call an Function on RPC server
45
+ * @param action
46
+ * @param params
47
+ * @param context
48
+ * @returns
49
+ */
50
+ export declare function call(action: string, params: any[], context: Context): Promise<ReturnsBody>;
51
+ export declare function execute(action: string, params: Array<any>, context: Context): Promise<any>;
@@ -0,0 +1,8 @@
1
+ export declare function getAllEnvArgs(): {
2
+ [x: string]: any;
3
+ };
4
+ export declare function getEnvArgs(names: string[]): {
5
+ [x: string]: any;
6
+ };
7
+ export declare function getEnvArg(name: string): any;
8
+ export declare function parseEnvArg(value: string): any;
@@ -0,0 +1,4 @@
1
+ #! /usr/bin/env node
2
+ import { startup } from './starter';
3
+ export declare const version: string;
4
+ export { startup };
@@ -0,0 +1,3 @@
1
+ export declare function configure(mergeEnv?: {
2
+ [x: string]: any;
3
+ }): Promise<any>;
@@ -0,0 +1 @@
1
+ export declare function proxyGroup(groupDirectory: string, excludes?: any[]): void;
@@ -0,0 +1 @@
1
+ export declare function registry(urls: string | string[]): Promise<void>;
@@ -0,0 +1,3 @@
1
+ export declare function startup(env?: {
2
+ [x: string]: any;
3
+ }, entryFilename?: string): Promise<void>;
@@ -0,0 +1,76 @@
1
+ /// <reference types="node" />
2
+ import * as app from './app';
3
+ import Module, { ModuleConfig } from './modules/module';
4
+ import Modules from './modules';
5
+ export { ReturnsBody } from './app';
6
+ export { Module, ModuleConfig };
7
+ export declare const modules: Modules;
8
+ export declare const asyncStore: import("async_hooks").AsyncLocalStorage<app.Context>, setMethods: typeof app.setMethods, getMethods: typeof app.getMethods, kvMethods: Map<string, Function>, sourceKVMethods: Map<string, Function>, call: typeof app.call, execute: typeof app.execute, logger: typeof app.logger, on: typeof app.on, once: typeof app.once, off: typeof app.off, emit: typeof app.emit;
9
+ export declare class Context extends app.Context {
10
+ sourceIP: string;
11
+ ip: string;
12
+ caller: string;
13
+ callerId: string;
14
+ connection?: RPCKeepAliveConnection;
15
+ toJSON?(): {} & this;
16
+ }
17
+ export declare class Config {
18
+ [x: string]: any;
19
+ name: string;
20
+ entryFile: {
21
+ path: string;
22
+ group: string;
23
+ };
24
+ host: string;
25
+ port: number;
26
+ origin: string;
27
+ }
28
+ export declare const config: Config;
29
+ export declare function setGenTraceIdFunction(fn: () => string): void;
30
+ /**
31
+ * 生成随机不重复id
32
+ */
33
+ export declare function genTraceId(): string;
34
+ /**
35
+ * 获取链路跟踪上下文
36
+ */
37
+ export declare function genContext(context?: Context): Context;
38
+ export declare function getContext(): Context;
39
+ export declare function serve(): Promise<void>;
40
+ export declare function stop(): Promise<void>;
41
+ export interface RPCConnectionAdapter {
42
+ rpc(connection: any, action: string, params: any[], context: Context): Promise<any>;
43
+ }
44
+ export interface RPCKeepAliveConnectionData {
45
+ /**
46
+ * 是否连接成功
47
+ */
48
+ connected: boolean;
49
+ /**
50
+ * 连接主机地址
51
+ */
52
+ host: string;
53
+ /**
54
+ * 连接服务名称
55
+ */
56
+ name: string;
57
+ /**
58
+ * 目标服务网络唯一ID
59
+ */
60
+ id: string;
61
+ }
62
+ export declare class RPCKeepAliveConnection {
63
+ data: RPCKeepAliveConnectionData;
64
+ nativeConnection: any;
65
+ adapter: RPCConnectionAdapter;
66
+ constructor(adapter: RPCConnectionAdapter, nativeConnection: any, data?: RPCKeepAliveConnectionData);
67
+ }
68
+ export declare const keepAliveConnections: Map<string, Map<string, RPCKeepAliveConnection>>;
69
+ export declare function getKeepAliveConnections(name: string): Map<string, RPCKeepAliveConnection>;
70
+ export declare function getKeepAliveConnection(name: string, id: string): RPCKeepAliveConnection | null;
71
+ export declare function addKeepAliveConnection(connection: RPCKeepAliveConnection): void;
72
+ export declare function removeKeepAliveConnection(connection: RPCKeepAliveConnection): void;
73
+ export declare function removeKeepAliveConnection(name: string, id: string): void;
74
+ export declare function setLoadBalancePolicy(policy: (name: string) => RPCKeepAliveConnection): void;
75
+ export declare function rpc(appName: string, action: string, params: any[], context?: Context): Promise<any>;
76
+ export declare function rpc(connection: RPCKeepAliveConnection, action: string, params: any[], context?: Context): Promise<any>;
@@ -0,0 +1,4 @@
1
+ export declare function info(...msgs: any[]): void;
2
+ export declare function warn(...msgs: any[]): void;
3
+ export declare function error(...msgs: any[]): void;
4
+ export declare function trace(name?: string): void;
@@ -0,0 +1,47 @@
1
+ /// <reference types="node" />
2
+ import * as http from 'node:http';
3
+ import * as oox from '../../index';
4
+ import Module, { ModuleConfig } from '../module';
5
+ export declare class HTTPConfig extends ModuleConfig {
6
+ port: number;
7
+ path: string;
8
+ origin: string;
9
+ }
10
+ export default class HTTPModule extends Module {
11
+ name: string;
12
+ config: HTTPConfig;
13
+ server: http.Server;
14
+ setConfig(config: HTTPConfig): void;
15
+ getConfig(): HTTPConfig;
16
+ /**
17
+ * start http service
18
+ */
19
+ serve(): Promise<void>;
20
+ /**
21
+ * stop http service
22
+ */
23
+ stop(): Promise<void>;
24
+ /**
25
+ * browser cross origin
26
+ */
27
+ cors(request: http.IncomingMessage, response: http.ServerResponse): boolean;
28
+ /**
29
+ * HTTP-RPC服务器请求监听方法
30
+ */
31
+ call(request: http.IncomingMessage, response: http.ServerResponse): Promise<void>;
32
+ /**
33
+ * HTTP Response Catch
34
+ */
35
+ respond(request: http.IncomingMessage, response: http.ServerResponse, format: {
36
+ body?: any;
37
+ success: boolean;
38
+ error?: {
39
+ message: any;
40
+ stack: any;
41
+ };
42
+ }): void;
43
+ /**
44
+ * HTTP RPC
45
+ */
46
+ rpc(url: string | URL, action: string, params: Array<any>, context?: oox.Context): Promise<any>;
47
+ }
@@ -0,0 +1,17 @@
1
+ /// <reference types="node" />
2
+ /// <reference types="node" />
3
+ /// <reference types="node" />
4
+ import * as http from 'node:http';
5
+ import { Readable } from 'node:stream';
6
+ /**
7
+ * Stream => Buffer
8
+ */
9
+ export declare function stream2buffer(stream: Readable, totalLength?: number): Promise<Buffer>;
10
+ /**
11
+ * Request => JSONObject
12
+ */
13
+ export declare function parseHTTPBody(request: http.IncomingMessage): Promise<any>;
14
+ /**
15
+ * http request
16
+ */
17
+ export declare function httpRequest(url: URL | string, options: http.RequestOptions, body: string): Promise<any>;
@@ -0,0 +1,24 @@
1
+ import Module from './module';
2
+ import HTTP from './http';
3
+ import SocketIO from './socketio';
4
+ export default class Modules extends Module {
5
+ #private;
6
+ /**
7
+ * the module unique name
8
+ */
9
+ name: string;
10
+ /**
11
+ * all builtin modules
12
+ */
13
+ builtins: {
14
+ http: HTTP;
15
+ socketio: SocketIO;
16
+ };
17
+ constructor();
18
+ add(module: Module): this;
19
+ get(name: string): Module;
20
+ remove(name: string): Promise<void>;
21
+ setConfig(config: any): void;
22
+ serve(): Promise<void>;
23
+ stop(): Promise<void>;
24
+ }
@@ -0,0 +1,13 @@
1
+ export declare class ModuleConfig {
2
+ [x: string]: any;
3
+ disabled: boolean;
4
+ }
5
+ export default class Module {
6
+ [x: string]: any;
7
+ config: ModuleConfig;
8
+ name: string;
9
+ setConfig(config: any): void;
10
+ getConfig(): ModuleConfig;
11
+ serve(): Promise<void>;
12
+ stop(): Promise<void>;
13
+ }
@@ -0,0 +1,23 @@
1
+ import { ClientSocket as Socket } from './socket';
2
+ import SocketIOServer from './server';
3
+ export default class SocketIOCore extends SocketIOServer {
4
+ /**
5
+ * connect to <SocketIO RPC> service
6
+ */
7
+ connect(url: string): Promise<Socket>;
8
+ /**
9
+ * 客户端Socket连接事件
10
+ */
11
+ clientOnSocketConnection(socket: Socket): void;
12
+ clientOnDisconnect(socket: Socket, reason: any): void;
13
+ clientOnConnection(socket: Socket): void;
14
+ /**
15
+ * 客户端Socket断开事件
16
+ * @param {Socket} socket
17
+ */
18
+ clientOnSocketDisconnect(socket: Socket, reason: any): void;
19
+ /**
20
+ * 等待socket连接
21
+ */
22
+ clientWaitConnection(socket: Socket): Promise<void>;
23
+ }