196 lines
7.7 KiB
JavaScript
196 lines
7.7 KiB
JavaScript
|
import React from 'react';
|
||
|
import PropTypes from 'prop-types';
|
||
|
import { Field, reduxForm } from 'redux-form';
|
||
|
import { Trans, withNamespaces } from 'react-i18next';
|
||
|
import flow from 'lodash/flow';
|
||
|
|
||
|
import { renderField, renderSelectField, required, toNumber, port } from '../../../helpers/form';
|
||
|
import i18n from '../../../i18n';
|
||
|
|
||
|
const validate = (values) => {
|
||
|
const errors = {};
|
||
|
|
||
|
if (values.port_dns_over_tls === values.port_https) {
|
||
|
errors.port_dns_over_tls = i18n.t('form_error_equal');
|
||
|
errors.port_https = i18n.t('form_error_equal');
|
||
|
}
|
||
|
|
||
|
return errors;
|
||
|
};
|
||
|
|
||
|
const Form = (props) => {
|
||
|
const {
|
||
|
t,
|
||
|
handleSubmit,
|
||
|
invalid,
|
||
|
submitting,
|
||
|
processing,
|
||
|
} = props;
|
||
|
|
||
|
return (
|
||
|
<form onSubmit={handleSubmit}>
|
||
|
<div className="row">
|
||
|
<div className="col-12">
|
||
|
<label className="form__label" htmlFor="server_name">
|
||
|
<Trans>encryption_server</Trans>
|
||
|
</label>
|
||
|
</div>
|
||
|
<div className="col-lg-6">
|
||
|
<div className="form__group form__group--settings">
|
||
|
<Field
|
||
|
id="server_name"
|
||
|
name="server_name"
|
||
|
component={renderField}
|
||
|
type="text"
|
||
|
className="form-control"
|
||
|
placeholder={t('encryption_server_enter')}
|
||
|
validate={[required]}
|
||
|
/>
|
||
|
<div className="form__desc">
|
||
|
<Trans>encryption_server_desc</Trans>
|
||
|
</div>
|
||
|
</div>
|
||
|
</div>
|
||
|
<div className="col-lg-6">
|
||
|
<div className="form__group form__group--settings">
|
||
|
<Field
|
||
|
name="force_https"
|
||
|
type="checkbox"
|
||
|
component={renderSelectField}
|
||
|
placeholder={t('encryption_redirect')}
|
||
|
/>
|
||
|
<div className="form__desc">
|
||
|
<Trans>encryption_redirect_desc</Trans>
|
||
|
</div>
|
||
|
</div>
|
||
|
</div>
|
||
|
</div>
|
||
|
<div className="row">
|
||
|
<div className="col-lg-6">
|
||
|
<div className="form__group form__group--settings">
|
||
|
<label className="form__label" htmlFor="port_https">
|
||
|
<Trans>encryption_https</Trans>
|
||
|
</label>
|
||
|
<Field
|
||
|
id="port_https"
|
||
|
name="port_https"
|
||
|
component={renderField}
|
||
|
type="number"
|
||
|
className="form-control"
|
||
|
placeholder={t('encryption_https')}
|
||
|
validate={[required, port]}
|
||
|
normalize={toNumber}
|
||
|
/>
|
||
|
<div className="form__desc">
|
||
|
<Trans>encryption_https_desc</Trans>
|
||
|
</div>
|
||
|
</div>
|
||
|
</div>
|
||
|
<div className="col-lg-6">
|
||
|
<div className="form__group form__group--settings">
|
||
|
<label className="form__label" htmlFor="port_dns_over_tls">
|
||
|
<Trans>encryption_dot</Trans>
|
||
|
</label>
|
||
|
<Field
|
||
|
id="port_dns_over_tls"
|
||
|
name="port_dns_over_tls"
|
||
|
component={renderField}
|
||
|
type="number"
|
||
|
className="form-control"
|
||
|
placeholder={t('encryption_dot')}
|
||
|
validate={[required, port]}
|
||
|
normalize={toNumber}
|
||
|
/>
|
||
|
<div className="form__desc">
|
||
|
<Trans>encryption_dot_desc</Trans>
|
||
|
</div>
|
||
|
</div>
|
||
|
</div>
|
||
|
</div>
|
||
|
<div className="row">
|
||
|
<div className="col-12">
|
||
|
<div className="form__group form__group--settings">
|
||
|
<label className="form__label form__label--bold" htmlFor="certificate_chain">
|
||
|
<Trans>encryption_certificates</Trans>
|
||
|
</label>
|
||
|
<div className="form__desc form__desc--top">
|
||
|
<Trans>encryption_certificates_desc</Trans>
|
||
|
</div>
|
||
|
<Field
|
||
|
id="certificate_chain"
|
||
|
name="certificate_chain"
|
||
|
component="textarea"
|
||
|
type="text"
|
||
|
className="form-control form-control--textarea"
|
||
|
placeholder={t('encryption_certificates_input')}
|
||
|
validate={[required]}
|
||
|
/>
|
||
|
<div className="form__status">
|
||
|
<div className="form__label form__label--bold">
|
||
|
<Trans>encryption_status</Trans>:
|
||
|
</div>
|
||
|
<div>
|
||
|
<Trans>encryption_certificates_for</Trans>
|
||
|
*.example.org, example.org
|
||
|
</div>
|
||
|
<div>
|
||
|
<Trans>encryption_expire</Trans>
|
||
|
2022-01-01
|
||
|
</div>
|
||
|
</div>
|
||
|
</div>
|
||
|
</div>
|
||
|
</div>
|
||
|
<div className="row">
|
||
|
<div className="col-12">
|
||
|
<div className="form__group form__group--settings">
|
||
|
<label className="form__label form__label--bold" htmlFor="private_key">
|
||
|
<Trans>encryption_key</Trans>
|
||
|
</label>
|
||
|
<Field
|
||
|
id="private_key"
|
||
|
name="private_key"
|
||
|
component="textarea"
|
||
|
type="text"
|
||
|
className="form-control form-control--textarea"
|
||
|
placeholder="Copy/paste your PEM-encoded private key for your cerficate here."
|
||
|
validate={[required]}
|
||
|
/>
|
||
|
<div className="form__status">
|
||
|
<div className="form__label form__label--bold">
|
||
|
<Trans>encryption_status</Trans>:
|
||
|
</div>
|
||
|
<div>Valid RSA private key</div>
|
||
|
</div>
|
||
|
</div>
|
||
|
</div>
|
||
|
</div>
|
||
|
|
||
|
<button
|
||
|
type="submit"
|
||
|
className="btn btn-success btn-standart"
|
||
|
disabled={invalid || submitting || processing}
|
||
|
>
|
||
|
{t('save_config')}
|
||
|
</button>
|
||
|
</form>
|
||
|
);
|
||
|
};
|
||
|
|
||
|
Form.propTypes = {
|
||
|
handleSubmit: PropTypes.func.isRequired,
|
||
|
submitting: PropTypes.bool.isRequired,
|
||
|
invalid: PropTypes.bool.isRequired,
|
||
|
initialValues: PropTypes.object.isRequired,
|
||
|
processing: PropTypes.bool.isRequired,
|
||
|
t: PropTypes.func.isRequired,
|
||
|
};
|
||
|
|
||
|
export default flow([
|
||
|
withNamespaces(),
|
||
|
reduxForm({
|
||
|
form: 'encryptionForm',
|
||
|
validate,
|
||
|
}),
|
||
|
])(Form);
|