2019-12-07 13:28:52 +02:00
|
|
|
import React from 'react';
|
2019-12-10 09:47:32 +02:00
|
|
|
import { RouteComponentProps, Redirect } from 'react-router-dom';
|
2017-09-09 17:22:19 +03:00
|
|
|
import { connect } from 'react-redux';
|
2019-12-07 21:02:00 +02:00
|
|
|
import MultiFactorAuth, {
|
|
|
|
MfaStep,
|
|
|
|
} from 'app/components/profile/multiFactorAuth';
|
|
|
|
import { FormModel } from 'app/components/ui/form';
|
|
|
|
import { User } from 'app/components/user';
|
|
|
|
import { RootState } from 'app/reducers';
|
2019-12-12 09:26:23 +02:00
|
|
|
import Context from 'app/components/profile/Context';
|
2019-12-07 13:28:52 +02:00
|
|
|
|
|
|
|
interface Props
|
|
|
|
extends RouteComponentProps<{
|
|
|
|
step?: '1' | '2' | '3';
|
|
|
|
}> {
|
|
|
|
user: User;
|
|
|
|
}
|
2017-07-22 18:57:38 +03:00
|
|
|
|
2019-12-07 13:28:52 +02:00
|
|
|
class MultiFactorAuthPage extends React.Component<Props> {
|
2019-12-12 09:26:23 +02:00
|
|
|
static contextType = Context;
|
|
|
|
/* TODO: use declare */ context: React.ContextType<typeof Context>;
|
2019-11-27 11:03:32 +02:00
|
|
|
|
2019-12-10 09:47:32 +02:00
|
|
|
render() {
|
|
|
|
const {
|
|
|
|
user,
|
|
|
|
match: {
|
|
|
|
params: { step },
|
|
|
|
},
|
|
|
|
} = this.props;
|
2019-11-27 11:03:32 +02:00
|
|
|
|
|
|
|
if (step) {
|
|
|
|
if (!/^[1-3]$/.test(step)) {
|
|
|
|
// wrong param value
|
2019-12-10 09:47:32 +02:00
|
|
|
return <Redirect to="/404" />;
|
2019-11-27 11:03:32 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
if (user.isOtpEnabled) {
|
2019-12-10 09:47:32 +02:00
|
|
|
return <Redirect to="/mfa" />;
|
2019-11-27 11:03:32 +02:00
|
|
|
}
|
2017-07-22 18:57:38 +03:00
|
|
|
}
|
2019-11-27 11:03:32 +02:00
|
|
|
|
|
|
|
return (
|
|
|
|
<MultiFactorAuth
|
|
|
|
isMfaEnabled={user.isOtpEnabled}
|
|
|
|
onSubmit={this.onSubmit}
|
|
|
|
step={this.getStep()}
|
|
|
|
onChangeStep={this.onChangeStep}
|
|
|
|
onComplete={this.onComplete}
|
|
|
|
/>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
getStep(): MfaStep {
|
2019-12-07 13:28:52 +02:00
|
|
|
const step = Number(this.props.match.params.step) - 1;
|
2019-11-27 11:03:32 +02:00
|
|
|
|
|
|
|
if (step !== 0 && step !== 1 && step !== 2) {
|
2019-12-10 09:47:32 +02:00
|
|
|
return 0;
|
2017-07-22 18:57:38 +03:00
|
|
|
}
|
|
|
|
|
2019-11-27 11:03:32 +02:00
|
|
|
return step;
|
|
|
|
}
|
2017-09-09 18:04:26 +03:00
|
|
|
|
2020-01-17 23:37:52 +03:00
|
|
|
onChangeStep = (step: number) => {
|
2019-11-27 11:03:32 +02:00
|
|
|
this.props.history.push(`/profile/mfa/step${step + 1}`);
|
|
|
|
};
|
2017-07-22 18:57:38 +03:00
|
|
|
|
2019-12-07 13:28:52 +02:00
|
|
|
onSubmit = (form: FormModel, sendData: () => Promise<void>) => {
|
2019-11-27 11:03:32 +02:00
|
|
|
return this.context.onSubmit({
|
|
|
|
form,
|
|
|
|
sendData,
|
|
|
|
});
|
|
|
|
};
|
2017-07-22 18:57:38 +03:00
|
|
|
|
2019-11-27 11:03:32 +02:00
|
|
|
onComplete = () => {
|
|
|
|
this.context.goToProfile();
|
|
|
|
};
|
2017-07-22 18:57:38 +03:00
|
|
|
}
|
|
|
|
|
2019-12-07 13:28:52 +02:00
|
|
|
export default connect(({ user }: RootState) => ({ user }))(
|
2019-11-27 11:03:32 +02:00
|
|
|
MultiFactorAuthPage,
|
|
|
|
);
|