From 4d08172ab52c9c68b33287c4f08c3171e9e1718b Mon Sep 17 00:00:00 2001 From: Edgar Costa Date: Tue, 6 Aug 2024 12:40:33 -0300 Subject: [PATCH 1/6] feat: Adding Lambda, SNS and SQS Controllers --- README.md | 15 ++ examples/complete/main.tf | 3 + main.tf | 376 ++++++++++++++++++++++++++++++++++++++ outputs.tf | 18 ++ variables.tf | 48 +++++ 5 files changed, 460 insertions(+) diff --git a/README.md b/README.md index 42b310f..5297864 100644 --- a/README.md +++ b/README.md @@ -75,10 +75,13 @@ Examples codified under the [`examples`](https://github.com/aws-ia/terraform-aws | [eventbridge](#module\_eventbridge) | aws-ia/eks-blueprints-addon/aws | 1.1.1 | | [iam](#module\_iam) | aws-ia/eks-blueprints-addon/aws | 1.1.1 | | [kms](#module\_kms) | aws-ia/eks-blueprints-addon/aws | 1.1.1 | +| [lambda](#module\_lambda) | aws-ia/eks-blueprints-addon/aws | 1.1.1 | | [prometheusservice](#module\_prometheusservice) | aws-ia/eks-blueprints-addon/aws | 1.1.1 | | [rds](#module\_rds) | aws-ia/eks-blueprints-addon/aws | 1.1.1 | | [s3](#module\_s3) | aws-ia/eks-blueprints-addon/aws | 1.1.1 | | [sfn](#module\_sfn) | aws-ia/eks-blueprints-addon/aws | 1.1.1 | +| [sns](#module\_sns) | aws-ia/eks-blueprints-addon/aws | 1.1.1 | +| [sqs](#module\_sqs) | aws-ia/eks-blueprints-addon/aws | 1.1.1 | ## Resources @@ -89,9 +92,15 @@ Examples codified under the [`examples`](https://github.com/aws-ia/terraform-aws | [aws_iam_policy.emrcontainers](https://registry.terraform.io/providers/hashicorp/aws/latest/docs/resources/iam_policy) | resource | | [aws_iam_policy.iampolicy](https://registry.terraform.io/providers/hashicorp/aws/latest/docs/resources/iam_policy) | resource | | [aws_iam_policy.kmspolicy](https://registry.terraform.io/providers/hashicorp/aws/latest/docs/resources/iam_policy) | resource | +| [aws_iam_policy.lambdapolicy](https://registry.terraform.io/providers/hashicorp/aws/latest/docs/resources/iam_policy) | resource | | [aws_iam_policy.sfnpasspolicy](https://registry.terraform.io/providers/hashicorp/aws/latest/docs/resources/iam_policy) | resource | +| [aws_iam_policy.snspolicy](https://registry.terraform.io/providers/hashicorp/aws/latest/docs/resources/iam_policy) | resource | +| [aws_iam_policy.sqspolicy](https://registry.terraform.io/providers/hashicorp/aws/latest/docs/resources/iam_policy) | resource | | [time_sleep.this](https://registry.terraform.io/providers/hashicorp/time/latest/docs/resources/sleep) | resource | | [aws_iam_policy_document.emrcontainers](https://registry.terraform.io/providers/hashicorp/aws/latest/docs/data-sources/iam_policy_document) | data source | +| [aws_iam_policy_document.lambda_controller](https://registry.terraform.io/providers/hashicorp/aws/latest/docs/data-sources/iam_policy_document) | data source | +| [aws_iam_policy_document.sns_controller](https://registry.terraform.io/providers/hashicorp/aws/latest/docs/data-sources/iam_policy_document) | data source | +| [aws_iam_policy_document.sqs_controller](https://registry.terraform.io/providers/hashicorp/aws/latest/docs/data-sources/iam_policy_document) | data source | | [aws_partition.current](https://registry.terraform.io/providers/hashicorp/aws/latest/docs/data-sources/partition) | data source | | [aws_region.current](https://registry.terraform.io/providers/hashicorp/aws/latest/docs/data-sources/region) | data source | @@ -123,18 +132,24 @@ Examples codified under the [`examples`](https://github.com/aws-ia/terraform-aws | [enable\_eventbridge](#input\_enable\_eventbridge) | Enable ACK EventBridge add-on | `bool` | `false` | no | | [enable\_iam](#input\_enable\_iam) | Enable ACK iam add-on | `bool` | `false` | no | | [enable\_kms](#input\_enable\_kms) | Enable ACK kms add-on | `bool` | `false` | no | +| [enable\_lambda](#input\_enable\_lambda) | Enable ACK Lambda add-on | `bool` | `false` | no | | [enable\_prometheusservice](#input\_enable\_prometheusservice) | Enable ACK prometheusservice add-on | `bool` | `false` | no | | [enable\_rds](#input\_enable\_rds) | Enable ACK rds add-on | `bool` | `false` | no | | [enable\_s3](#input\_enable\_s3) | Enable ACK s3 add-on | `bool` | `false` | no | | [enable\_sfn](#input\_enable\_sfn) | Enable ACK step functions add-on | `bool` | `false` | no | +| [enable\_sns](#input\_enable\_sns) | Enable ACK SNS add-on | `bool` | `false` | no | +| [enable\_sqs](#input\_enable\_sqs) | Enable ACK SQS add-on | `bool` | `false` | no | | [eventbridge](#input\_eventbridge) | ACK EventBridge Helm Chart config | `any` | `{}` | no | | [iam](#input\_iam) | ACK iam Helm Chart config | `any` | `{}` | no | | [kms](#input\_kms) | ACK kms Helm Chart config | `any` | `{}` | no | +| [lambda](#input\_lambda) | ACK Lambda Helm Chart config | `any` | `{}` | no | | [oidc\_provider\_arn](#input\_oidc\_provider\_arn) | The ARN of the cluster OIDC Provider | `string` | n/a | yes | | [prometheusservice](#input\_prometheusservice) | ACK prometheusservice Helm Chart config | `any` | `{}` | no | | [rds](#input\_rds) | ACK rds Helm Chart config | `any` | `{}` | no | | [s3](#input\_s3) | ACK s3 Helm Chart config | `any` | `{}` | no | | [sfn](#input\_sfn) | ACK step functions Helm Chart config | `any` | `{}` | no | +| [sns](#input\_sns) | ACK SNS Helm Chart config | `any` | `{}` | no | +| [sqs](#input\_sqs) | ACK SQS Helm Chart config | `any` | `{}` | no | | [tags](#input\_tags) | Additional tags (e.g. `map('BusinessUnit`,`XYZ`) | `map(string)` | `{}` | no | ## Outputs diff --git a/examples/complete/main.tf b/examples/complete/main.tf index 050debf..4b09b4d 100644 --- a/examples/complete/main.tf +++ b/examples/complete/main.tf @@ -131,6 +131,9 @@ module "eks_ack_addons" { ecrpublic_token = data.aws_ecrpublic_authorization_token.token.password # Controllers to enable + enable_sns = true + enable_sqs = true + enable_lambda = true enable_iam = true enable_ec2 = true enable_eks = true diff --git a/main.tf b/main.tf index de96a9c..f93cdbb 100644 --- a/main.tf +++ b/main.tf @@ -32,6 +32,382 @@ locals { repository_password = var.create_kubernetes_resources ? var.ecrpublic_token : "" } +################################################################################ +# SNS +################################################################################ + +locals { + sns_name = "ack-sns" +} + +module "sns" { + source = "aws-ia/eks-blueprints-addon/aws" + version = "1.1.1" + + create = var.enable_sns + + # Disable helm release + create_release = var.create_kubernetes_resources + + # public.ecr.aws/aws-controllers-k8s/sns-chart:1.0.11 + name = try(var.sns.name, local.sns_name) + description = try(var.sns.description, "Helm Chart for SNS controller for ACK") + namespace = try(var.sns.namespace, "ack-system") + create_namespace = try(var.sns.create_namespace, true) + chart = "sns-chart" + chart_version = try(var.sns.chart_version, "1.0.11") + repository = try(var.sns.repository, "oci://public.ecr.aws/aws-controllers-k8s") + values = try(var.sns.values, []) + + timeout = try(var.sns.timeout, null) + repository_key_file = try(var.sns.repository_key_file, null) + repository_cert_file = try(var.sns.repository_cert_file, null) + repository_ca_file = try(var.sns.repository_ca_file, null) + repository_username = try(var.sns.repository_username, local.repository_username) + repository_password = try(var.sns.repository_password, local.repository_password) + devel = try(var.sns.devel, null) + verify = try(var.sns.verify, null) + keyring = try(var.sns.keyring, null) + disable_webhooks = try(var.sns.disable_webhooks, null) + reuse_values = try(var.sns.reuse_values, null) + reset_values = try(var.sns.reset_values, null) + force_update = try(var.sns.force_update, null) + recreate_pods = try(var.sns.recreate_pods, null) + cleanup_on_fail = try(var.sns.cleanup_on_fail, null) + max_history = try(var.sns.max_history, null) + atomic = try(var.sns.atomic, null) + skip_crds = try(var.sns.skip_crds, null) + render_subchart_notes = try(var.sns.render_subchart_notes, null) + disable_openapi_validation = try(var.sns.disable_openapi_validation, null) + wait = try(var.sns.wait, false) + wait_for_jobs = try(var.sns.wait_for_jobs, null) + dependency_update = try(var.sns.dependency_update, null) + replace = try(var.sns.replace, null) + lint = try(var.sns.lint, null) + + postrender = try(var.sns.postrender, []) + + set = concat([ + { + # shortens pod name from `ack-sns-sns-chart-xxxxxxxxxxxxx` to `ack-sns-xxxxxxxxxxxxx` + name = "nameOverride" + value = "ack-sns" + }, + { + name = "aws.region" + value = local.region + }, + { + name = "serviceAccount.name" + value = local.sns_name + }], + try(var.sns.set, []) + ) + set_sensitive = try(var.sns.set_sensitive, []) + + # IAM role for service account (IRSA) + set_irsa_names = ["serviceAccount.annotations.eks\\.amazonaws\\.com/role-arn"] + create_role = try(var.sns.create_role, true) + role_name = try(var.sns.role_name, "ack-sns") + role_name_use_prefix = try(var.sns.role_name_use_prefix, true) + role_path = try(var.sns.role_path, "/") + role_permissions_boundary_arn = lookup(var.sns, "role_permissions_boundary_arn", null) + role_description = try(var.sns.role_description, "IRSA for SNS controller for ACK") + role_policies = lookup(var.sns, "role_policies", { + AWSSNSPolicy = var.enable_sns ? aws_iam_policy.snspolicy[0].arn : null + }) + create_policy = try(var.sns.create_policy, false) + + oidc_providers = { + this = { + provider_arn = local.oidc_provider_arn + # namespace is inherited from chart + service_account = local.sns_name + } + } + + tags = var.tags +} + +# recommended iam-controller policy https://github.com/aws-controllers-k8s/sns-controller/blob/main/config/iam/recommended-policy-arn +data "aws_iam_policy_document" "sns_controller" { + count = var.enable_sns ? 1 : 0 + + statement { + effect = "Allow" + actions = [ + "sns:*" + ] + resources = ["*"] + } +} + +resource "aws_iam_policy" "snspolicy" { + count = var.enable_sns ? 1 : 0 + + name = "SNSController" + description = "IAM policy for SNS Controller" + policy = data.aws_iam_policy_document.sns_controller[0].json + + tags = var.tags +} + +################################################################################ +# SQS +################################################################################ + +locals { + sqs_name = "ack-sqs" +} + +module "sqs" { + source = "aws-ia/eks-blueprints-addon/aws" + version = "1.1.1" + + create = var.enable_sqs + + # Disable helm release + create_release = var.create_kubernetes_resources + + # public.ecr.aws/aws-controllers-k8s/sqs-chart:1.0.14 + name = try(var.sqs.name, local.sqs_name) + description = try(var.sqs.description, "Helm Chart for SQS controller for ACK") + namespace = try(var.sqs.namespace, "ack-system") + create_namespace = try(var.sqs.create_namespace, true) + chart = "sqs-chart" + chart_version = try(var.sqs.chart_version, "1.0.14") + repository = try(var.sqs.repository, "oci://public.ecr.aws/aws-controllers-k8s") + values = try(var.sqs.values, []) + + timeout = try(var.sqs.timeout, null) + repository_key_file = try(var.sqs.repository_key_file, null) + repository_cert_file = try(var.sqs.repository_cert_file, null) + repository_ca_file = try(var.sqs.repository_ca_file, null) + repository_username = try(var.sqs.repository_username, local.repository_username) + repository_password = try(var.sqs.repository_password, local.repository_password) + devel = try(var.sqs.devel, null) + verify = try(var.sqs.verify, null) + keyring = try(var.sqs.keyring, null) + disable_webhooks = try(var.sqs.disable_webhooks, null) + reuse_values = try(var.sqs.reuse_values, null) + reset_values = try(var.sqs.reset_values, null) + force_update = try(var.sqs.force_update, null) + recreate_pods = try(var.sqs.recreate_pods, null) + cleanup_on_fail = try(var.sqs.cleanup_on_fail, null) + max_history = try(var.sqs.max_history, null) + atomic = try(var.sqs.atomic, null) + skip_crds = try(var.sqs.skip_crds, null) + render_subchart_notes = try(var.sqs.render_subchart_notes, null) + disable_openapi_validation = try(var.sqs.disable_openapi_validation, null) + wait = try(var.sqs.wait, false) + wait_for_jobs = try(var.sqs.wait_for_jobs, null) + dependency_update = try(var.sqs.dependency_update, null) + replace = try(var.sqs.replace, null) + lint = try(var.sqs.lint, null) + + postrender = try(var.sqs.postrender, []) + + set = concat([ + { + # shortens pod name from `ack-sqs-sqs-chart-xxxxxxxxxxxxx` to `ack-sqs-xxxxxxxxxxxxx` + name = "nameOverride" + value = "ack-sqs" + }, + { + name = "aws.region" + value = local.region + }, + { + name = "serviceAccount.name" + value = local.sqs_name + }], + try(var.sqs.set, []) + ) + set_sensitive = try(var.sqs.set_sensitive, []) + + # IAM role for service account (IRSA) + set_irsa_names = ["serviceAccount.annotations.eks\\.amazonaws\\.com/role-arn"] + create_role = try(var.sqs.create_role, true) + role_name = try(var.sqs.role_name, "ack-sqs") + role_name_use_prefix = try(var.sqs.role_name_use_prefix, true) + role_path = try(var.sqs.role_path, "/") + role_permissions_boundary_arn = lookup(var.sqs, "role_permissions_boundary_arn", null) + role_description = try(var.sqs.role_description, "IRSA for SQS controller for ACK") + role_policies = lookup(var.sqs, "role_policies", { + AWSSQSPolicy = var.enable_sqs ? aws_iam_policy.sqspolicy[0].arn : null + }) + create_policy = try(var.sqs.create_policy, false) + + oidc_providers = { + this = { + provider_arn = local.oidc_provider_arn + # namespace is inherited from chart + service_account = local.sqs_name + } + } + + tags = var.tags +} + +# recommended iam-controller policy https://github.com/aws-controllers-k8s/sqs-controller/blob/main/config/iam/recommended-policy-arn +data "aws_iam_policy_document" "sqs_controller" { + count = var.enable_sqs ? 1 : 0 + + statement { + effect = "Allow" + actions = [ + "sqs:*" + ] + resources = ["*"] + } +} + +resource "aws_iam_policy" "sqspolicy" { + count = var.enable_sqs ? 1 : 0 + + name = "SQSController" + description = "IAM policy for SQS Controller" + policy = data.aws_iam_policy_document.sqs_controller[0].json + + tags = var.tags +} + +################################################################################ +# Lambda +################################################################################ + +locals { + lambda_name = "ack-lambda" +} + +module "lambda" { + source = "aws-ia/eks-blueprints-addon/aws" + version = "1.1.1" + + create = var.enable_lambda + + # Disable helm release + create_release = var.create_kubernetes_resources + + # public.ecr.aws/aws-controllers-k8s/lambda-chart:1.5.1 + name = try(var.lambda.name, local.lambda_name) + description = try(var.lambda.description, "Helm Chart for Lambda controller for ACK") + namespace = try(var.lambda.namespace, "ack-system") + create_namespace = try(var.lambda.create_namespace, true) + chart = "lambda-chart" + chart_version = try(var.lambda.chart_version, "1.5.1") + repository = try(var.lambda.repository, "oci://public.ecr.aws/aws-controllers-k8s") + values = try(var.lambda.values, []) + + timeout = try(var.lambda.timeout, null) + repository_key_file = try(var.lambda.repository_key_file, null) + repository_cert_file = try(var.lambda.repository_cert_file, null) + repository_ca_file = try(var.lambda.repository_ca_file, null) + repository_username = try(var.lambda.repository_username, local.repository_username) + repository_password = try(var.lambda.repository_password, local.repository_password) + devel = try(var.lambda.devel, null) + verify = try(var.lambda.verify, null) + keyring = try(var.lambda.keyring, null) + disable_webhooks = try(var.lambda.disable_webhooks, null) + reuse_values = try(var.lambda.reuse_values, null) + reset_values = try(var.lambda.reset_values, null) + force_update = try(var.lambda.force_update, null) + recreate_pods = try(var.lambda.recreate_pods, null) + cleanup_on_fail = try(var.lambda.cleanup_on_fail, null) + max_history = try(var.lambda.max_history, null) + atomic = try(var.lambda.atomic, null) + skip_crds = try(var.lambda.skip_crds, null) + render_subchart_notes = try(var.lambda.render_subchart_notes, null) + disable_openapi_validation = try(var.lambda.disable_openapi_validation, null) + wait = try(var.lambda.wait, false) + wait_for_jobs = try(var.lambda.wait_for_jobs, null) + dependency_update = try(var.lambda.dependency_update, null) + replace = try(var.lambda.replace, null) + lint = try(var.lambda.lint, null) + + postrender = try(var.lambda.postrender, []) + + set = concat([ + { + # shortens pod name from `ack-lambda-lambda-chart-xxxxxxxxxxxxx` to `ack-lambda-xxxxxxxxxxxxx` + name = "nameOverride" + value = "ack-lambda" + }, + { + name = "aws.region" + value = local.region + }, + { + name = "serviceAccount.name" + value = local.lambda_name + }], + try(var.lambda.set, []) + ) + set_sensitive = try(var.lambda.set_sensitive, []) + + # IAM role for service account (IRSA) + set_irsa_names = ["serviceAccount.annotations.eks\\.amazonaws\\.com/role-arn"] + create_role = try(var.lambda.create_role, true) + role_name = try(var.lambda.role_name, "ack-lambda") + role_name_use_prefix = try(var.lambda.role_name_use_prefix, true) + role_path = try(var.lambda.role_path, "/") + role_permissions_boundary_arn = lookup(var.lambda, "role_permissions_boundary_arn", null) + role_description = try(var.lambda.role_description, "IRSA for Lambda controller for ACK") + role_policies = lookup(var.lambda, "role_policies", { + AWSlambdaPolicy = var.enable_lambda ? aws_iam_policy.lambdapolicy[0].arn : null + }) + create_policy = try(var.lambda.create_policy, false) + + oidc_providers = { + this = { + provider_arn = local.oidc_provider_arn + # namespace is inherited from chart + service_account = local.lambda_name + } + } + + tags = var.tags +} + +# recommended iam-controller policy https://github.com/aws-controllers-k8s/lambda-controller/blob/main/config/iam/recommended-inline-policy +data "aws_iam_policy_document" "lambda_controller" { + count = var.enable_lambda ? 1 : 0 + + statement { + effect = "Allow" + actions = [ + "lambda:*", + "s3:Get*", + "ecr:Get*", + "ecr:BatchGet*", + "ec2:DescribeSecurityGroups", + "ec2:DescribeSubnets", + "ec2:DescribeVpcs", + ] + resources = ["*"] + } + + statement { + effect = "Allow" + actions = ["iam:PassRole"] + resources = ["*"] + condition { + test = "StringEquals" + variable = "iam:PassedToService" + values = ["lambda.amazonaws.com"] + } + } +} + +resource "aws_iam_policy" "lambdapolicy" { + count = var.enable_lambda ? 1 : 0 + + name = "LambdaController" + description = "IAM policy for Lambda Controller" + policy = data.aws_iam_policy_document.lambda_controller[0].json + + tags = var.tags +} ################################################################################ # IAM diff --git a/outputs.tf b/outputs.tf index 18992ce..ec9e874 100644 --- a/outputs.tf +++ b/outputs.tf @@ -11,6 +11,24 @@ added or an addon is updated, and new metadata for the Helm chart is needed. output "gitops_metadata" { description = "GitOps Bridge metadata" value = merge( + { for k, v in { + iam_role_arn = module.sns.iam_role_arn + namespace = try(var.sns.namespace, "ack-system") + service_account = local.sns_name + } : "ack_iam_${k}" => v if var.enable_sns + }, + { for k, v in { + iam_role_arn = module.sqs.iam_role_arn + namespace = try(var.sqs.namespace, "ack-system") + service_account = local.sqs_name + } : "ack_iam_${k}" => v if var.enable_sqs + }, + { for k, v in { + iam_role_arn = module.lambda.iam_role_arn + namespace = try(var.lambda.namespace, "ack-system") + service_account = local.lambda_name + } : "ack_iam_${k}" => v if var.enable_lambda + }, { for k, v in { iam_role_arn = module.iam.iam_role_arn namespace = try(var.iam.namespace, "ack-system") diff --git a/variables.tf b/variables.tf index 3b0825d..2afe618 100644 --- a/variables.tf +++ b/variables.tf @@ -43,6 +43,54 @@ variable "tags" { default = {} } +################################################################################ +# SNS +################################################################################ + +variable "enable_sns" { + description = "Enable ACK SNS add-on" + type = bool + default = false +} + +variable "sns" { + description = "ACK SNS Helm Chart config" + type = any + default = {} +} + +################################################################################ +# SQS +################################################################################ + +variable "enable_sqs" { + description = "Enable ACK SQS add-on" + type = bool + default = false +} + +variable "sqs" { + description = "ACK SQS Helm Chart config" + type = any + default = {} +} + +################################################################################ +# Lambda +################################################################################ + +variable "enable_lambda" { + description = "Enable ACK Lambda add-on" + type = bool + default = false +} + +variable "lambda" { + description = "ACK Lambda Helm Chart config" + type = any + default = {} +} + ################################################################################ # IAM ################################################################################ From 991600026a4885fd945987eae10a92097657d694 Mon Sep 17 00:00:00 2001 From: candonov <25967713+candonov@users.noreply.github.com> Date: Wed, 7 Aug 2024 10:37:57 -0700 Subject: [PATCH 2/6] Update main.tf --- main.tf | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/main.tf b/main.tf index f93cdbb..af92da6 100644 --- a/main.tf +++ b/main.tf @@ -354,7 +354,7 @@ module "lambda" { role_permissions_boundary_arn = lookup(var.lambda, "role_permissions_boundary_arn", null) role_description = try(var.lambda.role_description, "IRSA for Lambda controller for ACK") role_policies = lookup(var.lambda, "role_policies", { - AWSlambdaPolicy = var.enable_lambda ? aws_iam_policy.lambdapolicy[0].arn : null + policy = var.enable_lambda ? aws_iam_policy.lambdapolicy[0].arn : null }) create_policy = try(var.lambda.create_policy, false) From fa9e0793ac4f01ad4c0ac398a551af6fb10fe7d1 Mon Sep 17 00:00:00 2001 From: candonov <25967713+candonov@users.noreply.github.com> Date: Wed, 7 Aug 2024 10:38:03 -0700 Subject: [PATCH 3/6] Update main.tf --- main.tf | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/main.tf b/main.tf index af92da6..8afbd10 100644 --- a/main.tf +++ b/main.tf @@ -114,7 +114,7 @@ module "sns" { role_permissions_boundary_arn = lookup(var.sns, "role_permissions_boundary_arn", null) role_description = try(var.sns.role_description, "IRSA for SNS controller for ACK") role_policies = lookup(var.sns, "role_policies", { - AWSSNSPolicy = var.enable_sns ? aws_iam_policy.snspolicy[0].arn : null + policy = var.enable_sns ? aws_iam_policy.snspolicy[0].arn : null }) create_policy = try(var.sns.create_policy, false) From 5b568352c50662a7cf55e29877466bdc42e7f4fe Mon Sep 17 00:00:00 2001 From: candonov <25967713+candonov@users.noreply.github.com> Date: Wed, 7 Aug 2024 10:38:10 -0700 Subject: [PATCH 4/6] Update main.tf --- main.tf | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/main.tf b/main.tf index 8afbd10..7917db2 100644 --- a/main.tf +++ b/main.tf @@ -234,7 +234,7 @@ module "sqs" { role_permissions_boundary_arn = lookup(var.sqs, "role_permissions_boundary_arn", null) role_description = try(var.sqs.role_description, "IRSA for SQS controller for ACK") role_policies = lookup(var.sqs, "role_policies", { - AWSSQSPolicy = var.enable_sqs ? aws_iam_policy.sqspolicy[0].arn : null + policy = var.enable_sqs ? aws_iam_policy.sqspolicy[0].arn : null }) create_policy = try(var.sqs.create_policy, false) From b0c40e22265066a77ccc216b415b23ffe9d0aa3a Mon Sep 17 00:00:00 2001 From: Edgar Costa Date: Thu, 8 Aug 2024 11:02:49 -0300 Subject: [PATCH 5/6] updading tests readme with the new controllers --- examples/complete/README.md | 70 ++++++++++++++++++++++++++----------- 1 file changed, 49 insertions(+), 21 deletions(-) diff --git a/examples/complete/README.md b/examples/complete/README.md index a1948f6..f03dda3 100644 --- a/examples/complete/README.md +++ b/examples/complete/README.md @@ -2,11 +2,23 @@ Configuration in this directory creates an AWS EKS cluster with the following ACK addons: -- ACK API Gateway controller -- ACK DynamoDB controller -- ACK RDS controller -- ACK S3 controller -- ACK Elasticache controller +- Amazon ACM Controller +- Amazon ApiGatewayV2 Controller +- Amazon DynamoDB Controller +- Amazon EC2 Controller +- Amazon EKS Controller +- Amazon ElastiCache Controller +- Amazon EMR Containers Controller +- Amazon EventBridge Controller +- Amazon IAM Controller +- Amazon KMS Controller +- AWS Lambda Controller +- Amazon Prometheus Service Controller +- Amazon RDS Controller +- Amazon S3 Controller +- AWS SFN Controller +- Amazon SNS Controller +- Amazon SQS Controller In addition, this example provisions a sample application which demonstrates using the ACK controllers for resource provisioning. The arhchitecture looks like this:
@@ -46,22 +58,38 @@ aws eks --region update-kubeconfig --name ```sh kubectl get pods -A -NAMESPACE NAME READY STATUS RESTARTS AGE -ack-api-gateway ack-api-gateway-75499bfcfd-d5627 1/1 Running 0 26s -ack-dynamodb ack-dynamodb-76fdf5cf77-jpwd9 1/1 Running 0 26s -ack-elasticache ack-elasticache-45eeg7dv12-m5asf 1/1 Running 0 26s -ack-rds ack-rds-85c7ccdbf6-tkpvz 1/1 Running 0 26s -ack-s3 ack-s3-7f4c79cbc8-g4tgl 1/1 Running 0 26s -kube-system aws-load-balancer-controller-596d8cb765-wwmzt 1/1 Running 0 26s -kube-system aws-load-balancer-controller-596d8cb765-zpkw5 1/1 Running 0 26s -kube-system aws-node-cvt8c 1/1 Running 0 26s -kube-system aws-node-dhk98 1/1 Running 0 26s -kube-system aws-node-fk4bb 1/1 Running 0 26s -kube-system coredns-57ff979f67-6vmrg 1/1 Running 0 26s -kube-system coredns-57ff979f67-xnwvn 1/1 Running 0 26s -kube-system kube-proxy-5ww6m 1/1 Running 0 26s -kube-system kube-proxy-84fk2 1/1 Running 0 26s -kube-system kube-proxy-jwwkl 1/1 Running 0 26s +NAMESPACE NAME READY STATUS RESTARTS AGE +ack-system ack-acm-5ffccbd5d5-62kx9 1/1 Running 0 11m +ack-system ack-apigatewayv2-cf6cd9d67-vxhsk 1/1 Running 0 11m +ack-system ack-dynamodb-bd47f88b7-7jbgw 1/1 Running 0 10m +ack-system ack-ec2-54dfcf968-pdbs2 1/1 Running 0 10m +ack-system ack-eks-9cb44fc-95k6x 1/1 Running 0 11m +ack-system ack-elasticache-5758ff66bd-6vbgc 1/1 Running 0 11m +ack-system ack-emrcontainers-69ffb54758-78ksb 1/1 Running 0 11m +ack-system ack-eventbridge-58c7d4c8f5-vvfz5 1/1 Running 0 11m +ack-system ack-iam-7486c996c8-kbb2h 1/1 Running 0 11m +ack-system ack-kms-bb956b4fc-x69lv 1/1 Running 0 11m +ack-system ack-lambda-65bd7fbc8d-6jn8k 1/1 Running 0 11m +ack-system ack-prometheusservice-5bccddc6f-7tkl5 1/1 Running 0 11m +ack-system ack-rds-57499b447d-pg9tq 1/1 Running 0 10m +ack-system ack-s3-78b44bf586-b8qnj 1/1 Running 0 11m +ack-system ack-sfn-7494cbccf-vx6g7 1/1 Running 0 10m +ack-system ack-sns-56bb579874-h26s5 1/1 Running 0 11m +ack-system ack-sqs-5f7bc84d45-47zw4 1/1 Running 0 11m +kube-system aws-load-balancer-controller-84b5bf9c5f-45fkt 1/1 Running 0 10m +kube-system aws-load-balancer-controller-84b5bf9c5f-vtwj4 1/1 Running 0 10m +kube-system aws-node-btph9 2/2 Running 0 10m +kube-system aws-node-dqh67 2/2 Running 0 10m +kube-system aws-node-kt5mp 2/2 Running 0 10m +kube-system coredns-787cb67946-hlqfm 1/1 Running 0 14m +kube-system coredns-787cb67946-q8lzj 1/1 Running 0 14m +kube-system eks-pod-identity-agent-lhj4d 1/1 Running 0 10m +kube-system eks-pod-identity-agent-vvf46 1/1 Running 0 10m +kube-system eks-pod-identity-agent-zw2qv 1/1 Running 0 10m +kube-system kube-proxy-27k5q 1/1 Running 0 10m +kube-system kube-proxy-6q78s 1/1 Running 0 10m +kube-system kube-proxy-x5hhm 1/1 Running 0 10m +kube-system metrics-server-7577444cf8-9l7h8 1/1 Running 0 12m ``` ## Sample Application Deployment From 53949fe2d4c0b65fd59ceccdcdba90f7b213ceb6 Mon Sep 17 00:00:00 2001 From: Edgar Costa Date: Thu, 8 Aug 2024 12:51:29 -0300 Subject: [PATCH 6/6] updating module readme to include new controllers --- README.md | 3 +++ 1 file changed, 3 insertions(+) diff --git a/README.md b/README.md index 5297864..497fbcb 100644 --- a/README.md +++ b/README.md @@ -18,6 +18,9 @@ module "eks_ack_addons" { ecrpublic_token = "" # Controllers to enable + enable_sns = true + enable_sqs = true + enable_lambda = true enable_iam = true enable_ec2 = true enable_eks = true