Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[Security Solution] Expandable flyout - Rule preview contents #163027

Merged
merged 6 commits into from
Aug 10, 2023

Conversation

christineweng
Copy link
Contributor

@christineweng christineweng commented Aug 2, 2023

Summary

This PR is part 2 of adding a rule preview panel to the expandable flyout. PR (#161999) adds the preview skeleton, and this PR populates the actual content related to rule details:

Expandable flyout:

  • Updated title to include created by and updated by timestamps, and rule switch button
  • Added contents for about, define, schedule and actions (if any)
  • Added a hook to fetch data for rule switch button - logic mimics rule details page (~/security_solution/public/detection_engine/rule_details_ui/pages/rule_details/index.tsx)

Rule & detections:

  • Added isPanelView option allow rendering rule details in smaller font, so that it can fit in panel view
  • Minor UI updates to gutter sizes and spacing to accommodate long text
  • Extracted createdBy and updatedBy to ~/security_solution/public/detections/components/rules/rule_info to be shared between rule details page and flyout

image

How to test

  • add xpack.securitySolution.enableExperimental: ['securityFlyoutEnabled'] to the kibana.dev.json file
  • go to the Alerts page, and click on the expand detail button on any row of the table
  • click on Overview, About, view Rule Summary, the rule preview panel should pop up

Checklist

@christineweng christineweng self-assigned this Aug 2, 2023
@christineweng christineweng added release_note:feature Makes this part of the condensed release notes Team:Threat Hunting:Investigations Security Solution Investigations Team v8.10.0 labels Aug 2, 2023
@christineweng christineweng force-pushed the 6999-rule-preview-contents branch from c8ef38d to 36206d9 Compare August 2, 2023 21:14
@christineweng christineweng force-pushed the 6999-rule-preview-contents branch from 36206d9 to f1da4a1 Compare August 3, 2023 17:35
@christineweng christineweng marked this pull request as ready for review August 3, 2023 21:29
@christineweng christineweng requested review from a team as code owners August 3, 2023 21:29
@christineweng christineweng requested a review from maximpn August 3, 2023 21:29
Copy link
Contributor

@PhilippeOberti PhilippeOberti left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Left a few comments, the major one being the isInPanelView prop approach.

I would be fine keeping it, but I'm not a fan of props that are only there to drive the UI, especially if they are specific to a single use. In our case, it is extremely unlikely anybody else would ever need this specific behavior when reusing this component... Doing this a recipe to have later way too many props... (I understand that the columns prop is already doing that so we're not breaking a pattern here, but also to my point that's already 2 props to drive the UI...)

A few options I can see:

  • have some sort of prop that would include all css changes
  • like I mentioned in the comment, maybe try to see what we can do with the titleProps prop?
  • could we pass in css changes and use them (I know it's feasible in Angular but have never done it with React)

But I believe my favorite approach would be to have our own component. If we look at the StepRuleDescriptionComponent, it's really not doing much... We don't care about the if (column==='multi') or the singleSplit sections.
Could we extract the listItems logic and build our own component?
The code duplication would be pretty small, and we wouldn't introduce a new usage-specific prop?

If you think it's too much work for not much value (which I don't deny) and if the @elastic/security-detection-rule-management team is OK with the current change, I can be convinced to merge the code as it is (after fixing the few nits)

Copy link
Contributor

@maximpn maximpn left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@christineweng these are nice changes for the rule preview 👍

Basically I agree with @PhilippeOberti regarding isInPanelView prop. We should avoid parametrisation as it adds too much complexity. React's philosophy is composition so we need to focus on this. Obviously it will require more effort but we can address some tech debt here. Rule details page wasn't designed to share its components in a wider environment and has suboptimal structure. It's possible to refactor it a bit to make the components you need shared. Specifically we need to address the following

  • Have an ability to reuse rule details page's content with customizations at some other place (refactor for that StepRuleDescriptionComponent to split it or have a render prop)
  • Make RuleSwitch shared without necessity to pull all the data and permission (avoid custom useRuleSwitch appearing in different places)
  • Share the text (it looks like updated by, created by and enable/disabled rule texts are the same and it worth to find a way to share it via ready to use components)

I understand that it inflates the scope but I think we can find a way to address it. Feel free to reach me to discuss the above by voice if necessary.

@maximpn
Copy link
Contributor

maximpn commented Aug 8, 2023

@christineweng fyi, Rule Management team has been working on a similar task having a flyout with rule details in this PR. There is an idea to build rule details lightweight components everyone can reuse to display rule details information. The feature is targeted 8.10. Taking into account my comments above it makes sense to have isInPanelView for now.

@nikitaindik
Copy link
Contributor

@christineweng @maximpn Hey folks! Just wanted to clarify that we (the Rules Mgmt team) can't guarantee that we will be able to properly implement the reusable components mentioned above by FF date. We are doing our best to squeeze this refactoring in, but please don't count on us to have it fully ready by FF.

@christineweng
Copy link
Contributor Author

@maximpn thank you so much for the feedback!

  • Have an ability to reuse rule details page's content with customizations at some other place (refactor for that StepRuleDescriptionComponent to split it or have a render prop)
  • Based on the current work from Nikita, keep current implementation as is, maybe plus some documentation to explain what it does
  • Make RuleSwitch shared without necessity to pull all the data and permission (avoid custom useRuleSwitch appearing in different places)
  • i think this would be the biggest effort to refactor, and I agree that the current hook should not be necessary (it essentially duplicate all the CRUD/rule checking). Since the rule switch was not part of the MVP of this preview, I talked with product and they are ok to have it in a later release. I removed all the switch related code.
  • Share the text (it looks like updated by, created by and enable/disabled rule texts are the same and it worth to find a way to share it via ready to use components)
  • I'm open to sharing components, will ping you about file location etc.

@christineweng christineweng force-pushed the 6999-rule-preview-contents branch from 712ae7e to 0a1c401 Compare August 9, 2023 19:50
@christineweng christineweng force-pushed the 6999-rule-preview-contents branch from ab8fa09 to ae63e2b Compare August 9, 2023 22:17
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

just an idea, but it the CreatedBy and UpdatedBy components were taking a single prop rule: Rule | null it would simplify the way devs use it, and they wouldn't have to check if the rule is null when using the component, like you do now (for example rule?.updated_by). That logic would be embedded in your component, which is a slightly nicer developer experience...

I'm not strongly attached to this though, and for the sake of time (mainly updating tests) I'm ok keeping what you have!

Copy link
Contributor

@PhilippeOberti PhilippeOberti left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM, thanks for making all the changes! I left a few more small nits, I'll leave it to you to implement them or not!

One last request: would you mind writing a ticket on our expandable flyout board to log the tech debt (to better share hooks and components)?

@christineweng
Copy link
Contributor Author

@PhilippeOberti thanks! ticket created here

Copy link
Contributor

@maximpn maximpn left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@christineweng thank you for addressing my comments 🙏 special thanks for CreatedBy and UpdatedBy components 😉

@christineweng christineweng enabled auto-merge (squash) August 10, 2023 19:12
@christineweng christineweng merged commit c28cb61 into elastic:main Aug 10, 2023
@kibana-ci
Copy link
Collaborator

💚 Build Succeeded

Metrics [docs]

Module Count

Fewer modules leads to a faster build time

id before after diff
securitySolution 4393 4396 +3

Async chunks

Total size of all lazy-loaded chunks that will be downloaded as the user navigates the app

id before after diff
securitySolution 15.6MB 15.6MB +11.0KB
Unknown metric groups

References to deprecated APIs

id before after diff
securitySolution 625 630 +5

History

To update your PR or re-run it, just comment with:
@elasticmachine merge upstream

cc @christineweng

@kibanamachine kibanamachine added the backport:skip This commit does not require backporting label Aug 10, 2023
christineweng added a commit that referenced this pull request Oct 25, 2023
… components (#169029)

This PR updates rule preview panel in the document expandable flyout:

- Replaced rule details sections with the simplified components from
#166158
- Added `itemRenderer` to allow custom render of the description list
- Removed `isPanelView` props from the rule detail read only components.
It was added to accommodate the preview styling
(#163027)

**No UI change from this PR**

**How to test**
- Go to alerts page and generate some alerts
- Expand a row in the table, a flyout should appear
- Click `Show rule summary` to expand the rule preview panel
@michaelolo24 michaelolo24 added this to the 8.10 milestone Mar 5, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
backport:skip This commit does not require backporting release_note:feature Makes this part of the condensed release notes Team:Threat Hunting:Investigations Security Solution Investigations Team v8.10.0
Projects
None yet
Development

Successfully merging this pull request may close these issues.

7 participants