-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathmain.tf_irsa
More file actions
76 lines (62 loc) · 1.83 KB
/
main.tf_irsa
File metadata and controls
76 lines (62 loc) · 1.83 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
data "terraform_remote_state" "eks" {
backend = "s3"
config = {
bucket = "my-tf-state-2023-06-01"
key = "my-eks.tfstate"
region = "us-east-1"
}
}
data "aws_route53_zone" "this" {
for_each = toset(var.route53_zone_ids)
zone_id = each.key
}
locals {
route53_zone_names = [for k, v in data.aws_route53_zone.this : v.name]
route53_zone_arns = [for k, v in data.aws_route53_zone.this : v.arn]
}
module "irsa_role" {
source = "terraform-aws-modules/iam/aws//modules/iam-role-for-service-accounts-eks"
version = "5.44.0"
role_name = "eks-external-dns-controller-${data.terraform_remote_state.eks.outputs.cluster_name}-${var.region}"
attach_external_dns_policy = true
external_dns_hosted_zone_arns = local.route53_zone_arns
oidc_providers = {
ex = {
provider_arn = data.terraform_remote_state.eks.outputs.oidc_provider_arn
namespace_service_accounts = ["kube-system:external-dns"]
}
}
}
resource "helm_release" "this" {
name = "external-dns"
repository = "oci://registry-1.docker.io/bitnamicharts"
chart = "external-dns"
version = var.helm_package_version
namespace = "kube-system"
set {
name = "serviceAccount.create"
value = "true"
}
set {
name = "serviceAccount.annotations.eks\\.amazonaws\\.com/role-arn"
value = module.irsa_role.iam_role_arn
}
set {
name = "provider"
value = "aws"
}
set {
name = "txtOwnerId"
value = "External-dns addon of ${data.terraform_remote_state.eks.outputs.cluster_name} EKS cluster"
}
set {
name = "domainFilters"
# list like "example.com,example-internal.com"
value = format("{%s}", join(",", local.route53_zone_names))
}
# it removes unused domains after removing related resources
set {
name = "policy"
value = "sync"
}
}