@lskjs/server
Version:
LSK server.
138 lines (103 loc) • 14 kB
JavaScript
;
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = _default;
var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
var _dns = _interopRequireDefault(require("dns"));
var _socket = _interopRequireDefault(require("socket.io-redis"));
var _bluebird = _interopRequireDefault(require("bluebird"));
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0, _defineProperty2["default"])(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
var dnsLookup = _bluebird["default"].promisify(_dns["default"].lookup);
function _default() {
return _ref.apply(this, arguments);
}
function _ref() {
_ref = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee() {
var _this = this;
var pubClient, subClient, DEBUG, reconnectTime, pubAddress, subAddress;
return _regenerator["default"].wrap(function _callee$(_context) {
while (1) {
switch (_context.prev = _context.next) {
case 0:
return _context.abrupt("return", false);
case 6:
pubAddress = _context.sent;
DEBUG && console.log("pub redis address ".concat(pubAddress), "instance ".concat(__INSTANCE)); //eslint-disable-line
_context.next = 10;
return new _bluebird["default"](function (resolve) {
DEBUG && console.log('pub config', "instance ".concat(__INSTANCE), _this.config.redis); //eslint-disable-line
pubClient = redis.createClient(_objectSpread(_objectSpread({}, _this.config.redis), {}, {
retry_strategy: function retry_strategy(options) {
DEBUG && console.log('pub error', "instance ".concat(__INSTANCE), options); //eslint-disable-line
if (!options.error) {
DEBUG && console.log('redis упал (pub), надо перезапуститься без него'); //eslint-disable-line
process.exit(1);
} else if (options.error && ['EHOSTUNREACH', 'ECONNREFUSED'].includes(options.error.code)) {
DEBUG && console.log("try reconnect pub after ".concat(reconnectTime)); //eslint-disable-line
return 5000;
}
return undefined;
}
}));
pubClient.on('connect', function () {
DEBUG && console.log('pub connected'); //eslint-disable-line
resolve();
});
});
case 10:
_context.next = 12;
return _bluebird["default"].delay(1000);
case 12:
_context.next = 14;
return _dns["default"].lookup(this.config.redis.host);
case 14:
subAddress = _context.sent;
DEBUG && console.log("sub redis address ".concat(subAddress), "instance ".concat(__INSTANCE)); //eslint-disable-line
_context.next = 18;
return new _bluebird["default"](function (resolve) {
DEBUG && console.log('sub config', "instance ".concat(__INSTANCE), _this.config.redis); //eslint-disable-line
subClient = redis.createClient(_objectSpread(_objectSpread({}, _this.config.redis), {}, {
retry_strategy: function retry_strategy(options) {
DEBUG && console.log('sub error', "instance ".concat(__INSTANCE), options); //eslint-disable-line
if (!options.error) {
DEBUG && console.log('redis упал (sub), надо перезапуститься без него'); //eslint-disable-line
process.exit(1);
} else if (options.error && ['EHOSTUNREACH', 'ECONNREFUSED'].includes(options.error.code)) {
DEBUG && console.log("try reconnect sub after ".concat(reconnectTime)); //eslint-disable-line
return 5000;
}
return undefined;
}
}));
subClient.on('connect', function () {
DEBUG && console.log('sub connected'); //eslint-disable-line
resolve();
});
});
case 18:
this.ws.adapter((0, _socket["default"])({
pubClient: pubClient,
subClient: subClient
}));
_context.next = 24;
break;
case 21:
_context.prev = 21;
_context.t0 = _context["catch"](3);
DEBUG && console.log('redis err', _context.t0); //eslint-disable-line
case 24:
case "end":
return _context.stop();
}
}
}, _callee, this, [[3, 21]]);
}));
return _ref.apply(this, arguments);
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/methods/runRedis.js"],"names":["dnsLookup","Promise","promisify","dns","lookup","pubAddress","DEBUG","console","log","__INSTANCE","resolve","config","redis","pubClient","createClient","retry_strategy","options","error","process","exit","includes","code","reconnectTime","undefined","on","delay","host","subAddress","subClient","ws","adapter"],"mappings":"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","sourcesContent":["import dns from 'dns';\nimport redisAdapter from 'socket.io-redis';\n// import redis from 'redis';\nimport Promise from 'bluebird';\n\nconst dnsLookup = Promise.promisify(dns.lookup);\n\nexport default async function () {\n  return false\n  let pubClient;\n  let subClient;\n  const DEBUG = this.config.redis.debug;\n  const reconnectTime = 5000;\n  try {\n    const pubAddress = await dnsLookup(this.config.redis.host);\n      DEBUG && console.log(`pub redis address ${pubAddress}`, `instance ${__INSTANCE}`);  //eslint-disable-line\n    await new Promise((resolve) => {\n        DEBUG && console.log('pub config', `instance ${__INSTANCE}`, this.config.redis);  //eslint-disable-line\n      pubClient = redis.createClient({\n        ...this.config.redis,\n        retry_strategy: (options) => {\n            DEBUG && console.log('pub error', `instance ${__INSTANCE}`, options);  //eslint-disable-line\n          if (!options.error) {\n              DEBUG && console.log('redis упал (pub), надо перезапуститься без него');  //eslint-disable-line\n            process.exit(1);\n          } else if (options.error && ['EHOSTUNREACH', 'ECONNREFUSED'].includes(options.error.code)) {\n              DEBUG && console.log(`try reconnect pub after ${reconnectTime}`);  //eslint-disable-line\n            return 5000;\n          }\n          return undefined;\n        },\n      });\n      pubClient.on('connect', () => {\n          DEBUG && console.log('pub connected');  //eslint-disable-line\n        resolve();\n      });\n    });\n    await Promise.delay(1000);\n    const subAddress = await dns.lookup(this.config.redis.host);\n      DEBUG && console.log(`sub redis address ${subAddress}`, `instance ${__INSTANCE}`);  //eslint-disable-line\n    await new Promise((resolve) => {\n        DEBUG && console.log('sub config', `instance ${__INSTANCE}`, this.config.redis);  //eslint-disable-line\n      subClient = redis.createClient({\n        ...this.config.redis,\n        retry_strategy: (options) => {\n            DEBUG && console.log('sub error', `instance ${__INSTANCE}`, options);  //eslint-disable-line\n          if (!options.error) {\n              DEBUG && console.log('redis упал (sub), надо перезапуститься без него');  //eslint-disable-line\n            process.exit(1);\n          } else if (options.error && ['EHOSTUNREACH', 'ECONNREFUSED'].includes(options.error.code)) {\n              DEBUG && console.log(`try reconnect sub after ${reconnectTime}`);  //eslint-disable-line\n            return 5000;\n          }\n          return undefined;\n        },\n      });\n      subClient.on('connect', () => {\n          DEBUG && console.log('sub connected');  //eslint-disable-line\n        resolve();\n      });\n    });\n    this.ws.adapter(redisAdapter({ pubClient, subClient }));\n  } catch (err) {\n      DEBUG && console.log('redis err', err);  //eslint-disable-line\n  }\n}\n"]}
//# sourceMappingURL=runRedis.js.map