2020-09-25 22:51:54 +00:00
|
|
|
// @flow
|
|
|
|
|
2021-06-02 19:21:39 +00:00
|
|
|
import Bourne from '@hapi/bourne';
|
2020-09-25 22:51:54 +00:00
|
|
|
import { jitsiLocalStorage } from '@jitsi/js-utils/jitsi-local-storage';
|
|
|
|
|
2021-01-15 12:44:24 +00:00
|
|
|
import { browser } from '../lib-jitsi-meet';
|
2020-09-25 22:51:54 +00:00
|
|
|
import { parseURLParams } from '../util/parseURLParams';
|
|
|
|
|
|
|
|
import logger from './logger';
|
|
|
|
|
|
|
|
declare var APP: Object;
|
2021-03-08 21:36:51 +00:00
|
|
|
declare var config: Object;
|
2020-09-25 22:51:54 +00:00
|
|
|
|
2021-08-24 07:41:49 +00:00
|
|
|
/**
|
|
|
|
* Checks whether we are loaded in an iframe.
|
|
|
|
*
|
|
|
|
* @returns {boolean} Returns {@code true} if loaded in iframe.
|
|
|
|
* @private
|
|
|
|
*/
|
2021-08-24 14:06:32 +00:00
|
|
|
function _inIframe() {
|
2021-08-24 07:41:49 +00:00
|
|
|
try {
|
|
|
|
return window.self !== window.top;
|
|
|
|
} catch (e) {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-09-25 22:51:54 +00:00
|
|
|
/**
|
|
|
|
* Handles changes of the fake local storage.
|
|
|
|
*
|
|
|
|
* @returns {void}
|
|
|
|
*/
|
|
|
|
function onFakeLocalStorageChanged() {
|
|
|
|
APP.API.notifyLocalStorageChanged(jitsiLocalStorage.serialize());
|
|
|
|
}
|
|
|
|
|
2021-03-08 21:36:51 +00:00
|
|
|
/**
|
|
|
|
* Checks if the local storage of the host page needs to be used instead jitsi-meet's local storage.
|
|
|
|
*
|
|
|
|
* @param {Object} urlParams - Object with parsed URL params.
|
|
|
|
* @returns {boolean} - True if the local storage of the host page needs to be used instead jitsi-meet's local storage
|
|
|
|
* and false otherwise.
|
|
|
|
*/
|
|
|
|
function shouldUseHostPageLocalStorage(urlParams) {
|
|
|
|
// NOTE: normally the url params and the config will be merged into the redux store. But we want to setup the local
|
|
|
|
// storage as soon as possible, the store is not created yet and the merging of the URL params and the config
|
2021-03-16 15:59:33 +00:00
|
|
|
// haven't been executed yet. That's why we need to manually parse the URL params and also access the config through
|
2021-03-08 21:36:51 +00:00
|
|
|
// the global variable.
|
|
|
|
if (urlParams['config.useHostPageLocalStorage'] === true
|
|
|
|
|| (typeof config === 'object' && config.useHostPageLocalStorage)) {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (jitsiLocalStorage.isLocalStorageDisabled()) { // We have detected that ou own local storage is not working.
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2021-08-24 07:41:49 +00:00
|
|
|
if (browser.isWebKitBased() && _inIframe()) {
|
|
|
|
// WebKit browsers don't persist local storage for third-party iframes.
|
|
|
|
|
2021-03-08 21:36:51 +00:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2020-09-25 22:51:54 +00:00
|
|
|
/**
|
|
|
|
* Performs initial setup of the jitsiLocalStorage.
|
|
|
|
*
|
|
|
|
* @returns {void}
|
|
|
|
*/
|
|
|
|
function setupJitsiLocalStorage() {
|
2021-03-08 21:36:51 +00:00
|
|
|
const urlParams = parseURLParams(window.location);
|
2020-09-25 22:51:54 +00:00
|
|
|
|
2021-03-08 21:36:51 +00:00
|
|
|
if (shouldUseHostPageLocalStorage(urlParams)) {
|
2020-09-25 22:51:54 +00:00
|
|
|
try {
|
2021-06-02 19:21:39 +00:00
|
|
|
const localStorageContent = Bourne.parse(urlParams['appData.localStorageContent']);
|
2020-09-25 22:51:54 +00:00
|
|
|
|
|
|
|
if (typeof localStorageContent === 'object') {
|
|
|
|
Object.keys(localStorageContent).forEach(key => {
|
|
|
|
jitsiLocalStorage.setItem(key, localStorageContent[key]);
|
|
|
|
});
|
|
|
|
}
|
|
|
|
} catch (error) {
|
|
|
|
logger.error('Can\'t parse localStorageContent.', error);
|
|
|
|
}
|
|
|
|
|
|
|
|
jitsiLocalStorage.on('changed', onFakeLocalStorageChanged);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
setupJitsiLocalStorage();
|