diff --git a/README.md b/README.md index f67173b..0bb563b 100644 --- a/README.md +++ b/README.md @@ -7,7 +7,7 @@ Truefoundry EKS Module | Name | Version | |------|---------| | [terraform](#requirement\_terraform) | >= 1.4 | -| [aws](#requirement\_aws) | 5.56.1 | +| [aws](#requirement\_aws) | 5.57.0 | ## Providers @@ -18,6 +18,7 @@ No providers. | Name | Source | Version | |------|--------|---------| | [aws-eks-kubernetes-cluster](#module\_aws-eks-kubernetes-cluster) | terraform-aws-modules/eks/aws | v20.15.0 | +| [eks\_blueprints\_addons](#module\_eks\_blueprints\_addons) | aws-ia/eks-blueprints-addons/aws | 1.16.3 | ## Resources @@ -30,6 +31,10 @@ No resources. | [cloudwatch\_log\_group\_retention\_in\_days](#input\_cloudwatch\_log\_group\_retention\_in\_days) | Number of days to retain log events. Default retention - 90 days | `number` | `90` | no | | [cluster\_access\_entries](#input\_cluster\_access\_entries) | value of the access entries for the EKS cluster | `any` | `{}` | no | | [cluster\_additional\_security\_group\_ids](#input\_cluster\_additional\_security\_group\_ids) | List of additional, externally created security group IDs to attach to the cluster control plane | `list(string)` | `[]` | no | +| [cluster\_addons\_coredns\_version](#input\_cluster\_addons\_coredns\_version) | Version of the CoreDNS addon | `string` | `"v1.11.1-eksbuild.9"` | no | +| [cluster\_addons\_eks\_pod\_identity\_agent\_version](#input\_cluster\_addons\_eks\_pod\_identity\_agent\_version) | Version of the EKS Pod Identity Agent addon | `string` | `"v1.3.0-eksbuild.1"` | no | +| [cluster\_addons\_kube\_proxy\_version](#input\_cluster\_addons\_kube\_proxy\_version) | Version of the kube-proxy addon | `string` | `"v1.30.0-eksbuild.3"` | no | +| [cluster\_addons\_vpc\_cni\_version](#input\_cluster\_addons\_vpc\_cni\_version) | Version of the VPC CNI addon | `string` | `"v1.18.2-eksbuild.1"` | no | | [cluster\_authentication\_mode](#input\_cluster\_authentication\_mode) | value of the authentication mode for the EKS cluster | `string` | `"API_AND_CONFIG_MAP"` | no | | [cluster\_enabled\_log\_types](#input\_cluster\_enabled\_log\_types) | A list of the desired control plane logs to enable. For more information, see Amazon EKS Control Plane Logging documentation (https://docs.aws.amazon.com/eks/latest/userguide/control-plane-logs.html) | `list(string)` |
[
"audit",
"api",
"authenticator"
]
| no | | [cluster\_endpoint\_private\_access](#input\_cluster\_endpoint\_private\_access) | Indicates whether or not the Amazon EKS private API server endpoint is enabled | `bool` | `true` | no | diff --git a/eks_addons.tf b/eks_addons.tf new file mode 100644 index 0000000..9decbe8 --- /dev/null +++ b/eks_addons.tf @@ -0,0 +1,30 @@ +################################################################################### +# AWS EKS Module Addons +################################################################################### + +module "eks_blueprints_addons" { + source = "aws-ia/eks-blueprints-addons/aws" + version = "1.16.3" + + cluster_name = module.aws-eks-kubernetes-cluster.cluster_name + cluster_endpoint = module.aws-eks-kubernetes-cluster.cluster_endpoint + cluster_version = module.aws-eks-kubernetes-cluster.cluster_version + oidc_provider_arn = module.aws-eks-kubernetes-cluster.oidc_provider_arn + + eks_addons = { + coredns = { + addon_version = var.cluster_addons_coredns_version + } + vpc-cni = { + addon_version = var.cluster_addons_vpc_cni_version + } + kube-proxy = { + addon_version = var.cluster_addons_kube_proxy_version + } + eks-pod-identity-agent = { + addon_version = var.cluster_addons_eks_pod_identity_agent_version + } + } + + tags = local.tags +} \ No newline at end of file diff --git a/output.tf b/output.tf index a6366ec..483878a 100644 --- a/output.tf +++ b/output.tf @@ -111,7 +111,7 @@ output "cluster_iam_role_unique_id" { output "cluster_addons" { description = "Map of attribute maps for all EKS cluster addons enabled" - value = module.aws-eks-kubernetes-cluster.cluster_addons + value = module.eks_blueprints_addons.eks_addons } ################################################################################ diff --git a/variables.tf b/variables.tf index 48e9d40..8fc7c94 100644 --- a/variables.tf +++ b/variables.tf @@ -202,4 +202,55 @@ variable "karpenter_fargate_profile_attach_cni_policy" { description = "Attach CNI policy to IAM role for Karpenter Fargate profile" type = bool default = true +} + +################################################################################## +## EKS addons +################################################################################## +# variable "cluster_addons_coredns_enable" { +# description = "Enable the CoreDNS addon" +# type = bool +# default = true +# } + +variable "cluster_addons_coredns_version" { + description = "Version of the CoreDNS addon" + type = string + default = "v1.11.1-eksbuild.9" +} + +# variable "cluster_addons_vpc_cni_enable" { +# description = "Enable the VPC CNI addon" +# type = bool +# default = true +# } + +variable "cluster_addons_vpc_cni_version" { + description = "Version of the VPC CNI addon" + type = string + default = "v1.18.2-eksbuild.1" +} + +# variable "cluster_addons_kube_proxy_enable" { +# description = "Enable the kube-proxy addon" +# type = bool +# default = true +# } + +variable "cluster_addons_kube_proxy_version" { + description = "Version of the kube-proxy addon" + type = string + default = "v1.30.0-eksbuild.3" +} + +# variable "cluster_addons_eks_pod_identity_agent_enable" { +# description = "Enable the EKS Pod Identity Agent addon" +# type = bool +# default = false +# } + +variable "cluster_addons_eks_pod_identity_agent_version" { + description = "Version of the EKS Pod Identity Agent addon" + type = string + default = "v1.3.0-eksbuild.1" } \ No newline at end of file diff --git a/versions.tf b/versions.tf index 8e5c8ee..9ec8dae 100644 --- a/versions.tf +++ b/versions.tf @@ -3,7 +3,7 @@ terraform { required_providers { aws = { source = "hashicorp/aws" - version = "5.56.1" + version = "5.57.0" } } } \ No newline at end of file