-
Notifications
You must be signed in to change notification settings - Fork 8.3k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Browse files
Browse the repository at this point in the history
Co-authored-by: Patryk Kopyciński <[email protected]>
- Loading branch information
1 parent
457e11f
commit 79c3c9d
Showing
30 changed files
with
460 additions
and
177 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
2 changes: 1 addition & 1 deletion
2
x-pack/plugins/osquery/public/common/schemas/osquery/v5.0.1.json
Large diffs are not rendered by default.
Oops, something went wrong.
This file was deleted.
Oops, something went wrong.
132 changes: 132 additions & 0 deletions
132
x-pack/plugins/osquery/public/fleet_integration/config_uploader.tsx
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,132 @@ | ||
/* | ||
* Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one | ||
* or more contributor license agreements. Licensed under the Elastic License | ||
* 2.0; you may not use this file except in compliance with the Elastic License | ||
* 2.0. | ||
*/ | ||
|
||
import { EuiLink, EuiFormRow, EuiFilePicker, EuiSpacer } from '@elastic/eui'; | ||
import React, { useCallback, useState, useRef } from 'react'; | ||
import { i18n } from '@kbn/i18n'; | ||
import { FormattedMessage } from '@kbn/i18n/react'; | ||
|
||
const SUPPORTED_CONFIG_EXTENSIONS = ['application/json', 'text/plain']; | ||
|
||
const ExampleConfigLink = React.memo(() => ( | ||
<EuiLink | ||
href="https://github.com/osquery/osquery/blob/master/tools/deployment/osquery.example.conf" | ||
target="_blank" | ||
> | ||
<FormattedMessage | ||
id="xpack.osquery.configUploader.exampleConfigLinkLabel" | ||
defaultMessage="Example config" | ||
/> | ||
</EuiLink> | ||
)); | ||
|
||
ExampleConfigLink.displayName = 'ExampleOsqueryConfigLink'; | ||
|
||
interface ConfigUploaderProps { | ||
onChange: (payload: Record<string, unknown>) => void; | ||
} | ||
|
||
const ConfigUploaderComponent: React.FC<ConfigUploaderProps> = ({ onChange }) => { | ||
const filePickerRef = useRef<EuiFilePicker>(null); | ||
const [isInvalid, setIsInvalid] = useState<string | null>(null); | ||
// @ts-expect-error update types | ||
let fileReader; | ||
|
||
const handleFileRead = () => { | ||
// @ts-expect-error update types | ||
const content = fileReader.result; | ||
|
||
let parsedContent; | ||
|
||
try { | ||
parsedContent = JSON.parse(content.replaceAll('\\\n', ''), (key, value) => { | ||
if (key === 'query') { | ||
// remove any multiple spaces from the query | ||
return value.replaceAll(/\s(?=\s)/gm, ''); | ||
} | ||
return value; | ||
}); | ||
|
||
setIsInvalid(null); | ||
} catch (error) { | ||
setIsInvalid(error); | ||
// @ts-expect-error update types | ||
filePickerRef.current?.removeFiles(new Event('fake')); | ||
} | ||
|
||
onChange(parsedContent); | ||
// @ts-expect-error update types | ||
filePickerRef.current?.removeFiles(new Event('fake')); | ||
}; | ||
|
||
// @ts-expect-error update types | ||
// eslint-disable-next-line react-hooks/exhaustive-deps | ||
const handleFileChosen = (file) => { | ||
fileReader = new FileReader(); | ||
fileReader.onloadend = handleFileRead; | ||
fileReader.readAsText(file); | ||
}; | ||
|
||
const handleInputChange = useCallback( | ||
(inputFiles) => { | ||
if (!inputFiles.length) { | ||
return; | ||
} | ||
|
||
if ( | ||
inputFiles.length && | ||
((!!inputFiles[0].type.length && | ||
!SUPPORTED_CONFIG_EXTENSIONS.includes(inputFiles[0].type)) ?? | ||
!inputFiles[0].name.endsWith('.conf')) | ||
) { | ||
setIsInvalid( | ||
i18n.translate('xpack.osquery.configUploader.unsupportedFileTypeText', { | ||
defaultMessage: | ||
'File type {fileType} is not supported, please upload {supportedFileTypes} config file', | ||
values: { | ||
fileType: inputFiles[0].type, | ||
supportedFileTypes: SUPPORTED_CONFIG_EXTENSIONS.join(' or '), | ||
}, | ||
}) | ||
); | ||
// @ts-expect-error update types | ||
filePickerRef.current?.removeFiles(new Event('fake')); | ||
return; | ||
} | ||
|
||
handleFileChosen(inputFiles[0]); | ||
}, | ||
[handleFileChosen] | ||
); | ||
|
||
return ( | ||
<> | ||
<EuiSpacer size="xl" /> | ||
<EuiFormRow | ||
fullWidth | ||
labelAppend={<ExampleConfigLink />} | ||
isInvalid={!!isInvalid} | ||
error={<>{`${isInvalid}`}</>} | ||
> | ||
<EuiFilePicker | ||
ref={filePickerRef} | ||
id="osquery_config_picker" | ||
initialPromptText={i18n.translate('xpack.osquery.configUploader.initialPromptTextLabel', { | ||
defaultMessage: 'Select or drag and drop osquery config file', | ||
})} | ||
onChange={handleInputChange} | ||
display="large" | ||
fullWidth | ||
isInvalid={!!isInvalid} | ||
accept={SUPPORTED_CONFIG_EXTENSIONS.join(',')} | ||
/> | ||
</EuiFormRow> | ||
</> | ||
); | ||
}; | ||
|
||
export const ConfigUploader = React.memo(ConfigUploaderComponent); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.