2017-02-23 02:59:47 +08:00
|
|
|
import { check } from 'meteor/check';
|
2017-10-12 10:00:28 +08:00
|
|
|
import Users from '/imports/api/users';
|
2019-09-07 00:50:31 +08:00
|
|
|
import VideoStreams from '/imports/api/video-streams';
|
2017-02-23 02:59:47 +08:00
|
|
|
import Logger from '/imports/startup/server/logger';
|
2021-03-23 04:44:53 +08:00
|
|
|
import setloggedOutStatus from '/imports/api/users-persistent-data/server/modifiers/setloggedOutStatus';
|
2021-02-21 20:19:01 +08:00
|
|
|
import stopWatchingExternalVideoSystemCall from '/imports/api/external-videos/server/methods/stopWatchingExternalVideoSystemCall';
|
2019-04-06 06:32:21 +08:00
|
|
|
import clearUserInfoForRequester from '/imports/api/users-infos/server/modifiers/clearUserInfoForRequester';
|
2020-09-01 20:07:56 +08:00
|
|
|
import ClientConnections from '/imports/startup/server/ClientConnections';
|
2017-02-23 02:59:47 +08:00
|
|
|
|
2018-02-20 23:02:04 +08:00
|
|
|
const clearAllSessions = (sessionUserId) => {
|
|
|
|
const serverSessions = Meteor.server.sessions;
|
|
|
|
Object.keys(serverSessions)
|
2021-04-17 01:58:53 +08:00
|
|
|
.filter((i) => serverSessions[i].userId === sessionUserId)
|
|
|
|
.forEach((i) => serverSessions[i].close());
|
2018-02-20 23:02:04 +08:00
|
|
|
};
|
|
|
|
|
2017-02-23 02:59:47 +08:00
|
|
|
export default function removeUser(meetingId, userId) {
|
|
|
|
check(meetingId, String);
|
|
|
|
check(userId, String);
|
|
|
|
|
2020-03-04 23:54:32 +08:00
|
|
|
const userToRemove = Users.findOne({ userId, meetingId });
|
2019-02-19 20:14:29 +08:00
|
|
|
|
|
|
|
if (userToRemove) {
|
|
|
|
const { presenter } = userToRemove;
|
|
|
|
if (presenter) {
|
2021-02-21 20:19:01 +08:00
|
|
|
stopWatchingExternalVideoSystemCall({ meetingId, requesterUserId: 'system-presenter-was-removed' });
|
2019-02-19 20:14:29 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-02-23 02:59:47 +08:00
|
|
|
const selector = {
|
|
|
|
meetingId,
|
|
|
|
userId,
|
|
|
|
};
|
|
|
|
|
2020-11-25 04:44:13 +08:00
|
|
|
try {
|
2021-03-23 04:44:53 +08:00
|
|
|
setloggedOutStatus(userId, meetingId, true);
|
2020-11-25 04:44:13 +08:00
|
|
|
VideoStreams.remove({ meetingId, userId });
|
2018-02-20 23:02:04 +08:00
|
|
|
const sessionUserId = `${meetingId}-${userId}`;
|
2020-09-01 20:07:56 +08:00
|
|
|
|
|
|
|
ClientConnections.removeClientConnection(`${meetingId}--${userId}`);
|
|
|
|
|
2018-02-20 23:02:04 +08:00
|
|
|
clearAllSessions(sessionUserId);
|
|
|
|
|
2019-04-06 06:32:21 +08:00
|
|
|
clearUserInfoForRequester(meetingId, userId);
|
|
|
|
|
2021-04-17 03:32:16 +08:00
|
|
|
/*
|
|
|
|
Timeout added to reduce the probability that "userRemove" happens too close to "ejectUser",
|
|
|
|
redirecting user to the wrong component.
|
|
|
|
This is a workaround and should be removed as soon as a better fix is made
|
|
|
|
see: https://github.com/bigbluebutton/bigbluebutton/pull/12057
|
|
|
|
*/
|
|
|
|
const DELAY_USER_REMOVAL_TIMEOUT_MS = 1000;
|
|
|
|
|
2021-04-17 01:58:53 +08:00
|
|
|
Meteor.wrapAsync((callback) => {
|
|
|
|
Meteor.setTimeout(() => {
|
|
|
|
Users.remove(selector);
|
|
|
|
callback();
|
2021-04-17 03:32:16 +08:00
|
|
|
}, DELAY_USER_REMOVAL_TIMEOUT_MS);
|
2021-04-17 01:58:53 +08:00
|
|
|
})();
|
2020-12-02 04:02:50 +08:00
|
|
|
|
|
|
|
Logger.info(`Removed user id=${userId} meeting=${meetingId}`);
|
2020-11-25 04:44:13 +08:00
|
|
|
} catch (err) {
|
2020-12-02 04:02:50 +08:00
|
|
|
Logger.error(`Removing user from Users collection: ${err}`);
|
2020-11-25 04:44:13 +08:00
|
|
|
}
|
2017-06-03 03:25:02 +08:00
|
|
|
}
|