Merge pull request #518 from isymchych/really-fix-auth

Fix login/logout
This commit is contained in:
Paweł Domas 2016-02-25 11:06:21 -06:00
commit 259fae331f
5 changed files with 93 additions and 30 deletions

View File

@ -110,6 +110,33 @@ function muteLocalVideo (muted) {
}
}
/**
* Disconnect from the conference and optionally request user feedback.
* @param {boolean} [requestFeedback=false] if user feedback should be requested
*/
function hangup (requestFeedback = false) {
let promise = Promise.resolve();
if (requestFeedback) {
promise = APP.UI.requestFeedback();
}
promise.then(function () {
connection.disconnect();
if (!config.enableWelcomePage) {
return;
}
// redirect to welcome page
setTimeout(() => {
APP.settings.setWelcomePageEnabled(true);
window.location.pathname = "/";
}, 3000);
}, function (err) {
console.error('Failed to hangup the call:', err);
});
}
/**
* Create local tracks of specified types.
* @param {string[]} devices required track types ('audio', 'video' etc.)
@ -624,10 +651,16 @@ export default {
_setupListeners () {
// add local streams when joined to the conference
room.on(ConferenceEvents.CONFERENCE_JOINED, () => {
APP.UI.updateAuthInfo(room.isAuthEnabled(), room.getAuthLogin());
APP.UI.mucJoined();
});
room.on(
ConferenceEvents.AUTH_STATUS_CHANGED,
function (authEnabled, authLogin) {
APP.UI.updateAuthInfo(authEnabled, authLogin);
}
);
room.on(ConferenceEvents.USER_JOINED, (id, user) => {
console.log('USER %s connnected', id, user);
@ -909,25 +942,18 @@ export default {
// call hangup
APP.UI.addListener(UIEvents.HANGUP, () => {
APP.UI.requestFeedback().then(() => {
connection.disconnect();
config.enableWelcomePage && setTimeout(() => {
window.localStorage.welcomePageDisabled = false;
window.location.pathname = "/";
}, 3000);
}, (err) => {console.error(err);});
hangup(true);
});
// logout
APP.UI.addListener(UIEvents.LOGOUT, () => {
// FIXME handle logout
// APP.xmpp.logout(function (url) {
// if (url) {
// window.location.href = url;
// } else {
// hangup();
// }
// });
AuthHandler.logout(room).then(function (url) {
if (url) {
window.location.href = url;
} else {
hangup(true);
}
});
});
APP.UI.addListener(UIEvents.SIP_DIAL, (sipNumber) => {

View File

@ -315,8 +315,7 @@ UI.start = function () {
document.title = interfaceConfig.APP_NAME;
var setupWelcomePage = null;
if(config.enableWelcomePage && window.location.pathname == "/" &&
(!window.localStorage.welcomePageDisabled ||
window.localStorage.welcomePageDisabled == "false")) {
Settings.isWelcomePageEnabled()) {
$("#videoconference_page").hide();
if (!setupWelcomePage)
setupWelcomePage = require("./welcome_page/WelcomePage");

View File

@ -69,13 +69,8 @@ function doXmppAuth (room, lockPassword) {
APP.translation.translateString('connection.GOT_SESSION_ID')
);
if (room.isJoined()) {
// just reallocate focus if already joined
room.room.moderator.allocateConferenceFocus();
} else {
// or join
// authenticate conference on the fly
room.join(lockPassword);
}
loginDialog.close();
}).catch(function (error, code) {
@ -111,6 +106,26 @@ function authenticate (room, lockPassword) {
}
}
/**
* De-authenticate local user.
*
* @param {JitsiConference} room
* @param {string} [lockPassword] password to use if the conference is locked
* @returns {Promise}
*/
function logout (room) {
return new Promise(function (resolve) {
room.room.moderator.logout(resolve);
}).then(function (url) {
// de-authenticate conference on the fly
if (room.isJoined()) {
room.join();
}
return url;
});
}
/**
* Notify user that authentication is required to create the conference.
* @param {JitsiConference} room
@ -145,5 +160,6 @@ function closeAuth() {
export default {
authenticate,
requireAuth,
closeAuth
closeAuth,
logout
};

View File

@ -1,4 +1,4 @@
/* global $, interfaceConfig */
/* global $, interfaceConfig, APP */
var animateTimeout, updateTimeout;
var RoomnameGenerator = require("../../util/RoomnameGenerator");
@ -87,8 +87,9 @@ function setupWelcomePage() {
}
$("#disable_welcome").click(function () {
window.localStorage.welcomePageDisabled =
$("#disable_welcome").is(":checked");
APP.settings.setWelcomePageEnabled(
!$("#disable_welcome").is(":checked")
);
});
}

View File

@ -7,6 +7,7 @@ let userId;
let language = null;
let cameraDeviceId = '';
let micDeviceId = '';
let welcomePageDisabled = false;
function supportsLocalStorage() {
try {
@ -37,6 +38,9 @@ if (supportsLocalStorage()) {
language = window.localStorage.language;
cameraDeviceId = window.localStorage.cameraDeviceId || '';
micDeviceId = window.localStorage.micDeviceId || '';
welcomePageDisabled = JSON.parse(
window.localStorage.welcomePageDisabled || false
);
} else {
console.log("local storage is not supported");
userId = generateUniqueId();
@ -130,5 +134,22 @@ export default {
setMicDeviceId: function (newId = '') {
micDeviceId = newId;
window.localStorage.micDeviceId = newId;
},
/**
* Check if welcome page is enabled or not.
* @returns {boolean}
*/
isWelcomePageEnabled () {
return !welcomePageDisabled;
},
/**
* Enable or disable welcome page.
* @param {boolean} enabled if welcome page should be enabled or not
*/
setWelcomePageEnabled (enabled) {
welcomePageDisabled = !enabled;
window.localStorage.welcomePageDisabled = welcomePageDisabled;
}
};