UNPKG

14.6 kBJavaScriptView Raw
1'use strict';
2
3var _toConsumableArray2 = require('babel-runtime/helpers/toConsumableArray');
4
5var _toConsumableArray3 = _interopRequireDefault(_toConsumableArray2);
6
7var _slicedToArray2 = require('babel-runtime/helpers/slicedToArray');
8
9var _slicedToArray3 = _interopRequireDefault(_slicedToArray2);
10
11var _classCallCheck2 = require('babel-runtime/helpers/classCallCheck');
12
13var _classCallCheck3 = _interopRequireDefault(_classCallCheck2);
14
15var _createClass2 = require('babel-runtime/helpers/createClass');
16
17var _createClass3 = _interopRequireDefault(_createClass2);
18
19function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
20
21var Promise = require('bluebird');
22var _ = require('lodash');
23
24/**
25 * Service infrastructure failures recovery.
26 *
27 * @mixin
28 * @memberof chat-service
29 * @see chat-service.ChatService.event:storeConsistencyFailure
30 */
31
32var RecoveryAPI = function () {
33 function RecoveryAPI(state, transport, execUserCommand, instanceUID) {
34 (0, _classCallCheck3.default)(this, RecoveryAPI);
35
36 this.state = state;
37 this.transport = transport;
38 this.instanceUID = instanceUID;
39 this.execUserCommand = execUserCommand;
40 }
41
42 (0, _createClass3.default)(RecoveryAPI, [{
43 key: 'checkUserSockets',
44 value: function checkUserSockets(user) {
45 var _this = this;
46
47 var userName = user.userName;
48
49 return user.userState.getSocketsToInstance().then(function (sockets) {
50 return Promise.each(_.toPairs(sockets), function (_ref) {
51 var _ref2 = (0, _slicedToArray3.default)(_ref, 2);
52
53 var socket = _ref2[0];
54 var instance = _ref2[1];
55
56 if (instance === _this.instanceUID) {
57 if (!_this.transport.getSocket(socket)) {
58 return user.userState.removeSocket(socket);
59 }
60 }
61 return Promise.resolve();
62 });
63 }).then(function () {
64 return user.userState.getSocketsToRooms();
65 }).then(function (data) {
66 var args = _.values(data);
67 return _.intersection.apply(_, (0, _toConsumableArray3.default)(args));
68 }).then(function (rooms) {
69 return Promise.each(rooms, function (roomName) {
70 return _this.state.getRoom(roomName).then(function (room) {
71 return room.roomState.hasInList('userlist', userName);
72 }).then(function (isPresent) {
73 return isPresent ? Promise.resolve() : user.removeFromRoom(roomName);
74 }).catchReturn();
75 });
76 });
77 }
78 }, {
79 key: 'checkRoomJoined',
80 value: function checkRoomJoined(room) {
81 var _this2 = this;
82
83 var roomName = room.roomName;
84
85 return room.getList(null, 'userlist', true).then(function (userlist) {
86 return Promise.each(userlist, function (userName) {
87 return _this2.state.getUser(userName).then(function (user) {
88 return user.userState.getRoomToSockets(roomName).then(function (sockets) {
89 if (!sockets || !sockets.length) {
90 return user.removeFromRoom(roomName);
91 } else {
92 return Promise.resolve();
93 }
94 }).catchReturn().then(function () {
95 return room.checkAcess(userName);
96 }).catch(function () {
97 return user.removeFromRoom(roomName);
98 });
99 }).catchReturn();
100 });
101 });
102 }
103
104 /**
105 * Sync user to sockets associations.
106 *
107 * @param {string} userName User name.
108 * @param {callback} [cb] Optional callback.
109 *
110 * @return {Promise<undefined>} Promise that resolves without any data.
111 */
112
113 }, {
114 key: 'userStateSync',
115 value: function userStateSync(userName, cb) {
116 var _this3 = this;
117
118 return this.state.getUser(userName).then(function (user) {
119 return _this3.checkUserSockets(user);
120 }).asCallback(cb);
121 }
122
123 /**
124 * Sync room to users associations.
125 *
126 * @param {string} roomName Room name.
127 * @param {callback} [cb] Optional callback.
128 *
129 * @return {Promise<undefined>} Promise that resolves without any data.
130 */
131
132 }, {
133 key: 'roomStateSync',
134 value: function roomStateSync(roomName, cb) {
135 var _this4 = this;
136
137 return this.state.getRoom(roomName).then(function (room) {
138 return _this4.checkRoomJoined(room);
139 }).asCallback(cb);
140 }
141
142 /**
143 * Fixes an instance data after an incorrect service shutdown.
144 *
145 * @param {string} id Instance id.
146 * @param {callback} [cb] Optional callback.
147 *
148 * @return {Promise<undefined>} Promise that resolves without any data.
149 */
150
151 }, {
152 key: 'instanceRecovery',
153 value: function instanceRecovery(id, cb) {
154 var _this5 = this;
155
156 return this.state.getInstanceSockets(id).then(function (sockets) {
157 return Promise.each(_.toPairs(sockets), function (_ref3) {
158 var _ref4 = (0, _slicedToArray3.default)(_ref3, 2);
159
160 var id = _ref4[0];
161 var userName = _ref4[1];
162
163 return _this5.state.getUser(userName).then(function (user) {
164 return user.removeSocket(id);
165 }).catchReturn();
166 });
167 }).asCallback(cb);
168 }
169
170 /**
171 * Gets an instance heartbeat.
172 *
173 * @param {string} id Instance id.
174 * @param {callback} [cb] Optional callback.
175 *
176 * @return {Promise<number>} Heartbeat timestamp.
177 */
178
179 }, {
180 key: 'getInstanceHeartbeat',
181 value: function getInstanceHeartbeat(id, cb) {
182 return this.state.getInstanceHeartbeat(id).asCallback(cb);
183 }
184 }]);
185 return RecoveryAPI;
186}();
187
188module.exports = RecoveryAPI;
189//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/RecoveryAPI.js"],"names":[],"mappings":"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","file":"RecoveryAPI.js","sourcesContent":["'use strict'\n\nconst Promise = require('bluebird')\nconst _ = require('lodash')\n\n/**\n * Service infrastructure failures recovery.\n *\n * @mixin\n * @memberof chat-service\n * @see chat-service.ChatService.event:storeConsistencyFailure\n */\nclass RecoveryAPI {\n\n  constructor (state, transport, execUserCommand, instanceUID) {\n    this.state = state\n    this.transport = transport\n    this.instanceUID = instanceUID\n    this.execUserCommand = execUserCommand\n  }\n\n  checkUserSockets (user) {\n    let { userName } = user\n    return user.userState.getSocketsToInstance().then(sockets => {\n      return Promise.each(_.toPairs(sockets), ([socket, instance]) => {\n        if (instance === this.instanceUID) {\n          if (!this.transport.getSocket(socket)) {\n            return user.userState.removeSocket(socket)\n          }\n        }\n        return Promise.resolve()\n      })\n    }).then(() => {\n      return user.userState.getSocketsToRooms()\n    }).then(data => {\n      let args = _.values(data)\n      return _.intersection(...args)\n    }).then(rooms => {\n      return Promise.each(rooms, roomName => {\n        return this.state.getRoom(roomName)\n          .then(room => room.roomState.hasInList('userlist', userName))\n          .then(isPresent =>\n                isPresent ? Promise.resolve() : user.removeFromRoom(roomName))\n          .catchReturn()\n      })\n    })\n  }\n\n  checkRoomJoined (room) {\n    let { roomName } = room\n    return room.getList(null, 'userlist', true).then(userlist => {\n      return Promise.each(userlist, userName => {\n        return this.state.getUser(userName).then(user => {\n          return user.userState.getRoomToSockets(roomName).then(sockets => {\n            if (!sockets || !sockets.length) {\n              return user.removeFromRoom(roomName)\n            } else {\n              return Promise.resolve()\n            }\n          }).catchReturn()\n            .then(() => room.checkAcess(userName))\n            .catch(() => user.removeFromRoom(roomName))\n        }).catchReturn()\n      })\n    })\n  }\n\n  /**\n   * Sync user to sockets associations.\n   *\n   * @param {string} userName User name.\n   * @param {callback} [cb] Optional callback.\n   *\n   * @return {Promise<undefined>} Promise that resolves without any data.\n   */\n  userStateSync (userName, cb) {\n    return this.state.getUser(userName)\n      .then(user => this.checkUserSockets(user))\n      .asCallback(cb)\n  }\n\n  /**\n   * Sync room to users associations.\n   *\n   * @param {string} roomName Room name.\n   * @param {callback} [cb] Optional callback.\n   *\n   * @return {Promise<undefined>} Promise that resolves without any data.\n   */\n  roomStateSync (roomName, cb) {\n    return this.state.getRoom(roomName)\n      .then(room => this.checkRoomJoined(room))\n      .asCallback(cb)\n  }\n\n  /**\n   * Fixes an instance data after an incorrect service shutdown.\n   *\n   * @param {string} id Instance id.\n   * @param {callback} [cb] Optional callback.\n   *\n   * @return {Promise<undefined>} Promise that resolves without any data.\n   */\n  instanceRecovery (id, cb) {\n    return this.state.getInstanceSockets(id).then(sockets => {\n      return Promise.each(_.toPairs(sockets), ([id, userName]) => {\n        return this.state.getUser(userName)\n          .then(user => user.removeSocket(id))\n          .catchReturn()\n      })\n    }).asCallback(cb)\n  }\n\n  /**\n   * Gets an instance heartbeat.\n   *\n   * @param {string} id Instance id.\n   * @param {callback} [cb] Optional callback.\n   *\n   * @return {Promise<number>} Heartbeat timestamp.\n   */\n  getInstanceHeartbeat (id, cb) {\n    return this.state.getInstanceHeartbeat(id).asCallback(cb)\n  }\n\n}\n\nmodule.exports = RecoveryAPI\n"]}
\No newline at end of file