bigbluebutton-Github/bigbluebutton-html5/imports/api/users/server/publishers.js

75 lines
1.7 KiB
JavaScript
Raw Normal View History

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';
2017-06-01 01:54:43 +08:00
import mapToAcl from '/imports/startup/mapToAcl';
2017-02-07 23:29:27 +08:00
import userLeaving from './methods/userLeaving';
2017-03-11 02:33:46 +08:00
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);
2017-03-11 02:33:46 +08:00
const selector = {
meetingId,
userId: requesterUserId,
authToken: requesterToken,
};
const options = {
fields: {
user: false,
},
};
return Users.find(selector, options);
});
2017-06-01 01:54:43 +08:00
function users(credentials) {
const {
meetingId,
requesterUserId,
2017-06-06 00:40:36 +08:00
requesterToken,
2017-06-01 01:54:43 +08:00
} = credentials;
2017-03-11 02:33:46 +08:00
check(meetingId, String);
check(requesterUserId, String);
check(requesterToken, String);
2017-02-07 23:29:27 +08:00
const selector = {
2017-04-13 04:19:39 +08:00
meetingId,
};
const options = {
fields: {
authToken: false,
},
};
Logger.info(`Publishing Users for ${meetingId} ${requesterUserId} ${requesterToken}`);
return Users.find(selector, options);
}
2017-06-06 03:12:06 +08:00
function publish(...args) {
const boundUsers = users.bind(this);
return mapToAcl('subscriptions.users', boundUsers)(args);
}
Meteor.publish('users', publish);