Skip to content

Using generic CI/CD tools for your IaC automation? πŸ€–βš™οΈ

Download the Build vs Buy Guide→

External state accessΒ»

External state access allows you to read the state of the stack from outside authorized runs and tasks. In particular, this enables sharing the outputs between stacks using the Terraform mechanism of remote state or even accessing the state offline for analytical or compliance purposes.

If enabled for a particular stack, any user or stack with Write permission to that stack's space will be able to access its state.

This feature is off by default.

Enabling external accessΒ»

Info

Only administrative stacks or users with write permission to this Stack's space can access the state.

You can enable the external access in a couple of ways.

  • through the UI

1
2
3
4
5
6
resource "spacelift_stack" "example" {
  name                            = "example"
  repository                      = "spacelift-stacks"
  branch                          = "main"
  terraform_external_state_access = true
}

Sharing outputs between stacksΒ»

Sharing the outputs between stacks can be achieved using the Terraform mechanism of remote state.

Given an account called spacecorp, and a stack named deep-thought, having the following Terraform configuration.

1
2
3
output "answer" {
  value = 42
}

You can read that output from a different stack by using the terraform_remote_state data source.

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
data "terraform_remote_state" "deepthought" {
  backend = "remote"

  config = {
    hostname     = "spacelift.io" # (1)
    organization = "spacecorp"    # (2)

    workspaces = {
      name = "deep-thought"       # (3)
    }
  }
}

output "ultimate_answer" {
  value = data.terraform_remote_state.deepthought.outputs.answer
}
  1. The hostname of the Spacelift system.
  2. The name of the account.
  3. The ID of the stack you wish to retrieve outputs from.

Offline state accessΒ»

Given an account called spacecorp, and a stack named deep-thought, having the following Terraform configuration.

1
2
3
output "answer" {
  value = 42
}

Before you will be able to access the state of the stack, you need to retrieve an authentication token for spacelift.io.

1
terraform login spacelift.io

Next, you need a remote backend configuration.

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
terraform {
  backend "remote" {
    hostname     = "spacelift.io" # (1)
    organization = "spacecorp"    # (2)

    workspaces {
      name = "deep-thought"       # (3)
    }
  }
}
  1. The hostname of the Spacelift system.
  2. The name of the account.
  3. The ID of the stack you wish to retrieve outputs from.

Finally, you can download the state of the stack.

1
terraform state pull > terraform.tfstate