terraform: configure terraform cloud
This commit is contained in:
parent
6895b4b909
commit
d821d658d8
3 changed files with 54 additions and 1 deletions
|
@ -8,9 +8,10 @@ mkShellNoCC {
|
||||||
(terraform.withPlugins (
|
(terraform.withPlugins (
|
||||||
p: [
|
p: [
|
||||||
p.cloudflare
|
p.cloudflare
|
||||||
p.null
|
|
||||||
p.external
|
p.external
|
||||||
p.hydra
|
p.hydra
|
||||||
|
p.null
|
||||||
|
p.tfe
|
||||||
]
|
]
|
||||||
))
|
))
|
||||||
jq
|
jq
|
||||||
|
|
|
@ -11,6 +11,9 @@ terraform {
|
||||||
hydra = {
|
hydra = {
|
||||||
source = "DeterminateSystems/hydra"
|
source = "DeterminateSystems/hydra"
|
||||||
}
|
}
|
||||||
|
tfe = {
|
||||||
|
source = "hashicorp/tfe"
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
49
terraform/terraform_cloud.tf
Normal file
49
terraform/terraform_cloud.tf
Normal file
|
@ -0,0 +1,49 @@
|
||||||
|
# Configure Terraform Cloud, with Terraform
|
||||||
|
#
|
||||||
|
# Terraform Cloud is used only for one thing: to store the terraform state.
|
||||||
|
#
|
||||||
|
locals {
|
||||||
|
# FIXME: add all the admins of the org
|
||||||
|
# NOTE: there is a limit of 5 members in the free plan
|
||||||
|
tfe_owners = {
|
||||||
|
zimbatm = "zimbatm@zimbatm.com"
|
||||||
|
}
|
||||||
|
|
||||||
|
tfe_org = tfe_organization.nix-community.name
|
||||||
|
}
|
||||||
|
|
||||||
|
# Org setup
|
||||||
|
resource "tfe_organization" "nix-community" {
|
||||||
|
name = "nix-community"
|
||||||
|
# FIXME: host our own email
|
||||||
|
email = "nix-community@numtide.com"
|
||||||
|
}
|
||||||
|
|
||||||
|
# Members setup
|
||||||
|
|
||||||
|
resource "tfe_team" "owners" {
|
||||||
|
name = "owners"
|
||||||
|
organization = "nix-community"
|
||||||
|
}
|
||||||
|
|
||||||
|
resource "tfe_organization_membership" "owners" {
|
||||||
|
for_each = local.tfe_owners
|
||||||
|
organization = local.tfe_org
|
||||||
|
email = each.value
|
||||||
|
}
|
||||||
|
|
||||||
|
resource "tfe_team_organization_member" "owners" {
|
||||||
|
for_each = local.tfe_owners
|
||||||
|
team_id = tfe_team.owners.id
|
||||||
|
organization_membership_id = tfe_organization_membership.owners[each.key].id
|
||||||
|
}
|
||||||
|
|
||||||
|
# Workspaces setup
|
||||||
|
|
||||||
|
# For new we only have one workspace that contains everything
|
||||||
|
resource "tfe_workspace" "nix-community" {
|
||||||
|
name = "nix-community"
|
||||||
|
organization = local.tfe_org
|
||||||
|
description = ""
|
||||||
|
execution_mode = "local" # only use it to hold state
|
||||||
|
}
|
Loading…
Add table
Add a link
Reference in a new issue