accounts-frontend/packages/app/services/authFlow/PasswordState.ts

91 lines
2.9 KiB
TypeScript
Raw Normal View History

import logger from 'app/services/logger';
import { getCredentials } from 'app/components/auth/reducer';
2020-05-24 04:38:24 +05:30
import { getActiveAccount, getAvailableAccounts } from 'app/components/accounts/reducer';
2016-03-02 02:06:14 +05:30
import AbstractState from './AbstractState';
import ChooseAccountState from './ChooseAccountState';
2016-03-02 02:06:14 +05:30
import CompleteState from './CompleteState';
import ForgotPasswordState from './ForgotPasswordState';
import LoginState from './LoginState';
2017-08-23 00:09:08 +05:30
import MfaState from './MfaState';
2019-12-07 16:58:52 +05:30
import { AuthContext } from './AuthFlow';
2016-03-02 02:06:14 +05:30
export default class PasswordState extends AbstractState {
2020-05-24 04:38:24 +05:30
enter(context: AuthContext): Promise<void> | void {
const { login, isTotpRequired } = getCredentials(context.getState());
2016-03-02 02:06:14 +05:30
2020-05-24 04:38:24 +05:30
if (isTotpRequired) {
context.setState(new MfaState());
} else if (login) {
context.navigate('/password');
} else {
context.setState(new CompleteState());
}
2016-03-02 02:06:14 +05:30
}
2020-05-24 04:38:24 +05:30
resolve(
context: AuthContext,
{
password,
rememberMe,
}: {
password: string;
rememberMe: boolean;
},
): Promise<void> | void {
const { login, returnUrl } = getCredentials(context.getState());
2016-03-02 02:06:14 +05:30
2020-05-24 04:38:24 +05:30
return context
.run('login', {
password,
rememberMe,
login,
})
.then(() => {
const { isTotpRequired } = getCredentials(context.getState());
2020-05-24 04:38:24 +05:30
if (isTotpRequired) {
return context.setState(new MfaState());
}
2020-05-24 04:38:24 +05:30
if (returnUrl) {
context.navigate(returnUrl);
2020-05-24 04:38:24 +05:30
return;
}
2016-03-02 02:06:14 +05:30
2020-05-24 04:38:24 +05:30
return context.setState(new CompleteState());
})
.catch((err = {}) => err.errors || logger.warn('Error logging in', err));
}
2016-03-02 02:06:14 +05:30
2020-05-24 04:38:24 +05:30
reject(context: AuthContext): void {
context.setState(new ForgotPasswordState());
}
2020-05-24 04:38:24 +05:30
goBack(context: AuthContext): void {
const state = context.getState();
const { isRelogin } = getCredentials(state);
2020-05-24 04:38:24 +05:30
if (isRelogin) {
const availableAccounts = getAvailableAccounts(state);
const accountToRemove = getActiveAccount(state);
2020-05-24 04:38:24 +05:30
if (availableAccounts.length === 1 || !accountToRemove) {
context.run('logout');
context.run('setLogin', null);
context.setState(new LoginState());
} else {
const accountToReplace = availableAccounts.find(({ id }) => id !== accountToRemove.id);
2020-05-24 04:38:24 +05:30
context.run('activateAccount', accountToReplace);
context.run('removeAccount', accountToRemove);
context.setState(new ChooseAccountState());
}
} else {
context.run('setLogin', null);
context.setState(new LoginState());
}
2016-03-02 02:06:14 +05:30
}
}