2014-11-28 15:31:01 +00:00
|
|
|
/* global $, $iq, config, connection, Etherpad, hangUp, roomName, Strophe,
|
|
|
|
Toolbar, Util, VideoLayout */
|
2014-11-28 15:17:53 +00:00
|
|
|
/**
|
|
|
|
* Contains logic responsible for enabling/disabling functionality available
|
|
|
|
* only to moderator users.
|
|
|
|
*/
|
|
|
|
var Moderator = (function (my) {
|
|
|
|
|
2014-11-28 15:18:12 +00:00
|
|
|
var getNextTimeout = Util.createExpBackoffTimer(1000);
|
2014-11-28 15:18:31 +00:00
|
|
|
var getNextErrorTimeout = Util.createExpBackoffTimer(1000);
|
2014-11-28 15:18:12 +00:00
|
|
|
|
2014-11-28 15:17:53 +00:00
|
|
|
my.isModerator = function () {
|
|
|
|
return connection.emuc.isModerator();
|
|
|
|
};
|
|
|
|
|
|
|
|
my.onModeratorStatusChanged = function (isModerator) {
|
|
|
|
|
|
|
|
Toolbar.showSipCallButton(isModerator);
|
|
|
|
Toolbar.showRecordingButton(
|
|
|
|
isModerator); //&&
|
|
|
|
// FIXME:
|
|
|
|
// Recording visible if
|
|
|
|
// there are at least 2(+ 1 focus) participants
|
|
|
|
//Object.keys(connection.emuc.members).length >= 3);
|
|
|
|
|
|
|
|
if (isModerator && config.etherpad_base) {
|
|
|
|
Etherpad.init();
|
|
|
|
}
|
|
|
|
|
|
|
|
$(document).trigger('local.role.moderator', [isModerator]);
|
|
|
|
};
|
|
|
|
|
|
|
|
my.init = function () {
|
|
|
|
$(document).bind(
|
|
|
|
'role.changed.muc',
|
|
|
|
function (event, jid, info, pres) {
|
|
|
|
console.info(
|
|
|
|
"Role changed for " + jid + ", new role: " + info.role);
|
|
|
|
VideoLayout.showModeratorIndicator();
|
|
|
|
}
|
|
|
|
);
|
|
|
|
|
|
|
|
$(document).bind(
|
|
|
|
'local.role.changed.muc',
|
|
|
|
function (event, jid, info, pres) {
|
|
|
|
console.info("My role changed, new role: " + info.role);
|
|
|
|
VideoLayout.showModeratorIndicator();
|
|
|
|
Moderator.onModeratorStatusChanged(Moderator.isModerator());
|
|
|
|
}
|
|
|
|
);
|
2014-11-28 15:18:12 +00:00
|
|
|
|
|
|
|
$(document).bind(
|
|
|
|
'left.muc',
|
|
|
|
function (event, jid) {
|
|
|
|
console.info("Someone left is it focus ? " + jid);
|
|
|
|
var resource = Strophe.getResourceFromJid(jid);
|
|
|
|
if (resource === 'focus') {
|
|
|
|
console.info(
|
|
|
|
"Focus has left the room - leaving conference");
|
|
|
|
//hangUp();
|
|
|
|
// We'd rather reload to have everything re-initialized
|
2014-11-28 15:18:31 +00:00
|
|
|
// FIXME: show some message before reload
|
2014-11-28 15:18:12 +00:00
|
|
|
location.reload();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
2014-11-28 15:31:01 +00:00
|
|
|
my.createConferenceIq = function () {
|
2014-11-28 15:18:12 +00:00
|
|
|
var elem = $iq({to: config.hosts.focus, type: 'set'});
|
|
|
|
elem.c('conference', {
|
|
|
|
xmlns: 'http://jitsi.org/protocol/focus',
|
|
|
|
room: roomName
|
|
|
|
});
|
2014-11-28 15:31:01 +00:00
|
|
|
if (config.channelLastN !== undefined)
|
|
|
|
{
|
|
|
|
elem.c(
|
|
|
|
'property',
|
|
|
|
{ name: 'channelLastN', value: config.channelLastN})
|
|
|
|
.up();
|
|
|
|
}
|
|
|
|
if (config.adaptiveLastN !== undefined)
|
|
|
|
{
|
|
|
|
elem.c(
|
|
|
|
'property',
|
|
|
|
{ name: 'adaptiveLastN', value: config.adaptiveLastN})
|
|
|
|
.up();
|
|
|
|
}
|
|
|
|
if (config.adaptiveSimulcast !== undefined)
|
|
|
|
{
|
|
|
|
elem.c(
|
|
|
|
'property',
|
|
|
|
{ name: 'adaptiveSimulcast', value: config.adaptiveSimulcast})
|
|
|
|
.up();
|
|
|
|
}
|
2014-11-28 15:18:12 +00:00
|
|
|
elem.up();
|
2014-11-28 15:31:01 +00:00
|
|
|
return elem;
|
|
|
|
};
|
|
|
|
|
|
|
|
// FIXME: we need to show the fact that we're waiting for the focus
|
|
|
|
// to the user(or that focus is not available)
|
|
|
|
my.allocateConferenceFocus = function (roomName, callback) {
|
|
|
|
var iq = Moderator.createConferenceIq();
|
|
|
|
connection.sendIQ(
|
|
|
|
iq,
|
2014-11-28 15:18:12 +00:00
|
|
|
function (result) {
|
|
|
|
if ('true' === $(result).find('conference').attr('ready')) {
|
2014-11-28 15:18:31 +00:00
|
|
|
// Reset both timers
|
2014-11-28 15:18:12 +00:00
|
|
|
getNextTimeout(true);
|
2014-11-28 15:18:31 +00:00
|
|
|
getNextErrorTimeout(true);
|
2014-11-28 15:18:12 +00:00
|
|
|
callback();
|
|
|
|
} else {
|
|
|
|
var waitMs = getNextTimeout();
|
|
|
|
console.info("Waiting for the focus... " + waitMs);
|
2014-11-28 15:18:31 +00:00
|
|
|
// Reset error timeout
|
|
|
|
getNextErrorTimeout(true);
|
2014-11-28 15:18:12 +00:00
|
|
|
window.setTimeout(
|
|
|
|
function () {
|
2014-11-28 15:31:01 +00:00
|
|
|
Moderator.allocateConferenceFocus(
|
|
|
|
roomName, callback);
|
2014-11-28 15:18:12 +00:00
|
|
|
}, waitMs);
|
|
|
|
}
|
|
|
|
},
|
|
|
|
function (error) {
|
2014-11-28 15:18:31 +00:00
|
|
|
var waitMs = getNextErrorTimeout();
|
2014-11-28 15:18:12 +00:00
|
|
|
console.error("Focus error, retry after " + waitMs, error);
|
2014-11-28 15:18:31 +00:00
|
|
|
// Reset response timeout
|
|
|
|
getNextTimeout(true);
|
2014-11-28 15:18:12 +00:00
|
|
|
window.setTimeout(
|
|
|
|
function () {
|
|
|
|
Moderator.allocateConferenceFocus(roomName, callback);
|
|
|
|
}, waitMs);
|
|
|
|
}
|
|
|
|
);
|
2014-11-28 15:17:53 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
return my;
|
|
|
|
}(Moderator || {}));
|
|
|
|
|
|
|
|
|
|
|
|
|