139 lines
		
	
	
	
		
			3.4 KiB
		
	
	
	
		
			HCL
		
	
	
	
	
	
			
		
		
	
	
			139 lines
		
	
	
	
		
			3.4 KiB
		
	
	
	
		
			HCL
		
	
	
	
	
	
| variable "region" {
 | ||
|   description = "Region for the STACKIT Cloud"
 | ||
|   type        = string
 | ||
|   default     = "eu01"
 | ||
| }
 | ||
| 
 | ||
| variable "project_id" {
 | ||
|   description = "STACKIT Cloud project ID"
 | ||
|   type        = string
 | ||
| }
 | ||
| 
 | ||
| variable "service_account_token" {
 | ||
|   description = "Service account token for authentication"
 | ||
|   sensitive   = true
 | ||
|   type        = string
 | ||
| }
 | ||
| 
 | ||
| variable "service_account_key_path" {
 | ||
|   type    = string
 | ||
|   default = ""
 | ||
| }
 | ||
| 
 | ||
| variable "organization_id" {
 | ||
|   description = "Organization ID"
 | ||
|   type        = string
 | ||
| }
 | ||
| 
 | ||
| variable "owner_email" {
 | ||
|   description = "Email of the project owner"
 | ||
|   type        = string
 | ||
|   default     = null
 | ||
| }
 | ||
| 
 | ||
| variable "security_groups" {
 | ||
|   type = map(object({
 | ||
|     name        = optional(string)
 | ||
|     description = optional(string)
 | ||
|     rules = list(object({
 | ||
|       direction   = string
 | ||
|       description = optional(string)
 | ||
|       ether_type  = optional(string)
 | ||
|       icmp_parameters = optional(object({
 | ||
|         type = optional(number)
 | ||
|         code = optional(number)
 | ||
|       }))
 | ||
|       ip_range = optional(string)
 | ||
|       port_range = optional(object({
 | ||
|         min = number
 | ||
|         max = number
 | ||
|       }))
 | ||
|       protocol = optional(object({
 | ||
|         name   = optional(string)
 | ||
|         number = optional(number)
 | ||
|       }))
 | ||
|       remote_security_group_id = optional(string)
 | ||
|     }))
 | ||
|   }))
 | ||
| }
 | ||
| 
 | ||
| variable "postgres_instances" {
 | ||
|   type = map(object({
 | ||
|     name            = string
 | ||
|     version         = number
 | ||
|     flavor          = object({ cpu = number, ram = number })
 | ||
|     storage         = object({ class = string, size = number })
 | ||
|     replicas        = number
 | ||
|     acl             = list(string)
 | ||
|     backup_schedule = string
 | ||
|     users = list(object({
 | ||
|       username = string
 | ||
|       roles    = set(string)
 | ||
|     }))
 | ||
|     databases = list(object({
 | ||
|       name  = string
 | ||
|       owner = string
 | ||
|     }))
 | ||
|   }))
 | ||
| }
 | ||
| 
 | ||
| # Network definition map
 | ||
| variable "networks" {
 | ||
|   type = map(object({
 | ||
|     name = string
 | ||
| 
 | ||
|     # IPv4 settings
 | ||
|     ipv4_gateway       = optional(string)
 | ||
|     ipv4_nameservers   = optional(list(string))
 | ||
|     ipv4_prefix        = optional(string)
 | ||
|     ipv4_prefix_length = optional(number)
 | ||
| 
 | ||
|     # IPv6 settings
 | ||
|     ipv6_gateway       = optional(string)
 | ||
|     ipv6_nameservers   = optional(list(string))
 | ||
|     ipv6_prefix        = optional(string)
 | ||
|     ipv6_prefix_length = optional(number)
 | ||
| 
 | ||
|     # Flags & labels
 | ||
|     labels          = optional(map(string))
 | ||
|     no_ipv4_gateway = optional(bool)
 | ||
|     no_ipv6_gateway = optional(bool)
 | ||
|     routed          = optional(bool)
 | ||
| 
 | ||
|     # NIC‑specific options
 | ||
|     nics = optional(map(object({
 | ||
|       nic_ipv4                 = optional(string)
 | ||
|       nic_name                 = string
 | ||
|       nic_allowed_addresses    = optional(list(string))
 | ||
|       nic_labels               = optional(map(string))
 | ||
|       nic_security             = optional(bool)
 | ||
|       nic_security_group_ids   = optional(list(string))
 | ||
|       nic_security_group_names = optional(list(string))
 | ||
|     })))
 | ||
|   }))
 | ||
| 
 | ||
|   default = {}
 | ||
| }
 | ||
| 
 | ||
| 
 | ||
| # variable "ske_clusters" {
 | ||
| #   type = map(object({
 | ||
| #     name                   = string
 | ||
| #     kubernetes_version_min = string
 | ||
| #     node_pools = list(object({
 | ||
| #       name               = string
 | ||
| #       machine_type       = string
 | ||
| #       availability_zones = list(string)
 | ||
| #       volume_size        = number
 | ||
| #       minimum            = number
 | ||
| #       maximum            = number
 | ||
| #     }))
 | ||
| #   }))
 | ||
| # }
 | ||
| 
 | ||
| # variable "observability_instances" {
 | ||
| #   type = map(object({
 | ||
| #     name      = string
 | ||
| #     plan_name = string
 | ||
| #   }))
 | ||
| # }
 |