mirror of
https://github.com/edgelesssys/constellation.git
synced 2025-01-15 09:27:19 -05:00
9667dfff58
* all vars have snail_case * make iam schema consistent * infrastructure schema * terraform: update AWS infrastructure module * fix ci * terraform: update AWS infrastructure module * terraform: update AWS IAM module * terraform: update Azure Infrastructure module inputs Signed-off-by: Moritz Sanft <58110325+msanft@users.noreply.github.com> * terraform: update Azure IAM module Signed-off-by: Moritz Sanft <58110325+msanft@users.noreply.github.com> * terraform: update GCP infrastructure module Signed-off-by: Moritz Sanft <58110325+msanft@users.noreply.github.com> * terraform: update GCP IAM module Signed-off-by: Moritz Sanft <58110325+msanft@users.noreply.github.com> * terraform: update OpenStack Infrastructure module Signed-off-by: Moritz Sanft <58110325+msanft@users.noreply.github.com> * terraform: update QEMU Infrastructure module Signed-off-by: Moritz Sanft <58110325+msanft@users.noreply.github.com> * terraform-module: fix input name Signed-off-by: Moritz Sanft <58110325+msanft@users.noreply.github.com> * terraform: tidy * cli: ignore whitespace in Terraform variable tests * terraform-module: fix AWS output names * terraform-module: fix output references Signed-off-by: Moritz Sanft <58110325+msanft@users.noreply.github.com> * terraform: rename `api_server_cert_sans` * Update terraform/infrastructure/aws/modules/public_private_subnet/variables.tf Co-authored-by: Daniel Weiße <66256922+daniel-weisse@users.noreply.github.com> * fix self-managed * terraform: revert AWS modules output file renaming * terraform: remove duplicate varable declaration * terraform: rename Azure location field * ci: adjust output name in self-managed e2e test * e2e: continuously print output in upgrade test * e2e: write to output variables * cli: migrate IAM variable names * cli: make `location` field optional --------- Signed-off-by: Moritz Sanft <58110325+msanft@users.noreply.github.com> Co-authored-by: Moritz Sanft <58110325+msanft@users.noreply.github.com> Co-authored-by: Daniel Weiße <66256922+daniel-weisse@users.noreply.github.com>
110 lines
2.9 KiB
HCL
110 lines
2.9 KiB
HCL
# Variables common to all CSPs
|
|
|
|
variable "name" {
|
|
type = string
|
|
default = "constellation"
|
|
description = "Name of the Constellation cluster."
|
|
}
|
|
|
|
variable "node_groups" {
|
|
type = map(object({
|
|
role = string
|
|
initial_count = number // number of instances in the node group
|
|
disk_size = number // size of state disk (GiB)
|
|
vcpus = number
|
|
memory = number // amount of memory per instance (MiB)
|
|
}))
|
|
validation {
|
|
condition = can([for group in var.node_groups : group.role == "control-plane" || group.role == "worker"])
|
|
error_message = "The role has to be 'control-plane' or 'worker'."
|
|
}
|
|
|
|
description = "A map of node group names to node group configurations."
|
|
}
|
|
|
|
variable "image_id" {
|
|
type = string
|
|
description = "Path to the OS image for the cluster's nodes."
|
|
}
|
|
|
|
variable "custom_endpoint" {
|
|
type = string
|
|
default = ""
|
|
description = "Custom endpoint to use for the Kubernetes API server. If not set, the default endpoint will be used."
|
|
}
|
|
|
|
# QEMU-specific variables
|
|
|
|
variable "machine" {
|
|
type = string
|
|
default = "q35"
|
|
description = "Machine type. Use 'q35' for secure boot and 'pc' for non secure boot. See 'qemu-system-x86_64 -machine help'."
|
|
}
|
|
|
|
variable "libvirt_uri" {
|
|
type = string
|
|
description = "URI of the Libvirt socket."
|
|
}
|
|
|
|
variable "constellation_boot_mode" {
|
|
type = string
|
|
description = "Constellation boot mode. Can be 'uefi' or 'direct-linux-boot'."
|
|
validation {
|
|
condition = anytrue([
|
|
var.constellation_boot_mode == "uefi",
|
|
var.constellation_boot_mode == "direct-linux-boot",
|
|
])
|
|
error_message = "constellation_boot_mode must be 'uefi' or 'direct-linux-boot'."
|
|
}
|
|
}
|
|
|
|
variable "constellation_kernel" {
|
|
type = string
|
|
description = "Constellation Kernel file path."
|
|
default = ""
|
|
}
|
|
|
|
variable "constellation_initrd" {
|
|
type = string
|
|
description = "Constellation initrd file path."
|
|
default = ""
|
|
}
|
|
|
|
variable "constellation_cmdline" {
|
|
type = string
|
|
description = "Constellation kernel cmdline."
|
|
default = ""
|
|
}
|
|
|
|
variable "image_format" {
|
|
type = string
|
|
default = "qcow2"
|
|
description = "Image format."
|
|
}
|
|
|
|
variable "firmware" {
|
|
type = string
|
|
default = "/usr/share/OVMF/OVMF_CODE.fd"
|
|
description = "Path to UEFI firmware file. Use \"OVMF_CODE_4M.ms.fd\" on Ubuntu and \"OVMF_CODE.fd\" or \"OVMF_CODE.secboot.fd\" on Fedora."
|
|
}
|
|
|
|
variable "nvram" {
|
|
type = string
|
|
description = "Path to UEFI NVRAM template file. Used for secure boot."
|
|
}
|
|
|
|
variable "metadata_api_image" {
|
|
type = string
|
|
description = "Container image of the QEMU metadata API server."
|
|
}
|
|
|
|
variable "metadata_libvirt_uri" {
|
|
type = string
|
|
description = "Libvirt URI for the metadata API server."
|
|
}
|
|
|
|
variable "libvirt_socket_path" {
|
|
type = string
|
|
description = "Path to Libvirt socket in case of unix socket."
|
|
}
|