From 22e61f5ee974ef3a62a4eed46777e505bf07c424 Mon Sep 17 00:00:00 2001 From: "opensearch-trigger-bot[bot]" <98922864+opensearch-trigger-bot[bot]@users.noreply.github.com> Date: Fri, 30 Dec 2022 00:22:01 +0530 Subject: [PATCH] rule details flyout on detector create 4th step (#266) (#275) * rule details flyout on detector create 4th step Signed-off-by: Aleksandar Djindjic * rule details flyout on detector edit page Signed-off-by: Aleksandar Djindjic Signed-off-by: Aleksandar Djindjic (cherry picked from commit 5bf6b2e3b0f998e409ce5034dc004a3ff8d81f85) Co-authored-by: Aleksandar Djindjic --- .../DetectionRules/types/interfaces.ts | 2 + .../DetectorRulesView/DetectorRulesView.tsx | 72 ++++++++++++++----- .../components/UpdateRules/UpdateRules.tsx | 27 +++++++ public/utils/helpers.tsx | 1 + 4 files changed, 85 insertions(+), 17 deletions(-) diff --git a/public/pages/CreateDetector/components/DefineDetector/components/DetectionRules/types/interfaces.ts b/public/pages/CreateDetector/components/DefineDetector/components/DetectionRules/types/interfaces.ts index 18e5dd9be..6977ff601 100644 --- a/public/pages/CreateDetector/components/DefineDetector/components/DetectionRules/types/interfaces.ts +++ b/public/pages/CreateDetector/components/DefineDetector/components/DetectionRules/types/interfaces.ts @@ -4,6 +4,7 @@ */ import { RuleItemInfoBase } from '../../../../../../Rules/models/types'; +import { RuleInfo } from './../../../../../../../../server/models/interfaces/Rules'; export interface RuleItem { name: string; @@ -13,6 +14,7 @@ export interface RuleItem { library: string; description: string; active: boolean; + ruleInfo: RuleInfo; } export type RuleItemInfo = RuleItemInfoBase & { enabled: boolean }; diff --git a/public/pages/Detectors/components/DetectorRulesView/DetectorRulesView.tsx b/public/pages/Detectors/components/DetectorRulesView/DetectorRulesView.tsx index e3762bade..1b3731ce9 100644 --- a/public/pages/Detectors/components/DetectorRulesView/DetectorRulesView.tsx +++ b/public/pages/Detectors/components/DetectorRulesView/DetectorRulesView.tsx @@ -13,6 +13,9 @@ import { Detector } from '../../../../../models/interfaces'; import { RuleInfo } from '../../../../../server/models/interfaces'; import { errorNotificationToast, translateToRuleItems } from '../../../../utils/helpers'; import { NotificationsStart } from 'opensearch-dashboards/public'; +import { RulesTable } from '../../../Rules/components/RulesTable/RulesTable'; +import { RuleTableItem } from '../../../Rules/utils/helpers'; +import { RuleViewerFlyout } from '../../../Rules/components/RuleViewerFlyout/RuleViewerFlyout'; export interface DetectorRulesViewProps { detector: Detector; @@ -21,6 +24,18 @@ export interface DetectorRulesViewProps { notifications: NotificationsStart; } +const mapRuleItemToRuleTableItem = (ruleItem: RuleItem): RuleTableItem => { + return { + title: ruleItem.name, + level: ruleItem.severity, + category: ruleItem.logType, + description: ruleItem.description, + source: ruleItem.library, + ruleId: ruleItem.id, + ruleInfo: { ...ruleItem.ruleInfo, prePackaged: ruleItem.library === 'Sigma' }, + }; +}; + export const DetectorRulesView: React.FC = (props) => { const totalSelected = props.detector.inputs.reduce((sum, inputObj) => { return ( @@ -30,6 +45,7 @@ export const DetectorRulesView: React.FC = (props) => { ); }, 0); + const [flyoutData, setFlyoutData] = useState(null); const [enabledRuleItems, setEnabledRuleItems] = useState([]); const [allRuleItems, setAllRuleItems] = useState([]); const [loading, setLoading] = useState(false); @@ -125,22 +141,44 @@ export const DetectorRulesView: React.FC = (props) => { const getDetectionRulesTitle = () => `View detection rules (${totalSelected})`; - return props.rulesCanFold ? ( - -

{getDetectionRulesTitle()}

- - } - > - - {rules} -
- ) : ( - - {rules} - + const onShowRuleDetails = (rule: RuleTableItem) => { + setFlyoutData(() => rule); + }; + + return ( + <> + {flyoutData ? ( + setFlyoutData(() => null)} + history={null as any} + ruleTableItem={flyoutData} + ruleService={null as any} + notifications={props.notifications} + /> + ) : null} + {props.rulesCanFold ? ( + +

{getDetectionRulesTitle()}

+ + } + > + + mapRuleItemToRuleTableItem(i))} + showRuleDetails={onShowRuleDetails} + /> + {rules} +
+ ) : ( + + {rules} + + )} + ); }; diff --git a/public/pages/Detectors/components/UpdateRules/UpdateRules.tsx b/public/pages/Detectors/components/UpdateRules/UpdateRules.tsx index 26a132202..bd1f2ecf3 100644 --- a/public/pages/Detectors/components/UpdateRules/UpdateRules.tsx +++ b/public/pages/Detectors/components/UpdateRules/UpdateRules.tsx @@ -20,6 +20,8 @@ import { ServicesContext } from '../../../../services'; import { ServerResponse } from '../../../../../server/models/types'; import { NotificationsStart } from 'opensearch-dashboards/public'; import { errorNotificationToast, successNotificationToast } from '../../../../utils/helpers'; +import { RuleTableItem } from '../../../Rules/utils/helpers'; +import { RuleViewerFlyout } from '../../../Rules/components/RuleViewerFlyout/RuleViewerFlyout'; export interface UpdateDetectorRulesProps extends RouteComponentProps< @@ -38,6 +40,7 @@ export const UpdateDetectorRules: React.FC = (props) = const [customRuleItems, setCustomRuleItems] = useState([]); const [prePackagedRuleItems, setPrePackagedRuleItems] = useState([]); const detectorId = props.location.pathname.replace(`${ROUTES.EDIT_DETECTOR_RULES}/`, ''); + const [flyoutData, setFlyoutData] = useState(null); useEffect(() => { const getDetector = async () => { @@ -86,6 +89,7 @@ export const UpdateDetectorRules: React.FC = (props) = library: 'Sigma', description: rule._source.description, active: enabledRuleIds.includes(rule._id), + ruleInfo: rule, })); setPrePackagedRuleItems(ruleItems); } else { @@ -124,6 +128,7 @@ export const UpdateDetectorRules: React.FC = (props) = library: 'Custom', description: rule._source.description, active: enabledRuleIds.includes(rule._id), + ruleInfo: rule, })); setCustomRuleItems(ruleItems); } else { @@ -210,8 +215,29 @@ export const UpdateDetectorRules: React.FC = (props) = }; const ruleItems = prePackagedRuleItems.concat(customRuleItems); + + const onRuleDetails = (ruleItem: RuleItem) => { + console.log('onRuleDetails', ruleItem); + setFlyoutData(() => ({ + title: ruleItem.name, + level: ruleItem.severity, + category: ruleItem.logType, + description: ruleItem.description, + source: ruleItem.library, + ruleInfo: ruleItem.ruleInfo, + ruleId: ruleItem.id, + })); + }; return (
+ {flyoutData ? ( + setFlyoutData(() => null)} + history={null as any} + ruleTableItem={flyoutData} + ruleService={null as any} + /> + ) : null}

Edit detector rules

@@ -222,6 +248,7 @@ export const UpdateDetectorRules: React.FC = (props) = ruleItems={ruleItems} onRuleActivationToggle={onToggle} onAllRulesToggled={onAllRulesToggle} + onRuleDetails={onRuleDetails} /> diff --git a/public/utils/helpers.tsx b/public/utils/helpers.tsx index a732171ad..a4f0cbdfc 100644 --- a/public/utils/helpers.tsx +++ b/public/utils/helpers.tsx @@ -122,6 +122,7 @@ export function ruleItemInfosToItems( logType: detectorType.toLowerCase(), name: itemInfo._source.title, severity: itemInfo._source.level, + ruleInfo: itemInfo, })); }