-
-
Notifications
You must be signed in to change notification settings - Fork 1k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add --terragrunt-queue-include-units-reading
flag to Terragrunt
#3418
Comments
I love the functionality here, but can we use a more intuitive flag name than Here are some random ideas:
|
Take a look at the rules being proposed under Technical Details --> Document Design Philosophy --> Rules. The name of this flag is trying to do the following:
This might feel more intuitive in the context of the
This will make all the flags that can impact the queue of Units that are going to be |
I cut a PoC alpha release here. It adds a hook to In addition, during conversations with the team, we discovered that there's advantage to being able to explicitly mark files as being read in this fashion, as they may be read by something hard to detect (e.g. read within a bash script, within OpenTofu or in an HCL function not directly defined in the Terragrunt codebase). For that reason, an additional HCL function will be introduced, |
Summary
Add a new flag that works similarly to the terragrunt-modules-that-include flag, but instead adds Units (terragrunt.hcl files) to the queue of units that will be added to the Directed Acyclic Graph (DAG), if they read a file using a Terragrunt function.
NOTE: This RFC will use the relatively new language of "Unit" to refer to the directory where a
terragrunt.hcl
file leaf node is. See Stacks for more info. This language will become standard eventually.Motivation
Users have asked for similar functionality to that which is available with terragrunt-modules-that-include, but specifically to handle things like updated JSON files and updated SOPS encrypted files to determine which Units need to be added to the DAG.
Right now, the best solution that users have available to them is to manually stitch together the list of Units that read external files by manually parsing
terragrunt.hcl
files. This can be error prone, however, as users have to work around issues like relative paths, and interpolated HCL functions changing which file is read.Proposal
Introduce a hook that is used in every HCL function Terragrunt supports which reads a file to update a central mapping of files being read to the Units that read them.
Also introduce the flag
--terragrunt-queue-include-units-reading
that can be used inrun-all
commands to include Units that match up with the central mapping derived from the hook in HCL functions reading files.Technical Details
Functions that definitely need the hook:
read_terragrunt_config
sops_decrypt_file
read_tfvars_file
Over time, more functions can support this behavior.
Whenever any of these HCL functions are called, they will update the shared mapping of files to Units. As part of the
run-all
command, all Units in a given working directory are read and parsed, those parses should result in the mapping being updated, which will change how the queue is updated accordingly.Press Release
Terragrunt can now watch for changes in external files!
Using the new
--terragrunt-queue-include-units-reading
flag, users can now drive updates to any Unit that reads from a file using an HCL function. This allows for CI/CD workflows to intelligently handle updates to files in formats other than HCL, like YML or JSON, including encrypted files using SOPS.Drawbacks
This might result in a performance penalty for functions that read files.
We have to be careful introducing functionality like this, as functions often be repeatedly called during parsing in a way that degrades performance. Smart memoization, etc can reduce the impact of this.
Alternatives
terragrunt.hcl
files for references to files that read files in HCL functions.Migration Strategy
No response
Unresolved Questions
No response
References
No response
Proof of Concept Pull Request
No response
Support Level
Customer Name
No response
The text was updated successfully, but these errors were encountered: