bigbluebutton-Github/bigbluebutton-html5/imports/api/2.0/users/server/modifiers/addUser.js

99 lines
2.3 KiB
JavaScript
Raw Normal View History

2017-06-19 21:13:35 +08:00
import { check } from 'meteor/check';
import Logger from '/imports/startup/server/logger';
2017-06-29 02:14:29 +08:00
import Users from '/imports/api/2.0/users';
2017-07-26 22:09:07 +08:00
import flat from 'flat';
2017-08-01 21:10:12 +08:00
import addVoiceUser from '/imports/api/2.0/voice-users/server/modifiers/addVoiceUser';
2017-06-19 21:13:35 +08:00
export default function addUser(meetingId, user) {
check(meetingId, String);
2017-07-26 22:50:02 +08:00
check(user, {
intId: String,
extId: String,
name: String,
role: String,
guest: Boolean,
authed: Boolean,
waitingForAcceptance: Boolean,
emoji: String,
presenter: Boolean,
locked: Boolean,
avatar: String,
});
2017-06-22 00:54:04 +08:00
const userId = user.intId;
2017-06-19 21:13:35 +08:00
check(userId, String);
const selector = {
meetingId,
userId,
};
const USER_CONFIG = Meteor.settings.public.user;
const ROLE_MODERATOR = USER_CONFIG.role_moderator;
const ROLE_VIEWER = USER_CONFIG.role_viewer;
const APP_CONFIG = Meteor.settings.public.app;
const ALLOW_HTML5_MODERATOR = APP_CONFIG.allowHTML5Moderator;
// override moderator status of html5 client users, depending on a system flag
const dummyUser = Users.findOne(selector);
let userRole = user.role;
if (
dummyUser &&
2017-06-19 21:13:35 +08:00
dummyUser.clientType === 'HTML5' &&
userRole === ROLE_MODERATOR &&
!ALLOW_HTML5_MODERATOR
) {
userRole = ROLE_VIEWER;
2017-06-19 21:13:35 +08:00
}
const userRoles = [
2017-07-26 00:21:07 +08:00
'viewer',
user.presenter ? 'presenter' : false,
userRole === ROLE_MODERATOR ? 'moderator' : false,
].filter(Boolean);
2017-06-19 21:13:35 +08:00
const modifier = {
2017-07-26 22:09:07 +08:00
$set: Object.assign(
{
meetingId,
connectionStatus: 'online',
roles: userRoles,
sortName: user.name.trim().toLowerCase(),
},
2017-07-26 22:09:07 +08:00
flat(user),
),
2017-06-19 21:13:35 +08:00
};
2017-08-01 21:10:12 +08:00
addVoiceUser(meetingId, {
voiceUserId: '',
intId: userId,
callerName: user.name,
callerNum: '',
muted: false,
talking: false,
callingWith: '',
listenOnly: false,
voiceConf: '',
});
2017-06-19 21:13:35 +08:00
const cb = (err, numChanged) => {
if (err) {
return Logger.error(`Adding user to collection: ${err}`);
}
// TODO: Do we really need to request the stun/turn everytime?
// requestStunTurn(meetingId, userId);
2017-06-19 21:13:35 +08:00
const { insertedId } = numChanged;
if (insertedId) {
return Logger.info(`Added user id=${userId} meeting=${meetingId}`);
}
2017-07-17 20:00:18 +08:00
return Logger.info(`Upserted user id=${userId} meeting=${meetingId}`);
2017-06-19 21:13:35 +08:00
};
return Users.upsert(selector, modifier, cb);
}