-
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.
[Security Solution] Integrate state and components for Prebuilt Rule …
…Update Workflow (#193531) **Epic:** #174168 **Addresses:** #171520 ## Summary This PR introduces a new `Update` tab allowing users to resolve rule upgrade conflicts. It's a result of combination of read-only components implemented in #193261 and rule upgrade state implemented in #191721. ## Details The goal of this PR is to provide intermediate integration between rule upgrade state ([PR](#191721)) and components displaying the diff and read-only state ([PR](#193261)). It will facilitate further development of rule field editable components and streamline rule upgrade functionality developing. ## How to test? The functionality is hidden under `prebuiltRulesCustomizationEnabled` feature flag. Add the following to your Kibana config ```yaml xpack.securitySolution.enableExperimental: - prebuiltRulesCustomizationEnabled ``` When the above feature flag enabled the new `Update` tab is displayed instead of the old one. ## Screenshots Suggested components design ![image](https://github.com/user-attachments/assets/b5aaf571-286a-4595-9bd4-fdaf9a423b03) New `Update` tab <img width="1718" alt="image" src="https://github.com/user-attachments/assets/28aa6bb3-f805-4109-a808-d67e58c7c5b8">
- Loading branch information
Showing
21 changed files
with
538 additions
and
141 deletions.
There are no files selected for viewing
8 changes: 8 additions & 0 deletions
8
x-pack/plugins/security_solution/public/common/components/split_accordion/index.ts
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,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 * from './split_accordion'; |
47 changes: 47 additions & 0 deletions
47
...ck/plugins/security_solution/public/common/components/split_accordion/split_accordion.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,47 @@ | ||
/* | ||
* 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 { EuiAccordion, EuiSplitPanel, useEuiTheme, useGeneratedHtmlId } from '@elastic/eui'; | ||
import { css } from '@emotion/css'; | ||
import type { PropsWithChildren } from 'react'; | ||
|
||
interface SplitAccordionProps { | ||
header: React.ReactNode; | ||
initialIsOpen?: boolean; | ||
'data-test-subj'?: string; | ||
} | ||
|
||
export const SplitAccordion = ({ | ||
header, | ||
initialIsOpen, | ||
'data-test-subj': dataTestSubj, | ||
children, | ||
}: PropsWithChildren<SplitAccordionProps>) => { | ||
const accordionId = useGeneratedHtmlId(); | ||
const { euiTheme } = useEuiTheme(); | ||
|
||
return ( | ||
<EuiSplitPanel.Outer data-test-subj={`${dataTestSubj}Wrapper`} hasBorder> | ||
<EuiAccordion | ||
id={accordionId} | ||
initialIsOpen={initialIsOpen} | ||
css={css` | ||
.euiAccordion__triggerWrapper { | ||
background: ${euiTheme.colors.lightestShade}; | ||
padding: ${euiTheme.size.m}; | ||
} | ||
`} | ||
buttonContent={header} | ||
> | ||
<EuiSplitPanel.Inner data-test-subj={`${dataTestSubj}Content`} color="transparent"> | ||
{children} | ||
</EuiSplitPanel.Inner> | ||
</EuiAccordion> | ||
</EuiSplitPanel.Outer> | ||
); | ||
}; |
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
45 changes: 0 additions & 45 deletions
45
...etection_engine/rule_management/components/rule_details/diff_components/panel_wrapper.tsx
This file was deleted.
Oops, something went wrong.
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
67 changes: 67 additions & 0 deletions
67
...nt/components/rule_details/three_way_diff/components/field_upgrade_conflicts_resolver.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,67 @@ | ||
/* | ||
* 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 { EuiFlexGroup, EuiFlexItem, EuiSpacer, useEuiTheme } from '@elastic/eui'; | ||
import { css } from '@emotion/css'; | ||
import { SplitAccordion } from '../../../../../../common/components/split_accordion'; | ||
import type { | ||
DiffableAllFields, | ||
DiffableRule, | ||
RuleFieldsDiff, | ||
ThreeWayDiff, | ||
} from '../../../../../../../common/api/detection_engine'; | ||
import { ThreeWayDiffConflict } from '../../../../../../../common/api/detection_engine'; | ||
import { ComparisonSide } from '../comparison_side/comparison_side'; | ||
import { FinalSide } from '../final_side/final_side'; | ||
import { FieldUpgradeConflictsResolverHeader } from './field_upgrade_conflicts_resolver_header'; | ||
|
||
interface FieldUpgradeConflictsResolverProps<FieldName extends keyof RuleFieldsDiff> { | ||
fieldName: FieldName; | ||
fieldThreeWayDiff: RuleFieldsDiff[FieldName]; | ||
finalDiffableRule: DiffableRule; | ||
} | ||
|
||
export function FieldUpgradeConflictsResolver<FieldName extends keyof RuleFieldsDiff>({ | ||
fieldName, | ||
fieldThreeWayDiff, | ||
finalDiffableRule, | ||
}: FieldUpgradeConflictsResolverProps<FieldName>): JSX.Element { | ||
const { euiTheme } = useEuiTheme(); | ||
const hasConflict = fieldThreeWayDiff.conflict !== ThreeWayDiffConflict.NONE; | ||
|
||
return ( | ||
<> | ||
<SplitAccordion | ||
header={<FieldUpgradeConflictsResolverHeader fieldName={fieldName} />} | ||
initialIsOpen={hasConflict} | ||
data-test-subj="ruleUpgradePerFieldDiff" | ||
> | ||
<EuiFlexGroup gutterSize="s" alignItems="flexStart"> | ||
<EuiFlexItem grow={1}> | ||
<ComparisonSide | ||
fieldName={fieldName} | ||
fieldThreeWayDiff={fieldThreeWayDiff as ThreeWayDiff<DiffableAllFields[FieldName]>} | ||
resolvedValue={finalDiffableRule[fieldName] as DiffableAllFields[FieldName]} | ||
/> | ||
</EuiFlexItem> | ||
<EuiFlexItem | ||
grow={0} | ||
css={css` | ||
align-self: stretch; | ||
border-right: ${euiTheme.border.thin}; | ||
`} | ||
/> | ||
<EuiFlexItem grow={1}> | ||
<FinalSide fieldName={fieldName} finalDiffableRule={finalDiffableRule} /> | ||
</EuiFlexItem> | ||
</EuiFlexGroup> | ||
</SplitAccordion> | ||
<EuiSpacer size="s" /> | ||
</> | ||
); | ||
} |
25 changes: 25 additions & 0 deletions
25
...onents/rule_details/three_way_diff/components/field_upgrade_conflicts_resolver_header.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,25 @@ | ||
/* | ||
* 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 { camelCase, startCase } from 'lodash'; | ||
import { EuiTitle } from '@elastic/eui'; | ||
import { fieldToDisplayNameMap } from '../../diff_components/translations'; | ||
|
||
interface FieldUpgradeConflictsResolverHeaderProps { | ||
fieldName: string; | ||
} | ||
|
||
export function FieldUpgradeConflictsResolverHeader({ | ||
fieldName, | ||
}: FieldUpgradeConflictsResolverHeaderProps): JSX.Element { | ||
return ( | ||
<EuiTitle data-test-subj="ruleUpgradeFieldDiffLabel" size="xs"> | ||
<h5>{fieldToDisplayNameMap[fieldName] ?? startCase(camelCase(fieldName))}</h5> | ||
</EuiTitle> | ||
); | ||
} |
40 changes: 40 additions & 0 deletions
40
...ent/components/rule_details/three_way_diff/components/rule_upgrade_conflicts_resolver.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,40 @@ | ||
/* | ||
* 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 { | ||
RuleUpgradeState, | ||
SetRuleFieldResolvedValueFn, | ||
} from '../../../../../rule_management_ui/components/rules_table/upgrade_prebuilt_rules_table/use_prebuilt_rules_upgrade_state'; | ||
import { FieldUpgradeConflictsResolver } from './field_upgrade_conflicts_resolver'; | ||
|
||
interface RuleUpgradeConflictsResolverProps { | ||
ruleUpgradeState: RuleUpgradeState; | ||
setRuleFieldResolvedValue: SetRuleFieldResolvedValueFn; | ||
} | ||
|
||
export function RuleUpgradeConflictsResolver({ | ||
ruleUpgradeState, | ||
setRuleFieldResolvedValue, | ||
}: RuleUpgradeConflictsResolverProps): JSX.Element { | ||
const fieldDiffEntries = Object.entries(ruleUpgradeState.diff.fields) as Array< | ||
[ | ||
keyof typeof ruleUpgradeState.diff.fields, | ||
Required<typeof ruleUpgradeState.diff.fields>[keyof typeof ruleUpgradeState.diff.fields] | ||
] | ||
>; | ||
const fields = fieldDiffEntries.map(([fieldName, fieldDiff]) => ( | ||
<FieldUpgradeConflictsResolver | ||
key={fieldName} | ||
fieldName={fieldName} | ||
fieldThreeWayDiff={fieldDiff} | ||
finalDiffableRule={ruleUpgradeState.finalRule} | ||
/> | ||
)); | ||
|
||
return <>{fields}</>; | ||
} |
47 changes: 47 additions & 0 deletions
47
...le_management/components/rule_details/three_way_diff/components/rule_upgrade_info_bar.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,47 @@ | ||
/* | ||
* 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 { RuleUpgradeState } from '../../../../../rule_management_ui/components/rules_table/upgrade_prebuilt_rules_table/use_prebuilt_rules_upgrade_state'; | ||
import { | ||
UtilityBar, | ||
UtilityBarGroup, | ||
UtilityBarSection, | ||
UtilityBarText, | ||
} from '../../../../../../common/components/utility_bar'; | ||
import * as i18n from './translations'; | ||
|
||
interface UpgradeInfoBarProps { | ||
ruleUpgradeState: RuleUpgradeState; | ||
} | ||
|
||
export function RuleUpgradeInfoBar({ ruleUpgradeState }: UpgradeInfoBarProps): JSX.Element { | ||
const numOfFieldsWithUpdates = ruleUpgradeState.diff.num_fields_with_updates; | ||
const numOfConflicts = ruleUpgradeState.diff.num_fields_with_conflicts; | ||
|
||
return ( | ||
<UtilityBar> | ||
<UtilityBarSection> | ||
<UtilityBarGroup> | ||
<UtilityBarText dataTestSubj="showingRules"> | ||
{i18n.NUM_OF_FIELDS_WITH_UPDATES(numOfFieldsWithUpdates)} | ||
</UtilityBarText> | ||
</UtilityBarGroup> | ||
<UtilityBarGroup> | ||
<UtilityBarText dataTestSubj="showingRules"> | ||
{i18n.NUM_OF_CONFLICTS(numOfConflicts)} | ||
</UtilityBarText> | ||
</UtilityBarGroup> | ||
</UtilityBarSection> | ||
<UtilityBarSection> | ||
<UtilityBarGroup> | ||
<i18n.RuleUpgradeHelper /> | ||
</UtilityBarGroup> | ||
</UtilityBarSection> | ||
</UtilityBar> | ||
); | ||
} |
Oops, something went wrong.