1 | ;
|
2 |
|
3 | var _toConsumableArray2 = require('babel-runtime/helpers/toConsumableArray');
|
4 |
|
5 | var _toConsumableArray3 = _interopRequireDefault(_toConsumableArray2);
|
6 |
|
7 | var _slicedToArray2 = require('babel-runtime/helpers/slicedToArray');
|
8 |
|
9 | var _slicedToArray3 = _interopRequireDefault(_slicedToArray2);
|
10 |
|
11 | var _classCallCheck2 = require('babel-runtime/helpers/classCallCheck');
|
12 |
|
13 | var _classCallCheck3 = _interopRequireDefault(_classCallCheck2);
|
14 |
|
15 | var _createClass2 = require('babel-runtime/helpers/createClass');
|
16 |
|
17 | var _createClass3 = _interopRequireDefault(_createClass2);
|
18 |
|
19 | function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
20 |
|
21 | var Promise = require('bluebird');
|
22 | var _ = 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 |
|
32 | var 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 |
|
188 | module.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 |