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] Rule with cases connector after downgrading to essentials cannot be edited #189978

Closed
MadameSheema opened this issue Aug 6, 2024 · 16 comments
Assignees
Labels
8.16 candidate bug Fixes for quality problems that affect the customer experience Feature:Cases Cases feature fixed impact:high Addressing this issue will have a high level of impact on the quality/strength of our product. Project:Serverless Work as part of the Serverless project for its initial release Project:Serverless-GA Team:Detection Engine Security Solution Detection Engine Area Team:ResponseOps Label for the ResponseOps team (formerly the Cases and Alerting teams) Team: SecuritySolution Security Solutions Team working on SIEM, Endpoint, Timeline, Resolver, etc.

Comments

@MadameSheema
Copy link
Member

Originally reported by @dhurley14

Describe the bug:

  • Rule with cases connector after downgrading to essentials cannot be edited

Preconditions:

  • To have a rule with cases connector in complete tier
  • Downgrade to essentials

Steps to reproduce:

  1. Edit the rule with the cases connector

Current behavior:

  • The cases connector is displayed
  • When the user edits the rule and clicks on the save button an error is displayed

image

@MadameSheema MadameSheema added bug Fixes for quality problems that affect the customer experience triage_needed Team:ResponseOps Label for the ResponseOps team (formerly the Cases and Alerting teams) Team: SecuritySolution Security Solutions Team working on SIEM, Endpoint, Timeline, Resolver, etc. Feature:Cases Cases feature Team:Detection Engine Security Solution Detection Engine Area labels Aug 6, 2024
@elasticmachine
Copy link
Contributor

Pinging @elastic/security-solution (Team: SecuritySolution)

@elasticmachine
Copy link
Contributor

Pinging @elastic/response-ops-cases (Feature:Cases)

@elasticmachine
Copy link
Contributor

Pinging @elastic/security-detection-engine (Team:Detection Engine)

@elasticmachine
Copy link
Contributor

Pinging @elastic/response-ops (Team:ResponseOps)

@MadameSheema
Copy link
Member Author

@cnasikas @yctercero can you please take a look at this issue? Thanks!

@yctercero
Copy link
Contributor

This is likely an issue we'll run into when we break exceptions out into it's own subprivelege as well. We don't have a good way of saying you can edit this portion of the rule schema and not another. @banderror @marshallmain correct me here if I'm wrong, but I think we need to think through how to design such changes.

@banderror
Copy link
Contributor

@yctercero I think the question is, from the product/UX standpoint, what needs to happen with such rules on downgrade to essentials:

  • Do we want to remove from rules all the actions referencing cases connectors?
  • Do we want to disable these connectors?
  • Do we want to let those rules/actions and connectors continue to work?

I guess, in any case, we want the rules to continue to be editable.

When we have this understanding, we could think about what needs to be done technically.

@yctercero Not sure I understand what is being asked with regards to exceptions and RBAC.

@yctercero
Copy link
Contributor

@approksiu @ARWNightingale could you please confirm what the intended behavior should be here?

@yctercero yctercero added the Project:Serverless Work as part of the Serverless project for its initial release label Aug 27, 2024
@cnasikas
Copy link
Member

cnasikas commented Sep 9, 2024

When a rule is created an API key is also created and connected to the rule. The API key represents the user that created the rule. This is needed to execute the rule and the actions under the user's permission. When someone edits a rule, the API key is updated to represent the user who updated the rule. So, if we let the user update the rule without having access to cases the case action will start to fail due to permission errors. As @yctercero said we do not have a way to have different permissions per portions of the rule's schema. The downgrade scenario is interesting though because it means that no user has access to cases. Does the rule fail either way by downgrading to essentials?

Related: #191681.

@yctercero yctercero added 8.16 candidate impact:high Addressing this issue will have a high level of impact on the quality/strength of our product. and removed triage_needed labels Sep 9, 2024
@yctercero
Copy link
Contributor

@cnasikas cold we do something where we disable the action? Users would be able to delete the action, but we could still maintain it there in case they upgrade. How difficult would the concept of enabled/disabled actions be to introduce?

@yctercero
Copy link
Contributor

@MadameSheema does this occur with the other actions that are only present for higher tiers or is this specific behavior to cases?

@cnasikas
Copy link
Member

cnasikas commented Oct 2, 2024

@yctercero I tested and for the other connectors we allow to save the rule but we do not execute the actions. We also show a warning in the rule's flyout. For the system actions, we perform extra authorization checks this is why the update of the rule fails. We could skip the authorization if the license is not sufficient, allow the rule to be saved as with the other actions, and disable the action as you suggested. I prioritized it but I am not sure if we can make it for 8.16.

Image
Image

@MadameSheema
Copy link
Member Author

@MadameSheema does this occur with the other actions that are only present for higher tiers or is this specific behavior to cases?

@yctercero specific for cases connector/action.

@yctercero
Copy link
Contributor

@cnasikas Thanks so much! That sounds like a great way forward.

@cnasikas
Copy link
Member

@MadameSheema Fixed by #201396.

cnasikas added a commit that referenced this issue Nov 23, 2024
…ot have the sufficient license for system actions. (#201396)

If a user does not have a sufficient license for a connector and the
rule is already configured with such a connector we show the following
message:

<img width="1026" alt="Screenshot 2024-11-22 at 1 48 10 PM"
src="https://github.com/user-attachments/assets/4b3d7197-ff3c-4673-9b37-9ca627dab0db">

This PR does the same for system actions.

<img width="1162" alt="Screenshot 2024-11-22 at 1 03 06 PM"
src="https://github.com/user-attachments/assets/d1cbd479-ff65-453d-889a-ae7f5cd2b63b">

## Testing

1. Create a rule with a case action in Platinum license
2. Downgrade to basic
3. Verify that a licensing message is showing for the case action.
Verify in all solutions.

Issue: #189978

### Checklist

Check the PR satisfies following conditions. 

Reviewers should verify this PR satisfies this list as well.

- [x] [Unit or functional
tests](https://www.elastic.co/guide/en/kibana/master/development-tests.html)
were updated or added to match the most common scenarios
kibanamachine pushed a commit to kibanamachine/kibana that referenced this issue Nov 23, 2024
…ot have the sufficient license for system actions. (elastic#201396)

If a user does not have a sufficient license for a connector and the
rule is already configured with such a connector we show the following
message:

<img width="1026" alt="Screenshot 2024-11-22 at 1 48 10 PM"
src="https://github.com/user-attachments/assets/4b3d7197-ff3c-4673-9b37-9ca627dab0db">

This PR does the same for system actions.

<img width="1162" alt="Screenshot 2024-11-22 at 1 03 06 PM"
src="https://github.com/user-attachments/assets/d1cbd479-ff65-453d-889a-ae7f5cd2b63b">

## Testing

1. Create a rule with a case action in Platinum license
2. Downgrade to basic
3. Verify that a licensing message is showing for the case action.
Verify in all solutions.

Issue: elastic#189978

### Checklist

Check the PR satisfies following conditions.

Reviewers should verify this PR satisfies this list as well.

- [x] [Unit or functional
tests](https://www.elastic.co/guide/en/kibana/master/development-tests.html)
were updated or added to match the most common scenarios

(cherry picked from commit e020595)
paulinashakirova pushed a commit to paulinashakirova/kibana that referenced this issue Nov 26, 2024
…ot have the sufficient license for system actions. (elastic#201396)

If a user does not have a sufficient license for a connector and the
rule is already configured with such a connector we show the following
message:

<img width="1026" alt="Screenshot 2024-11-22 at 1 48 10 PM"
src="https://github.com/user-attachments/assets/4b3d7197-ff3c-4673-9b37-9ca627dab0db">

This PR does the same for system actions.

<img width="1162" alt="Screenshot 2024-11-22 at 1 03 06 PM"
src="https://github.com/user-attachments/assets/d1cbd479-ff65-453d-889a-ae7f5cd2b63b">

## Testing

1. Create a rule with a case action in Platinum license
2. Downgrade to basic
3. Verify that a licensing message is showing for the case action.
Verify in all solutions.

Issue: elastic#189978

### Checklist

Check the PR satisfies following conditions. 

Reviewers should verify this PR satisfies this list as well.

- [x] [Unit or functional
tests](https://www.elastic.co/guide/en/kibana/master/development-tests.html)
were updated or added to match the most common scenarios
@MadameSheema
Copy link
Member Author

Tested the fix on MKI using the dev-devenv version available at a time (38fab2d).

CAWilson94 pushed a commit to CAWilson94/kibana that referenced this issue Dec 12, 2024
…ot have the sufficient license for system actions. (elastic#201396)

If a user does not have a sufficient license for a connector and the
rule is already configured with such a connector we show the following
message:

<img width="1026" alt="Screenshot 2024-11-22 at 1 48 10 PM"
src="https://github.com/user-attachments/assets/4b3d7197-ff3c-4673-9b37-9ca627dab0db">

This PR does the same for system actions.

<img width="1162" alt="Screenshot 2024-11-22 at 1 03 06 PM"
src="https://github.com/user-attachments/assets/d1cbd479-ff65-453d-889a-ae7f5cd2b63b">

## Testing

1. Create a rule with a case action in Platinum license
2. Downgrade to basic
3. Verify that a licensing message is showing for the case action.
Verify in all solutions.

Issue: elastic#189978

### Checklist

Check the PR satisfies following conditions. 

Reviewers should verify this PR satisfies this list as well.

- [x] [Unit or functional
tests](https://www.elastic.co/guide/en/kibana/master/development-tests.html)
were updated or added to match the most common scenarios
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
8.16 candidate bug Fixes for quality problems that affect the customer experience Feature:Cases Cases feature fixed impact:high Addressing this issue will have a high level of impact on the quality/strength of our product. Project:Serverless Work as part of the Serverless project for its initial release Project:Serverless-GA Team:Detection Engine Security Solution Detection Engine Area Team:ResponseOps Label for the ResponseOps team (formerly the Cases and Alerting teams) Team: SecuritySolution Security Solutions Team working on SIEM, Endpoint, Timeline, Resolver, etc.
Projects
None yet
Development

No branches or pull requests

5 participants