51 lines
1.5 KiB
TypeScript
Raw Normal View History

import { authenticate, logoutStrangers } from 'app/components/accounts/actions';
import { getActiveAccount } from 'app/components/accounts/reducer';
import request from 'app/services/request';
import { Store } from 'app/types';
2019-12-07 13:28:52 +02:00
import { changeLang } from './actions';
import bearerHeaderMiddleware from './middlewares/bearerHeaderMiddleware';
import refreshTokenMiddleware from './middlewares/refreshTokenMiddleware';
2019-12-07 13:28:52 +02:00
let promise: Promise<void>;
2016-08-09 22:17:49 +03:00
/**
* Initializes User state with the fresh data
*
* @param {object} store - redux store
*
* @returns {Promise<User>} - a promise, that resolves in User state
*/
2019-12-07 13:28:52 +02:00
export function factory(store: Store): Promise<void> {
2020-05-24 02:08:24 +03:00
if (promise) {
return promise;
}
2016-08-09 22:17:49 +03:00
2020-05-24 02:08:24 +03:00
request.addMiddleware(refreshTokenMiddleware(store));
request.addMiddleware(bearerHeaderMiddleware(store));
2020-05-24 02:08:24 +03:00
promise = Promise.resolve()
.then(() => store.dispatch(logoutStrangers()))
.then(async () => {
const activeAccount = getActiveAccount(store.getState());
2020-05-24 02:08:24 +03:00
if (activeAccount) {
// authorizing user if it is possible
await store.dispatch(authenticate(activeAccount));
2019-12-07 13:28:52 +02:00
2020-05-24 02:08:24 +03:00
return;
}
2020-05-24 02:08:24 +03:00
throw new Error('No active account found');
})
.catch(async () => {
// the user is guest or user authentication failed
const { user } = store.getState();
2020-05-24 02:08:24 +03:00
// auto-detect guest language
await store.dispatch(changeLang(user.lang));
});
2016-08-09 22:17:49 +03:00
2020-05-24 02:08:24 +03:00
return promise;
}