Skip to content

Latest commit

 

History

History
62 lines (51 loc) · 2.73 KB

README.rst

File metadata and controls

62 lines (51 loc) · 2.73 KB

tfe-dependency-runner

Listens for Terraform Enterprise (TFE) build notifications and initiates dependent workspace runs

This function is designed to be attached to an AWS API Gateway web-hook receiver whose endpoint is registered for workspace run notifications.

It will only execute on run:completed notifications. When one of these is received:

  1. We get the current state version
  2. We retrieve the actual state file
  3. We parse the state file, looking for any declared terraform_remote_state objects
  4. We retrieve the organization/workspace for any terraform_remote_state that are of type atlas
  5. We register the found dependencies for the current workspace
  6. If there are any TFE workspaces that depend upon the notified workspace, we create runs
  7. If we are not longer able to get the workspace_id for an organization/workspace, we remove the organization/workspace from the dependencies table

Required AWS Resources

API Gateway
Provides Lambda Proxy events to this function
DynamoDB Table
Where the dependency map is stored. Must have a partition key called orgainzation and a range key called workspace

Required Permissions

  • dynamodb:DeleteItem
  • dynamodb:PutItem
  • dynamodb:Scan

Environment Variables

API_TOKEN (Required)
The TFE API Token. It must be either a user token or a team token. It cannot be an organization token.
WORKSPACE_DEPENDENCIES_TABLE (Required)
The AWS DynamoDB table to store the workspace dependencies in.
NOTIFICATION_TOKEN (Optional, Required if set in TFE)
The token set on the TFE notification setup. TFE recommends that you use tokens on notification in order to allow for HMAC validation of those notifications.

Known Limitations

  • If a run fails to create, there is no retry. Currently we only warn in the logs.
  • Recursive remote state dependencies will cause endless runs if the apply is automatic. You should probably never do either of these things...
  • Not compatible with TF versions < 0.12

License: APL2