mirror of
https://github.com/edgelesssys/constellation.git
synced 2025-01-04 04:10:59 -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>
127 lines
3.5 KiB
HCL
127 lines
3.5 KiB
HCL
terraform {
|
|
required_providers {
|
|
libvirt = {
|
|
source = "dmacvicar/libvirt"
|
|
version = "0.7.1"
|
|
}
|
|
docker = {
|
|
source = "kreuzwerker/docker"
|
|
version = "3.0.2"
|
|
}
|
|
}
|
|
}
|
|
|
|
provider "libvirt" {
|
|
uri = var.libvirt_uri
|
|
}
|
|
|
|
provider "docker" {
|
|
host = "unix:///var/run/docker.sock"
|
|
}
|
|
|
|
locals {
|
|
cidr_vpc_subnet_nodes = "10.42.0.0/22"
|
|
cidr_vpc_subnet_control_planes = "10.42.1.0/24"
|
|
cidr_vpc_subnet_worker = "10.42.2.0/24"
|
|
}
|
|
|
|
resource "random_password" "init_secret" {
|
|
length = 32
|
|
special = true
|
|
override_special = "_%@"
|
|
}
|
|
resource "docker_image" "qemu_metadata" {
|
|
name = var.metadata_api_image
|
|
keep_locally = true
|
|
}
|
|
|
|
resource "docker_container" "qemu_metadata" {
|
|
name = "${var.name}-qemu-metadata"
|
|
image = docker_image.qemu_metadata.image_id
|
|
network_mode = "host"
|
|
rm = true
|
|
command = [
|
|
"--network",
|
|
"${var.name}-network",
|
|
"--libvirt-uri",
|
|
"${var.metadata_libvirt_uri}",
|
|
"--initsecrethash",
|
|
"${random_password.init_secret.bcrypt_hash}",
|
|
]
|
|
mounts {
|
|
source = abspath(var.libvirt_socket_path)
|
|
target = "/var/run/libvirt/libvirt-sock"
|
|
type = "bind"
|
|
}
|
|
}
|
|
|
|
module "node_group" {
|
|
source = "./modules/instance_group"
|
|
base_name = var.name
|
|
for_each = var.node_groups
|
|
node_group_name = each.key
|
|
role = each.value.role
|
|
amount = each.value.initial_count
|
|
state_disk_size = each.value.disk_size
|
|
vcpus = each.value.vcpus
|
|
memory = each.value.memory
|
|
machine = var.machine
|
|
cidr = each.value.role == "control-plane" ? local.cidr_vpc_subnet_control_planes : local.cidr_vpc_subnet_worker
|
|
network_id = libvirt_network.constellation.id
|
|
pool = libvirt_pool.cluster.name
|
|
boot_mode = var.constellation_boot_mode
|
|
boot_volume_id = libvirt_volume.image_id.id
|
|
kernel_volume_id = local.kernel_volume_id
|
|
initrd_volume_id = local.initrd_volume_id
|
|
kernel_cmdline = each.value.role == "control-plane" ? local.kernel_cmdline : var.constellation_cmdline
|
|
firmware = var.firmware
|
|
nvram = var.nvram
|
|
}
|
|
|
|
resource "libvirt_pool" "cluster" {
|
|
name = "${var.name}-storage-pool"
|
|
type = "dir"
|
|
path = "/var/lib/libvirt/images"
|
|
}
|
|
|
|
resource "libvirt_volume" "image_id" {
|
|
name = "${var.name}-node-image"
|
|
pool = libvirt_pool.cluster.name
|
|
source = var.image_id
|
|
format = var.image_format
|
|
}
|
|
|
|
resource "libvirt_volume" "constellation_kernel" {
|
|
name = "${var.name}-kernel"
|
|
pool = libvirt_pool.cluster.name
|
|
source = var.constellation_kernel
|
|
format = "raw"
|
|
count = var.constellation_boot_mode == "direct-linux-boot" ? 1 : 0
|
|
}
|
|
|
|
resource "libvirt_volume" "constellation_initrd" {
|
|
name = "${var.name}-initrd"
|
|
pool = libvirt_pool.cluster.name
|
|
source = var.constellation_initrd
|
|
format = "raw"
|
|
count = var.constellation_boot_mode == "direct-linux-boot" ? 1 : 0
|
|
}
|
|
|
|
resource "libvirt_network" "constellation" {
|
|
name = "${var.name}-network"
|
|
mode = "nat"
|
|
addresses = ["10.42.0.0/16"]
|
|
dhcp {
|
|
enabled = true
|
|
}
|
|
dns {
|
|
enabled = true
|
|
}
|
|
}
|
|
|
|
locals {
|
|
kernel_volume_id = var.constellation_boot_mode == "direct-linux-boot" ? libvirt_volume.constellation_kernel[0].id : null
|
|
initrd_volume_id = var.constellation_boot_mode == "direct-linux-boot" ? libvirt_volume.constellation_initrd[0].id : null
|
|
kernel_cmdline = var.constellation_boot_mode == "direct-linux-boot" ? var.constellation_cmdline : null
|
|
}
|