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

feat: Combine files in a multisource repo (#12471 #12485) #12508

Closed
wants to merge 64 commits into from

Conversation

gczuczy
Copy link
Contributor

@gczuczy gczuczy commented Feb 17, 2023

Fixes #12471
Fixes #12476
Fixes #7189
Fixes #13220
Fixes #14521

Note on DCO:

If the DCO action in the integration test fails, one or more of your commits are not signed off. Please click on the Details link next to the DCO action for instructions on how to resolve this.

Checklist:

  • Either (a) I've created an enhancement proposal and discussed it with the community, (b) this is a bug fix, or (c) this does not need to be in the release notes.
  • The title of the PR states what changed and the related issues number (used for the release note).
  • I've included "Closes [ISSUE #]" or "Fixes [ISSUE #]" in the description to automatically close the associated issue.
  • I've updated both the CLI and UI to expose my feature, or I plan to submit a second PR with them.
  • Does this PR require documentation updates?
  • I've updated documentation as required by this PR.
  • Optional. My organization is added to USERS.md.
  • I have signed off all my commits as required by DCO
  • I have written unit and/or e2e tests for my change. PRs without these are unlikely to be merged.
  • My build is green (troubleshooting builds).

@codecov
Copy link

codecov bot commented Feb 17, 2023

Codecov Report

Attention: Patch coverage is 46.07330% with 206 lines in your changes are missing coverage. Please review.

Project coverage is 49.46%. Comparing base (2b6b9bf) to head (1b8cb9f).
Report is 6 commits behind head on master.

❗ Current head 1b8cb9f differs from pull request most recent head acf443f. Consider uploading reports for the commit acf443f to get more accurate results

Files Patch % Lines
reposerver/repository/repository.go 40.65% 156 Missing and 25 partials ⚠️
util/app/path/path.go 67.92% 13 Missing and 4 partials ⚠️
util/argo/argo.go 72.72% 4 Missing and 2 partials ⚠️
pkg/apis/application/v1alpha1/types.go 0.00% 2 Missing ⚠️
Additional details and impacted files
@@            Coverage Diff             @@
##           master   #12508      +/-   ##
==========================================
+ Coverage   49.45%   49.46%   +0.01%     
==========================================
  Files         273      271       -2     
  Lines       48662    48140     -522     
==========================================
- Hits        24066    23813     -253     
+ Misses      22235    21960     -275     
- Partials     2361     2367       +6     

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

@gczuczy
Copy link
Contributor Author

gczuczy commented Feb 17, 2023

There's a lot of code duplicated from repository.go:679 (valueFiles logic) to the new copyFrom logic. I think these should be refactored to call common functions. Also, they way that both parts are checking out repos and deferring to closer functions for cleanup individually is something I don't like the idea of. Probably repos should be checked out once, cached, and when it's time for the manifest generation released and cleaned up.

I think once the copyFrom logic is there and I both have a clearer view of how stuff works and I'm more comfortable with the logics here, I will see how can I clean this mess up.

And I'm also planning to address the LintGo failing test later.

@gczuczy
Copy link
Contributor Author

gczuczy commented Feb 21, 2023

I've got the following errors while running test-local:

# github.com/argoproj/argo-cd/v2/controller
controller/state.go:191:3: github.com/sirupsen/logrus.Debugf format %s has arg source of wrong type github.com/argoproj/argo-cd/v2/pkg/apis/application/v1alpha1.ApplicationSource
(...)
# github.com/argoproj/argo-cd/v2/util/argo
util/argo/argo.go:417:14: fmt.Sprintf format %s has arg source of wrong type github.com/argoproj/argo-cd/v2/pkg/apis/application/v1alpha1.ApplicationSource

And the String operator for ApplicationSources is defined at pkg/apis/application/v1alpha1/generated.pb.go:16086:

func (this *ApplicationSource) String() string {
  if this == nil {
    return "nil"
  }

IIRC I haven't fiddled with this part, and I'm not really sure what might have caused those test errors.

@gczuczy gczuczy changed the title Combine files in a multisource repo (#12471 #12485) feat: Combine files in a multisource repo (#12471 #12485) Feb 24, 2023
@gczuczy
Copy link
Contributor Author

gczuczy commented Feb 24, 2023

I think the PR looks feature-complete right now, unit tests are also passing. The place I couldn't find the tests for are the changes in the reposerver/repository/repository.go:runManifestGenAsync function, that's where the logic responsible for this change is called. Everything else should be covered by the unit tests.

Docs are still to be adjusted.

@gczuczy
Copy link
Contributor Author

gczuczy commented Feb 24, 2023

Docs are updated as well.

@ishitasequeira, could you please review it?

@ishitasequeira
Copy link
Member

Docs are updated as well.

@ishitasequeira, could you please review it?

Will review it today.

@gczuczy gczuczy marked this pull request as ready for review February 24, 2023 16:22
@crenshaw-dev
Copy link
Member

This is looking really cool!

We'll probably want some e2e tests to validate a few base use cases for this feature.

docs/user-guide/multiple_sources.md Outdated Show resolved Hide resolved
reposerver/repository/repository.go Outdated Show resolved Hide resolved
Makefile Outdated Show resolved Hide resolved
reposerver/repository/repository.go Outdated Show resolved Hide resolved
reposerver/repository/repository.go Outdated Show resolved Hide resolved
reposerver/repository/repository.go Show resolved Hide resolved
reposerver/repository/repository.go Outdated Show resolved Hide resolved
@ishitasequeira
Copy link
Member

One thought that comes to my mind is, are we allowing a nested access of referenced sources for from? For example, something like below:

sources:
  - repoURL: http://my/repo.git
     targetRevision: master
     ref: values1
  - repoURL: http://my/repo-one.git
     targetRevision: 42.0.1
     ref: values2
     from:
       - ref: $values1
	 sourcePath: "dev/values.yaml"
          destinationPath: "env-values.yaml"
  - repoURL: http://my/repo-two.git
     targetRevision: 42.0.1
     from:
        - ref: $values2
	   sourcePath: "env-values.yaml"
           destinationPath: "dev/env-values.yaml"

I think this can lead to a lot of concerns. We should probably not allow ref and from in the same source. WDYT?

@gczuczy
Copy link
Contributor Author

gczuczy commented Feb 27, 2023

One thought that comes to my mind is, are we allowing a nested access of referenced sources for from? For example, something like below:

sources:
  - repoURL: http://my/repo.git
     targetRevision: master
     ref: values1
  - repoURL: http://my/repo-one.git
     targetRevision: 42.0.1
     ref: values2
     from:
       - ref: $values1
	 sourcePath: "dev/values.yaml"
          destinationPath: "env-values.yaml"
  - repoURL: http://my/repo-two.git
     targetRevision: 42.0.1
     from:
        - ref: $values2
	   sourcePath: "env-values.yaml"
           destinationPath: "dev/env-values.yaml"

I think this can lead to a lot of concerns. We should probably not allow ref and from in the same source. WDYT?

Currently that does make sense, however I'm considering another feature, where the output of a source can be referenced in another source building on this feature. Adding something like a saveOutput to the ApplicationSource, then being able to reference that both in the helm and from sections with something like $ref/$output. This with render the current mechanics into stage-like steps and interaction between them would be allowed. Moreover the builtin kustomize and helm processing facilities could coexists with standalone plugins. And right there disallowing having copy and ref at the same time would effectively block that feature.

I think, as of right now, putting a warning into the documentation is more effective.

Also, I think adding O_EXCL helps here with overwriting files:

O_EXCL Ensure  that this call creates the file: if this flag is specified in conjunction with O_CREAT, and pathname already exists, then open() fails with the error EEXIST```
This would solve accidental overwrites. Just tested this, and open indeed fails if the file already exists.

The question is, do we want to explicitly support transitive copies? I don't think that's something we should be factoring in.

@gczuczy
Copy link
Contributor Author

gczuczy commented Mar 3, 2023

I don't understand why the tests are broken, before i've synced the branch to master, everything was green.

@gczuczy gczuczy mentioned this pull request Mar 7, 2023
10 tasks
@gczuczy
Copy link
Contributor Author

gczuczy commented Mar 8, 2023

I don't really understand why the e2e test TestNamespacedAppLogs is failing. I shouldn't have touched anything related to that test's codepath. Also, when I'm reproducing it locally it fails differently:

time="2023-03-08T12:51:45+01:00" level=error msg="`../../dist/argocd app create argocd-e2e-external/test-namespaced-app-logs --repo http://argocd-e2e-server:9081/argo-e2e/testdata.git --dest-server https://kubernetes.default.svc --path guestbook-logs --project default --dest-namespace argocd-e2e--test-namespaced-app-logs-hthfa --server 127.0.0.1:4443 --auth-token *** --insecure` failed exit status 20: time=\"2023-03-08T12:51:45+01:00\" level=fatal msg=\"rpc error: code = Unknown desc = namespace 'argocd-e2e-external' is not permitted\"" execID=ca1ee
    actions.go:195: failed expectation: error

And the most interesting part is, I've reverted to a commit prior to my changes, and it still fails the same way as shown above:

$ git status
HEAD detached at 9fb7847f
$ git log 9fb7847f | head -7
commit 9fb7847f4e054b05b222a6cfabe4cd821d90f6e5
Author: Noah Krause <--->
Date:   Tue Mar 7 16:03:50 2023 -0500

    fix: typo in doc link (#12744)

    Signed-off-by: Noah Krause <--->

@crenshaw-dev
Copy link
Member

@gczuczy that test is flaky. I have an open PR to try to fix that.

Copy link
Member

@crenshaw-dev crenshaw-dev left a comment

Choose a reason for hiding this comment

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

Partial review

docs/user-guide/multiple_sources.md Outdated Show resolved Hide resolved
docs/user-guide/multiple_sources.md Outdated Show resolved Hide resolved
pkg/apis/application/v1alpha1/types.go Outdated Show resolved Hide resolved
reposerver/repository/repository.go Outdated Show resolved Hide resolved
reposerver/repository/repository.go Outdated Show resolved Hide resolved
@gczuczy gczuczy requested review from crenshaw-dev and ishitasequeira and removed request for crenshaw-dev and ishitasequeira March 13, 2023 16:37
@mircyb
Copy link

mircyb commented Mar 14, 2023

I'm eagerly waiting for the merge of this PR. Keep up the good work!

@gczuczy
Copy link
Contributor Author

gczuczy commented Mar 16, 2023

Here's a simplistic test example:

kubectl apply -f https://raw.githubusercontent.com/gczuczy/argocd-copyfrom-test/main/ArgoApp.yaml

This application has a kustomization in one repo, and one of the kustomization.yaml's inputs are in another repo, by environment. The involved repos are:
https://github.com/gczuczy/argocd-copyfrom-test
https://github.com/gczuczy/argocd-copyfrom-test-envs

There was another internal test, which is rather complicated, it deploys an ArgoCD ecosystem with a superchart, ArgoCD and ArgoWorkflows as a subchart, with a fair amount of secrets, for which we're using AVP to acquire. The gist of that secret are the following two snippets:

For the Application spec, here's the important part:

sources:
  - repoURL: 'https://valu.es/repo/sitory.git'
    targetRevision: master
    ref: valuesrepo
  - repoURL: 'https:/artifact.repo/testing'
    targetRevision: 0.42.24
    plugin:
      env:
        - name: VALUES
          value: env-values.yaml
    chart: our-argo-superchart
    from:
      - sourcePath: $valuesrepo/dev/values.yaml
        destinationPath: env-values.yaml

Here the chart has nil values for all the secrets, and the values repo's values.yaml has <placeholder>s all over the place. Even for the AVP credentials.

The environment-specific values.yaml is passed to the AVP plugin through the $ARGOCD_ENV_VALUES envvars, and the plugin definition has the following spec.generate.command:

      generate:
        command:
          - sh
          - "-c"
          - "/usr/local/bin/helm template $ARGOCD_APP_NAME -n $ARGOCD_APP_NAMESPACE --values $ARGOCD_ENV_VALUES . | /usr/local/bin/argocd-vault-plugin generate - -s namespace:avp-config-cm"

So, helm is using the environment-specific values from a separate repo and its output is fed to AVP, which is taking care of the <placeholder> replacements, and nicely adding the environment-specific secrets all over the place. This pattern deploys argocd itself in our internal testing environment.

cmpserver/plugin/plugin.go Outdated Show resolved Hide resolved
docs/user-guide/multiple_sources.md Outdated Show resolved Hide resolved
docs/user-guide/multiple_sources.md Outdated Show resolved Hide resolved
pkg/apis/application/v1alpha1/types.go Outdated Show resolved Hide resolved
reposerver/repository/repository.go Outdated Show resolved Hide resolved
reposerver/repository/repository.go Outdated Show resolved Hide resolved
reposerver/repository/repository.go Show resolved Hide resolved
reposerver/repository/repository.go Outdated Show resolved Hide resolved
test/remote/README.md Outdated Show resolved Hide resolved
test/remote/README.md Outdated Show resolved Hide resolved
@grosenba
Copy link

grosenba commented Mar 3, 2024

What capabilities does our plugin have today:

  • Setting variable values in all yaml and json files. The values come from labels located in the cluster-config in ArgoCD. This enables dynamic configuration.
  • Loading our helm value files from other git repos
  • load extra kustomize from other git repos
  • combine helm and kustomize manifest
  • Load secret from Vault

Issues:

  • Plugins do not support multisource -> we have to clone everything that comes from gitlab and is outside the app definition for kustomize in the plugin - for helm, the values and additional kustomize descriptions must always be loaded from gitlab. -> To load it from gitlab, we need access to the secrets. These are currently in the plugin container. Which is a real pain. I can certainly be loaded via a k8s secret, but changes cannot be detected anyway.
  • Since it's not multisourceable, we need to make sure we tell ArgoCD that something has changed in the application and ArgoCD needs to reload everything. Comparable to a hard refresh. In case of an update this has to be done by itself and if there is no significant change to the app there is no automatic update.

gczuczy added 3 commits March 11, 2024 08:04
Signed-off-by: Gergely Czuczy <gergely.czuczy@sap.com>
Signed-off-by: Gergely Czuczy <gergely.czuczy@sap.com>
Signed-off-by: Gergely Czuczy <gergely.czuczy@sap.com>
@alexgenon
Copy link

Hi all,
We're also facing the limitation reported in #13220. That is, being able to use in Helm the other source repo not only for valuesFiles param but also for other parameters such as fileParameters.
The overall solution would be more coherent (it seems counter-intuitive that the ref resolution is only applied to the  valuesFiles parameter) and it would avoid the need for umbrella charts just to do basic wiring.

I understand that the proposal from this PR provides more features than this simple ask and could lead to many anti-patterns, or prevent the argoCD community to migrate to cleaner approaches. But we should probably consider some of the use cases as there might be quick wins,

Thank you for the hard work! As argoCD users, we really appreciate the discussions and debates that are leading to a better solution.

@ntaylor1781
Copy link

I get the thought process on this being an anti-pattern. I think that makes perfect sense when you control the creation of the helm/kustomize. This gets more tricky when you are not in control. We currently only use ArgoCD to handle deploying supporting infrastructure, and not our apps. This means we are restricted by what is done in the upstream helm/kustomize. Not all projects follow best practices. I found 3 different projects, we use, that store secrets in ConfigMaps. Currently we are getting by without this PR (though it would be nice to have). If AVP is ruled an anti pattern, and not supported moving forward, it would create a lot of work for my team if we wanted to continue using ArgoCD.

I believe I would be able to open PRs to upstream projects to hopefully update their projects, but if those got denied it would mean maintaining our own copies of their projects and keeping up with their updates. That would introduce a lot of work, and may cause us to look for a solution other than ArgoCD.

If that was the case it may be that our use case is just not the intended use case for ArgoCD, and that would be fine. If the intended use case for ArgoCD is to handle upstream helm/kustomize, and not just custom, I think that is worth thinking about.

All you great folks do the work though, and know what you can/can't take on. I just wanted to share my view point, as I feel that the others didn't share it exactly. I am super grateful for all the work put into this project.

@crenshaw-dev
Copy link
Member

being able to use in Helm the other source repo not only for valuesFiles param but also for other parameters such as fileParameters.

@alexgenon I agree, that feature would be a relatively intuitive, maintainable, and impactful feature. I'd definitely welcome that change!

This means we are restricted by what is done in the upstream helm/kustomize. Not all projects follow best practices.

100%. I wonder if the problem is more that these open source charts/kustomize bases can't support secret refs (not enough maintenance resources) or don't actually see it as a problem.

I found 3 different projects, we use, that store secrets in ConfigMaps.

I think that's just a general Kubernetes anti-pattern. Secrets should be stored in Secrets.

If AVP is ruled an anti pattern, and not supported moving forward, it would create a lot of work for my team if we wanted to continue using ArgoCD.... may cause us to look for a solution other than ArgoCD.

That's a fair analysis. In my opinion, "safe, robust secrets injection" lies outside what the Argo CD team can currently offer. To provide a strong core product, I think we should encourage folks to adopt the much more compatible solution of external secrets operators. Some won't be able to make that switch, but I don't think that's a problem the Argo team is currently well-positioned to solve.

cardoe added a commit to cardoe/argo-cd that referenced this pull request Apr 12, 2024
Added documentation for fileParameters in a helm source Application or
the --helm-set-file cli option from argoproj#2751. Added a note about argoproj#13220 so
users are aware. argoproj#12508 aims to remove this limitation so the warning
can probably be removed with that.
cardoe added a commit to cardoe/argo-cd that referenced this pull request Apr 12, 2024
Added documentation for fileParameters in a helm source Application or
the --helm-set-file cli option from argoproj#2751. Added a note about argoproj#13220 so
users are aware. argoproj#12508 aims to remove this limitation so the warning
can probably be removed with that.

Signed-off-by: Doug Goldstein <cardoe@cardoe.com>
@kingbj940429
Copy link

Hi guys

this was indeed a great discussion. As a argocd user, I'm curious about one thing: what happens next?

@newbenji
Copy link

Hi guys

this was indeed a great discussion. As a argocd user, I'm curious about one thing: what happens next?

consider if going for alternative og live with the decision

@av-sebastian
Copy link

ArgoCD 2.11: This comes with something that looks similar to the feature discussed here. - https://argo-cd.readthedocs.io/en/latest/user-guide/multiple_sources/
So there might come something good out of the wait time here :-)

@joebowbeer
Copy link
Contributor

joebowbeer commented Apr 16, 2024

ArgoCD 2.11: This comes with something that looks similar to the feature discussed here. - https://argo-cd.readthedocs.io/en/latest/user-guide/multiple_sources/ So there might come something good out of the wait time here :-)

The multi-source docs haven't changed appreciably since v2.8

AFAICT, this feature is adding a from section

     from:
       - ref: $values1
         sourcePath: "dev/values.yaml"
         destinationPath: "env-values.yaml"

@gczuczy
Copy link
Contributor Author

gczuczy commented Apr 16, 2024

ArgoCD 2.11: This comes with something that looks similar to the feature discussed here. - https://argo-cd.readthedocs.io/en/latest/user-guide/multiple_sources/ So there might come something good out of the wait time here :-)

This PR would have expanded the multi-source support. The problem with multi-source is, it's not working with plugins, and many people need plugins and multisources, that's how this PR was born. Our usecase was AVP for secrets specifically.

@gczuczy gczuczy closed this Apr 16, 2024
@reachfivejenkins
Copy link

Hello, I ended up here after noticing multisource isn't compatible with helm-secrets. What's the point to have multisource, if no plugins can be used to decrypt values ? Who stores it sensible values unencrypted ?
So as of now, there is absolutly no way to do that ? That is a very common scenario, loading a versioned chart from repo, and encrypted values from another... I love argocd a lot but that restriction may oblige me to look for another solution

@morremeyer
Copy link
Contributor

@reachfivejenkins There‘s other ways to deploy secrets, e.g. with external-secrets.

The point of multi-source as it is is to provide multi source applications to whoever can use them in the current state.

@Obirah
Copy link

Obirah commented Apr 16, 2024

Hello, I ended up here after noticing multisource isn't compatible with helm-secrets. What's the point to have multisource, if no plugins can be used to decrypt values ? Who stores it sensible values unencrypted ? So as of now, there is absolutly no way to do that ? That is a very common scenario, loading a versioned chart from repo, and encrypted values from another... I love argocd a lot but that restriction may oblige me to look for another solution

Been using this configuration for helm-secrets and multi-source for quite some time and it's working nicely for us.

@stephaneetje
Copy link

Hello, I ended up here after noticing multisource isn't compatible with helm-secrets. What's the point to have multisource, if no plugins can be used to decrypt values ? Who stores it sensible values unencrypted ? So as of now, there is absolutly no way to do that ? That is a very common scenario, loading a versioned chart from repo, and encrypted values from another... I love argocd a lot but that restriction may oblige me to look for another solution

Been using this configuration for helm-secrets and multi-source for quite some time and it's working nicely for us.

I looked at it, but we are using SOPS with googleKMS, i doesn't look compatible.
I have a helm repo + sops encrypted values github repo, we just moved from monorepo as we wanted to take advantage of multi source, but indeed multi source can be used here on very minor use cases as it can't load any plugins...

@morremeyer
Copy link
Contributor

morremeyer commented Apr 16, 2024

Could you please take this discussion to the appropriate forum/Q&A/discussion?

This is already a PR with lots of on-topic discussion that only gets harder to parse with more and more unrelated comments.

Thank you!

cardoe added a commit to cardoe/argo-cd that referenced this pull request Apr 17, 2024
Added documentation for fileParameters in a helm source Application or
the --helm-set-file cli option from argoproj#2751. Added a note about argoproj#13220 so
users are aware. argoproj#12508 aims to remove this limitation so the warning
can probably be removed with that.

Signed-off-by: Doug Goldstein <cardoe@cardoe.com>
@NikOverflow
Copy link

NikOverflow commented Jun 15, 2024

I don't know in which discussion i should write. How is this going? I need that feature for secret and configmap replacing. I did my own replacer that uses kubernetes secrets and configmaps and realize that argocd is the limitation.

@volk1234
Copy link

I don't know in which discussion i should write. How is this going? I need that feature for secret and configmap replacing. I did my own replacer that uses kubernetes secrets and configmaps and realize that argocd is the limitation.

This is not going. @crenshaw-dev personally thinks that this is antipattern :) You know it's like JSON format don't have comments because the author didn't like how some people use them. As @crenshaw-dev is a PM for the whole Argo you can estimate probability of merging this PR.

so we shouldn't use such approach. To be a serious - you can separate secret management from app management and not use helm_template in favor of avp plugin. This is quite easy - just another argocd app. Also you can try ESM.

@NikOverflow
Copy link

I don't know in which discussion i should write. How is this going? I need that feature for secret and configmap replacing. I did my own replacer that uses kubernetes secrets and configmaps and realize that argocd is the limitation.

This is not going. @crenshaw-dev personally thinks that this is antipattern :) You know it's like JSON format don't have comments because the author didn't like how some people use them. As @crenshaw-dev is a PM for the whole Argo you can estimate probability of merging this PR.

so we shouldn't use such approach. To be a serious - you can separate secret management from app management and not use helm_template in favor of avp plugin. This is quite easy - just another argocd app. Also you can try ESM.

but this is easier for me. I changed my script a bit today and fixed some other issues. The only problem is that it does not work with the external value files. Using a url is stupid because it won't be updated when you change the values file.

@morremeyer
Copy link
Contributor

It might be easier for you, but that means additional maintenance efforts are needed.

One of the maintainers has clearly stated that that is not going to happen for now.

I can understand that this is not what you would like, but it’s a maintainer decision we all have to respect.

Instead of complaining about that, let’s work together as a community to find solutions that the maintainers are happy to support that help us do what we want.

@Lawliet2012
Copy link

So if you think that it is antipattern and you need some more maintenance efforts so how to use your product properly? I always thought that using secret managers for storing secrets is best practice but here in thread where guy made this possible for using secrets in argocd in way that I and he is preferred other guys say "This is antipattern" I don't know what to do.

How I need to use gitops approach with all the tools if

  1. I'm not a maintainer of 3rd party chart and don't want to download it and sync versions in my repo
  2. I have repo with all services values.yaml files
  3. I need to get some secrets from my vault cluster

If argocd and gitops is the NEW way of managing deployments, so why it has this kind of problems that maintainers do not want to resolve

@morremeyer
Copy link
Contributor

@Lawliet2012 You can always manage secrets with another tool and then use them in your containers. Different ways have been shown here already, a quick recap:

Deploy secrets without ArgoCD A lot of helm charts enable this with an `existingSecret` value, for example the [bitnami/postgresql](https://github.com/bitnami/charts/blob/aeecba3c132c3bc89a9877300f235222985287e7/bitnami/postgresql/values.yaml#L155) chart.

To do so:

  1. Use whatever tool you like to deploy the secret. For example the external-secrets operator or sealed secrets.
  2. Reference the secret in your helm values, Kubernetes manifests, etc.
  3. Deploy the helm chart, Kubernetes manifests, etc. with ArgoCD

For your use case, it sounds like you're using Hashicorp Vault, so I recommend to take a look at the external-secrets operator. We're using it with great success.

If argocd and gitops is the NEW way of managing deployments, so why it has this kind of problems that maintainers do not want to resolve

This problem is already resolved. ArgoCD however is not the tool to resolve it and there is a clear decision that it will not become that tool.

Please stop accusing maintainers of not wanting to resolve issues, they have shown a lot of patience in this issue to explain why this is not going to happen: It is not part of what ArgoCD's core "mission" is and it would be a lot of effort to maintain.

With that decision, there is no issue to resolve anymore since other ways exist to achieve what has been discussed here.

@3coma3
Copy link

3coma3 commented Jun 26, 2024

So if you think that it is antipattern and you need some more maintenance efforts so how to use your product properly? I always thought that using secret managers for storing secrets is best practice but here in thread where guy made this possible for using secrets in argocd in way that I and he is preferred other guys say "This is antipattern" I don't know what to do.

How I need to use gitops approach with all the tools if

  1. I'm not a maintainer of 3rd party chart and don't want to download it and sync versions in my repo
  2. I have repo with all services values.yaml files
  3. I need to get some secrets from my vault cluster

If argocd and gitops is the NEW way of managing deployments, so why it has this kind of problems that maintainers do not want to resolve

I think it's partially that the main maintainer sees it as an antipattern, but also that the feature is actually more generic than the secrets management case, and complex enough to draw significant resources from the project that they don't have, to maintain the feature (and all that could be built on top of that). And both reasons "collide" somehow, "coincidentally". That is my take, and I do think it's fair, if a bit of a bummer because (imo) it really would be a killer feature, but given the stance I don't see a reason to argue, it is what it is and the reasons above are valid as they are, regardless of how I agree or not, at any rate.

Just my 2c

@volk1234
Copy link

volk1234 commented Jun 26, 2024

@

So if you think that it is antipattern and you need some more maintenance efforts so how to use your product properly? I always thought that using secret managers for storing secrets is best practice but here in thread where guy made this possible for using secrets in argocd in way that I and he is preferred other guys say "This is antipattern" I don't know what to do.

Again - you can still use AVP plugin. But not together with helm and multiple values templating. Just step a side, create simple yaml files with the path to the secret create ArgoCD app with simple yaml sidecar plugin. It also works with simple helm chart(but rendering with AVP plugin not helm: valuesFiles)

I prefer to use this approach to manage everything with one tool - ArgoCD (and in one place). If you don't want to spend more time configuring ArgoCD apps you can try external-secrets like @morremeyer mentioned.

ArgoCD team cannot turn something to an antipattern. But they have every right not to implement any feature if they feel this is not in the product scope. The same as we can use any other approach to manage secrets with or without ArgoCD.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment