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

129 lines
3.4 KiB
JavaScript
Raw Normal View History

import { check } from 'meteor/check';
import Logger from '/imports/startup/server/logger';
import Users from '/imports/api/users';
import Meetings from '/imports/api/meetings';
import VoiceUsers from '/imports/api/voice-users/';
2017-10-12 09:02:23 +08:00
import stringHash from 'string-hash';
import flat from 'flat';
import addVoiceUser from '/imports/api/voice-users/server/modifiers/addVoiceUser';
2017-10-26 01:29:03 +08:00
import changeRole from '/imports/api/users/server/modifiers/changeRole';
2017-10-12 09:02:23 +08:00
const COLOR_LIST = [
2018-05-30 00:40:50 +08:00
'#7b1fa2', '#6a1b9a', '#4a148c', '#5e35b1', '#512da8', '#4527a0',
2017-10-12 09:02:23 +08:00
'#311b92', '#3949ab', '#303f9f', '#283593', '#1a237e', '#1976d2', '#1565c0',
2018-05-30 00:40:50 +08:00
'#0d47a1', '#0277bd', '#01579b',
2017-10-12 09:02:23 +08:00
];
export default function addUser(meetingId, user) {
check(meetingId, String);
2017-02-24 01:59:56 +08:00
2017-10-12 09:02:23 +08:00
check(user, {
intId: String,
extId: String,
name: String,
role: String,
guest: Boolean,
authed: Boolean,
waitingForAcceptance: Match.Maybe(Boolean),
guestStatus: String,
2017-10-12 09:02:23 +08:00
emoji: String,
presenter: Boolean,
locked: Boolean,
avatar: String,
clientType: String,
2017-10-12 09:02:23 +08:00
});
const userId = user.intId;
check(userId, String);
const selector = {
meetingId,
userId,
};
const USER_CONFIG = Meteor.settings.public.user;
2017-10-26 01:29:03 +08:00
const ROLE_PRESENTER = USER_CONFIG.role_presenter;
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;
const Meeting = Meetings.findOne({ meetingId });
// override moderator status of html5 client users, depending on a system flag
2017-06-03 03:25:02 +08:00
const dummyUser = Users.findOne(selector);
2017-10-12 09:02:23 +08:00
let userRole = user.role;
if (
2019-03-09 10:02:46 +08:00
dummyUser
&& dummyUser.clientType === 'HTML5'
&& userRole === ROLE_MODERATOR
&& !ALLOW_HTML5_MODERATOR
2017-10-12 09:02:23 +08:00
) {
userRole = ROLE_VIEWER;
}
2017-10-12 09:02:23 +08:00
/* While the akka-apps dont generate a color we just pick one
from a list based on the userId */
const color = COLOR_LIST[stringHash(user.intId) % COLOR_LIST.length];
2017-06-05 22:16:19 +08:00
const modifier = {
2017-10-12 09:02:23 +08:00
$set: Object.assign(
{
meetingId,
connectionStatus: 'online',
2017-10-26 01:29:03 +08:00
roles: [ROLE_VIEWER.toLowerCase()],
2017-10-12 09:02:23 +08:00
sortName: user.name.trim().toLowerCase(),
color,
2019-02-08 01:56:33 +08:00
breakoutProps: {
isBreakoutUser: Meeting.meetingProp.isBreakout,
parentId: Meeting.breakoutProps.parentId,
},
2019-02-27 01:40:01 +08:00
inactivityCheck: false,
responseDelay: 0,
2017-10-12 09:02:23 +08:00
},
flat(user),
),
};
// Only add an empty VoiceUser if there isn't one already. We want to avoid overwriting good data
if (!VoiceUsers.findOne({ meetingId, intId: userId })) {
addVoiceUser(meetingId, {
voiceUserId: '',
intId: userId,
callerName: user.name,
callerNum: '',
muted: false,
talking: false,
callingWith: '',
listenOnly: false,
voiceConf: '',
joined: false,
});
}
2017-10-12 09:02:23 +08:00
const cb = (err, numChanged) => {
if (err) {
return Logger.error(`Adding user to collection: ${err}`);
}
2017-10-26 01:29:03 +08:00
if (user.presenter) {
changeRole(ROLE_PRESENTER, true, userId, meetingId);
}
if (userRole === ROLE_MODERATOR) {
changeRole(ROLE_MODERATOR, true, userId, meetingId);
}
const { insertedId } = numChanged;
if (insertedId) {
return Logger.info(`Added user id=${userId} meeting=${meetingId}`);
}
2017-10-12 09:02:23 +08:00
return Logger.info(`Upserted user id=${userId} meeting=${meetingId}`);
};
return Users.upsert(selector, modifier, cb);
2017-06-03 03:25:02 +08:00
}