51 lines
1.4 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/reducers';
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> {
if (promise) {
return promise;
}
2016-08-09 22:17:49 +03:00
request.addMiddleware(refreshTokenMiddleware(store));
request.addMiddleware(bearerHeaderMiddleware(store));
promise = Promise.resolve()
.then(() => store.dispatch(logoutStrangers()))
2019-12-07 13:28:52 +02:00
.then(async () => {
const activeAccount = getActiveAccount(store.getState());
if (activeAccount) {
// authorizing user if it is possible
2019-12-07 13:28:52 +02:00
await store.dispatch(authenticate(activeAccount));
return;
}
return Promise.reject();
})
2019-12-07 13:28:52 +02:00
.catch(async () => {
// the user is guest or user authentication failed
const { user } = store.getState();
// auto-detect guest language
2019-12-07 13:28:52 +02:00
await store.dispatch(changeLang(user.lang));
});
2016-08-09 22:17:49 +03:00
return promise;
}