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

65 lines
1.3 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,
},
],
});
let selector = {
2017-06-03 03:25:02 +08:00
meetingId,
};
const options = {
fields: {
2017-10-12 08:33:57 +08:00
userId: 1,
_id: 0,
},
};
const userIds = Users.find(selector, options)
2017-10-12 08:33:57 +08:00
.fetch()
.map((user) => {
if (user.userId !== requesterId) return user.userId;
});
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}`);
};
2016-10-22 01:42:43 +08:00
return Polls.upsert(selector, modifier, cb);
2017-06-03 03:25:02 +08:00
}