accounts-frontend/src/services/authFlow/LoginState.js

50 lines
1.5 KiB
JavaScript
Raw Normal View History

// @flow
import logger from 'services/logger';
2017-08-23 00:09:08 +05:30
import { getLogin } from 'components/auth/reducer';
2016-03-02 02:06:14 +05:30
import AbstractState from './AbstractState';
import PasswordState from './PasswordState';
import RegisterState from './RegisterState';
2016-03-02 02:06:14 +05:30
import type { AuthContext } from './AuthFlow';
2016-03-02 02:06:14 +05:30
export default class LoginState extends AbstractState {
enter(context: AuthContext) {
2017-08-23 00:09:08 +05:30
const login = getLogin(context.getState());
const {user} = context.getState();
2016-03-02 02:06:14 +05:30
const isUserAddsSecondAccount = !user.isGuest
&& /login|password/.test(context.getRequest().path); // TODO: improve me
// TODO: it may not allow user to leave password state till he click back or enters password
2017-08-23 00:09:08 +05:30
if (login) {
2016-03-02 02:06:14 +05:30
context.setState(new PasswordState());
} else if (user.isGuest || isUserAddsSecondAccount) {
2016-03-02 02:06:14 +05:30
context.navigate('/login');
2016-11-13 20:17:56 +05:30
} else {
// can not detect needed state. Delegating decision to the next state
2016-11-13 20:17:56 +05:30
context.setState(new PasswordState());
2016-03-02 02:06:14 +05:30
}
}
resolve(context: AuthContext, payload: {
login: string
}) {
2016-03-02 02:06:14 +05:30
context.run('login', payload)
.then(() => context.setState(new PasswordState()))
2017-03-02 11:28:33 +05:30
.catch((err = {}) =>
err.errors || logger.warn('Error validating login', err)
);
2016-03-02 02:06:14 +05:30
}
reject(context: AuthContext) {
context.setState(new RegisterState());
}
goBack(context: AuthContext) {
context.run('goBack', {
fallbackUrl: '/'
});
}
2016-03-02 02:06:14 +05:30
}