openreplay/frontend/app/components/Client/Integrations/ElasticsearchForm.js
2021-05-04 18:59:46 +05:30

74 lines
2.2 KiB
JavaScript

import { connect } from 'react-redux';
import IntegrationForm from './IntegrationForm';
import { withRequest } from 'HOCs';
import { edit } from 'Duck/integrations/actions';
import DocLink from 'Shared/DocLink/DocLink';
@connect(state => ({
config: state.getIn([ 'elasticsearch', 'instance' ])
}), { edit })
@withRequest({
dataName: "isValid",
initialData: false,
dataWrapper: data => data.state,
requestName: "validateConfig",
endpoint: '/integrations/elasticsearch/test',
method: 'POST',
})
export default class ElasticsearchForm extends React.PureComponent {
componentWillReceiveProps(newProps) {
const { config: { host, port, apiKeyId, apiKey } } = this.props;
const { loading, config } = newProps;
const valuesChanged = host !== config.host || port !== config.port || apiKeyId !== config.apiKeyId || apiKey !== config.apiKey;
if (!loading && valuesChanged && newProps.config.validateKeys() && newProps) {
this.validateConfig(newProps);
}
}
validateConfig = (newProps) => {
const { config } = newProps;
this.props.validateConfig({
host: config.host,
port: config.port,
apiKeyId: config.apiKeyId,
apiKey: config.apiKey,
}).then((res) => {
const { isValid } = this.props;
this.props.edit('elasticsearch', { isValid: isValid })
});
}
render() {
const props = this.props;
return (
<>
<div className="p-5 border-b mb-4">
<div>How to integrate Elasticsearch with OpenReplay and see backend errors alongside session recordings.</div>
<DocLink className="mt-4" label="Integrate Elasticsearch" url="https://docs.openreplay.com/integrations/elastic" />
</div>
<IntegrationForm
{ ...props }
name="elasticsearch"
formFields={[ {
key: "host",
label: "Host",
}, {
key: "apiKeyId",
label: "API Key ID",
}, {
key: "apiKey",
label: "API Key",
}, {
key: "indexes",
label: "Indexes",
}, {
key: "port",
label: "Port",
type: "number",
}
]}
/>
</>
)
}
};