-
Notifications
You must be signed in to change notification settings - Fork 13
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
[WIP] proposal: extending ldap support for different types of users #19
base: main
Are you sure you want to change the base?
Changes from 1 commit
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,87 @@ | ||
--- | ||
title: Proposal to extend user definitions in LDAP | ||
authors: | ||
- "@kleesc" | ||
reviewers: | ||
- "@bcaton85" | ||
approvers: | ||
- "@bcaton85" | ||
creation-date: 2022-07-08 | ||
last-updated: 2022-07-08 | ||
status: implementable | ||
--- | ||
|
||
# Extending users groups in LDAP | ||
|
||
## Summary | ||
|
||
Currently, Red Hat Quay supports the use of LDAP as an identity | ||
provider for Quay. This means when setup, users can login/register to | ||
Quay using their LDAP credentials setup by their administrators. Other | ||
Quay features based on LDAP includes team membership syncing with | ||
groups. | ||
|
||
As part of Quay 3.8, we are looking at extending this to support | ||
different type of users based on LDAP group/filters. These would | ||
specifically be targetted towards enterprise users, as opposed to | ||
Quay.io. | ||
|
||
## Open Questions | ||
|
||
- TODO | ||
|
||
### Goals | ||
|
||
- Define different set of users based on an external identity provider (non-database) | ||
- Still backwards compatible with the current state | ||
|
||
## Design Details | ||
|
||
### Superusers | ||
|
||
Currently, when superusers are enabled, the list of users with such | ||
access is defined at runtime, in Quay's configuration file. This can | ||
get tedious to maintain when large number of superusers are | ||
required. It also means having multiple set of users to maintain, in | ||
LDAP AND in Quay. | ||
|
||
This proposal is to add the possibility of maintaining that same list | ||
of users, in LDAP itself, either based on some extra LDAP group or | ||
filters. The main benefit of such feature is that system administrator | ||
would now only have to worry about their LDAP deployment, and not the | ||
Quay configuration when on-boarding and off-boarding members. | ||
|
||
### Restricted users | ||
|
||
Similarly, we can define another different set of LDAP users, with | ||
restricted access to content. One of the use case would be to give | ||
temporary, or read-only access to such user (for auditing purposes, | ||
for example). | ||
|
||
Another use case would be to limit who can or cannot create | ||
organization, as it is currently not enforced at all. (i.e any user is | ||
able to create and squat on a organization's namespace). | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. how generic can we get here? do we have a generic way to check these entitlements without having to add checks all over our code?
Comment on lines
+54
to
+63
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. This use case is fundamental to many enterprise users of Quay, this includes installations that rely on the Quay database to provide authentication and not LDAP. As a result we need to make this new user persona configurable outside of LDAP search queries. Open to opinions here but one way to do it is to either define all users to "restricted users" by default and manually enumerate the type of users who do not fall into this category, very much like we do with superusers today. We could call them privileged users. |
||
|
||
### Api access constraints based on authentication group | ||
|
||
Based on these extra groups/filters that allows Quay to select | ||
distinct users groups from the identity provider, we can extend the | ||
federated user identity interface (`data/users/`) to select a specific | ||
set of users. For example, being able to return a list of superusers | ||
from an LDAP deployment. Another example, for a Quay deployment using | ||
LDAP, Quay could limit creation of organizations to a specific set of | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I see retrieving a list of superusers being referenced often here. What is retrieving that list going to be used for? Also how are the permissions going to be checked? Are they going to be validated against the LDAP server on each request? Are they going to be retrieved initially and stored in a JWT and check the permissions on the JWT for future requests? |
||
user group based on some LDAP constraint. Similarly, we could limit | ||
(or grant) access to Quay's api or content based on another similarly | ||
defined LDAP entity. | ||
|
||
## Constraints | ||
|
||
- This proposal would only be for deployments making use of a federated identity with Quay (LDAP, keystone, ...) | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Isn't this specific to LDAP? How will the other identity providers be implemented? |
||
|
||
## Risks and Mitigations | ||
|
||
- The implementation of this proposal should not affect or block any of Quay.io's deployments. Any features, when implemented should be feature flagged, as not every deployment uses a federated identity service like LDAP. | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. conversely, this feature should be easy to add to quay deployments already using LDAP- the specification of the LDAP groups for superusers or restricted users should be done independently from configuring the LDAP provider itself. |
||
|
||
## Implementation History | ||
|
||
- 2022-07-08 Initial proposal |
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.
Would it be possible to give write permissions to a user in the restricted LDAP group through the Quay UI? What permissions model takes precedence?