Newer
Older
/*
* Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
* SPDX-License-Identifier: MIT-0
*
* Permission is hereby granted, free of charge, to any person obtaining a copy of this
* software and associated documentation files (the "Software"), to deal in the Software
* without restriction, including without limitation the rights to use, copy, modify,
* merge, publish, distribute, sublicense, and/or sell copies of the Software, and to
* permit persons to whom the Software is furnished to do so.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED,
* INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A
* PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
* HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
* OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
* SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
*/
# ---------------------------------------------------------------------------------------------------------------------
# MANAGED NODE GROUPS
# ---------------------------------------------------------------------------------------------------------------------
module "aws_eks_managed_node_groups" {
source = "./modules/aws-eks-managed-node-groups"
for_each = { for key, value in var.managed_node_groups : key => value

Vara Bonthu
committed
if var.enable_managed_nodegroups && length(var.managed_node_groups) > 0
}
managed_ng = each.value
eks_cluster_name = module.aws_eks.cluster_id
cluster_ca_base64 = module.aws_eks.cluster_certificate_authority_data
cluster_endpoint = module.aws_eks.cluster_endpoint

Vara Bonthu
committed
vpc_id = var.vpc_id
private_subnet_ids = var.private_subnet_ids
public_subnet_ids = var.public_subnet_ids
worker_security_group_id = module.aws_eks.worker_security_group_id
cluster_security_group_id = module.aws_eks.cluster_security_group_id
cluster_primary_security_group_id = module.aws_eks.cluster_primary_security_group_id
tags = module.eks_tags.tags
depends_on = [module.aws_eks, kubernetes_config_map.aws_auth]
}
# ---------------------------------------------------------------------------------------------------------------------
# SELF MANAGED NODE GROUPS
# ---------------------------------------------------------------------------------------------------------------------
module "aws_eks_self_managed_node_groups" {
source = "./modules/aws-eks-self-managed-node-groups"
for_each = { for key, value in var.self_managed_node_groups : key => value

Vara Bonthu
committed
if var.enable_self_managed_nodegroups && length(var.self_managed_node_groups) > 0
}
self_managed_ng = each.value
eks_cluster_name = module.aws_eks.cluster_id
cluster_endpoint = module.aws_eks.cluster_endpoint
cluster_ca_base64 = module.aws_eks.cluster_certificate_authority_data
tags = module.eks_tags.tags

Vara Bonthu
committed
vpc_id = var.vpc_id
private_subnet_ids = var.private_subnet_ids
public_subnet_ids = var.public_subnet_ids
worker_security_group_id = module.aws_eks.worker_security_group_id
cluster_security_group_id = module.aws_eks.cluster_security_group_id
cluster_primary_security_group_id = module.aws_eks.cluster_primary_security_group_id
kubernetes_version = var.kubernetes_version
depends_on = [module.aws_eks, kubernetes_config_map.aws_auth]
}
# ---------------------------------------------------------------------------------------------------------------------
# FARGATE PROFILES
# ---------------------------------------------------------------------------------------------------------------------
module "aws_eks_fargate_profiles" {
source = "./modules/aws-eks-fargate-profiles"
for_each = { for k, v in var.fargate_profiles : k => v if var.enable_fargate && length(var.fargate_profiles) > 0 }
fargate_profile = each.value
eks_cluster_name = module.aws_eks.cluster_id
tags = module.eks_tags.tags
depends_on = [module.aws_eks, kubernetes_config_map.aws_auth]
}
# ---------------------------------------------------------------------------------------------------------------------
# AWS EKS Add-ons (VPC CNI, CoreDNS, KubeProxy )
# ---------------------------------------------------------------------------------------------------------------------
module "aws_eks_addon" {
count = var.create_eks && var.enable_managed_nodegroups || var.create_eks && var.enable_self_managed_nodegroups || var.create_eks && var.enable_fargate ? 1 : 0
source = "./modules/aws-eks-addon"
cluster_name = module.aws_eks.cluster_id
enable_vpc_cni_addon = var.enable_vpc_cni_addon
vpc_cni_addon_version = var.vpc_cni_addon_version
enable_coredns_addon = var.enable_coredns_addon
coredns_addon_version = var.coredns_addon_version
enable_kube_proxy_addon = var.enable_kube_proxy_addon
kube_proxy_addon_version = var.kube_proxy_addon_version
tags = module.eks_tags.tags