2017-09-09 17:22:19 +03:00
|
|
|
// @flow
|
|
|
|
import React, { Component } from 'react';
|
2019-01-27 22:12:58 +03:00
|
|
|
import PropTypes from 'prop-types';
|
2017-09-09 17:22:19 +03:00
|
|
|
|
|
|
|
import logger from 'services/logger';
|
2019-01-27 22:12:58 +03:00
|
|
|
import { disable as disableMFA } from 'services/api/mfa';
|
2017-09-09 17:22:19 +03:00
|
|
|
|
|
|
|
import MfaDisableForm from './disableForm/MfaDisableForm';
|
|
|
|
import MfaStatus from './status/MfaStatus';
|
|
|
|
|
|
|
|
import type { FormModel } from 'components/ui/form';
|
|
|
|
|
|
|
|
export default class MfaDisable extends Component<{
|
|
|
|
onSubmit: (form: FormModel, sendData: () => Promise<*>) => Promise<*>,
|
|
|
|
onComplete: Function
|
|
|
|
}, {
|
|
|
|
showForm?: bool
|
|
|
|
}> {
|
2019-01-27 22:12:58 +03:00
|
|
|
static contextTypes = {
|
|
|
|
userId: PropTypes.number.isRequired,
|
|
|
|
};
|
|
|
|
|
2017-09-09 17:22:19 +03:00
|
|
|
state = {};
|
|
|
|
|
|
|
|
render() {
|
|
|
|
const { showForm } = this.state;
|
|
|
|
|
|
|
|
return showForm ? (
|
|
|
|
<MfaDisableForm onSubmit={this.onSubmit}/>
|
|
|
|
) : (
|
|
|
|
<MfaStatus onProceed={this.onProceed} />
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
onProceed = () => this.setState({showForm: true});
|
|
|
|
|
|
|
|
onSubmit = (form: FormModel) => {
|
|
|
|
return this.props.onSubmit(
|
|
|
|
form,
|
|
|
|
() => {
|
|
|
|
const data = form.serialize();
|
|
|
|
|
2019-01-27 22:12:58 +03:00
|
|
|
return disableMFA(this.context.userId, data);
|
2017-09-09 17:22:19 +03:00
|
|
|
}
|
|
|
|
)
|
|
|
|
.then(() => this.props.onComplete())
|
|
|
|
.catch((resp) => {
|
|
|
|
const {errors} = resp || {};
|
|
|
|
|
|
|
|
if (errors) {
|
|
|
|
return Promise.reject(errors);
|
|
|
|
}
|
|
|
|
|
|
|
|
logger.error('MFA: Unexpected disable form result', {
|
|
|
|
resp
|
|
|
|
});
|
|
|
|
});
|
|
|
|
};
|
|
|
|
}
|