-
Notifications
You must be signed in to change notification settings - Fork 8.3k
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
[ResponseOps] Granular Connector RBAC #203503
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Verified below scenarios locally and they are working as expected 🎉
- disabled EDR connectors ✅
- enabled EDR connectors ✅
- Run it again but replace the subAction with isolateHost. ✅
- Try to create a rule, and verify that you don't see the SentinelOne connector. ✅
- Try to create a rule using the API and add your SentinelOne connector, verify that the API throws an error. ✅
- Test the same behaviors when trying to add a SentinelOne connector to existing rules. ✅
@cnasikas Thought you might want to take a look, since you seem to be the RBAC / subaction connectors expert. At least to see what changes are being made ... |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
LGTM. Left a comment about the text of an error message that feel like could be improved.
if (edrActionTypeIds.length > 0) { | ||
errors.push( | ||
i18n.translate('xpack.alerting.rulesClient.validateActions.edrConnector', { | ||
defaultMessage: 'Invalid EDR connectors', |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This makes it sound like there is a problem with the EDR connector, but actually the problem is that you can't use these connectors as alerting actions, correct? If so, perhaps the message should be something like "EDR connectors cannot be used as alerting actions" or similar ...
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks for catching updated in the commit, aa216e6
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
code change LGTM
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Security GenAI changes LGTM
💚 Build Succeeded
Metrics [docs]Public APIs missing comments
Async chunks
Page load bundle
Unknown metric groupsAPI count
History
|
Starting backport for target branches: 8.x https://github.com/elastic/kibana/actions/runs/12638516032 |
💔 All backports failed
Manual backportTo create the backport manually run:
Questions ?Please refer to the Backport tool documentation |
Part of elastic#180908 ## Summary **EDR Connector Subfeature Privilege** This PR creates a new EDR connector sub-feature privilege under the read privilege for connectors. The read privilege currently allows users to execute connectors, and this new privilege will limit some of the connectors that can be executed. When the EDR privilege is turned on, users will be able to execute EDR connectors, and when it is off they will not execute. This new privilege includes SentinelOne and Crowdstrike connectors. To determine which connectors are considered EDR connectors, we leverage`getKibanaPrivileges` in the connector type definition. I removed the restrictions to use this field only for system actions and renamed `getSystemActionKibanaPrivileges` to `getActionKibanaPrivileges`. I also added a field, `subFeatureType `, to the connector type definition to help disable testing/executing an connectors that are restricted under a sub-feature. **EDR Connector Execution for Testing** The execution of EDR connectors using the API is limited to a single sub-action for testing purposes. This ensures users can still configure/test EDR connectors. In a separate [PR](elastic#204804), I added back the SentinelOne and Crowdstrike params UIs with options restricted to one sub-action. **Rule API and Feature Configuration Updates** Validation has been added to the rule APIs to enforce restrictions on adding EDR connectors. The connector feature configuration has been updated to include a new feature ID, EdrForSecurityFeature, which ensures that EDR connectors are hidden on the rule form. Note: I saw that EDR connectors are also temporarily restricted in the Security Solution UI. To streamline this, I removed the `isBidirectionalConnectorType` check in `action_type_registry.ts`. Instead, I removed `SecurityConnectorFeatureId` from the `supportedFeatureIds` of the SentinelOne connector type definition. ### Checklist Check the PR satisfies following conditions. - [ ] [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 ## To test **EDR Connector Subfeature Privilege** 1. Create a new role and disable EDR connectors under the Actions and Connectors privilege 2. Create a new user and assign that role to user 3. Create a Sentinel One connector (It doesn't need to work, you can use fake values for the url and token) 4. Login as the new user and run the following in Dev Tools to verify that you aren't authorized execute the Sentinel One connector ``` POST kbn:/api/actions/connector/$CONNECTOR_ID/_execute { "params": { "subAction": "getAgents", "subActionParams": {} } } ``` 7. Update the role to enable EDR connectors and repeat the steps to verify that you are authorized to run the connector. (It will fail but verify it's not Unauthorized) **EDR Connector Execution for Testing** 1. Enable the EDR connectors privilege in the role you created above and log in as the user you created above. 2. Run the following in Dev Tools to verify that you are authorized execute the Sentinel One connector using only the `getAgents` sub-action. (It will fail but verify it's not `Unauthorized`) ``` POST kbn:/api/actions/connector/$CONNECTOR_ID/_execute { "params": { "subAction": "getAgents", "subActionParams": {} } } ``` 3. Run it again but replace the `subAction` with `isolateHost`. Verify that you get an unauthorized error. **Rule API and Feature Configuration Updates** 1. 1. Enable the EDR connectors privilege in the role you created above and log in as the user you created above. 2. Go to Stack Management 3. Try to create a rule, and verify that you don't see the SentinelOne connector. 4. Try to create a rule using the API and add your SentinelOne connector, verify that the API throws an error. ``` POST kbn:/api/alerting/rule { "tags": [], "params": {}, "schedule": { "interval": "1m" }, "consumer": "alerts", "name": "Always firing rule", "rule_type_id": "example.always-firing", "actions": [ { "group": "small", "id": "$CONNECTOR_ID", "params": { "subAction": "isolateAgent", "subActionParams": {} }, "frequency": { "notify_when": "onActionGroupChange", "throttle": null, "summary": false } } ], "alert_delay": { "active": 1 } } ``` 5. You can test the same behaviors when trying to add a SentinelOne connector to existing rules. --------- Co-authored-by: kibanamachine <42973632+kibanamachine@users.noreply.github.com> (cherry picked from commit 23a5c6d) # Conflicts: # x-pack/platform/plugins/shared/actions/server/application/connector/methods/execute/execute.ts # x-pack/platform/plugins/shared/actions/server/authorization/actions_authorization.test.ts # x-pack/platform/plugins/shared/actions/server/authorization/actions_authorization.ts
💚 All backports created successfully
Note: Successful backport PRs will be merged automatically after passing CI. Questions ?Please refer to the Backport tool documentation |
}, | ||
]); | ||
await expect( | ||
validateActions(context as unknown as RulesClientContext, ruleType, data, false) | ||
).rejects.toThrowErrorMatchingInlineSnapshot( | ||
'"Failed to validate actions due to the following error: Invalid EDR connectors"' | ||
'"Failed to validate actions due to the following error: IEndpoint security connectors cannot be used as alerting actions"' |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
s/IEndpoint/Endpoint/
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks! Should have been fixed in this commit, 66103c8
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
yup, was looking at a stake copy ...
# Backport This will backport the following commits from `main` to `8.x`: - [[ResponseOps] Granular Connector RBAC (#203503)](#203503) <!--- Backport version: 8.9.8 --> ### Questions ? Please refer to the [Backport tool documentation](https://github.com/sqren/backport) <!--BACKPORT [{"author":{"name":"Alexi Doak","email":"109488926+doakalexi@users.noreply.github.com"},"sourceCommit":{"committedDate":"2025-01-06T18:53:35Z","message":"[ResponseOps] Granular Connector RBAC (#203503)\n\nPart of https://github.com/elastic/kibana/issues/180908\r\n\r\n## Summary\r\n\r\n**EDR Connector Subfeature Privilege**\r\nThis PR creates a new EDR connector sub-feature privilege under the read\r\nprivilege for connectors. The read privilege currently allows users to\r\nexecute connectors, and this new privilege will limit some of the\r\nconnectors that can be executed. When the EDR privilege is turned on,\r\nusers will be able to execute EDR connectors, and when it is off they\r\nwill not execute. This new privilege includes SentinelOne and\r\nCrowdstrike connectors.\r\n\r\nTo determine which connectors are considered EDR connectors, we\r\nleverage`getKibanaPrivileges` in the connector type definition. I\r\nremoved the restrictions to use this field only for system actions and\r\nrenamed `getSystemActionKibanaPrivileges` to\r\n`getActionKibanaPrivileges`. I also added a field, `subFeatureType `, to\r\nthe connector type definition to help disable testing/executing an\r\nconnectors that are restricted under a sub-feature.\r\n\r\n**EDR Connector Execution for Testing**\r\nThe execution of EDR connectors using the API is limited to a single\r\nsub-action for testing purposes. This ensures users can still\r\nconfigure/test EDR connectors. In a separate\r\n[PR](#204804), I added back the\r\nSentinelOne and Crowdstrike params UIs with options restricted to one\r\nsub-action.\r\n\r\n**Rule API and Feature Configuration Updates**\r\nValidation has been added to the rule APIs to enforce restrictions on\r\nadding EDR connectors. The connector feature configuration has been\r\nupdated to include a new feature ID, EdrForSecurityFeature, which\r\nensures that EDR connectors are hidden on the rule form.\r\nNote: I saw that EDR connectors are also temporarily restricted in the\r\nSecurity Solution UI. To streamline this, I removed the\r\n`isBidirectionalConnectorType` check in `action_type_registry.ts`.\r\nInstead, I removed `SecurityConnectorFeatureId` from the\r\n`supportedFeatureIds` of the SentinelOne connector type definition.\r\n\r\n\r\n### Checklist\r\n\r\nCheck the PR satisfies following conditions. \r\n\r\n- [ ] [Unit or functional\r\ntests](https://www.elastic.co/guide/en/kibana/master/development-tests.html)\r\nwere updated or added to match the most common scenarios\r\n\r\n\r\n## To test\r\n\r\n**EDR Connector Subfeature Privilege**\r\n1. Create a new role and disable EDR connectors under the Actions and\r\nConnectors privilege\r\n2. Create a new user and assign that role to user\r\n3. Create a Sentinel One connector (It doesn't need to work, you can use\r\nfake values for the url and token)\r\n4. Login as the new user and run the following in Dev Tools to verify\r\nthat you aren't authorized execute the Sentinel One connector\r\n```\r\nPOST kbn:/api/actions/connector/$CONNECTOR_ID/_execute\r\n{\r\n \"params\": {\r\n \"subAction\": \"getAgents\",\r\n \"subActionParams\": {}\r\n }\r\n}\r\n```\r\n7. Update the role to enable EDR connectors and repeat the steps to\r\nverify that you are authorized to run the connector. (It will fail but\r\nverify it's not Unauthorized)\r\n\r\n**EDR Connector Execution for Testing**\r\n1. Enable the EDR connectors privilege in the role you created above and\r\nlog in as the user you created above.\r\n2. Run the following in Dev Tools to verify that you are authorized\r\nexecute the Sentinel One connector using only the `getAgents`\r\nsub-action. (It will fail but verify it's not `Unauthorized`)\r\n```\r\nPOST kbn:/api/actions/connector/$CONNECTOR_ID/_execute\r\n{\r\n \"params\": {\r\n \"subAction\": \"getAgents\",\r\n \"subActionParams\": {}\r\n }\r\n}\r\n```\r\n3. Run it again but replace the `subAction` with `isolateHost`. Verify\r\nthat you get an unauthorized error.\r\n\r\n**Rule API and Feature Configuration Updates**\r\n1. 1. Enable the EDR connectors privilege in the role you created above\r\nand log in as the user you created above.\r\n2. Go to Stack Management\r\n3. Try to create a rule, and verify that you don't see the SentinelOne\r\nconnector.\r\n4. Try to create a rule using the API and add your SentinelOne\r\nconnector, verify that the API throws an error.\r\n```\r\nPOST kbn:/api/alerting/rule\r\n{\r\n \"tags\": [],\r\n \"params\": {},\r\n \"schedule\": {\r\n \"interval\": \"1m\"\r\n },\r\n \"consumer\": \"alerts\",\r\n \"name\": \"Always firing rule\",\r\n \"rule_type_id\": \"example.always-firing\",\r\n \"actions\": [\r\n {\r\n \"group\": \"small\",\r\n \"id\": \"$CONNECTOR_ID\",\r\n \"params\": {\r\n \"subAction\": \"isolateAgent\",\r\n \"subActionParams\": {}\r\n },\r\n \"frequency\": {\r\n \"notify_when\": \"onActionGroupChange\",\r\n \"throttle\": null,\r\n \"summary\": false\r\n }\r\n }\r\n ],\r\n \"alert_delay\": {\r\n \"active\": 1\r\n }\r\n}\r\n```\r\n5. You can test the same behaviors when trying to add a SentinelOne\r\nconnector to existing rules.\r\n\r\n---------\r\n\r\nCo-authored-by: kibanamachine <42973632+kibanamachine@users.noreply.github.com>","sha":"23a5c6d2db1cd8d501e94c1af872d4ce7792e9ee","branchLabelMapping":{"^v9.0.0$":"main","^v8.18.0$":"8.x","^v(\\d+).(\\d+).\\d+$":"$1.$2"}},"sourcePullRequest":{"labels":["release_note:skip","Team:ResponseOps","v9.0.0","backport:prev-minor","Team:Obs AI Assistant","v8.18.0"],"number":203503,"url":"https://github.com/elastic/kibana/pull/203503","mergeCommit":{"message":"[ResponseOps] Granular Connector RBAC (#203503)\n\nPart of https://github.com/elastic/kibana/issues/180908\r\n\r\n## Summary\r\n\r\n**EDR Connector Subfeature Privilege**\r\nThis PR creates a new EDR connector sub-feature privilege under the read\r\nprivilege for connectors. The read privilege currently allows users to\r\nexecute connectors, and this new privilege will limit some of the\r\nconnectors that can be executed. When the EDR privilege is turned on,\r\nusers will be able to execute EDR connectors, and when it is off they\r\nwill not execute. This new privilege includes SentinelOne and\r\nCrowdstrike connectors.\r\n\r\nTo determine which connectors are considered EDR connectors, we\r\nleverage`getKibanaPrivileges` in the connector type definition. I\r\nremoved the restrictions to use this field only for system actions and\r\nrenamed `getSystemActionKibanaPrivileges` to\r\n`getActionKibanaPrivileges`. I also added a field, `subFeatureType `, to\r\nthe connector type definition to help disable testing/executing an\r\nconnectors that are restricted under a sub-feature.\r\n\r\n**EDR Connector Execution for Testing**\r\nThe execution of EDR connectors using the API is limited to a single\r\nsub-action for testing purposes. This ensures users can still\r\nconfigure/test EDR connectors. In a separate\r\n[PR](#204804), I added back the\r\nSentinelOne and Crowdstrike params UIs with options restricted to one\r\nsub-action.\r\n\r\n**Rule API and Feature Configuration Updates**\r\nValidation has been added to the rule APIs to enforce restrictions on\r\nadding EDR connectors. The connector feature configuration has been\r\nupdated to include a new feature ID, EdrForSecurityFeature, which\r\nensures that EDR connectors are hidden on the rule form.\r\nNote: I saw that EDR connectors are also temporarily restricted in the\r\nSecurity Solution UI. To streamline this, I removed the\r\n`isBidirectionalConnectorType` check in `action_type_registry.ts`.\r\nInstead, I removed `SecurityConnectorFeatureId` from the\r\n`supportedFeatureIds` of the SentinelOne connector type definition.\r\n\r\n\r\n### Checklist\r\n\r\nCheck the PR satisfies following conditions. \r\n\r\n- [ ] [Unit or functional\r\ntests](https://www.elastic.co/guide/en/kibana/master/development-tests.html)\r\nwere updated or added to match the most common scenarios\r\n\r\n\r\n## To test\r\n\r\n**EDR Connector Subfeature Privilege**\r\n1. Create a new role and disable EDR connectors under the Actions and\r\nConnectors privilege\r\n2. Create a new user and assign that role to user\r\n3. Create a Sentinel One connector (It doesn't need to work, you can use\r\nfake values for the url and token)\r\n4. Login as the new user and run the following in Dev Tools to verify\r\nthat you aren't authorized execute the Sentinel One connector\r\n```\r\nPOST kbn:/api/actions/connector/$CONNECTOR_ID/_execute\r\n{\r\n \"params\": {\r\n \"subAction\": \"getAgents\",\r\n \"subActionParams\": {}\r\n }\r\n}\r\n```\r\n7. Update the role to enable EDR connectors and repeat the steps to\r\nverify that you are authorized to run the connector. (It will fail but\r\nverify it's not Unauthorized)\r\n\r\n**EDR Connector Execution for Testing**\r\n1. Enable the EDR connectors privilege in the role you created above and\r\nlog in as the user you created above.\r\n2. Run the following in Dev Tools to verify that you are authorized\r\nexecute the Sentinel One connector using only the `getAgents`\r\nsub-action. (It will fail but verify it's not `Unauthorized`)\r\n```\r\nPOST kbn:/api/actions/connector/$CONNECTOR_ID/_execute\r\n{\r\n \"params\": {\r\n \"subAction\": \"getAgents\",\r\n \"subActionParams\": {}\r\n }\r\n}\r\n```\r\n3. Run it again but replace the `subAction` with `isolateHost`. Verify\r\nthat you get an unauthorized error.\r\n\r\n**Rule API and Feature Configuration Updates**\r\n1. 1. Enable the EDR connectors privilege in the role you created above\r\nand log in as the user you created above.\r\n2. Go to Stack Management\r\n3. Try to create a rule, and verify that you don't see the SentinelOne\r\nconnector.\r\n4. Try to create a rule using the API and add your SentinelOne\r\nconnector, verify that the API throws an error.\r\n```\r\nPOST kbn:/api/alerting/rule\r\n{\r\n \"tags\": [],\r\n \"params\": {},\r\n \"schedule\": {\r\n \"interval\": \"1m\"\r\n },\r\n \"consumer\": \"alerts\",\r\n \"name\": \"Always firing rule\",\r\n \"rule_type_id\": \"example.always-firing\",\r\n \"actions\": [\r\n {\r\n \"group\": \"small\",\r\n \"id\": \"$CONNECTOR_ID\",\r\n \"params\": {\r\n \"subAction\": \"isolateAgent\",\r\n \"subActionParams\": {}\r\n },\r\n \"frequency\": {\r\n \"notify_when\": \"onActionGroupChange\",\r\n \"throttle\": null,\r\n \"summary\": false\r\n }\r\n }\r\n ],\r\n \"alert_delay\": {\r\n \"active\": 1\r\n }\r\n}\r\n```\r\n5. You can test the same behaviors when trying to add a SentinelOne\r\nconnector to existing rules.\r\n\r\n---------\r\n\r\nCo-authored-by: kibanamachine <42973632+kibanamachine@users.noreply.github.com>","sha":"23a5c6d2db1cd8d501e94c1af872d4ce7792e9ee"}},"sourceBranch":"main","suggestedTargetBranches":["8.x"],"targetPullRequestStates":[{"branch":"main","label":"v9.0.0","labelRegex":"^v9.0.0$","isSourceBranch":true,"state":"MERGED","url":"https://github.com/elastic/kibana/pull/203503","number":203503,"mergeCommit":{"message":"[ResponseOps] Granular Connector RBAC (#203503)\n\nPart of https://github.com/elastic/kibana/issues/180908\r\n\r\n## Summary\r\n\r\n**EDR Connector Subfeature Privilege**\r\nThis PR creates a new EDR connector sub-feature privilege under the read\r\nprivilege for connectors. The read privilege currently allows users to\r\nexecute connectors, and this new privilege will limit some of the\r\nconnectors that can be executed. When the EDR privilege is turned on,\r\nusers will be able to execute EDR connectors, and when it is off they\r\nwill not execute. This new privilege includes SentinelOne and\r\nCrowdstrike connectors.\r\n\r\nTo determine which connectors are considered EDR connectors, we\r\nleverage`getKibanaPrivileges` in the connector type definition. I\r\nremoved the restrictions to use this field only for system actions and\r\nrenamed `getSystemActionKibanaPrivileges` to\r\n`getActionKibanaPrivileges`. I also added a field, `subFeatureType `, to\r\nthe connector type definition to help disable testing/executing an\r\nconnectors that are restricted under a sub-feature.\r\n\r\n**EDR Connector Execution for Testing**\r\nThe execution of EDR connectors using the API is limited to a single\r\nsub-action for testing purposes. This ensures users can still\r\nconfigure/test EDR connectors. In a separate\r\n[PR](#204804), I added back the\r\nSentinelOne and Crowdstrike params UIs with options restricted to one\r\nsub-action.\r\n\r\n**Rule API and Feature Configuration Updates**\r\nValidation has been added to the rule APIs to enforce restrictions on\r\nadding EDR connectors. The connector feature configuration has been\r\nupdated to include a new feature ID, EdrForSecurityFeature, which\r\nensures that EDR connectors are hidden on the rule form.\r\nNote: I saw that EDR connectors are also temporarily restricted in the\r\nSecurity Solution UI. To streamline this, I removed the\r\n`isBidirectionalConnectorType` check in `action_type_registry.ts`.\r\nInstead, I removed `SecurityConnectorFeatureId` from the\r\n`supportedFeatureIds` of the SentinelOne connector type definition.\r\n\r\n\r\n### Checklist\r\n\r\nCheck the PR satisfies following conditions. \r\n\r\n- [ ] [Unit or functional\r\ntests](https://www.elastic.co/guide/en/kibana/master/development-tests.html)\r\nwere updated or added to match the most common scenarios\r\n\r\n\r\n## To test\r\n\r\n**EDR Connector Subfeature Privilege**\r\n1. Create a new role and disable EDR connectors under the Actions and\r\nConnectors privilege\r\n2. Create a new user and assign that role to user\r\n3. Create a Sentinel One connector (It doesn't need to work, you can use\r\nfake values for the url and token)\r\n4. Login as the new user and run the following in Dev Tools to verify\r\nthat you aren't authorized execute the Sentinel One connector\r\n```\r\nPOST kbn:/api/actions/connector/$CONNECTOR_ID/_execute\r\n{\r\n \"params\": {\r\n \"subAction\": \"getAgents\",\r\n \"subActionParams\": {}\r\n }\r\n}\r\n```\r\n7. Update the role to enable EDR connectors and repeat the steps to\r\nverify that you are authorized to run the connector. (It will fail but\r\nverify it's not Unauthorized)\r\n\r\n**EDR Connector Execution for Testing**\r\n1. Enable the EDR connectors privilege in the role you created above and\r\nlog in as the user you created above.\r\n2. Run the following in Dev Tools to verify that you are authorized\r\nexecute the Sentinel One connector using only the `getAgents`\r\nsub-action. (It will fail but verify it's not `Unauthorized`)\r\n```\r\nPOST kbn:/api/actions/connector/$CONNECTOR_ID/_execute\r\n{\r\n \"params\": {\r\n \"subAction\": \"getAgents\",\r\n \"subActionParams\": {}\r\n }\r\n}\r\n```\r\n3. Run it again but replace the `subAction` with `isolateHost`. Verify\r\nthat you get an unauthorized error.\r\n\r\n**Rule API and Feature Configuration Updates**\r\n1. 1. Enable the EDR connectors privilege in the role you created above\r\nand log in as the user you created above.\r\n2. Go to Stack Management\r\n3. Try to create a rule, and verify that you don't see the SentinelOne\r\nconnector.\r\n4. Try to create a rule using the API and add your SentinelOne\r\nconnector, verify that the API throws an error.\r\n```\r\nPOST kbn:/api/alerting/rule\r\n{\r\n \"tags\": [],\r\n \"params\": {},\r\n \"schedule\": {\r\n \"interval\": \"1m\"\r\n },\r\n \"consumer\": \"alerts\",\r\n \"name\": \"Always firing rule\",\r\n \"rule_type_id\": \"example.always-firing\",\r\n \"actions\": [\r\n {\r\n \"group\": \"small\",\r\n \"id\": \"$CONNECTOR_ID\",\r\n \"params\": {\r\n \"subAction\": \"isolateAgent\",\r\n \"subActionParams\": {}\r\n },\r\n \"frequency\": {\r\n \"notify_when\": \"onActionGroupChange\",\r\n \"throttle\": null,\r\n \"summary\": false\r\n }\r\n }\r\n ],\r\n \"alert_delay\": {\r\n \"active\": 1\r\n }\r\n}\r\n```\r\n5. You can test the same behaviors when trying to add a SentinelOne\r\nconnector to existing rules.\r\n\r\n---------\r\n\r\nCo-authored-by: kibanamachine <42973632+kibanamachine@users.noreply.github.com>","sha":"23a5c6d2db1cd8d501e94c1af872d4ce7792e9ee"}},{"branch":"8.x","label":"v8.18.0","labelRegex":"^v8.18.0$","isSourceBranch":false,"state":"NOT_CREATED"}]}] BACKPORT-->
Part of elastic#180908 ## Summary **EDR Connector Subfeature Privilege** This PR creates a new EDR connector sub-feature privilege under the read privilege for connectors. The read privilege currently allows users to execute connectors, and this new privilege will limit some of the connectors that can be executed. When the EDR privilege is turned on, users will be able to execute EDR connectors, and when it is off they will not execute. This new privilege includes SentinelOne and Crowdstrike connectors. To determine which connectors are considered EDR connectors, we leverage`getKibanaPrivileges` in the connector type definition. I removed the restrictions to use this field only for system actions and renamed `getSystemActionKibanaPrivileges` to `getActionKibanaPrivileges`. I also added a field, `subFeatureType `, to the connector type definition to help disable testing/executing an connectors that are restricted under a sub-feature. **EDR Connector Execution for Testing** The execution of EDR connectors using the API is limited to a single sub-action for testing purposes. This ensures users can still configure/test EDR connectors. In a separate [PR](elastic#204804), I added back the SentinelOne and Crowdstrike params UIs with options restricted to one sub-action. **Rule API and Feature Configuration Updates** Validation has been added to the rule APIs to enforce restrictions on adding EDR connectors. The connector feature configuration has been updated to include a new feature ID, EdrForSecurityFeature, which ensures that EDR connectors are hidden on the rule form. Note: I saw that EDR connectors are also temporarily restricted in the Security Solution UI. To streamline this, I removed the `isBidirectionalConnectorType` check in `action_type_registry.ts`. Instead, I removed `SecurityConnectorFeatureId` from the `supportedFeatureIds` of the SentinelOne connector type definition. ### Checklist Check the PR satisfies following conditions. - [ ] [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 ## To test **EDR Connector Subfeature Privilege** 1. Create a new role and disable EDR connectors under the Actions and Connectors privilege 2. Create a new user and assign that role to user 3. Create a Sentinel One connector (It doesn't need to work, you can use fake values for the url and token) 4. Login as the new user and run the following in Dev Tools to verify that you aren't authorized execute the Sentinel One connector ``` POST kbn:/api/actions/connector/$CONNECTOR_ID/_execute { "params": { "subAction": "getAgents", "subActionParams": {} } } ``` 7. Update the role to enable EDR connectors and repeat the steps to verify that you are authorized to run the connector. (It will fail but verify it's not Unauthorized) **EDR Connector Execution for Testing** 1. Enable the EDR connectors privilege in the role you created above and log in as the user you created above. 2. Run the following in Dev Tools to verify that you are authorized execute the Sentinel One connector using only the `getAgents` sub-action. (It will fail but verify it's not `Unauthorized`) ``` POST kbn:/api/actions/connector/$CONNECTOR_ID/_execute { "params": { "subAction": "getAgents", "subActionParams": {} } } ``` 3. Run it again but replace the `subAction` with `isolateHost`. Verify that you get an unauthorized error. **Rule API and Feature Configuration Updates** 1. 1. Enable the EDR connectors privilege in the role you created above and log in as the user you created above. 2. Go to Stack Management 3. Try to create a rule, and verify that you don't see the SentinelOne connector. 4. Try to create a rule using the API and add your SentinelOne connector, verify that the API throws an error. ``` POST kbn:/api/alerting/rule { "tags": [], "params": {}, "schedule": { "interval": "1m" }, "consumer": "alerts", "name": "Always firing rule", "rule_type_id": "example.always-firing", "actions": [ { "group": "small", "id": "$CONNECTOR_ID", "params": { "subAction": "isolateAgent", "subActionParams": {} }, "frequency": { "notify_when": "onActionGroupChange", "throttle": null, "summary": false } } ], "alert_delay": { "active": 1 } } ``` 5. You can test the same behaviors when trying to add a SentinelOne connector to existing rules. --------- Co-authored-by: kibanamachine <42973632+kibanamachine@users.noreply.github.com>
Part of #180908
Summary
EDR Connector Subfeature Privilege
This PR creates a new EDR connector sub-feature privilege under the read privilege for connectors. The read privilege currently allows users to execute connectors, and this new privilege will limit some of the connectors that can be executed. When the EDR privilege is turned on, users will be able to execute EDR connectors, and when it is off they will not execute. This new privilege includes SentinelOne and Crowdstrike connectors.
To determine which connectors are considered EDR connectors, we leverage
getKibanaPrivileges
in the connector type definition. I removed the restrictions to use this field only for system actions and renamedgetSystemActionKibanaPrivileges
togetActionKibanaPrivileges
. I also added a field,subFeatureType
, to the connector type definition to help disable testing/executing an connectors that are restricted under a sub-feature.EDR Connector Execution for Testing
The execution of EDR connectors using the API is limited to a single sub-action for testing purposes. This ensures users can still configure/test EDR connectors. In a separate PR, I added back the SentinelOne and Crowdstrike params UIs with options restricted to one sub-action.
Rule API and Feature Configuration Updates
Validation has been added to the rule APIs to enforce restrictions on adding EDR connectors. The connector feature configuration has been updated to include a new feature ID, EdrForSecurityFeature, which ensures that EDR connectors are hidden on the rule form.
Note: I saw that EDR connectors are also temporarily restricted in the Security Solution UI. To streamline this, I removed the
isBidirectionalConnectorType
check inaction_type_registry.ts
. Instead, I removedSecurityConnectorFeatureId
from thesupportedFeatureIds
of the SentinelOne connector type definition.Checklist
Check the PR satisfies following conditions.
To test
EDR Connector Subfeature Privilege
EDR Connector Execution for Testing
getAgents
sub-action. (It will fail but verify it's notUnauthorized
)subAction
withisolateHost
. Verify that you get an unauthorized error.Rule API and Feature Configuration Updates