42 lines
1.5 KiB
JavaScript
42 lines
1.5 KiB
JavaScript
import VoiceUsers from '/imports/api/voice-users';
|
|
import { Meteor } from 'meteor/meteor';
|
|
import Logger from '/imports/startup/server/logger';
|
|
import AuthTokenValidation, { ValidationStates } from '/imports/api/auth-token-validation';
|
|
import ejectUserFromVoice from './methods/ejectUserFromVoice';
|
|
import _ from 'lodash';
|
|
|
|
function voiceUser() {
|
|
const tokenValidation = AuthTokenValidation.findOne({ connectionId: this.connection.id });
|
|
|
|
if (!tokenValidation || tokenValidation.validationStatus !== ValidationStates.VALIDATED) {
|
|
Logger.warn(`Publishing VoiceUsers was requested by unauth connection ${this.connection.id}`);
|
|
return VoiceUsers.find({ meetingId: '' });
|
|
}
|
|
|
|
const { meetingId, userId: requesterUserId } = tokenValidation;
|
|
|
|
const onCloseConnection = Meteor.bindEnvironment(() => {
|
|
try {
|
|
// I used user because voiceUser is the function's name
|
|
const User = VoiceUsers.findOne({ meetingId, requesterUserId });
|
|
if (User) {
|
|
ejectUserFromVoice(requesterUserId);
|
|
}
|
|
} catch (e) {
|
|
Logger.error(`Exception while executing ejectUserFromVoice for ${requesterUserId}: ${e}`);
|
|
}
|
|
});
|
|
|
|
Logger.debug('Publishing Voice User', { meetingId, requesterUserId });
|
|
|
|
this._session.socket.on('close', _.debounce(onCloseConnection, 100));
|
|
return VoiceUsers.find({ meetingId });
|
|
}
|
|
|
|
function publish(...args) {
|
|
const boundVoiceUser = voiceUser.bind(this);
|
|
return boundVoiceUser(...args);
|
|
}
|
|
|
|
Meteor.publish('voiceUsers', publish);
|