jiti-meet/react/features/base/connection/actions.web.js

106 lines
3.5 KiB
JavaScript
Raw Normal View History

2017-02-03 18:50:06 +00:00
/* @flow */
import type { Dispatch } from 'redux';
2016-12-12 21:13:17 +00:00
import {
JitsiConferenceEvents,
libInitError,
WEBRTC_NOT_READY,
WEBRTC_NOT_SUPPORTED
} from '../lib-jitsi-meet';
2016-12-12 21:13:17 +00:00
import UIEvents from '../../../../service/UI/UIEvents';
2017-02-03 18:50:06 +00:00
declare var APP: Object;
2017-02-16 21:22:40 +00:00
declare var config: Object;
2017-02-03 18:50:06 +00:00
const logger = require('jitsi-meet-logger').getLogger(__filename);
2016-12-12 21:13:17 +00:00
export {
connectionEstablished,
connectionFailed,
setLocationURL
} from './actions.native.js';
2016-12-12 21:13:17 +00:00
/**
* Opens new connection.
*
* @returns {Promise<JitsiConnection>}
*/
export function connect() {
2017-02-03 18:50:06 +00:00
return (dispatch: Dispatch<*>, getState: Function) => {
2016-12-12 21:13:17 +00:00
const state = getState();
2017-01-15 19:05:17 +00:00
// XXX Lib-jitsi-meet does not accept uppercase letters.
const room = state['features/base/conference'].room.toLowerCase();
2016-12-12 21:13:17 +00:00
// XXX For web based version we use conference initialization logic
// from the old app (at the moment of writing).
return APP.conference.init({ roomName: room }).then(() => {
if (APP.logCollector) {
// Start the LogCollector's periodic "store logs" task
APP.logCollector.start();
APP.logCollectorStarted = true;
// Make an attempt to flush in case a lot of logs have been
// cached, before the collector was started.
APP.logCollector.flush();
// This event listener will flush the logs, before
// the statistics module (CallStats) is stopped.
//
// NOTE The LogCollector is not stopped, because this event can
// be triggered multiple times during single conference
// (whenever statistics module is stopped). That includes
// the case when Jicofo terminates the single person left in the
// room. It will then restart the media session when someone
// eventually join the room which will start the stats again.
APP.conference.addConferenceListener(
JitsiConferenceEvents.BEFORE_STATISTICS_DISPOSED,
2016-12-12 21:13:17 +00:00
() => {
if (APP.logCollector) {
APP.logCollector.flush();
}
}
);
}
APP.UI.initConference();
2017-03-01 04:53:45 +00:00
APP.UI.addListener(
2017-06-15 00:40:51 +00:00
UIEvents.LANG_CHANGED,
language => APP.translation.setLanguage(language));
2016-12-12 21:13:17 +00:00
APP.keyboardshortcut.init();
2017-02-16 21:22:40 +00:00
if (config.requireDisplayName && !APP.settings.getDisplayName()) {
APP.UI.promptDisplayName();
}
2016-12-12 21:13:17 +00:00
})
.catch(error => {
2016-12-12 21:13:17 +00:00
APP.API.notifyConferenceLeft(APP.conference.roomName);
logger.error(error);
// TODO The following are in fact Errors raised by
// JitsiMeetJS.init() which should be taken care of in
// features/base/lib-jitsi-meet but we are not there yet on the
// Web at the time of this writing.
switch (error.name) {
case WEBRTC_NOT_READY:
case WEBRTC_NOT_SUPPORTED:
dispatch(libInitError(error));
2017-02-14 22:28:15 +00:00
}
2016-12-12 21:13:17 +00:00
});
};
}
/**
* Closes connection.
*
* @returns {Function}
*/
export function disconnect() {
// XXX For web based version we use conference hanging up logic from the old
// app.
2016-12-12 21:13:17 +00:00
return () => APP.conference.hangup();
}