Skip to main content
  1. Docs
  2. Secrets & Configuration
  3. Providers
  4. IaC
  5. terraform-state

terraform-state

    The terraform-state provider enables you to read outputs from Terraform state files stored in S3 or Terraform Cloud. By importing those outputs into your environment, you can seamlessly consume Terraform-managed infrastructure as inputs to your Pulumi programs — referencing values such as VPC IDs, subnet IDs, and cluster endpoints directly, without copying them by hand or rewriting your Terraform in Pulumi. This bridges the two tools, so you can adopt Pulumi incrementally alongside an existing Terraform footprint.

    Imported outputs are available under the outputs key (for example, ${terraform.outputs.vpc_id}) and can be mapped to either of the following:

    • pulumiConfig — to consume them as stack configuration (that is, as inputs to your Pulumi program).
    • environmentVariables — to expose them as environment variables for the Pulumi CLI, a downstream Terraform run, or any other tooling.

    Example

    S3 backend

    values:
      terraform:
        fn::open::terraform-state:
          backend:
            s3:
              login:
                fn::open::aws-login:
                  oidc:
                    roleArn: arn:aws:iam::123456789012:role/esc-oidc
                    sessionName: pulumi-environments-session
              bucket: my-terraform-state-bucket
              key: path/to/terraform.tfstate
              region: us-west-2
      pulumiConfig:
        # Consume the Terraform outputs as Pulumi stack configuration (inputs to your program)
        vpcId: ${terraform.outputs.vpc_id}
        subnetIds: ${terraform.outputs.subnet_ids}
      environmentVariables:
        # Expose the outputs as TF_VAR_* environment variables to feed a downstream Terraform run
        TF_VAR_vpc_id: ${terraform.outputs.vpc_id}
    

    Terraform Cloud backend

    values:
      terraform:
        fn::open::terraform-state:
          backend:
            remote:
              organization: my-terraform-org
              workspace: my-workspace
              token:
                fn::secret: tfc-token-value
      pulumiConfig:
        # Consume the Terraform outputs as Pulumi stack configuration (inputs to your program)
        vpcId: ${terraform.outputs.vpc_id}
        subnetIds: ${terraform.outputs.subnet_ids}
      environmentVariables:
        # Expose the outputs as TF_VAR_* environment variables to feed a downstream Terraform run
        TF_VAR_vpc_id: ${terraform.outputs.vpc_id}
    

    Inputs

    PropertyTypeDescription
    backendBackendConfiguration for the Terraform state backend (S3 or remote).

    Backend

    The backend property must contain exactly one of the following:

    S3

    PropertyTypeDescription
    loginaws-loginThe credentials to use to access the state file.
    bucketstringThe S3 bucket name containing the state file.
    keystringThe S3 object key for the state file.
    regionstringThe AWS region where the bucket is located.

    Remote

    PropertyTypeDescription
    hostnamestring[Optional] - The remote backend hostname to connect to. Defaults to app.terraform.io.
    organizationstringThe name of the organization containing the targeted workspace.
    workspacestringThe name of the remote workspace.
    tokenstringThe token used to authenticate with the remote backend.

    Outputs

    PropertyTypeDescription
    outputsobjectA map of all outputs from the Terraform state. Any output marked as sensitive in the terraform state will be secret.