bigbluebutton-Github/bigbluebutton-html5/imports/api/timer/server/methods/stopTimer.js
Arthurk12 f13217607e feat(timer): add model and messages to akka apps
This commit makes the messages of the timer feature to be proxied by
akka-apps and also adds a timer model that is updated based on these
messages.
Moving the timer panel opening logic to the timer button component in
the navigation panel was a consequence of these changes.
2023-05-18 15:29:42 -03:00

90 lines
2.2 KiB
JavaScript

import { check } from 'meteor/check';
import Timer from '/imports/api/timer';
import RedisPubSub from '/imports/startup/server/redis';
import Logger from '/imports/startup/server/logger';
import { extractCredentials } from '/imports/api/common/server/helpers';
export default function stopTimer() {
const REDIS_CONFIG = Meteor.settings.private.redis;
const CHANNEL = REDIS_CONFIG.channels.toAkkaApps;
const EVENT_NAME = 'StopTimerReqMsg';
try {
const { meetingId, requesterUserId } = extractCredentials(this.userId);
check(meetingId, String);
check(requesterUserId, String);
const now = Date.now();
const timer = Timer.findOne(
{ meetingId },
{ fields:
{
stopwatch: 1,
time: 1,
accumulated: 1,
timestamp: 1,
},
},
);
if (timer) {
const {
timestamp,
} = timer;
const accumulated = timer.accumulated + (now - timestamp);
const payload = {
accumulated
};
RedisPubSub.publishUserMessage(CHANNEL, EVENT_NAME, meetingId, requesterUserId, payload);
} else {
Logger.warn(`Could not stop timer for meeting=${meetingId}`);
}
} catch (err) {
Logger.error(`Stopping timer: ${err}`);
}
}
// This method should only be used by the server
export function sysStopTimer(meetingId) {
const REDIS_CONFIG = Meteor.settings.private.redis;
const CHANNEL = REDIS_CONFIG.channels.toAkkaApps;
const EVENT_NAME = 'StopTimerReqMsg';
const USER_ID = 'nodeJSapp';
try {
check(meetingId, String);
const now = Date.now();
const timer = Timer.findOne(
{ meetingId },
{ fields:
{
stopwatch: 1,
time: 1,
accumulated: 1,
timestamp: 1,
},
},
);
if (timer) {
const {
timestamp,
} = timer;
const accumulated = timer.accumulated + (now - timestamp);
const payload = {
accumulated
};
RedisPubSub.publishUserMessage(CHANNEL, EVENT_NAME, meetingId, USER_ID, payload);
} else {
Logger.warn(`Could not stop timer for meeting=${meetingId}`);
}
} catch (err) {
Logger.error(`Stopping timer: ${err}`);
}
}