From bfe79a27f0a9449d8bb15d8c5956df4553a1751e Mon Sep 17 00:00:00 2001
From: "Leo J." <153937047+leiicamundi@users.noreply.github.com>
Date: Tue, 12 Nov 2024 13:53:08 +0100
Subject: [PATCH] feat: implement choice of AZs (#99)
* feat: implement choice of AZs
This PR introduce a choice for the AWS AZs, it's backward compatible,
and implement both the AZs definition in the VPC and the ROSA Cluster
itself
Related to
https://github.com/camunda/team-infrastructure-experience/issues/411
* chore: add desc
---
modules/rosa-hcp/README.md | 4 +++-
modules/rosa-hcp/rosa.tf | 9 ++++++---
modules/rosa-hcp/vars.tf | 15 ++++++++++++++-
3 files changed, 23 insertions(+), 5 deletions(-)
diff --git a/modules/rosa-hcp/README.md b/modules/rosa-hcp/README.md
index 01dcbfa..9719151 100644
--- a/modules/rosa-hcp/README.md
+++ b/modules/rosa-hcp/README.md
@@ -17,7 +17,9 @@
| Name | Description | Type | Default | Required |
|------|-------------|------|---------|:--------:|
-| [availability\_zones\_count](#input\_availability\_zones\_count) | The number of availability zones to use for the cluster (minimum 2) | `number` | `2` | no |
+| [availability\_zones](#input\_availability\_zones) | A list of availability zone names in the region. By default, this is set to `null` and is not used; instead, `availability_zones_count` manages the number of availability zones. This value should not be updated directly. To make changes, please create a new resource. | `list(string)` | `null` | no |
+| [availability\_zones\_count](#input\_availability\_zones\_count) | The count of availability (minimum 2) zones to utilize within the specified AWS Region, where pairs of public and private subnets will be generated. Valid only when availability\_zones variable is not provided. This value should not be updated, please create a new resource instead. | `number` | `2` | no |
+| [aws\_availability\_zones](#input\_aws\_availability\_zones) | The AWS availability zones where instances of the default worker machine pool are deployed. Leave empty for the installer to pick availability zones from the VPC `availability_zones` or `availability_zones_count` | `list(string)` | `[]` | no |
| [cluster\_name](#input\_cluster\_name) | The name of the ROSA cluster to create | `string` | `"my-ocp-cluster"` | no |
| [compute\_node\_instance\_type](#input\_compute\_node\_instance\_type) | The EC2 instance type to use for compute nodes | `string` | `"m5.xlarge"` | no |
| [host\_prefix](#input\_host\_prefix) | The subnet mask to assign to each compute node in the cluster | `string` | `"23"` | no |
diff --git a/modules/rosa-hcp/rosa.tf b/modules/rosa-hcp/rosa.tf
index a28e7c3..5d94276 100644
--- a/modules/rosa-hcp/rosa.tf
+++ b/modules/rosa-hcp/rosa.tf
@@ -25,7 +25,8 @@ module "rosa_hcp" {
replicas = var.replicas
- aws_availability_zones = module.vpc.availability_zones
+ aws_availability_zones = length(var.aws_availability_zones) > 0 ? var.aws_availability_zones : module.vpc.availability_zones
+
aws_subnet_ids = concat(
module.vpc.public_subnets, module.vpc.private_subnets,
)
@@ -61,8 +62,10 @@ module "vpc" {
source = "terraform-redhat/rosa-hcp/rhcs//modules/vpc"
version = "1.6.5"
- name_prefix = var.cluster_name
- availability_zones_count = var.availability_zones_count
+ name_prefix = var.cluster_name
+
+ availability_zones_count = var.availability_zones != null ? null : var.availability_zones_count
+ availability_zones = var.availability_zones
vpc_cidr = var.vpc_cidr_block
}
diff --git a/modules/rosa-hcp/vars.tf b/modules/rosa-hcp/vars.tf
index ca5879a..82de5fa 100644
--- a/modules/rosa-hcp/vars.tf
+++ b/modules/rosa-hcp/vars.tf
@@ -41,10 +41,23 @@ variable "offline_access_token" {
variable "availability_zones_count" {
type = number
- description = "The number of availability zones to use for the cluster (minimum 2)"
+ description = "The count of availability (minimum 2) zones to utilize within the specified AWS Region, where pairs of public and private subnets will be generated. Valid only when availability_zones variable is not provided. This value should not be updated, please create a new resource instead."
default = 2
}
+variable "availability_zones" {
+ type = list(string)
+ description = "A list of availability zone names in the region. By default, this is set to `null` and is not used; instead, `availability_zones_count` manages the number of availability zones. This value should not be updated directly. To make changes, please create a new resource."
+ default = null
+}
+
+
+variable "aws_availability_zones" {
+ type = list(string)
+ description = "The AWS availability zones where instances of the default worker machine pool are deployed. Leave empty for the installer to pick availability zones from the VPC `availability_zones` or `availability_zones_count`"
+ default = []
+}
+
variable "vpc_cidr_block" {
type = string
description = "value of the CIDR block to use for the VPC"