75 lines
1.7 KiB
JavaScript
75 lines
1.7 KiB
JavaScript
import _ from 'lodash';
|
|
import Users from '/imports/api/users';
|
|
import { Meteor } from 'meteor/meteor';
|
|
import { check } from 'meteor/check';
|
|
import Logger from '/imports/startup/server/logger';
|
|
import mapToAcl from '/imports/startup/mapToAcl';
|
|
|
|
import userLeaving from './methods/userLeaving';
|
|
|
|
Meteor.publish('current-user', function currentUserPub(credentials) {
|
|
const { meetingId, requesterUserId, requesterToken } = credentials;
|
|
|
|
const connectionId = this.connection.id;
|
|
const onCloseConnection = Meteor.bindEnvironment(() => {
|
|
try {
|
|
userLeaving(credentials, requesterUserId, connectionId);
|
|
} catch (e) {
|
|
Logger.error(`Exception while executing userLeaving: ${e}`);
|
|
}
|
|
});
|
|
|
|
this._session.socket.on('close', _.debounce(onCloseConnection, 100));
|
|
|
|
check(meetingId, String);
|
|
check(requesterUserId, String);
|
|
check(requesterToken, String);
|
|
|
|
const selector = {
|
|
meetingId,
|
|
userId: requesterUserId,
|
|
authToken: requesterToken,
|
|
};
|
|
|
|
const options = {
|
|
fields: {
|
|
user: false,
|
|
},
|
|
};
|
|
|
|
return Users.find(selector, options);
|
|
});
|
|
|
|
function users(credentials) {
|
|
const {
|
|
meetingId,
|
|
requesterUserId,
|
|
requesterToken,
|
|
} = credentials;
|
|
|
|
check(meetingId, String);
|
|
check(requesterUserId, String);
|
|
check(requesterToken, String);
|
|
|
|
const selector = {
|
|
meetingId,
|
|
};
|
|
|
|
const options = {
|
|
fields: {
|
|
authToken: false,
|
|
},
|
|
};
|
|
|
|
Logger.info(`Publishing Users for ${meetingId} ${requesterUserId} ${requesterToken}`);
|
|
|
|
return Users.find(selector, options);
|
|
}
|
|
|
|
function publish(...args) {
|
|
const boundUsers = users.bind(this);
|
|
return mapToAcl('subscriptions.users', boundUsers)(args);
|
|
}
|
|
|
|
Meteor.publish('users', publish);
|