-
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
[Fleet][Endpoint][RBAC V2] Update fleet router and config to allow API access via RBAC controls #145361
Merged
ashokaditya
merged 68 commits into
elastic:main
from
ashokaditya:task/olm-policy-list-api-rbac-4926
Dec 14, 2022
Merged
[Fleet][Endpoint][RBAC V2] Update fleet router and config to allow API access via RBAC controls #145361
ashokaditya
merged 68 commits into
elastic:main
from
ashokaditya:task/olm-policy-list-api-rbac-4926
Dec 14, 2022
Conversation
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
020caa1
to
b29cd19
Compare
This was referenced Nov 21, 2022
c01607f
to
b82e709
Compare
gergoabraham
added a commit
that referenced
this pull request
Nov 23, 2022
## Summary RBAC UI features for Trusted Applications. To test, enable `endpointRbacEnabled` feature-flag, create a non-superuser user with _Security: ALL_ privilege and (All | Read | None) sub-privilege for _Trusted Applications_. <img width="541" alt="image" src="https://user-images.githubusercontent.com/39014407/203073992-fb71e293-2cd8-4639-8d61-4867e39ef071.png"> The modification should: - hide Trusted Apps from Manage navigation items if privilege is NONE, (note: it is still displayed for non-superusers, if the feature flag is disabled) - disable add/edit/delete for Trusted Applications if privilege is READ. ##⚠️ Note This PR focuses on _Read_ and _None_. The sub-privilege _All_ does not work perfectly at the moment, because of unauthorised API calls. A follow-up PR will fix this, after this PR is merged: #145361 ### Checklist Delete any items that are not applicable to this PR. - [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
e2d3807
to
e7a4db3
Compare
e7a4db3
to
7f5102a
Compare
2 tasks
ashokaditya
added a commit
to ashokaditya/kibana
that referenced
this pull request
Dec 19, 2022
ashokaditya
added a commit
to ashokaditya/kibana
that referenced
this pull request
Dec 19, 2022
ashokaditya
added a commit
to ashokaditya/kibana
that referenced
this pull request
Dec 19, 2022
ashokaditya
added a commit
to ashokaditya/kibana
that referenced
this pull request
Dec 19, 2022
ashokaditya
added a commit
to ashokaditya/kibana
that referenced
this pull request
Dec 22, 2022
ashokaditya
added a commit
to ashokaditya/kibana
that referenced
this pull request
Dec 22, 2022
ashokaditya
added a commit
to ashokaditya/kibana
that referenced
this pull request
Dec 23, 2022
ashokaditya
added a commit
that referenced
this pull request
Jan 3, 2023
## Summary Tests related to changes in /pull/145361 ### Checklist - [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 Co-authored-by: Mark Hopkin <mark.hopkin@elastic.co> Co-authored-by: kibanamachine <42973632+kibanamachine@users.noreply.github.com>
ashokaditya
added a commit
that referenced
this pull request
Jan 3, 2023
…thz` (#147696) ## Summary Follow up PR to update `api/fleet/agent_status` route. refs /pull/145361 refs elastic/security-team/issues/5539 ### Checklist - [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 ### For maintainers - [x] This was checked for breaking API changes and was [labeled appropriately](https://www.elastic.co/guide/en/kibana/master/contributing.html#kibana-release-notes-process) Co-authored-by: kibanamachine <42973632+kibanamachine@users.noreply.github.com>
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
OLM Sprint
release_note:feature
Makes this part of the condensed release notes
Team:Defend Workflows
“EDR Workflows” sub-team of Security Solution
Team:Fleet
Team label for Observability Data Collection Fleet team
v8.7.0
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Summary
This PR introduces the framework needed in fleet in order to be able to
support Package level Privileges - meaning: if a user does not have
authorization granted via Fleet and/or Integration privileges, then
package level privileges are check and API access granted. When access
is granted based on Package Privileges, the data is also validated to
ensure that it is limited to the integration package names that were
given authorization to the API.
The following APIs were updated to leverage this new framework:
Example of API error for Package policies api:
To test:
Log in as
elastic
/superuser and create some agent policies.Under
data:image/s3,"s3://crabby-images/699f9/699f9a8537f976cfdc2a395b4b2e2c2944579c5e" alt="Screenshot 2022-11-16 at 14 45 15"
Stack Management
, create a rolepolicy_role
with thefollowing RBAC settings. DO NOT select
Fleet -> All
or toggleIntegrations
. Leave those RBAC toggles set toNone
Create a user e.g.
policy_user
and assign them only the aboverole. NOT
superuser
.Login with this user and navigate to
app/security/administration/policy
or curl/postman.Expect to see the following:
api/fleet/epm/packages?category=security
should return a403
status.
api/fleet/package_policies?page=1&perPage=10&kuery=ingest-package-policies.package.name%3A%20endpoint
should return a list of policies.
/api/fleet/package_policies/<packagePolicyId>
should return a200
and a signle item that has the policie's details. Note that thepackage name of this item is
endpoint
.api/fleet/agent_policies/_bulk_get
, and should return a403
.Policy Management
RBAC set toAll
http://localhost:5601/api/fleet/package_policies/<packagePolicyId>
should return a
200
with the updated policy details as responseChecklist
Unit or functional
tests
were updated or added to match the most common scenarios
This was checked for breaking API changes and was labeled
appropriately
Co-authored-by: Paul Tavares paul.tavares@elastic.co