jiti-meet/react/features/dropbox/actions.ts

54 lines
1.7 KiB
TypeScript
Raw Permalink Normal View History

import { UPDATE_DROPBOX_TOKEN } from './actionTypes';
import { _authorizeDropbox } from './functions';
import logger from './logger';
/**
* Action to authorize the Jitsi Recording app in dropbox.
*
* @returns {Function}
*/
export function authorizeDropbox() {
return (dispatch: Function, getState: Function) => {
const state = getState();
const { locationURL } = state['features/base/connection'];
const { dropbox = {} } = state['features/base/config'];
// By default we use the static page on the main domain for redirection.
// So we need to setup only one redirect URI in dropbox app
// configuration (not multiple for all the tenants).
// In case deployment is running in subfolder dropbox.redirectURI
// can be configured.
const redirectURI
= dropbox.redirectURI || `${locationURL.origin}/static/oauth.html`;
_authorizeDropbox(dropbox.appKey, redirectURI)
.then(
({ token, rToken, expireDate }) => {
dispatch(updateDropboxToken(token, rToken, expireDate));
})
.catch(error => logger.log('Cannot authorize dropbox', error));
};
}
/**
* Action to update the dropbox access token.
*
* @param {string} token - The new token.
* @param {string} rToken - The refresh token.
* @param {number} expireDate - The token expiration date as UNIX timestamp.
* @returns {{
* type: UPDATE_DROPBOX_TOKEN,
* token: string,
* rToken: string,
* expireDate: number
* }}
*/
export function updateDropboxToken(token?: string, rToken?: string, expireDate?: number) {
return {
type: UPDATE_DROPBOX_TOKEN,
token,
rToken,
expireDate
};
}