constellation/terraform-provider-constellation/docs/resources/cluster.md
Moritz Sanft 367136add2
terraform-provider: support importing Constellation clusters (#2702)
* terraform-provider: support importing Constellation clusters

* bazel: shfmt exclusion for import script

* ci: fix godot check

* bazel: shellcheck exclusion for import script

* Update dev-docs/workflows/terraform-provider.md

Co-authored-by: Adrian Stobbe <stobbe.adrian@gmail.com>

* ci: fix Terraform lock exclude directories

---------

Co-authored-by: Adrian Stobbe <stobbe.adrian@gmail.com>
2023-12-12 16:00:03 +01:00

6.7 KiB

page_title subcategory description
constellation_cluster Resource - constellation Resource for a Constellation cluster.

constellation_cluster (Resource)

Resource for a Constellation cluster.

Example Usage

// Not up-to-date

data "constellation_attestation" "foo" {} # Fill accordingly for the CSP and attestation variant

data "constellation_image" "bar" {} # Fill accordingly for the CSP

resource "constellation_cluster" "aws_example" {
  csp                                = "aws"
  name                               = "constell"
  uid                                = "deadbeef"
  constellation_microservice_version = "vx.y.z"
  image                              = data.constellation_image.bar.image
  attestation                        = data.constellation_attestation.foo.attestation
  init_secret                        = "deadbeefdeadbeefdeadbeefdeadbeefdeadbeefdeadbeefdeadbeefdeadbeef"
  master_secret                      = "deadbeefdeadbeefdeadbeefdeadbeefdeadbeefdeadbeefdeadbeefdeadbeef"
  master_secret_salt                 = "deadbeefdeadbeefdeadbeefdeadbeefdeadbeefdeadbeefdeadbeefdeadbeef"
  out_of_cluster_endpoint            = "123.123.123.123"
  network_config = {
    ip_cidr_node    = "192.168.176.0/20"
    ip_cidr_service = "10.96.0.0/12"
  }
}

Schema

Required

  • attestation (Attributes) Attestation comprises the measurements and SEV-SNP specific parameters. (see below for nested schema)
  • csp (String) The Cloud Service Provider (CSP) the cluster should run on.
  • image_reference (String) Constellation OS image reference to use in the CSP specific reference format. Use the constellation_image data source to find the correct image reference for your CSP.
  • image_version (String) Constellation OS image version to use in the CSP specific reference format. Use the constellation_image data source to find the correct image version for your CSP.
  • init_secret (String) Secret used for initialization of the cluster.
  • master_secret (String) Hex-encoded 32-byte master secret for the cluster.
  • master_secret_salt (String) Hex-encoded 32-byte master secret salt for the cluster.
  • measurement_salt (String) Hex-encoded 32-byte measurement salt for the cluster.
  • name (String) Name used in the cluster's named resources / cluster name.
  • network_config (Attributes) Configuration for the cluster's network. (see below for nested schema)
  • out_of_cluster_endpoint (String) The endpoint of the cluster. Typically, this is the public IP of a loadbalancer.
  • uid (String) The UID of the cluster.

Optional

  • azure (Attributes) Azure-specific configuration. (see below for nested schema)
  • constellation_microservice_version (String) The version of Constellation's microservices used within the cluster. When not set, the provider default version is used.
  • extra_api_server_cert_sans (List of String) List of additional Subject Alternative Names (SANs) for the API server certificate.
  • extra_microservices (Attributes) Extra microservice settings. (see below for nested schema)
  • gcp (Attributes) GCP-specific configuration. (see below for nested schema)
  • in_cluster_endpoint (String) The endpoint of the cluster. When not set, the out-of-cluster endpoint is used.
  • kubernetes_version (String) The Kubernetes version to use for the cluster. When not set, version v1.27.8 is used. The supported versions are [v1.26.11 v1.27.8 v1.28.4].

Read-Only

  • cluster_id (String) The cluster ID of the cluster.
  • kubeconfig (String) The kubeconfig of the cluster.
  • owner_id (String) The owner ID of the cluster.

Nested Schema for attestation

Required:

  • amd_root_key (String)
  • bootloader_version (Number)
  • measurements (Attributes Map) (see below for nested schema)
  • microcode_version (Number)
  • snp_version (Number)
  • tee_version (Number)
  • variant (String) Attestation variant the image should work with. Can be one of:
    • aws-sev-snp
    • aws-nitro-tpm
    • azure-sev-snp
    • gcp-sev-es

Optional:

Nested Schema for attestation.measurements

Required:

  • expected (String)
  • warn_only (Boolean)

Nested Schema for attestation.azure_firmware_signer_config

Optional:

  • accepted_key_digests (List of String)
  • enforcement_policy (String)
  • maa_url (String)

Nested Schema for network_config

Required:

  • ip_cidr_node (String) CIDR range of the cluster's node network.
  • ip_cidr_service (String) CIDR range of the cluster's service network.

Optional:

  • ip_cidr_pod (String) CIDR range of the cluster's pod network. Only required for clusters running on GCP.

Nested Schema for azure

Required:

  • load_balancer_name (String) Name of the Azure load balancer used by the cluster.
  • location (String) Azure Location of the cluster.
  • network_security_group_name (String) Name of the Azure network security group used for the cluster.
  • resource_group (String) Name of the Azure resource group the cluster resides in.
  • subscription_id (String) ID of the Azure subscription the cluster resides in.
  • tenant_id (String) Tenant ID of the Azure account.
  • uami_client_id (String) Client ID of the User assigned managed identity (UAMI) used within the cluster.
  • uami_resource_id (String) Resource ID of the User assigned managed identity (UAMI) used within the cluster.

Nested Schema for extra_microservices

Required:

Nested Schema for gcp

Required:

  • project_id (String) ID of the GCP project the cluster resides in.
  • service_account_key (String) Base64-encoded private key JSON object of the service account used within the cluster.

Import

Import is supported using the following syntax:

terraform import constellation_cluster.constellation_cluster constellation-cluster://?kubeConfig=<base64-encoded-kubeconfig>&clusterEndpoint=<cluster-endpoint>&masterSecret=<hex-encoded-mastersecret>&masterSecretSalt=<hex-encoded-mastersecret-salt>