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

Auth design #87

Draft
wants to merge 1 commit into
base: main
Choose a base branch
from
Draft

Auth design #87

wants to merge 1 commit into from

Conversation

Kirill-Garbar
Copy link
Collaborator

@Kirill-Garbar Kirill-Garbar commented Mar 26, 2024

Guthub issue: #76

@Kirill-Garbar Kirill-Garbar force-pushed the auth-design branch 3 times, most recently from 66f2525 to 8d74637 Compare March 28, 2024 15:12
@kvaps kvaps modified the milestone: v0.0.3 Mar 31, 2024
@Kirill-Garbar Kirill-Garbar force-pushed the auth-design branch 2 times, most recently from 7b991cc to 607e718 Compare April 3, 2024 14:59
spec:
...
security:
peer:
Copy link
Collaborator Author

@Kirill-Garbar Kirill-Garbar Apr 3, 2024

Choose a reason for hiding this comment

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

As no separate enabler is proposed, we will have only 2 states: secrets provided by customer and auto-tls options from etcd.

Will we implement creation of the secrets in the operator with cert-manager objects? If yes, then we need to find a solution how to enable/disable it. Proposal: create in the future additional sections ~operatorManagedCertificates or so. Defined new section and defined secret references can't exist together and will be validated in a webhook.

If we agree that this is good option, then we will not extend specification for now.

Choose a reason for hiding this comment

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

Will we implement creation of the secrets in the operator with cert-manager objects?

The certificate management offered by CloudnativePG seems very good to me.

Essentially, if no values are provided, certs are managed by the Operator. With a user input, instead, the Operator does a look-up to use them.

Copy link
Member

@kvaps kvaps Apr 3, 2024

Choose a reason for hiding this comment

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

Totally agree, I think we have to enable certs generation if nothing specified.
I do not see the case where user would need etcd-cluster without certificates.

Copy link
Member

@kvaps kvaps Apr 3, 2024

Choose a reason for hiding this comment

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

Let's enable certificates generation by operator by default for now, and extend API spec for specifying custom user certificates later.

What do you think @serathius?

Copy link
Collaborator Author

@Kirill-Garbar Kirill-Garbar Apr 3, 2024

Choose a reason for hiding this comment

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

I think, for many users (not k8s control plane) auto-tls for transport encryption and password authentication is enough.

Self-managed certificates are for the future. I would say it is mature logic and it is a bit early to design this rotation before operator is able to operate (fully and reliably) etcd (scale, defrag, backup, restore). I thought the same in the very beginning, that we need to remove cert-manager dependency as soon as possible, but after that I though one more time:

  • Cert-manager is used by (I assume) every mature platform.
  • Even if it is not used => easy to install.
  • The only problem - Openshift where they have their own PKI infra. This problem should be investigated. Even there certman can be installed.

I assumed that operator will create cert-manager objects in the code and will depend on the installed cert-manager operator with its CRDs.

Copy link
Member

Choose a reason for hiding this comment

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

I would base this on the fact that the primary users for now are hosted Kubernetes control planes. We're ready to adopt the operator as soon as it offers a stable spec and a feature for managing x509 certificates.

I have nothing against using cert-manager. I was just considering that implementing basic logic for generating certificates (even for 10 years) might be simpler than agreeing on and stabilizing the spec for external certificate management at this phase.

...
```

It is expected that secrets contain sections with specific names: `tls.crt`, `tls.key` for tlsSecret and `ca.crt` for caSecret.
Copy link
Collaborator Author

Choose a reason for hiding this comment

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

Secret sections (filenames) will be hardcoded to decrease configuration complexity

@Kirill-Garbar Kirill-Garbar marked this pull request as ready for review April 3, 2024 15:30
@Kirill-Garbar Kirill-Garbar requested a review from kvaps as a code owner April 3, 2024 15:30
@kvaps kvaps marked this pull request as draft April 9, 2024 14:52
@kvaps
Copy link
Member

kvaps commented May 14, 2024

Could you please move to design subdirectory into website

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