From 8013dcdadfdeba35a6d043ca7339bf0515732780 Mon Sep 17 00:00:00 2001 From: Nikita Indik Date: Sun, 17 Nov 2024 18:56:48 +0100 Subject: [PATCH] Add `anomaly_threshold` --- .../anomaly_threshold_edit.tsx | 24 ++++++++++ .../components/anomaly_threshold/index.ts | 8 ++++ .../components/step_define_rule/index.tsx | 10 +--- .../anomaly_threshold_adapter.tsx | 13 ++++++ .../anomaly_threshold_form.tsx | 46 +++++++++++++++++++ .../machine_learning_rule_field_edit.tsx | 6 ++- 6 files changed, 98 insertions(+), 9 deletions(-) create mode 100644 x-pack/plugins/security_solution/public/detection_engine/rule_creation/components/anomaly_threshold/anomaly_threshold_edit.tsx create mode 100644 x-pack/plugins/security_solution/public/detection_engine/rule_creation/components/anomaly_threshold/index.ts create mode 100644 x-pack/plugins/security_solution/public/detection_engine/rule_management/components/rule_details/three_way_diff/final_edit/fields/anomaly_threshold/anomaly_threshold_adapter.tsx create mode 100644 x-pack/plugins/security_solution/public/detection_engine/rule_management/components/rule_details/three_way_diff/final_edit/fields/anomaly_threshold/anomaly_threshold_form.tsx diff --git a/x-pack/plugins/security_solution/public/detection_engine/rule_creation/components/anomaly_threshold/anomaly_threshold_edit.tsx b/x-pack/plugins/security_solution/public/detection_engine/rule_creation/components/anomaly_threshold/anomaly_threshold_edit.tsx new file mode 100644 index 000000000000..1cafa5dc570b --- /dev/null +++ b/x-pack/plugins/security_solution/public/detection_engine/rule_creation/components/anomaly_threshold/anomaly_threshold_edit.tsx @@ -0,0 +1,24 @@ +/* + * 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 React from 'react'; +import { UseField } from '../../../../shared_imports'; +import { AnomalyThresholdSlider } from '../../../rule_creation_ui/components/anomaly_threshold_slider'; + +const componentProps = { + describedByIds: ['anomalyThreshold'], +}; + +interface AnomalyThresholdEditProps { + path: string; +} + +export function AnomalyThresholdEdit({ path }: AnomalyThresholdEditProps): JSX.Element { + return ( + + ); +} diff --git a/x-pack/plugins/security_solution/public/detection_engine/rule_creation/components/anomaly_threshold/index.ts b/x-pack/plugins/security_solution/public/detection_engine/rule_creation/components/anomaly_threshold/index.ts new file mode 100644 index 000000000000..406e55579565 --- /dev/null +++ b/x-pack/plugins/security_solution/public/detection_engine/rule_creation/components/anomaly_threshold/index.ts @@ -0,0 +1,8 @@ +/* + * 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. + */ + +export { AnomalyThresholdEdit } from './anomaly_threshold_edit'; diff --git a/x-pack/plugins/security_solution/public/detection_engine/rule_creation_ui/components/step_define_rule/index.tsx b/x-pack/plugins/security_solution/public/detection_engine/rule_creation_ui/components/step_define_rule/index.tsx index a94e88a483f3..ec598ce74fe5 100644 --- a/x-pack/plugins/security_solution/public/detection_engine/rule_creation_ui/components/step_define_rule/index.tsx +++ b/x-pack/plugins/security_solution/public/detection_engine/rule_creation_ui/components/step_define_rule/index.tsx @@ -43,7 +43,6 @@ import { StepRuleDescription } from '../description_step'; import type { QueryBarDefineRuleProps } from '../query_bar'; import { QueryBarDefineRule } from '../query_bar'; import { SelectRuleType } from '../select_rule_type'; -import { AnomalyThresholdSlider } from '../anomaly_threshold_slider'; import { PickTimeline } from '../../../rule_creation/components/pick_timeline'; import { StepContentWrapper } from '../../../rule_creation/components/step_content_wrapper'; import { ThresholdInput } from '../threshold_input'; @@ -96,6 +95,7 @@ import { import { ThresholdAlertSuppressionEdit } from '../../../rule_creation/components/threshold_alert_suppression_edit'; import { usePersistentAlertSuppressionState } from './use_persistent_alert_suppression_state'; import { MachineLearningJobIdEdit } from '../../../rule_creation/components/machine_learning_job_id_edit'; +import { AnomalyThresholdEdit } from '../../../rule_creation/components/anomaly_threshold'; const CommonUseField = getUseField({ component: Field }); @@ -806,13 +806,7 @@ const StepDefineRuleComponent: FC = ({ <> - + ; +} diff --git a/x-pack/plugins/security_solution/public/detection_engine/rule_management/components/rule_details/three_way_diff/final_edit/fields/anomaly_threshold/anomaly_threshold_form.tsx b/x-pack/plugins/security_solution/public/detection_engine/rule_management/components/rule_details/three_way_diff/final_edit/fields/anomaly_threshold/anomaly_threshold_form.tsx new file mode 100644 index 000000000000..8cce8da19aa6 --- /dev/null +++ b/x-pack/plugins/security_solution/public/detection_engine/rule_management/components/rule_details/three_way_diff/final_edit/fields/anomaly_threshold/anomaly_threshold_form.tsx @@ -0,0 +1,46 @@ +/* + * 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 React from 'react'; +import type { FormData, FormSchema } from '../../../../../../../../shared_imports'; +import { schema } from '../../../../../../../rule_creation_ui/components/step_define_rule/schema'; +import { RuleFieldEditFormWrapper } from '../rule_field_edit_form_wrapper'; +import { AnomalyThresholdAdapter } from './anomaly_threshold_adapter'; +import type { AnomalyThreshold } from '../../../../../../../../../common/api/detection_engine'; + +interface AnomalyThresholdFormData { + anomalyThreshold: AnomalyThreshold; +} + +export function AnomalyThresholdForm(): JSX.Element { + return ( + + ); +} + +function deserializer(defaultValue: FormData): AnomalyThresholdFormData { + return { + anomalyThreshold: defaultValue.anomaly_threshold, + }; +} + +function serializer(formData: FormData): { + anomaly_threshold: AnomalyThresholdFormData; +} { + return { + anomaly_threshold: formData.anomalyThreshold, + }; +} + +const anomalyThresholdSchema = { + anomalyThreshold: schema.anomalyThreshold, +} as FormSchema; diff --git a/x-pack/plugins/security_solution/public/detection_engine/rule_management/components/rule_details/three_way_diff/final_edit/machine_learning_rule_field_edit.tsx b/x-pack/plugins/security_solution/public/detection_engine/rule_management/components/rule_details/three_way_diff/final_edit/machine_learning_rule_field_edit.tsx index da40ce843f72..9563c64da7da 100644 --- a/x-pack/plugins/security_solution/public/detection_engine/rule_management/components/rule_details/three_way_diff/final_edit/machine_learning_rule_field_edit.tsx +++ b/x-pack/plugins/security_solution/public/detection_engine/rule_management/components/rule_details/three_way_diff/final_edit/machine_learning_rule_field_edit.tsx @@ -7,8 +7,10 @@ import React from 'react'; import type { UpgradeableMachineLearningFields } from '../../../../model/prebuilt_rule_upgrade/fields'; +import { AnomalyThresholdForm } from './fields/anomaly_threshold/anomaly_threshold_form'; import { AlertSuppressionEditForm } from './fields/alert_suppression'; import { MachineLearningJobIdForm } from './fields/machine_learning_job_id/machine_learning_job_id_form'; +import { assertUnreachable } from '../../../../../../../common/utility_types'; interface MachineLearningRuleFieldEditProps { fieldName: UpgradeableMachineLearningFields; @@ -18,9 +20,11 @@ export function MachineLearningRuleFieldEdit({ fieldName }: MachineLearningRuleF switch (fieldName) { case 'alert_suppression': return ; + case 'anomaly_threshold': + return ; case 'machine_learning_job_id': return ; default: - return null; // Will be replaced with `assertUnreachable(fieldName)` once all fields are implemented + return assertUnreachable(fieldName); } }