accounts-frontend/packages/app/pages/profile/MultiFactorAuthPage.tsx

82 lines
1.8 KiB
TypeScript
Raw Permalink Normal View History

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';
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-12-10 09:47:32 +02:00
render() {
const {
user,
match: {
params: { step },
},
} = this.props;
if (step) {
if (!/^[1-3]$/.test(step)) {
// wrong param value
2019-12-10 09:47:32 +02:00
return <Redirect to="/404" />;
}
if (user.isOtpEnabled) {
2019-12-10 09:47:32 +02:00
return <Redirect to="/mfa" />;
}
2017-07-22 18:57:38 +03: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;
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
}
return step;
}
onChangeStep = (step: MfaStep) => {
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>) => {
return this.context.onSubmit({
form,
sendData,
});
};
2017-07-22 18:57:38 +03: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 }))(
MultiFactorAuthPage,
);