2017-02-07 21:08:06 +08:00
|
|
|
import Users from '/imports/api/users';
|
2017-02-06 23:56:09 +08:00
|
|
|
import { Meteor } from 'meteor/meteor';
|
|
|
|
import { check } from 'meteor/check';
|
|
|
|
import Logger from '/imports/startup/server/logger';
|
|
|
|
import { isAllowedTo } from '/imports/startup/server/userPermissions';
|
|
|
|
|
2017-02-07 23:29:27 +08:00
|
|
|
import userLeaving from './methods/userLeaving';
|
|
|
|
import validateAuthToken from './methods/validateAuthToken';
|
2017-02-06 23:56:09 +08:00
|
|
|
|
2017-02-07 23:29:27 +08:00
|
|
|
Meteor.publish('users', function (credentials) {
|
2017-02-06 23:56:09 +08:00
|
|
|
const { meetingId, requesterUserId, requesterToken } = credentials;
|
|
|
|
|
|
|
|
check(meetingId, String);
|
|
|
|
check(requesterUserId, String);
|
|
|
|
check(requesterToken, String);
|
|
|
|
|
2017-02-07 23:29:27 +08:00
|
|
|
let initializing = true;
|
|
|
|
|
|
|
|
validateAuthToken(credentials);
|
|
|
|
|
|
|
|
// const User = Users.find({ meetingId, userId: requesterUserId }).observeChanges({
|
|
|
|
// changed: (id, fields) => {
|
|
|
|
// console.log(fields);
|
|
|
|
// },
|
|
|
|
// });
|
|
|
|
|
|
|
|
if (!isAllowedTo('subscribeUsers', credentials)) {
|
|
|
|
console.error('lul');
|
|
|
|
this.error(new Meteor.Error(402, "The user was not authorized to subscribe for 'Users'"));
|
|
|
|
}
|
2017-02-06 23:56:09 +08:00
|
|
|
|
|
|
|
this.onStop(() => {
|
2017-02-07 23:29:27 +08:00
|
|
|
userLeaving(credentials, requesterUserId);
|
2017-02-06 23:56:09 +08:00
|
|
|
});
|
|
|
|
|
|
|
|
const selector = {
|
|
|
|
meetingId,
|
|
|
|
'user.connection_status': {
|
|
|
|
$in: ['online', ''],
|
|
|
|
},
|
|
|
|
};
|
|
|
|
|
|
|
|
const options = {
|
|
|
|
fields: {
|
|
|
|
authToken: false,
|
|
|
|
},
|
|
|
|
};
|
|
|
|
|
|
|
|
Logger.info(`Publishing Users for ${meetingId} ${requesterUserId} ${requesterToken}`);
|
|
|
|
|
|
|
|
return Users.find(selector, options);
|
|
|
|
});
|