bigbluebutton-Github/bigbluebutton-html5/imports/api/users/server/methods/userLeaving.js

50 lines
1.5 KiB
JavaScript
Raw Normal View History

2017-02-07 23:29:27 +08:00
import { Meteor } from 'meteor/meteor';
import { check } from 'meteor/check';
import RedisPubSub from '/imports/startup/server/redis';
import Logger from '/imports/startup/server/logger';
2020-09-10 19:49:22 +08:00
import AuthTokenValidation from '/imports/api/auth-token-validation';
import Users from '/imports/api/users';
import ClientConnections from '/imports/startup/server/ClientConnections';
export default function userLeaving(meetingId, userId, connectionId) {
const REDIS_CONFIG = Meteor.settings.private.redis;
2017-10-12 09:02:23 +08:00
const CHANNEL = REDIS_CONFIG.channels.toAkkaApps;
const EVENT_NAME = 'UserLeaveReqMsg';
check(userId, String);
2017-03-11 02:33:46 +08:00
const selector = {
meetingId,
userId,
2017-03-11 02:33:46 +08:00
};
const user = Users.findOne(selector);
if (!user) {
Logger.info(`Skipping userLeaving. Could not find ${userId} in ${meetingId}`);
return;
}
2020-09-10 19:49:22 +08:00
const auth = AuthTokenValidation.findOne({
meetingId,
userId,
}, { sort: { updatedAt: -1 } });
2020-09-10 19:49:22 +08:00
// If the current user connection is not the same that triggered the leave we skip
if (auth?.connectionId !== connectionId) {
Logger.info(`Skipping userLeaving. User connectionId=${user.connectionId} is different from requester connectionId=${connectionId}`);
return false;
2017-03-11 02:33:46 +08:00
}
2017-06-03 03:25:02 +08:00
const payload = {
2017-10-12 09:02:23 +08:00
userId,
sessionId: meetingId,
loggedOut: user.loggedOut,
};
ClientConnections.removeClientConnection(`${meetingId}--${userId}`, connectionId);
Logger.info(`User '${userId}' is leaving meeting '${meetingId}'`);
return RedisPubSub.publishUserMessage(CHANNEL, EVENT_NAME, meetingId, userId, payload);
2017-06-03 03:25:02 +08:00
}