Skip to content

Latest commit

 

History

History
104 lines (92 loc) · 3.85 KB

README.md

File metadata and controls

104 lines (92 loc) · 3.85 KB

aft-bootstrap

Purpose: Lay down the base resources for aft-framework

graph LR

    subgraph tf-example-org
        A[aft-bootstrap]
    end

    subgraph github-aft
        direction LR
        K[aft-framework]
        L[aft-account-customizations]
        M[aft-account-provisioning-customizations]
        N[aft-global-customizations]
        O[aft-account-requests]
    end

    subgraph tf-example-org-aft
        B[aft-framework]
        G[ct-aft-account-requests]
        H["ct-aft-account-provisioning-customizations *unused*"]
        subgraph global-customizations [global-customizations *unused*]
            I[123456789012-global-customizations]
        end
        subgraph account-customizations
            J[123456789012-account-customizations]
        end
    end

    subgraph aws-org
        Q[sandbox-123456789012]
    end

    subgraph tf-example-org-workloads
        C[sandbox-123456789012]
    end
    
    subgraph github-workloads
        P[sandbox-123456789012]
    end

    A --creates org, teams, aft-framework workspace--> tf-example-org-aft
    A --creates org, teams--> tf-example-org-workloads
    A --creates repos\nfrom templates--> github-aft
    B --> G
    B --> H
    G --creates\nworkspace--> I
    G --creates\nworkspace--> J
    J --creates\nworkspace--> C
    github-aft --repos link\nto workspaces--> tf-example-org-aft
    P --repo links\nto workspace--> C
    J --creates\nrepoo--> P
    G --creates\naccount--> Q
    J --creates OIDC\npolicies and role--> Q
    C --deploys to AWS account\nwith OIDC--> Q
Loading
  1. Choose an email address for AFT
  2. Create AFT HashiCorp user with that email
    1. Verify the email address
  3. Create AFT GitHub user with that email
    1. Verify the email address
  4. Create a repo called aft-bootstrap, using this repository as the template
  5. Log in to Terraform Cloud with an owner account
  6. If you haven't already, link Terraform to GitHub via personal oauth
  7. Create a project called "AFT Bootstrap"
  8. Create a workspace called aft-bootstrap
    1. Link the aft-bootstrap workspace to the new repo
  9. Populate variables
    1. aft_email
      1. The email from step 2
    2. github_token
      1. This token can be attached to either the AFT GitHub user, or another account within the same organization
      2. The user that the token is attached to must have the ability to create repositories
      3. The token must have permission to create repositories
      4. Set token expiration to 1 hour
    3. tfe_token
      1. The user that this token attached to must be a member of the Terraform Organization's "owner" team
      2. Set token expiration to 1 hour
  10. Plan and Apply
  11. Accept the invite to the Terraform organization in the AFT Hashicorp account (via email)

Actions Taken

  1. 5 GitHub repositories will be created in the same organization that the aft-bootstrap repository resides. These repositories will use robbycuenot/template-* repositories as a baseline, unless otherwise specified.
    • aft-account-customizations
    • aft-account-provisioning-customizations
    • aft-account-requests
    • aft-framework
    • aft-global-requests
  2. The AFT Terraform user will be added to the organization, based off of aft_email
  3. A new Terraform team called "aft-admins" will be created
  4. The AFT Terraform user will be added to this team
  5. A team token will be created on this team
  6. A workspace called "aft-framework" will be created in the default project
    1. This workspace will be linked to the newly created "aft-framework" repository
    2. The team token will be stored as a secret on this workspace
    3. The repository names will be stored on this workspace as variables
    4. Empty variables for AWS Account IDs and AWS Credentials will be created
  7. A new project will be created called "Workspaces"
  8. The aft-admins team will be granted admin access to the default and Workspaces projects