melo-example-robot 1.7.6

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/dist/app.js ADDED
@@ -0,0 +1,33 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ let envConfig = require('./app/config/env.json');
4
+ let config = require('./app/config/' + envConfig.env + '/config');
5
+ const melo_robot_1 = require("@bigtyphoon/melo-robot");
6
+ const fs = require("fs");
7
+ let robot = new melo_robot_1.Robot(config);
8
+ let mode = 'master';
9
+ if (process.argv.length > 2) {
10
+ mode = process.argv[2];
11
+ }
12
+ if (mode !== 'master' && mode !== 'client') {
13
+ throw new Error(' mode must be master or client');
14
+ }
15
+ if (mode === 'master') {
16
+ robot.runMaster(__filename);
17
+ }
18
+ else {
19
+ let script = (process.cwd() + envConfig.script);
20
+ script = script.replace(/\\/g, '/');
21
+ robot.runAgent(script);
22
+ }
23
+ process.on('uncaughtException', function (err) {
24
+ /* temporary code */
25
+ console.error(' Caught exception: ' + err.stack);
26
+ if (!!robot && !!robot.agent) {
27
+ // robot.agent.socket.emit('crash', err.stack);
28
+ }
29
+ fs.appendFile('./log/.log', err.stack, function (err) {
30
+ });
31
+ /* temporary code */
32
+ });
33
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBwLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vYXBwLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsSUFBSSxTQUFTLEdBQUcsT0FBTyxDQUFDLHVCQUF1QixDQUFDLENBQUM7QUFDakQsSUFBSSxNQUFNLEdBQUcsT0FBTyxDQUFDLGVBQWUsR0FBRyxTQUFTLENBQUMsR0FBRyxHQUFHLFNBQVMsQ0FBQyxDQUFDO0FBQ2xFLHVEQUErQztBQUMvQyx5QkFBMEI7QUFFMUIsSUFBSSxLQUFLLEdBQUcsSUFBSSxrQkFBSyxDQUFDLE1BQU0sQ0FBQyxDQUFDO0FBQzlCLElBQUksSUFBSSxHQUFHLFFBQVEsQ0FBQztBQUVwQixJQUFJLE9BQU8sQ0FBQyxJQUFJLENBQUMsTUFBTSxHQUFHLENBQUMsRUFBRTtJQUN6QixJQUFJLEdBQUcsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQztDQUMxQjtBQUVELElBQUksSUFBSSxLQUFLLFFBQVEsSUFBSSxJQUFJLEtBQUssUUFBUSxFQUFFO0lBQ3hDLE1BQU0sSUFBSSxLQUFLLENBQUMsZ0NBQWdDLENBQUMsQ0FBQztDQUNyRDtBQUVELElBQUksSUFBSSxLQUFLLFFBQVEsRUFBRTtJQUNuQixLQUFLLENBQUMsU0FBUyxDQUFDLFVBQVUsQ0FBQyxDQUFDO0NBQy9CO0tBQU07SUFDSCxJQUFJLE1BQU0sR0FBRyxDQUFDLE9BQU8sQ0FBQyxHQUFHLEVBQUUsR0FBRyxTQUFTLENBQUMsTUFBTSxDQUFDLENBQUM7SUFDaEQsTUFBTSxHQUFHLE1BQU0sQ0FBQyxPQUFPLENBQUMsS0FBSyxFQUFFLEdBQUcsQ0FBQyxDQUFDO0lBQ3BDLEtBQUssQ0FBQyxRQUFRLENBQUMsTUFBTSxDQUFDLENBQUM7Q0FDMUI7QUFFRCxPQUFPLENBQUMsRUFBRSxDQUFDLG1CQUFtQixFQUFFLFVBQVUsR0FBRztJQUN6QyxvQkFBb0I7SUFDcEIsT0FBTyxDQUFDLEtBQUssQ0FBQyxxQkFBcUIsR0FBRyxHQUFHLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDakQsSUFBSSxDQUFDLENBQUMsS0FBSyxJQUFJLENBQUMsQ0FBQyxLQUFLLENBQUMsS0FBSyxFQUFFO1FBQzFCLCtDQUErQztLQUNsRDtJQUNELEVBQUUsQ0FBQyxVQUFVLENBQUMsWUFBWSxFQUFFLEdBQUcsQ0FBQyxLQUFLLEVBQUUsVUFBVSxHQUFHO0lBQ3BELENBQUMsQ0FBQyxDQUFDO0lBQ0gsb0JBQW9CO0FBQ3hCLENBQUMsQ0FBQyxDQUFDIn0=
package/dist/http.js ADDED
@@ -0,0 +1,66 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const cluster_1 = require("cluster");
4
+ const http = require("http");
5
+ let envConfig = require('./app/config/env.json');
6
+ let config = require('./app/config/' + envConfig.env + '/config');
7
+ let path = __filename.substring(0, __filename.lastIndexOf('/'));
8
+ const melo_robot_1 = require("@bigtyphoon/melo-robot");
9
+ let robot = new melo_robot_1.Robot(config);
10
+ function run(num) {
11
+ for (let i = 0; i < num; i++) {
12
+ cluster_1.default.fork();
13
+ }
14
+ }
15
+ function stop() {
16
+ for (let id in cluster_1.default.workers) {
17
+ cluster_1.default.workers[id].process.kill();
18
+ }
19
+ }
20
+ function startHttp() {
21
+ http.createServer(function (req, res) {
22
+ if (req.method === 'GET') {
23
+ let url = require('url').parse(req.url, true);
24
+ if (url.pathname === '/') {
25
+ return res.end(JSON.stringify(config) + '\n');
26
+ }
27
+ else if (url.pathname === '/set') {
28
+ for (let key in url.query) {
29
+ config['apps'][key] = (typeof config[key] === 'number') ? +url.query[key] : url.query[key];
30
+ }
31
+ return res.end(JSON.stringify(config) + '\n');
32
+ }
33
+ else if (url.pathname === '/restart') {
34
+ require('child_process').exec('sudo restart client', function () { });
35
+ return res.end('OK\n');
36
+ }
37
+ else if (url.pathname === '/pull') {
38
+ require('child_process').exec('cd /home/ubuntu/hello && git pull ', function () { });
39
+ return res.end('OK\n');
40
+ }
41
+ else if (url.pathname === '/stop') {
42
+ setTimeout(function () { stop(); }, 1000);
43
+ return res.end('HTTP SERVER CLOSE OK\n');
44
+ }
45
+ else if (url.pathname === '/start') {
46
+ let num = url.query['num'] || 1;
47
+ run(num);
48
+ return res.end('OK\n' + num);
49
+ }
50
+ }
51
+ res.writeHead(404);
52
+ res.end('<h1>404<h1>\n');
53
+ }).listen(config.master.cwebport);
54
+ console.log(' http server start at http://127.0.0.1:' + config.master.cwebport);
55
+ }
56
+ process.on('uncaughtException', function (err) {
57
+ console.error(' Caught exception: ' + err.stack);
58
+ require('fs').writeFileSync('/tmp/log', err.stack, 'utf8');
59
+ });
60
+ if (cluster_1.default.isMaster) {
61
+ startHttp();
62
+ }
63
+ else {
64
+ robot.runAgent(path + envConfig.script);
65
+ }
66
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaHR0cC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL2h0dHAudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSxxQ0FBOEI7QUFDOUIsNkJBQTZCO0FBQzdCLElBQUksU0FBUyxHQUFHLE9BQU8sQ0FBQyx1QkFBdUIsQ0FBQyxDQUFDO0FBQ2pELElBQUksTUFBTSxHQUFHLE9BQU8sQ0FBQyxlQUFlLEdBQUcsU0FBUyxDQUFDLEdBQUcsR0FBRyxTQUFTLENBQUMsQ0FBQztBQUNsRSxJQUFJLElBQUksR0FBRyxVQUFVLENBQUMsU0FBUyxDQUFDLENBQUMsRUFBRSxVQUFVLENBQUMsV0FBVyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUM7QUFDaEUsdURBQStDO0FBRS9DLElBQUksS0FBSyxHQUFHLElBQUksa0JBQUssQ0FBQyxNQUFNLENBQUMsQ0FBQztBQUU5QixTQUFTLEdBQUcsQ0FBQyxHQUFHO0lBQ1osS0FBSyxJQUFJLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxHQUFHLEdBQUcsRUFBRSxDQUFDLEVBQUUsRUFBRTtRQUMxQixpQkFBTyxDQUFDLElBQUksRUFBRSxDQUFDO0tBQ2xCO0FBQ0wsQ0FBQztBQUVELFNBQVMsSUFBSTtJQUNULEtBQUssSUFBSSxFQUFFLElBQUksaUJBQU8sQ0FBQyxPQUFPLEVBQUU7UUFDNUIsaUJBQU8sQ0FBQyxPQUFPLENBQUMsRUFBRSxDQUFDLENBQUMsT0FBTyxDQUFDLElBQUksRUFBRSxDQUFDO0tBQ3RDO0FBQ0wsQ0FBQztBQUVELFNBQVMsU0FBUztJQUNkLElBQUksQ0FBQyxZQUFZLENBQUMsVUFBVSxHQUFHLEVBQUUsR0FBRztRQUNoQyxJQUFJLEdBQUcsQ0FBQyxNQUFNLEtBQUssS0FBSyxFQUFFO1lBQ3RCLElBQUksR0FBRyxHQUFHLE9BQU8sQ0FBQyxLQUFLLENBQUMsQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLEdBQUcsRUFBRSxJQUFJLENBQUMsQ0FBQztZQUM5QyxJQUFJLEdBQUcsQ0FBQyxRQUFRLEtBQUssR0FBRyxFQUFFO2dCQUN0QixPQUFPLEdBQUcsQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxNQUFNLENBQUMsR0FBRyxJQUFJLENBQUMsQ0FBQzthQUNqRDtpQkFBTSxJQUFJLEdBQUcsQ0FBQyxRQUFRLEtBQUssTUFBTSxFQUFFO2dCQUNoQyxLQUFLLElBQUksR0FBRyxJQUFJLEdBQUcsQ0FBQyxLQUFLLEVBQUU7b0JBQ3ZCLE1BQU0sQ0FBQyxNQUFNLENBQUMsQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFDLE9BQU8sTUFBTSxDQUFDLEdBQUcsQ0FBQyxLQUFLLFFBQVEsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUM7aUJBQzlGO2dCQUNELE9BQU8sR0FBRyxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLE1BQU0sQ0FBQyxHQUFHLElBQUksQ0FBQyxDQUFDO2FBQ2pEO2lCQUFNLElBQUksR0FBRyxDQUFDLFFBQVEsS0FBSyxVQUFVLEVBQUU7Z0JBQ3BDLE9BQU8sQ0FBQyxlQUFlLENBQUMsQ0FBQyxJQUFJLENBQUMscUJBQXFCLEVBQUUsY0FBYyxDQUFDLENBQUMsQ0FBQztnQkFDdEUsT0FBTyxHQUFHLENBQUMsR0FBRyxDQUFDLE1BQU0sQ0FBQyxDQUFDO2FBQzFCO2lCQUFNLElBQUksR0FBRyxDQUFDLFFBQVEsS0FBSyxPQUFPLEVBQUU7Z0JBQ2pDLE9BQU8sQ0FBQyxlQUFlLENBQUMsQ0FBQyxJQUFJLENBQUMsb0NBQW9DLEVBQUUsY0FBYyxDQUFDLENBQUMsQ0FBQztnQkFDckYsT0FBTyxHQUFHLENBQUMsR0FBRyxDQUFDLE1BQU0sQ0FBQyxDQUFDO2FBQzFCO2lCQUFNLElBQUksR0FBRyxDQUFDLFFBQVEsS0FBSyxPQUFPLEVBQUU7Z0JBQ2pDLFVBQVUsQ0FBQyxjQUFjLElBQUksRUFBRSxDQUFDLENBQUMsQ0FBQyxFQUFFLElBQUksQ0FBQyxDQUFDO2dCQUMxQyxPQUFPLEdBQUcsQ0FBQyxHQUFHLENBQUMsd0JBQXdCLENBQUMsQ0FBQzthQUM1QztpQkFBTSxJQUFJLEdBQUcsQ0FBQyxRQUFRLEtBQUssUUFBUSxFQUFFO2dCQUNsQyxJQUFJLEdBQUcsR0FBRyxHQUFHLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQztnQkFDaEMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxDQUFDO2dCQUNULE9BQU8sR0FBRyxDQUFDLEdBQUcsQ0FBQyxNQUFNLEdBQUcsR0FBRyxDQUFDLENBQUM7YUFDaEM7U0FDSjtRQUNELEdBQUcsQ0FBQyxTQUFTLENBQUMsR0FBRyxDQUFDLENBQUM7UUFDbkIsR0FBRyxDQUFDLEdBQUcsQ0FBQyxlQUFlLENBQUMsQ0FBQztJQUM3QixDQUFDLENBQUMsQ0FBQyxNQUFNLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxRQUFRLENBQUMsQ0FBQztJQUNsQyxPQUFPLENBQUMsR0FBRyxDQUFDLHlDQUF5QyxHQUFHLE1BQU0sQ0FBQyxNQUFNLENBQUMsUUFBUSxDQUFDLENBQUM7QUFDcEYsQ0FBQztBQUVELE9BQU8sQ0FBQyxFQUFFLENBQUMsbUJBQW1CLEVBQUUsVUFBVSxHQUFHO0lBQ3pDLE9BQU8sQ0FBQyxLQUFLLENBQUMscUJBQXFCLEdBQUcsR0FBRyxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ2pELE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQyxhQUFhLENBQUMsVUFBVSxFQUFFLEdBQUcsQ0FBQyxLQUFLLEVBQUUsTUFBTSxDQUFDLENBQUM7QUFDL0QsQ0FBQyxDQUFDLENBQUM7QUFFSCxJQUFJLGlCQUFPLENBQUMsUUFBUSxFQUFFO0lBQ2xCLFNBQVMsRUFBRSxDQUFDO0NBQ2Y7S0FBTTtJQUNILEtBQUssQ0FBQyxRQUFRLENBQUMsSUFBSSxHQUFHLFNBQVMsQ0FBQyxNQUFNLENBQUMsQ0FBQztDQUMzQyJ9
@@ -0,0 +1,19 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.cacheClass = void 0;
4
+ const fs = require("fs");
5
+ class CacheClass {
6
+ getCache() {
7
+ try {
8
+ return JSON.parse(fs.readFileSync(__dirname + '/cache.tmp').toString());
9
+ }
10
+ catch (err) {
11
+ return null;
12
+ }
13
+ }
14
+ saveCache(cache) {
15
+ fs.writeFileSync(__dirname + '/cache.tmp', JSON.stringify(cache, null, 4));
16
+ }
17
+ }
18
+ exports.cacheClass = new CacheClass();
19
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FjaGVDbGFzcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL25vZGVqcy10cy1jbGllbnQvY2FjaGVDbGFzcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFDQSx5QkFBeUI7QUFJekIsTUFBTSxVQUFVO0lBQ1osUUFBUTtRQUNKLElBQUc7WUFDQyxPQUFPLElBQUksQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDLFlBQVksQ0FBQyxTQUFTLEdBQUMsWUFBWSxDQUFDLENBQUMsUUFBUSxFQUFFLENBQU8sQ0FBQztTQUMvRTtRQUFBLE9BQU8sR0FBRyxFQUFDO1lBQ1IsT0FBTyxJQUFJLENBQUM7U0FDZjtJQUNMLENBQUM7SUFFRCxTQUFTLENBQUMsS0FBSztRQUNYLEVBQUUsQ0FBQyxhQUFhLENBQUMsU0FBUyxHQUFDLFlBQVksRUFBQyxJQUFJLENBQUMsU0FBUyxDQUFDLEtBQUssRUFBQyxJQUFJLEVBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUMxRSxDQUFDO0NBQ0o7QUFHWSxRQUFBLFVBQVUsR0FBRyxJQUFJLFVBQVUsRUFBRSxDQUFDIn0=
@@ -0,0 +1,396 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.Pomelo = void 0;
4
+ const WebSocket = require("ws");
5
+ const melo_protocol_1 = require("@bigtyphoon/melo-protocol");
6
+ const melo_protobuf_1 = require("@bigtyphoon/melo-protobuf");
7
+ const events_1 = require("events");
8
+ const cacheClass_1 = require("./cacheClass");
9
+ const my_logger_1 = require("./my.logger");
10
+ const JS_WS_CLIENT_TYPE = 'js-ws';
11
+ const JS_WS_CLIENT_VERSION = '0.0.1';
12
+ const RES_OK = 200;
13
+ const RES_OLD_CLIENT = 501;
14
+ const CODE_DICT_ERROR = 502;
15
+ const CODE_PROTOS_ERROR = 503;
16
+ class Pomelo extends events_1.EventEmitter {
17
+ constructor(useNestLogger = true, showPackageLog = true) {
18
+ super();
19
+ this.showPackageLog = showPackageLog;
20
+ this.socket = null;
21
+ this.reqId = 0;
22
+ this.callbacks = {};
23
+ this.handlers = {};
24
+ this.routeMap = {};
25
+ this.protobuf = null;
26
+ this.heartbeatInterval = 5000;
27
+ this.heartbeatTimeout = this.heartbeatInterval * 2;
28
+ this.nextHeartbeatTimeout = 0;
29
+ this.gapThreshold = 100; // heartbeat gap threshold
30
+ this.heartbeatId = null;
31
+ this.heartbeatTimeoutId = null;
32
+ this.handshakeCallback = null;
33
+ this.handshakeBuffer = {
34
+ 'sys': {
35
+ type: JS_WS_CLIENT_TYPE,
36
+ version: JS_WS_CLIENT_VERSION,
37
+ dictVersion: '',
38
+ protoVersion: ''
39
+ },
40
+ 'user': {}
41
+ };
42
+ this.initCallback = null;
43
+ this.params = null;
44
+ this.data = {};
45
+ this.sysCache = null;
46
+ this.handlers[melo_protocol_1.Package.TYPE_HANDSHAKE] = this.handshake.bind(this);
47
+ this.handlers[melo_protocol_1.Package.TYPE_HEARTBEAT] = this.heartbeat.bind(this);
48
+ this.handlers[melo_protocol_1.Package.TYPE_DATA] = this.onData.bind(this);
49
+ this.handlers[melo_protocol_1.Package.TYPE_KICK] = this.onKick.bind(this);
50
+ if (useNestLogger) {
51
+ this.logger = new my_logger_1.MyLogger('wsclient-' + ++Pomelo.ClientId);
52
+ }
53
+ else {
54
+ this.logger = console;
55
+ }
56
+ }
57
+ initAsync(params) {
58
+ return new Promise(resolve => {
59
+ this.params = params;
60
+ params.debug = true;
61
+ this.initCallback = resolve;
62
+ const host = params.host;
63
+ const port = params.port;
64
+ let url = host;
65
+ if (port) {
66
+ url += ':' + port;
67
+ }
68
+ this.sysCache = cacheClass_1.cacheClass.getCache() || {};
69
+ this.handshakeBuffer.sys.dictVersion = this.sysCache.dictVersion || 0;
70
+ this.handshakeBuffer.sys.protoVersion = this.sysCache.protoVersion || 0;
71
+ if (!params.type) {
72
+ this.logger.log('init websocket');
73
+ this.handshakeBuffer.user = params.user;
74
+ this.handshakeCallback = params.handshakeCallback;
75
+ this.initWebSocket(url, resolve);
76
+ }
77
+ });
78
+ }
79
+ init(params, cb) {
80
+ this.params = params;
81
+ params.debug = true;
82
+ this.initCallback = cb;
83
+ const host = params.host;
84
+ const port = params.port;
85
+ let url = 'ws://' + host;
86
+ if (port) {
87
+ url += ':' + port;
88
+ }
89
+ this.sysCache = cacheClass_1.cacheClass.getCache() || {};
90
+ this.handshakeBuffer.sys.dictVersion = this.sysCache.dictVersion || 0;
91
+ this.handshakeBuffer.sys.protoVersion = this.sysCache.protoVersion || 0;
92
+ if (!params.type) {
93
+ this.logger.log('init websocket');
94
+ this.handshakeBuffer.user = params.user;
95
+ this.handshakeCallback = params.handshakeCallback;
96
+ this.initWebSocket(url, cb);
97
+ }
98
+ }
99
+ ;
100
+ initWebSocket(url, cb) {
101
+ this.logger.log(url);
102
+ const onopen = (event) => {
103
+ this.logger.log('[pomeloclient.init] websocket connected!');
104
+ const obj = melo_protocol_1.Package.encode(melo_protocol_1.Package.TYPE_HANDSHAKE, melo_protocol_1.Protocol.strencode(JSON.stringify(this.handshakeBuffer)));
105
+ this.send(obj);
106
+ };
107
+ const onmessage = (event) => {
108
+ if (this.showPackageLog && event.data.byteLength != 4) {
109
+ this.logger.log('recv orgdata', event.data.byteLength, Buffer.from(event.data).toString('hex'));
110
+ }
111
+ this.processPackage(melo_protocol_1.Package.decode(event.data)); //, cb);
112
+ // new package arrived, update the heartbeat timeout
113
+ if (this.heartbeatTimeout) {
114
+ this.nextHeartbeatTimeout = Date.now() + this.heartbeatTimeout;
115
+ }
116
+ };
117
+ const onerror = (event) => {
118
+ this.emit('io-error', event);
119
+ this.logger.log('socket error %j ', event);
120
+ };
121
+ const onclose = (event) => {
122
+ this.emit('close', event);
123
+ this.logger.log('socket close %j ', event);
124
+ };
125
+ this.socket = new WebSocket(url);
126
+ this.socket.binaryType = 'arraybuffer';
127
+ this.socket.onopen = onopen;
128
+ this.socket.onmessage = onmessage;
129
+ this.socket.onerror = onerror;
130
+ this.socket.onclose = onclose;
131
+ }
132
+ ;
133
+ disconnect() {
134
+ if (this.socket) {
135
+ if (this.socket.disconnect)
136
+ this.socket.disconnect();
137
+ if (this.socket.close)
138
+ this.socket.close();
139
+ this.logger.log('disconnect');
140
+ this.socket = null;
141
+ }
142
+ if (this.heartbeatId) {
143
+ clearTimeout(this.heartbeatId);
144
+ this.heartbeatId = null;
145
+ }
146
+ if (this.heartbeatTimeoutId) {
147
+ clearTimeout(this.heartbeatTimeoutId);
148
+ this.heartbeatTimeoutId = null;
149
+ }
150
+ }
151
+ ;
152
+ request(route, msg) {
153
+ return new Promise((resolve, reject) => {
154
+ msg = msg || {};
155
+ route = route || msg.route;
156
+ if (!route) {
157
+ this.logger.log('fail to send request without route.');
158
+ return;
159
+ }
160
+ this.reqId++;
161
+ this.sendMessage(this.reqId, route, msg);
162
+ this.callbacks[this.reqId] = resolve;
163
+ this.routeMap[this.reqId] = route;
164
+ });
165
+ }
166
+ ;
167
+ notify(route, msg) {
168
+ msg = msg || {};
169
+ this.sendMessage(0, route, msg);
170
+ }
171
+ ;
172
+ sendMessage(reqId, route, msg) {
173
+ const type = reqId ? melo_protocol_1.Message.TYPE_REQUEST : melo_protocol_1.Message.TYPE_NOTIFY;
174
+ if (this.showPackageLog) {
175
+ this.logger.log('send', reqId, route, msg);
176
+ }
177
+ //compress message by protobuf
178
+ const protos = !!this.data.protos ? this.data.protos.client : {};
179
+ if (!!protos[route]) {
180
+ msg = this.protobuf.encode(route, msg);
181
+ }
182
+ else {
183
+ msg = melo_protocol_1.Protocol.strencode(JSON.stringify(msg));
184
+ }
185
+ let compressRoute = false;
186
+ if (this.data.dict && this.data.dict[route]) {
187
+ route = this.data.dict[route];
188
+ compressRoute = true;
189
+ }
190
+ msg = melo_protocol_1.Message.encode(reqId, type, compressRoute, route, msg);
191
+ const packet = melo_protocol_1.Package.encode(melo_protocol_1.Package.TYPE_DATA, msg);
192
+ if (this.showPackageLog) {
193
+ this.logger.log('send', "packet", packet.length, packet.toString('hex'));
194
+ }
195
+ this.send(packet);
196
+ }
197
+ ;
198
+ send(packet) {
199
+ if (!!this.socket) {
200
+ this.socket.send(packet.buffer || packet, { binary: true, mask: true });
201
+ }
202
+ }
203
+ ;
204
+ heartbeat(data) {
205
+ const obj = melo_protocol_1.Package.encode(melo_protocol_1.Package.TYPE_HEARTBEAT);
206
+ if (this.heartbeatTimeoutId) {
207
+ clearTimeout(this.heartbeatTimeoutId);
208
+ this.heartbeatTimeoutId = null;
209
+ }
210
+ if (this.heartbeatId) {
211
+ // already in a heartbeat interval
212
+ return;
213
+ }
214
+ this.heartbeatId = setTimeout(() => {
215
+ this.heartbeatId = null;
216
+ this.send(obj);
217
+ this.nextHeartbeatTimeout = Date.now() + this.heartbeatTimeout;
218
+ this.heartbeatTimeoutId = setTimeout(this.heartbeatTimeoutCb.bind(this), this.heartbeatTimeout);
219
+ }, this.heartbeatInterval);
220
+ }
221
+ ;
222
+ heartbeatTimeoutCb() {
223
+ const gap = this.nextHeartbeatTimeout - Date.now();
224
+ if (gap > this.gapThreshold) {
225
+ this.heartbeatTimeoutId = setTimeout(this.heartbeatTimeoutCb.bind(this), gap);
226
+ }
227
+ else {
228
+ this.logger.error('server heartbeat timeout');
229
+ this.emit('heartbeat timeout');
230
+ this.disconnect();
231
+ }
232
+ }
233
+ ;
234
+ handshake(data) {
235
+ data = JSON.parse(melo_protocol_1.Protocol.strdecode(data));
236
+ if (data.code === RES_OLD_CLIENT) {
237
+ this.emit('error', 'client version not fullfill');
238
+ return;
239
+ }
240
+ if (data.code !== RES_OK) {
241
+ this.emit('error', 'handshake fail');
242
+ return;
243
+ }
244
+ this.handshakeInit(data);
245
+ const obj = melo_protocol_1.Package.encode(melo_protocol_1.Package.TYPE_HANDSHAKE_ACK);
246
+ this.send(obj);
247
+ if (this.initCallback) {
248
+ this.initCallback(this.socket);
249
+ this.initCallback = null;
250
+ }
251
+ }
252
+ ;
253
+ onData(data) {
254
+ //probuff decode
255
+ const msg = melo_protocol_1.Message.decode(data);
256
+ if (msg.id > 0) {
257
+ msg.route = this.routeMap[msg.id];
258
+ delete this.routeMap[msg.id];
259
+ if (!msg.route) {
260
+ return;
261
+ }
262
+ }
263
+ msg.body = this.deCompose(msg);
264
+ if (this.showPackageLog) {
265
+ this.logger.log('recv', JSON.stringify(msg), "\n\tpacket", data.length, data.toString('hex'));
266
+ }
267
+ this.processMessage(msg);
268
+ }
269
+ ;
270
+ onKick(data) {
271
+ this.emit('onKick', data.toString());
272
+ }
273
+ ;
274
+ processPackage(msg) {
275
+ if (Array.isArray(msg)) {
276
+ for (let m of msg) {
277
+ this.handlers[m.type](m.body);
278
+ }
279
+ }
280
+ else {
281
+ this.handlers[msg.type](msg.body);
282
+ }
283
+ }
284
+ ;
285
+ processMessage(msg) {
286
+ if (!msg || !msg.id) {
287
+ // server push message
288
+ // this.logger.error('processMessage error!!!');
289
+ this.emit(msg.route, msg.body);
290
+ return;
291
+ }
292
+ //if have a id then find the callback function with the request
293
+ const cb = this.callbacks[msg.id];
294
+ delete this.callbacks[msg.id];
295
+ if (typeof cb !== 'function') {
296
+ return;
297
+ }
298
+ cb(msg.body);
299
+ return;
300
+ }
301
+ ;
302
+ processMessageBatch(pomelo, msgs) {
303
+ for (let i = 0, l = msgs.length; i < l; i++) {
304
+ this.processMessage(msgs[i]);
305
+ }
306
+ }
307
+ ;
308
+ deCompose(msg) {
309
+ const protos = !!this.data.protos ? this.data.protos.server : {};
310
+ const abbrs = this.data.abbrs;
311
+ let route = msg.route;
312
+ try {
313
+ //Decompose route from dict
314
+ if (msg.compressRoute) {
315
+ if (!abbrs[route]) {
316
+ this.logger.error('illegal msg!');
317
+ return {};
318
+ }
319
+ route = msg.route = abbrs[route];
320
+ }
321
+ if (!!protos[route]) {
322
+ return this.protobuf.decode(route, msg.body);
323
+ }
324
+ else {
325
+ return JSON.parse(melo_protocol_1.Protocol.strdecode(msg.body));
326
+ }
327
+ }
328
+ catch (ex) {
329
+ this.logger.error('route, body = ' + route + ", " + msg.body);
330
+ }
331
+ return msg;
332
+ }
333
+ ;
334
+ handshakeInit(data) {
335
+ if (data.sys && data.sys.heartbeat) {
336
+ this.heartbeatInterval = data.sys.heartbeat * 1000; // heartbeat interval
337
+ this.heartbeatTimeout = this.heartbeatInterval * 2; // max heartbeat timeout
338
+ }
339
+ else {
340
+ this.heartbeatInterval = 0;
341
+ this.heartbeatTimeout = 0;
342
+ }
343
+ this.initData(data);
344
+ if (typeof this.handshakeCallback === 'function') {
345
+ this.handshakeCallback(data.user);
346
+ }
347
+ }
348
+ ;
349
+ //Initilize data used in pomelo client
350
+ initData(data) {
351
+ if (!data || !data.sys) {
352
+ return;
353
+ }
354
+ const dictVersion = data.sys.dictVersion;
355
+ const protoVersion = data.sys.protos ? data.sys.protos.version : null;
356
+ let changed = false;
357
+ const dict = data.sys.dict || this.sysCache.dict;
358
+ const protos = data.sys.protos || this.sysCache.protos;
359
+ if (dictVersion) {
360
+ this.sysCache.dict = dict;
361
+ this.sysCache.dictVersion = dictVersion;
362
+ changed = true;
363
+ }
364
+ if (protoVersion) {
365
+ this.sysCache.protos = protos;
366
+ this.sysCache.protoVersion = protoVersion;
367
+ changed = true;
368
+ }
369
+ if (changed) {
370
+ cacheClass_1.cacheClass.saveCache(this.sysCache);
371
+ }
372
+ //Init compress dict
373
+ if (!!dict) {
374
+ this.data.dict = dict;
375
+ this.data.abbrs = {};
376
+ for (const route in dict) {
377
+ this.data.abbrs[dict[route]] = route;
378
+ }
379
+ }
380
+ //Init protobuf protos
381
+ if (!!protos) {
382
+ this.data.protos = {
383
+ server: protos.server || {},
384
+ client: protos.client || {}
385
+ };
386
+ if (!this.protobuf) {
387
+ // 要改WEB JS客户端的话 这里可能需要改一下。
388
+ this.protobuf = new melo_protobuf_1.Protobuf({ encoderProtos: protos.client, decoderProtos: protos.server });
389
+ }
390
+ }
391
+ }
392
+ ;
393
+ }
394
+ exports.Pomelo = Pomelo;
395
+ Pomelo.ClientId = 0;
396
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"client.js","sourceRoot":"","sources":["../../nodejs-ts-client/client.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,59 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.Logger = void 0;
4
+ const clc = require("cli-color");
5
+ class Logger {
6
+ constructor(context, isTimeDiffEnabled = false) {
7
+ this.context = context;
8
+ this.isTimeDiffEnabled = isTimeDiffEnabled;
9
+ }
10
+ log(message) {
11
+ const { logger } = Logger;
12
+ logger.log.call(logger, message, this.context, this.isTimeDiffEnabled);
13
+ }
14
+ error(message, trace = '') {
15
+ const { logger } = Logger;
16
+ logger.error.call(logger, message, trace, this.context, this.isTimeDiffEnabled);
17
+ }
18
+ warn(message) {
19
+ const { logger } = Logger;
20
+ logger.warn.call(logger, message, this.context, this.isTimeDiffEnabled);
21
+ }
22
+ static overrideLogger(logger) {
23
+ this.logger = logger;
24
+ }
25
+ static log(message, context = '', isTimeDiffEnabled = true) {
26
+ this.printMessage(message, clc.green, context, isTimeDiffEnabled);
27
+ }
28
+ static error(message, trace = '', context = '', isTimeDiffEnabled = true) {
29
+ this.printMessage(message, clc.red, context, isTimeDiffEnabled);
30
+ this.printStackTrace(trace);
31
+ }
32
+ static warn(message, context = '', isTimeDiffEnabled = true) {
33
+ this.printMessage(message, clc.yellow, context, isTimeDiffEnabled);
34
+ }
35
+ static printMessage(message, color, context = '', isTimeDiffEnabled) {
36
+ process.stdout.write(color(`${process.pid} - `));
37
+ process.stdout.write(`${new Date().toLocaleString()} `);
38
+ process.stdout.write(this.yellow(`[${context}] `));
39
+ process.stdout.write(color(message));
40
+ this.printTimestamp(isTimeDiffEnabled);
41
+ process.stdout.write(`\n`);
42
+ }
43
+ static printTimestamp(isTimeDiffEnabled) {
44
+ const includeTimestamp = Logger.prevTimestamp && isTimeDiffEnabled;
45
+ if (includeTimestamp) {
46
+ process.stdout.write(this.yellow(` +${Date.now() - Logger.prevTimestamp}ms`));
47
+ }
48
+ Logger.prevTimestamp = Date.now();
49
+ }
50
+ static printStackTrace(trace) {
51
+ process.stdout.write(trace);
52
+ process.stdout.write(`\n`);
53
+ }
54
+ }
55
+ exports.Logger = Logger;
56
+ Logger.prevTimestamp = null;
57
+ Logger.logger = Logger;
58
+ Logger.yellow = clc.xterm(3);
59
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9nZ2VyLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9ub2RlanMtdHMtY2xpZW50L2xvZ2dlci5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLGlDQUFpQztBQVVqQyxNQUFhLE1BQU07SUFNZixZQUNxQixPQUFlLEVBQ2Ysb0JBQW9CLEtBQUs7UUFEekIsWUFBTyxHQUFQLE9BQU8sQ0FBUTtRQUNmLHNCQUFpQixHQUFqQixpQkFBaUIsQ0FBUTtJQUMxQyxDQUFDO0lBRUwsR0FBRyxDQUFDLE9BQWU7UUFDZixNQUFNLEVBQUUsTUFBTSxFQUFFLEdBQUcsTUFBTSxDQUFDO1FBQ3pCLE1BQXdCLENBQUMsR0FBRyxDQUFDLElBQUksQ0FDOUIsTUFBTSxFQUNOLE9BQU8sRUFDUCxJQUFJLENBQUMsT0FBTyxFQUNaLElBQUksQ0FBQyxpQkFBaUIsQ0FDekIsQ0FBQztJQUNOLENBQUM7SUFFRCxLQUFLLENBQUMsT0FBZSxFQUFFLEtBQUssR0FBRyxFQUFFO1FBQzdCLE1BQU0sRUFBRSxNQUFNLEVBQUUsR0FBRyxNQUFNLENBQUM7UUFDekIsTUFBd0IsQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUNoQyxNQUFNLEVBQ04sT0FBTyxFQUNQLEtBQUssRUFDTCxJQUFJLENBQUMsT0FBTyxFQUNaLElBQUksQ0FBQyxpQkFBaUIsQ0FDekIsQ0FBQztJQUNOLENBQUM7SUFFRCxJQUFJLENBQUMsT0FBZTtRQUNoQixNQUFNLEVBQUUsTUFBTSxFQUFFLEdBQUcsTUFBTSxDQUFDO1FBQ3pCLE1BQXdCLENBQUMsSUFBSSxDQUFDLElBQUksQ0FDL0IsTUFBTSxFQUNOLE9BQU8sRUFDUCxJQUFJLENBQUMsT0FBTyxFQUNaLElBQUksQ0FBQyxpQkFBaUIsQ0FDekIsQ0FBQztJQUNOLENBQUM7SUFFRCxNQUFNLENBQUMsY0FBYyxDQUFDLE1BQXFCO1FBQ3ZDLElBQUksQ0FBQyxNQUFNLEdBQUcsTUFBTSxDQUFDO0lBQ3pCLENB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