bigbluebutton-Github/bigbluebutton-html5/imports/api/polls/server/modifiers/addPoll.js

58 lines
1.2 KiB
JavaScript
Raw Normal View History

import Users from '/imports/api/users';
import Polls from '/imports/api/polls';
import Logger from '/imports/startup/server/logger';
2017-10-12 08:33:57 +08:00
import flat from 'flat';
2016-10-21 21:21:09 +08:00
import { check } from 'meteor/check';
2016-05-13 01:43:59 +08:00
export default function addPoll(meetingId, requesterId, poll) {
2016-10-21 21:21:09 +08:00
check(requesterId, String);
2016-10-22 01:42:43 +08:00
check(meetingId, String);
2017-10-12 08:33:57 +08:00
check(poll, {
id: String,
answers: [
{
id: Number,
key: String,
},
],
});
const userSelector = {
2017-06-03 03:25:02 +08:00
meetingId,
2018-10-31 22:03:48 +08:00
userId: { $ne: requesterId },
2019-03-01 15:12:12 +08:00
clientType: { $ne: 'dial-in-user' },
};
const userIds = Users.find(userSelector, { fields: { userId: 1 } })
2017-10-12 08:33:57 +08:00
.fetch()
.map(user => user.userId);
const selector = {
2016-10-22 01:42:43 +08:00
meetingId,
requester: requesterId,
2017-10-12 08:33:57 +08:00
id: poll.id,
2016-10-22 01:42:43 +08:00
};
2017-10-12 08:33:57 +08:00
const modifier = Object.assign(
{ meetingId },
{ requester: requesterId },
{ users: userIds },
flat(poll, { safe: true }),
);
const cb = (err, numChanged) => {
if (err != null) {
return Logger.error(`Adding Poll to collection: ${poll.id}`);
}
const { insertedId } = numChanged;
if (insertedId) {
return Logger.info(`Added Poll id=${poll.id}`);
}
return Logger.info(`Upserted Poll id=${poll.id}`);
};
return Polls.upsert(selector, modifier, cb);
2017-06-03 03:25:02 +08:00
}