2018-03-07 00:28:19 +00:00
|
|
|
// @flow
|
2017-02-03 18:50:06 +00:00
|
|
|
|
|
|
|
import type { Dispatch } from 'redux';
|
2016-12-12 21:13:17 +00:00
|
|
|
|
2017-02-28 03:22:32 +00:00
|
|
|
import {
|
|
|
|
libInitError,
|
|
|
|
WEBRTC_NOT_READY,
|
|
|
|
WEBRTC_NOT_SUPPORTED
|
|
|
|
} from '../lib-jitsi-meet';
|
2016-12-12 21:13:17 +00:00
|
|
|
|
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
|
|
|
|
2017-01-10 21:55:31 +00:00
|
|
|
const logger = require('jitsi-meet-logger').getLogger(__filename);
|
2016-12-12 21:13:17 +00:00
|
|
|
|
2017-01-31 20:58:48 +00:00
|
|
|
export {
|
|
|
|
connectionEstablished,
|
2017-05-09 05:15:43 +00:00
|
|
|
connectionFailed,
|
|
|
|
setLocationURL
|
2017-09-07 17:21:56 +00:00
|
|
|
} from './actions.native';
|
2017-01-31 20:58:48 +00:00
|
|
|
|
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).
|
2017-11-16 22:54:49 +00:00
|
|
|
return APP.conference.init({ roomName: room })
|
2017-02-28 03:22:32 +00:00
|
|
|
.catch(error => {
|
2016-12-12 21:13:17 +00:00
|
|
|
APP.API.notifyConferenceLeft(APP.conference.roomName);
|
2017-02-28 03:22:32 +00:00
|
|
|
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.
|
|
|
|
*
|
2018-03-07 00:28:19 +00:00
|
|
|
* @param {boolean} [requestFeedback] - Whether or not to attempt showing a
|
|
|
|
* request for call feedback.
|
2016-12-12 21:13:17 +00:00
|
|
|
* @returns {Function}
|
|
|
|
*/
|
2018-03-07 00:28:19 +00:00
|
|
|
export function disconnect(requestFeedback: boolean = false) {
|
2017-01-10 21:55:31 +00:00
|
|
|
// XXX For web based version we use conference hanging up logic from the old
|
|
|
|
// app.
|
2018-03-07 00:28:19 +00:00
|
|
|
return () => APP.conference.hangup(requestFeedback);
|
2016-12-12 21:13:17 +00:00
|
|
|
}
|