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

[Request] Reports sidecars should be secured #806

Closed
Tracked by #814
andrewazores opened this issue May 3, 2024 · 7 comments
Closed
Tracked by #814

[Request] Reports sidecars should be secured #806

andrewazores opened this issue May 3, 2024 · 7 comments
Labels
feat New feature or request

Comments

@andrewazores
Copy link
Member

Describe the feature

When the Cryostat CR contains configuration to deploy Reports sidecars, the Operator should also place an auth proxy instance in front of these Pods. The Operator can generate a basic auth secret for this auth proxy to exclusively use, and can reconfigure the Cryostat container's reports service URL to include the basic auth credentials. This way the reports sidecar is not accessible by other processes within the cluster that can see its Service, but only by the Cryostat instance associated with the same CR.

Anything other information?

No response

@andrewazores
Copy link
Member Author

Another possibility instead of using an auth proxy and generated basic auth could be to use mutual TLS.

@andrewazores
Copy link
Member Author

Another option is to leave off the TLS and authentication and rely simply on a network policy to restrict allowed traffic to the reports Service to only requests originating from the Cryostat Pod(s). This is probably the simplest option.

Ideally, we have a network policy plus mTLS, or policy + TLS + auth.

@andrewazores andrewazores changed the title [Request] [Cryostat 3+] Reports sidecars should be secured by auth proxy [Request] Reports sidecars should be secured Jun 25, 2024
@tthvo
Copy link
Member

tthvo commented Jun 25, 2024

Another option is to leave off the TLS and authentication and rely simply on a network policy to restrict allowed traffic to the reports Service to only requests originating from the Cryostat Pod(s). This is probably the simplest option.

This does mean that the k8s cluster must have a network plugin that supports Network Policies. I think kindnet shipped with KinD does not support it yet: kubernetes-sigs/kind#842 so we might need to consider other alternatives for CI/dev environment.

May I help with this if no one has already started it?

@andrewazores
Copy link
Member Author

andrewazores commented Jun 25, 2024

I don't think anyone has started on this, though @mwangggg is working on #814 which might have some slight overlap in areas, since once those other containers are split out to separate Deployments (the same way -reports is) they will have the some concerns about access and security.

What happens if the cluster network plugin doesn't support these policies? If they just get ignored or emit a warning and proceed without the restriction then I think that would be fine. Otherwise, we might need to add some kind of capability test in the Operator controller before adding the configuration, if possible.

@andrewazores
Copy link
Member Author

Creating a NetworkPolicy resource without a controller that implements it will have no effect.

Sounds promising that it should be simple to add this as an enhancement, which will just be ignored if it isn't supported on the particular cluster. This does mean we should not rely on this alone, but it's a cheap and easy piece of additional security where it is supported.

@tthvo
Copy link
Member

tthvo commented Jun 25, 2024

I don't think anyone has started on this, though @mwangggg is working on #814 which might have some slight overlap in areas, since once those other containers are split out to separate Deployments (the same way -reports is) they will have the some concerns about access and security.

Ah right, I will leave it to @mwangggg then.

Creating a NetworkPolicy resource without a controller that implements it will have no effect.

Sounds promising that it should be simple to add this as an enhancement, which will just be ignored if it isn't supported on the particular cluster. This does mean we should not rely on this alone, but it's a cheap and easy piece of additional security where it is supported.

Yehh, it should fall into the same case with Ingress objects that requires an Ingress Controller. We can document and suggest the users with appropriate plugins (e.g. Calico, Cilium). I think on OpenShift side, that should be fine.

@andrewazores
Copy link
Member Author

No longer planned. Between TLS and network policies restricting traffic ingress to only originating from the Cryostat pod, and this being a stateless lambda-like service, and this also being a completely optional component (which is disabled by default), it does not seem like this is worth the effort at this time.

@github-project-automation github-project-automation bot moved this from Backlog to Done in 4.0.0 release Jan 20, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
feat New feature or request
Projects
Status: Done
Development

No branches or pull requests

2 participants