Skip to content

Provider allows mutually-exclusive configuration options #1179

@dak1n1

Description

@dak1n1

With the release of Kubernetes Provider 2.0, we began requiring explicit provider configuration with the intention of preventing the wrong clusters from being targeted during apply. However, in our implementation of this, we have introduced a new bug scenario where the provider silently chooses an authentication method when more than one is supplied in the provider config. This issue was already present to some extent, but in the past it could be partially mitigated with load_config_file = false. Now that load_config_file is no longer an option, the issue has become more prominent.

We can solve this in the provider code by adding ConflictsWith to mutually-exclusive configuation options, to give users complete control over which options are being chosen to authenticate to their Kubernetetes cluster. This will throw an error when two or more conflicting options are used together.

NOTE: This change will result in configuration errors when mutually-exclusive configuration options are specified.

The configuration errors have been silent since the 2.0 release, but with this proposed change, the error will become explicit, notifying the user of the conflicting options, and failing to run the provider until a single valid configuration is chosen.

Terraform Version, Provider Version and Kubernetes Version

Terraform version:
0.14.4
Kubernetes provider version:
2.0.2

Affected Resource(s)

Provider config block.

Terraform Configuration Files

The provider currently chooses KUBE_CONFIG_PATH over the explicit configuration. This is one of the bug scenarios that will be corrected.

export KUBE_CONFIG_PATH="~/.kube/config"
provider "kubernetes" {
  host                            = data.aws_eks_cluster.default.endpoint
  cluster_ca_certificate = base64decode(data.aws_eks_cluster.default.certificate_authority[0].data)
  token                          = data.aws_eks_cluster_auth.default.token

Debug Output

Panic Output

Steps to Reproduce

  1. terraform plan using the configuration options above (though you'll have to specify a resource too, to initialize the provider).

Expected Behavior

I think we should throw an error instead, and let the user choose which configuration they would like to use.

Actual Behavior

The provider silently chooses one of the given configurations. Sometimes this leads to the wrong cluster being targeted, which is what we were aiming to fix with issue #909.

Important Factoids

References

Adding more explicit configuration settings (ConflictsWith) should help solve the following issues, which have arisen since the 2.0 release.

#1134
#1167
#1127
#1131
#1175

Community Note

  • Please vote on this issue by adding a 👍 reaction to the original issue to help the community and maintainers prioritize this request
  • If you are interested in working on this issue or have submitted a pull request, please leave a comment

Metadata

Metadata

Assignees

No one assigned

    Type

    No type

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions