variable "cluster_name" { type = string description = "Unique cluster name (prepended to dns_zone)" } # Azure variable "location" { type = string description = "Azure location (e.g. centralus , see `az account list-locations --output table`)" } variable "dns_zone" { type = string description = "Azure DNS Zone (e.g. azure.example.com)" } variable "dns_zone_group" { type = string description = "Resource group where the Azure DNS Zone resides (e.g. global)" } # instances variable "os_image" { type = string description = "Channel for a Container Linux derivative (flatcar-stable, flatcar-beta, flatcar-alpha)" default = "flatcar-stable" validation { condition = contains(["flatcar-stable", "flatcar-beta", "flatcar-alpha"], var.os_image) error_message = "The os_image must be flatcar-stable, flatcar-beta, or flatcar-alpha." } } variable "controller_count" { type = number description = "Number of controllers (i.e. masters)" default = 1 } variable "controller_type" { type = string description = "Machine type for controllers (see `az vm list-skus --location centralus`)" default = "Standard_B2s" } variable "controller_disk_type" { type = string description = "Type of managed disk for controller node(s)" default = "Premium_LRS" } variable "controller_disk_size" { type = number description = "Size of the managed disk in GB for controller node(s)" default = 30 } variable "worker_count" { type = number description = "Number of workers" default = 1 } variable "worker_type" { type = string description = "Machine type for workers (see `az vm list-skus --location centralus`)" default = "Standard_D2as_v5" } variable "worker_disk_type" { type = string description = "Type of managed disk for worker nodes" default = "Standard_LRS" } variable "worker_disk_size" { type = number description = "Size of the managed disk in GB for worker nodes" default = 30 } variable "worker_ephemeral_disk" { type = bool description = "Use ephemeral local disk instead of managed disk (requires vm_type with local storage)" default = false } variable "worker_priority" { type = string description = "Set worker priority to Spot to use reduced cost surplus capacity, with the tradeoff that instances can be deallocated at any time." default = "Regular" } variable "controller_snippets" { type = list(string) description = "Controller Container Linux Config snippets" default = [] } variable "worker_snippets" { type = list(string) description = "Worker Container Linux Config snippets" default = [] } # configuration variable "ssh_authorized_key" { type = string description = "SSH public key for user 'core'" } variable "azure_authorized_key" { type = string description = "Optionally, pass a dummy RSA key to satisfy Azure validations (then use an ed25519 key set above)" default = "" } variable "networking" { type = string description = "Choice of networking provider (flannel, calico, or cilium)" default = "cilium" } variable "network_cidr" { type = object({ ipv4 = list(string) ipv6 = optional(list(string), ["fd9a:0d2f:b7dc::/48"]) }) description = "Virtual network CIDR ranges" default = { ipv4 = ["10.0.0.0/16"] } } variable "pod_cidr" { type = string description = "CIDR IPv4 range to assign Kubernetes pods" default = "10.2.0.0/16" } variable "service_cidr" { type = string description = <