UNPKG

@lskjs/server

Version:

LSK server.

138 lines (103 loc) 14 kB
"use strict"; 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