Some checks failed
Close stale issues and PRs / stale (push) Has been cancelled
91 lines
3.4 KiB
TypeScript
91 lines
3.4 KiB
TypeScript
// @ts-expect-error
|
|
import { jitsiLocalStorage } from '@jitsi/js-utils';
|
|
|
|
import { IStore } from '../../app/types';
|
|
import { getCustomerDetails } from '../../jaas/actions.any';
|
|
import { getJaasJWT, isVpaasMeeting } from '../../jaas/functions';
|
|
import { showWarningNotification } from '../../notifications/actions';
|
|
import { NOTIFICATION_TIMEOUT_TYPE } from '../../notifications/constants';
|
|
import { stopLocalVideoRecording } from '../../recording/actions.any';
|
|
import LocalRecordingManager from '../../recording/components/Recording/LocalRecordingManager.web';
|
|
import { setJWT } from '../jwt/actions';
|
|
|
|
import { _connectInternal } from './actions.any';
|
|
import logger from './logger';
|
|
|
|
export * from './actions.any';
|
|
|
|
/**
|
|
* Opens new connection.
|
|
*
|
|
* @param {string} [id] - The XMPP user's ID (e.g. {@code user@server.com}).
|
|
* @param {string} [password] - The XMPP user's password.
|
|
* @returns {Function}
|
|
*/
|
|
export function connect(id?: string, password?: string) {
|
|
return (dispatch: IStore['dispatch'], getState: IStore['getState']) => {
|
|
const state = getState();
|
|
const { jwt } = state['features/base/jwt'];
|
|
const { iAmRecorder, iAmSipGateway } = state['features/base/config'];
|
|
|
|
if (!iAmRecorder && !iAmSipGateway && isVpaasMeeting(state)) {
|
|
return dispatch(getCustomerDetails())
|
|
.then(() => {
|
|
if (!jwt) {
|
|
return getJaasJWT(state);
|
|
}
|
|
})
|
|
.then(j => {
|
|
j && dispatch(setJWT(j));
|
|
|
|
return dispatch(_connectInternal(id, password));
|
|
}).catch(e => {
|
|
logger.error('Connection error', e);
|
|
});
|
|
}
|
|
|
|
// used by jibri
|
|
const usernameOverride = jitsiLocalStorage.getItem('xmpp_username_override');
|
|
const passwordOverride = jitsiLocalStorage.getItem('xmpp_password_override');
|
|
|
|
if (usernameOverride && usernameOverride.length > 0) {
|
|
id = usernameOverride; // eslint-disable-line no-param-reassign
|
|
}
|
|
if (passwordOverride && passwordOverride.length > 0) {
|
|
password = passwordOverride; // eslint-disable-line no-param-reassign
|
|
}
|
|
|
|
return dispatch(_connectInternal(id, password));
|
|
};
|
|
}
|
|
|
|
/**
|
|
* Closes connection.
|
|
*
|
|
* @param {boolean} [requestFeedback] - Whether to attempt showing a
|
|
* request for call feedback.
|
|
* @param {string} [feedbackTitle] - The feedback title.
|
|
* @param {boolean} [notifyOnConferenceTermination] - Whether to notify
|
|
* the user on conference termination.
|
|
* @returns {Function}
|
|
*/
|
|
export function hangup(requestFeedback = false, feedbackTitle?: string, notifyOnConferenceTermination?: boolean) {
|
|
// XXX For web based version we use conference hanging up logic from the old app.
|
|
return async (dispatch: IStore['dispatch']) => {
|
|
if (LocalRecordingManager.isRecordingLocally()) {
|
|
dispatch(stopLocalVideoRecording());
|
|
dispatch(showWarningNotification({
|
|
titleKey: 'localRecording.stopping',
|
|
descriptionKey: 'localRecording.wait'
|
|
}, NOTIFICATION_TIMEOUT_TYPE.STICKY));
|
|
|
|
// wait 1000ms for the recording to end and start downloading
|
|
await new Promise(res => {
|
|
setTimeout(res, 1000);
|
|
});
|
|
}
|
|
|
|
return APP.conference.hangup(requestFeedback, feedbackTitle, notifyOnConferenceTermination);
|
|
};
|
|
}
|