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

📖 Document OLMv1 permission model #1380

Merged
merged 18 commits into from
Nov 18, 2024

Conversation

rashmi43
Copy link
Contributor

@rashmi43 rashmi43 commented Oct 16, 2024

Description

Document OLMv1 permission model
aims to clarify #1376

Reviewer Checklist

  • API Go Documentation
  • Tests: Unit Tests (and E2E Tests, if appropriate)
  • Comprehensive Commit Messages
  • Links to related GitHub Issue(s)

rashmi43 and others added 8 commits September 10, 2024 00:44
@rashmi43 rashmi43 requested a review from a team as a code owner October 16, 2024 06:24
Copy link

netlify bot commented Oct 16, 2024

Deploy Preview for olmv1 ready!

Name Link
🔨 Latest commit ad0a648
🔍 Latest deploy log https://app.netlify.com/sites/olmv1/deploys/6736e17c0c06a00008f0fdfa
😎 Deploy Preview https://deploy-preview-1380--olmv1.netlify.app
📱 Preview on mobile
Toggle QR Code...

QR Code

Use your smartphone camera to open QR code link.

To edit notification comments on pull requests, go to your Netlify site configuration.

Copy link

codecov bot commented Oct 17, 2024

Codecov Report

All modified and coverable lines are covered by tests ✅

Project coverage is 74.73%. Comparing base (b7674d8) to head (ad0a648).
Report is 64 commits behind head on main.

Additional details and impacted files
@@            Coverage Diff             @@
##             main    #1380      +/-   ##
==========================================
- Coverage   74.84%   74.73%   -0.12%     
==========================================
  Files          42       42              
  Lines        2516     3241     +725     
==========================================
+ Hits         1883     2422     +539     
- Misses        449      646     +197     
+ Partials      184      173      -11     
Flag Coverage Δ
e2e 52.42% <ø> (-4.34%) ⬇️
unit 57.20% <ø> (+4.50%) ⬆️

Flags with carried forward coverage won't be shown. Click here to find out more.

☔ View full report in Codecov by Sentry.
📢 Have feedback on the report? Share it here.

Signed-off-by: rashmi_kh <rashmi.khanna@in.ibm.com>
Signed-off-by: rashmi_kh <rashmi.khanna@in.ibm.com>
docs/concepts/permission-model.md Outdated Show resolved Hide resolved
Here we aim to describe the OLMv1 permission model. OLMv1 itself does not have permission to manage the installation and lifecycle of cluster extensions. Rather, it requires that each cluster extension specifies a service account that will be used to manage its bundle contents.


1) The purpose of the service account specified in the ClusterExtension spec, which is to manage everything in (2) below.
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think the structure of this section is a little bit unclear. Maybe we could call attention to the fact that the installer service account and the service account for the cluster extension's Deployment have different purposes: the first manages the lifecycle of the cluster extensions - so it needs to be able to create/modify the resources packed in the bundle, and assign RBAC to the extension's Deployment SA. And, the second, gives the extension controller the RBAC it needs to do its business.

I think most of that information is already here, we should just restructure it a bit to make clear this distinction and the roles of each of the SAs

docs/concepts/permission-model.md Outdated Show resolved Hide resolved
docs/concepts/permission-model.md Outdated Show resolved Hide resolved
Signed-off-by: rashmi_kh <rashmi.khanna@in.ibm.com>
@rashmi43 rashmi43 requested a review from joelanford October 21, 2024 16:20
3) The contents of the operator bundle may contain more service accounts and RBAC. Since the operator bundle contains its own RBAC, it means the ClusterExtension service account requires either:
- the same set of permissions that are defined in the RBAC that it is trying to create.
- bind/escalate verbs for RBAC, see https://kubernetes.io/docs/reference/access-authn-authz/rbac/#privilege-escalation-prevention-and-bootstrapping
4) The OLMv1 operator-controller generates a service account with the required RBAC for the extension controller based on the contents of the ClusterServiceVersion in much the same way that OLMv0 does. In the ArgoCD example, the [controller service account](https://github.com/argoproj-labs/argocd-operator/blob/da6b8a7e68f71920de9545152714b9066990fc4b/deploy/olm-catalog/argocd-operator/0.6.0/argocd-operator.v0.6.0.clusterserviceversion.yaml#L1124) permissions allow the operator to manage and run the controller logic.
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I'm on the fence about how important it is to include bullet (4). It seems that at a conceptual level, but bullet could be left out and the document would stand on its own, such that it describes the concept without delving into implementation specifics.

On the otherhand, concrete examples can be useful to illustrate a concept. Two alternative suggestions:

  1. Re-write this to be more of an example rather than another bullet point.
  2. Going along with (1), is there a place in the docs that we talk about registry+v1 specifics? If so, maybe we insert some details there about how OLMv1 generates service accounts and RBAC? Then we could link there from there.

Maybe we drop bullet (4) for now, and do an example in a follow-up?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

updating 4) to an example

Signed-off-by: rashmi_kh <rashmi.khanna@in.ibm.com>
@rashmi43 rashmi43 requested a review from perdasilva October 24, 2024 18:40
Signed-off-by: rashmi_kh <rashmi.khanna@in.ibm.com>
@rashmi43 rashmi43 requested a review from perdasilva November 7, 2024 17:34
Signed-off-by: rashmi_kh <rashmi.khanna@in.ibm.com>
@rashmi43
Copy link
Contributor Author

@perdasilva i have updated the example section, can you have a final look

Copy link
Contributor

@perdasilva perdasilva left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thank you ^^

@perdasilva perdasilva added this pull request to the merge queue Nov 18, 2024
Merged via the queue into operator-framework:main with commit e5820ae Nov 18, 2024
16 of 18 checks passed
rashmi43 added a commit to rashmi43/operator-controller that referenced this pull request Nov 19, 2024
Update go version checker (operator-framework#1474)

* Handle new files (old version is empty)
* Handle the case where .0 patch is added/removed

Signed-off-by: Todd Short <tshort@redhat.com>

sa not found

Signed-off-by: rashmi_kh <rashmi.khanna@in.ibm.com>

📖 Document OLMv1 permission model (operator-framework#1380)

* changes to derice minimum service account

Signed-off-by: rashmi_kh <rashmi.khanna@in.ibm.com>

* remove headers

Signed-off-by: rashmi_kh <rashmi.khanna@in.ibm.com>

* add details about registry+v1 support

* render yml correctly

Signed-off-by: rashmi_kh <rashmi.khanna@in.ibm.com>

* create doc for olmv1 permission model

Signed-off-by: rashmi_kh <rashmi.khanna@in.ibm.com>

* Delete docs/drafts directory

* Update permission-model.md

* update permission models with link

Signed-off-by: rashmi_kh <rashmi.khanna@in.ibm.com>

* add space

Signed-off-by: rashmi_kh <rashmi.khanna@in.ibm.com>

* add more structure

Signed-off-by: rashmi_kh <rashmi.khanna@in.ibm.com>

* incorporate review comments

Signed-off-by: rashmi_kh <rashmi.khanna@in.ibm.com>

* incorporate review comments

Signed-off-by: rashmi_kh <rashmi.khanna@in.ibm.com>

* pers review comments-s

* example as header-s

* update the example

Signed-off-by: rashmi_kh <rashmi.khanna@in.ibm.com>

---------

Signed-off-by: rashmi_kh <rashmi.khanna@in.ibm.com>

Delete docs/drafts/derive-serviceaccount.md

add custom sa not found

Signed-off-by: rashmi_kh <rashmi.khanna@in.ibm.com>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants