61 lines
1.7 KiB
TypeScript
Raw Normal View History

import React, { MouseEventHandler } from 'react';
import logger from 'app/services/logger';
import { disable as disableMFA } from 'app/services/api/mfa';
import { FormModel } from 'app/components/ui/form';
2017-09-09 17:22:19 +03:00
2019-12-12 09:26:23 +02:00
import Context from '../Context';
import MfaDisableForm from './MfaDisableForm';
import MfaStatus from './MfaStatus';
2017-09-09 17:22:19 +03:00
2019-12-07 13:28:52 +02:00
export default class MfaDisable extends React.Component<
2020-05-24 02:08:24 +03:00
{
onSubmit: (form: FormModel, sendData: () => Promise<void>) => Promise<void>;
onComplete: () => void;
},
{
showForm: boolean;
}
> {
2020-05-24 02:08:24 +03:00
static contextType = Context;
declare context: React.ContextType<typeof Context>;
2020-05-24 02:08:24 +03:00
state = {
showForm: false,
};
render() {
const { showForm } = this.state;
return showForm ? <MfaDisableForm onSubmit={this.onSubmit} /> : <MfaStatus onProceed={this.onProceed} />;
}
onProceed: MouseEventHandler<HTMLAnchorElement> = (event) => {
event.preventDefault();
this.setState({ showForm: true });
};
2020-05-24 02:08:24 +03:00
onSubmit = (form: FormModel) => {
return this.props
.onSubmit(form, () => {
const { totp, password } = form.serialize() as {
totp: string;
password?: string;
};
return disableMFA(this.context.userId, totp, password);
})
.then(() => this.props.onComplete())
.catch((resp) => {
const { errors } = resp || {};
if (errors) {
return Promise.reject(errors);
}
logger.error('MFA: Unexpected disable form result', {
resp,
});
});
};
2017-09-09 17:22:19 +03:00
}