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

TLS certs not passed correctly if helm repo contains path in repository URL #19138

Closed
svghadi opened this issue Jul 22, 2024 · 2 comments · Fixed by #19488
Closed

TLS certs not passed correctly if helm repo contains path in repository URL #19138

svghadi opened this issue Jul 22, 2024 · 2 comments · Fixed by #19488
Labels

Comments

@svghadi
Copy link
Contributor

svghadi commented Jul 22, 2024

Describe the bug

I am try to deploy a chart from a private OCI Helm registry with self-signed certificates. I have added the tls certificate for my domain my-registry.default in argocd-tls-certs-cm configmap.

$ kubctl get cm argocd-tls-certs-cm -o yaml -n default
apiVersion: v1
kind: ConfigMap
metadata:
  name: argocd-tls-certs-cm
data:
  my-registry.default: |-
    -----BEGIN CERTIFICATE-----
    <cert data>
    -----END CERTIFICATE-----

When I create a Helm repository with my-registry.default repository URL everything works as expected. However, if the repository URL contains a path eg: my-registry.default/helm-charts, the tls certificate for the domain i.e my-registry.default is not picked up by Argo CD and results into x509: certificate signed by unknown authority errors.

To Reproduce

  1. Add OCI registry certs into Argo CD via UI or CLI
  2. Create a Helm OCI repository with path in repo url.
  3. Observe repo connection status and repo server logs

Expected behavior

Argo CD should connect successfully to the registry

Screenshots

image

Version

v2.10.11

Didn't test with master but I think should be reproducible with it.

Logs
Repo server logs

# no path in url
time="2024-07-22T11:14:17Z" level=info msg=Trace args="[helm registry login my-registry --username ****** --password ****** --ca-file /app/config/tls/my-registry]" dir=/tmp/helm2649027701 operation_name="exec helm" time_ms=62.63742499999999
time="2024-07-22T11:14:17Z" level=info msg="took to test helm oci repository" seconds=0.062829967

# path in url
time="2024-07-22T11:15:34Z" level=info msg="helm registry login my-registry/helm-charts --username ****** --password ******" dir=/tmp/helm1150378190 execID=75776
time="2024-07-22T11:15:34Z" level=error msg="`helm registry login my-registry/helm-charts --username ****** --password ******` failed exit status 1: WARNING: Using --password ****** the CLI is insecure. Use --password-stdin.\ntime=\"2024-07-22T11:15:34Z\" level=info msg=\"Error logging in to endpoint, trying next endpoint\" error=\"Get \\\"https://my-registry/v2/\\\": tls: failed to verify certificate: x509: certificate signed by unknown authority\"\nError: Get \"https://my-registry/v2/\": tls: failed to verify certificate: x509: certificate signed by unknown authority" execID=75776```
@svghadi svghadi added the bug Something isn't working label Jul 22, 2024
@svghadi svghadi changed the title TLS certs not passed correctly if helm registry contains path in repository URL TLS certs not passed correctly if helm repo contains path in repository URL Jul 22, 2024
@svghadi
Copy link
Contributor Author

svghadi commented Jul 23, 2024

I did some digging, if the the repoURL contains oci scheme, the getCAPath func will return the correct CA cert even if the url contains path.

if parsedURL.Scheme == "https" || parsedURL.Scheme == "oci" {
hostname = parsedURL.Host

However, when I try to set the oci scheme in the url, eg. oci://my-registry.default/helm-charts, the creation of the repo fails with OCI Helm repository URL should include hostname and port only from cli. From UI, the repo is created but oci:// is truncated.

PR #5888 introduced this change to disallow oci scheme in URL. @alexmt, I noticed that you implemented this change. Do you think this can be reverted as helm now supports oci:// prefix?
https://helm.sh/docs/topics/registries/#other-subcommands

Support for the oci:// protocol is also available in various other subcommands. Here is a complete list:

An alternative simple solution to fix this bug could be to explicitly add oci:// scheme during fetching of the CA certs if the repo has EnableOCI set to true so that the url parsing correctly detects the hostname.

@svghadi
Copy link
Contributor Author

svghadi commented Aug 12, 2024

Another case(#8508 (comment)) of incorrect hostname parsing when repoURL contains port.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
None yet
Development

Successfully merging a pull request may close this issue.

2 participants