-
Notifications
You must be signed in to change notification settings - Fork 285
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 User Refactor #2594
Security User Refactor #2594
Conversation
Signed-off-by: Stephen Crawford <[email protected]>
Signed-off-by: Stephen Crawford <[email protected]>
Signed-off-by: Stephen Crawford <[email protected]>
Signed-off-by: Stephen Crawford <[email protected]>
Signed-off-by: Stephen Crawford <[email protected]>
Signed-off-by: Stephen Crawford <[email protected]>
Codecov Report
📣 This organization is not using Codecov’s GitHub App Integration. We recommend you install it so Codecov can continue to function properly for your repositories. Learn more @@ Coverage Diff @@
## main #2594 +/- ##
============================================
+ Coverage 61.38% 61.51% +0.13%
- Complexity 3383 3397 +14
============================================
Files 269 272 +3
Lines 18668 18740 +72
Branches 3279 3284 +5
============================================
+ Hits 11459 11528 +69
Misses 5613 5613
- Partials 1596 1599 +3
... and 3 files with indirect coverage changes Help us with your feedback. Take ten seconds to tell us how you rate us. Have a feature suggestion? Share it here. |
Hi @scrawfor99 , I think you are on the right track with the extensions registration process and creation of the service account at that time for extensions that require one, but I think we should start by introducing the notion of a service account. I see in this PR that For introduction of the concept of a service account, I would expect:
Once the concept of the service account is introduced, an API to list service accounts should be created and we can also start linking it to the extensions use-case like you are doing here to create one on extension registration. |
Signed-off-by: Stephen Crawford <[email protected]>
Hi @cwperks, thank you for your thoughtful comments. For specifications about defining service accounts, I would suggest we use the associated decision doc/question #2597. I think that some of the expectations you listed for service accounts sound like great ideas, but I also think we may need to come to a better understanding about some others. For instance, having an API to list service accounts sounds great. However, I am not sure why we need to restrict the number of roles a service account can have. How about we head over to the decision doc to hash things out and then we can come back here as I implement based on our decision? |
@scrawfor99 I will move the comments over to the decision doc. I was thinking that service account tokens would be narrowly used in order to allow extensions to write to reserved indices for those extensions that have special protections - similar to plugins with a system index, but without the need for stashing the thread context. It would be possible to increase the scope of the service account token for use-cases where an extension runs as a daemon if its been granted by the cluster admin. Single roles makes it a one stop place to look up the permissions. User's may have multiple roles, but for a service account limiting it to a single role would make it explicitly clear what it can do. I have seen other systems that implement service accounts hardcode the roles definition in code and the permissions are not modifiable at all. |
Signed-off-by: Stephen Crawford <[email protected]>
Signed-off-by: Stephen Crawford <[email protected]>
Signed-off-by: Stephen Crawford <[email protected]>
Signed-off-by: Stephen Crawford <[email protected]>
Signed-off-by: Stephen Crawford <[email protected]>
Signed-off-by: Stephen Crawford <[email protected]>
Signed-off-by: Stephen Crawford <[email protected]>
Signed-off-by: Stephen Crawford <[email protected]>
Signed-off-by: Stephen Crawford <[email protected]>
Signed-off-by: Stephen Crawford <[email protected]>
@scrawfor99 my apologies, I do not (yet) know this part of the plugin well enough, looking nonetheless but would let others to approve with confidence |
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.
Nice work! Thanks @scrawfor99
Btw, I saw Peter was requesting some changes, but for some reason I couldn't see that thru the log. Just wanna double check with you to make sure all the comments have been resolved. |
Hi @RyanL1997, thank you. Yeah, Peter's changes were addressed a while ago, I will dismiss if we get two approvals. |
src/main/java/org/opensearch/security/dlic/rest/api/InternalUsersApiAction.java
Show resolved
Hide resolved
src/main/java/org/opensearch/security/dlic/rest/api/InternalUsersApiAction.java
Show resolved
Hide resolved
src/main/java/org/opensearch/security/dlic/rest/api/InternalUsersApiAction.java
Show resolved
Hide resolved
|
||
if (!securityJsonNode.get("attributes").get("owner").isNull() && !securityJsonNode.get("attributes").get("owner").equals(accountName)) { // If this is a service account | ||
verifyServiceAccount(securityJsonNode, accountName); | ||
String password = generatePassword(); |
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.
why not use securityJsonNode.put('name')...
here to avoid duplicate declaration on line 115?
Having said that, I know that put()
doesn't exist in SecurityJsonNode for some unknown reason (probably to make it a read-only node). Do you think creating it might be worthwhile?
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.
See above. I can remove use of the contentAsNode pattern by adding methods to the SecurityJsonNode object. I was not sure which implementation would be preferred.
I am interpreting this as you would prefer that change so I will go that route.
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.
EDIT: Hi @DarshitChanpura Unless it is going to block this PR, I am going to suggest we leave it as is. I know it is not the most convenient solution but the securityJsonNode class has 40+ usages and was not intended to be directly modifiable. I have been working on modifying it but it requires changing the class from creating final instances of itself to creating mutable versions. I suspect a part of the reason the class was created how it is, is so that there would be an immutable version of a JSON node for implementations. Let me know if this will be a blocker and I can look more into it but I am going to suggest we leave this as is otherwise.
P.S. I did make the other changes you suggested.
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.
Sounds good, we can leave it as is. Thank you for taking time and going through SecurityJsonNode 😃. We can cover this in a separate PR in future
src/test/java/org/opensearch/security/dlic/rest/api/UserApiTest.java
Outdated
Show resolved
Hide resolved
b1a0373
to
e0531f2
Compare
Signed-off-by: Stephen Crawford <[email protected]>
e0531f2
to
3a106c5
Compare
Peter is not here this week or last.
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.
Thank you for addressing all the comments. I only have one last comment. The changes look good to me otherwise!
src/main/java/org/opensearch/security/dlic/rest/api/InternalUsersApiAction.java
Show resolved
Hide resolved
@DarshitChanpura, exactly, it is so that an account can be turned on/off and auth tokens will not be created for any disabled accounts. |
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.
Thank you for addressing all my comments @scrawfor99 ! I'm happy to merge this.
--------- Signed-off-by: Stephen Crawford <[email protected]> Signed-off-by: Stephen Crawford <[email protected]>
--------- Signed-off-by: Stephen Crawford <[email protected]> Signed-off-by: Stephen Crawford <[email protected]> Signed-off-by: Maciej Mierzwa <[email protected]>
--------- Signed-off-by: Stephen Crawford <[email protected]> Signed-off-by: Stephen Crawford <[email protected]>
--------- Signed-off-by: Stephen Crawford <[email protected]> Signed-off-by: Stephen Crawford <[email protected]>
--------- Signed-off-by: Stephen Crawford <[email protected]> Signed-off-by: Stephen Crawford <[email protected]>
…s, and multi tenancy changes (#2737) * [Extensions] Generate auth tokens for service accounts (#2716) * Generate auth tokens for service accounts Signed-off-by: Stephen Crawford <[email protected]> Signed-off-by: Stephen Crawford <[email protected]> * Security User Refactor (#2594) --------- Signed-off-by: Stephen Crawford <[email protected]> Signed-off-by: Stephen Crawford <[email protected]> * Backport service account changes Signed-off-by: Stephen Crawford <[email protected]> * Update test Signed-off-by: Stephen Crawford <[email protected]> * Optimize imports Signed-off-by: Stephen Crawford <[email protected]> * Spotless Signed-off-by: Stephen Crawford <[email protected]> * fix plugin Signed-off-by: Stephen Crawford <[email protected]> * fix whitespace Signed-off-by: Stephen Crawford <[email protected]> * Fix multitency config update (#2758) Moved multi-tenancy to REST API implementation Signed-off-by: Andrey Pleskach <[email protected]> * Remove SSLCertsAction Signed-off-by: Stephen Crawford <[email protected]> * Fix dependency Signed-off-by: Stephen Crawford <[email protected]> * fix tenancy tests Signed-off-by: Stephen Crawford <[email protected]> --------- Signed-off-by: Stephen Crawford <[email protected]> Signed-off-by: Stephen Crawford <[email protected]> Signed-off-by: Andrey Pleskach <[email protected]> Co-authored-by: Andrey Pleskach <[email protected]>
…s, and multi tenancy changes (#2737) * [Extensions] Generate auth tokens for service accounts (#2716) * Generate auth tokens for service accounts Signed-off-by: Stephen Crawford <[email protected]> Signed-off-by: Stephen Crawford <[email protected]> * Security User Refactor (#2594) --------- Signed-off-by: Stephen Crawford <[email protected]> Signed-off-by: Stephen Crawford <[email protected]> * Backport service account changes Signed-off-by: Stephen Crawford <[email protected]> * Update test Signed-off-by: Stephen Crawford <[email protected]> * Optimize imports Signed-off-by: Stephen Crawford <[email protected]> * Spotless Signed-off-by: Stephen Crawford <[email protected]> * fix plugin Signed-off-by: Stephen Crawford <[email protected]> * fix whitespace Signed-off-by: Stephen Crawford <[email protected]> * Fix multitency config update (#2758) Moved multi-tenancy to REST API implementation Signed-off-by: Andrey Pleskach <[email protected]> * Remove SSLCertsAction Signed-off-by: Stephen Crawford <[email protected]> * Fix dependency Signed-off-by: Stephen Crawford <[email protected]> * fix tenancy tests Signed-off-by: Stephen Crawford <[email protected]> --------- Signed-off-by: Stephen Crawford <[email protected]> Signed-off-by: Stephen Crawford <[email protected]> Signed-off-by: Andrey Pleskach <[email protected]> Co-authored-by: Andrey Pleskach <[email protected]> (cherry picked from commit fa33fc5)
…s, and multi tenancy changes (#2737) (#2777) * [Extensions] Generate auth tokens for service accounts (#2716) * Generate auth tokens for service accounts Signed-off-by: Stephen Crawford <[email protected]> Signed-off-by: Stephen Crawford <[email protected]> * Security User Refactor (#2594) --------- Signed-off-by: Stephen Crawford <[email protected]> Signed-off-by: Stephen Crawford <[email protected]> * Backport service account changes Signed-off-by: Stephen Crawford <[email protected]> * Update test Signed-off-by: Stephen Crawford <[email protected]> * Optimize imports Signed-off-by: Stephen Crawford <[email protected]> * Spotless Signed-off-by: Stephen Crawford <[email protected]> * fix plugin Signed-off-by: Stephen Crawford <[email protected]> * fix whitespace Signed-off-by: Stephen Crawford <[email protected]> * Fix multitency config update (#2758) Moved multi-tenancy to REST API implementation Signed-off-by: Andrey Pleskach <[email protected]> * Remove SSLCertsAction Signed-off-by: Stephen Crawford <[email protected]> * Fix dependency Signed-off-by: Stephen Crawford <[email protected]> * fix tenancy tests Signed-off-by: Stephen Crawford <[email protected]> --------- Signed-off-by: Stephen Crawford <[email protected]> Signed-off-by: Stephen Crawford <[email protected]> Signed-off-by: Andrey Pleskach <[email protected]> Co-authored-by: Andrey Pleskach <[email protected]> (cherry picked from commit fa33fc5) Co-authored-by: Stephen Crawford <[email protected]>
--------- Signed-off-by: Stephen Crawford <[email protected]> Signed-off-by: Stephen Crawford <[email protected]> Signed-off-by: Maciej Mierzwa <[email protected]>
--------- Signed-off-by: Stephen Crawford <[email protected]> Signed-off-by: Stephen Crawford <[email protected]> Signed-off-by: Maciej Mierzwa <[email protected]>
--------- Signed-off-by: Stephen Crawford <[email protected]> Signed-off-by: Stephen Crawford <[email protected]> Signed-off-by: Sam <[email protected]>
Description
This PR is meant to refactor the concept of a user from the Security Plugin's point of view. This will allow us to introduce the basics of service accounts on the Security plugin side.
Issues Resolved
This PR will contribute to resolving #2584.
Testing
The existing InternalUsersTests are being used to verify the previous functionality is maintained. After merging this change, specific Service Account operations can be performed and tests added to exercise service account logic.
Check List
By submitting this pull request, I confirm that my contribution is made under the terms of the Apache 2.0 license.
For more information on following Developer Certificate of Origin and signing off your commits, please check here.