#terragrunt (2020-01)
Terragrunt discussions
Archive: https://archive.sweetops.com/terragrunt/
2020-01-01
2020-01-09
data:image/s3,"s3://crabby-images/a25bb/a25bbe7dc97c91f827da346fc9f35c1c4c6cf230" alt="Milos Backonja avatar"
guys how to safely migrate state from one s3 bucket to another with terragrunt ?
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
First of all you can make a backup of your state by copying it elsewhere, this way you don’t get sweaty hands. Secondly, I think that the moment you change the backend in terragrunt, terragrunt/terraform will take care of the move.
data:image/s3,"s3://crabby-images/a25bb/a25bbe7dc97c91f827da346fc9f35c1c4c6cf230" alt="Milos Backonja avatar"
Thanks Maarten, well I synced s3 buckets and changed backend config after that. It looks ok now :)
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
Ive got a terraform module that creates resources in two different aws accounts. I handle this by doing the following:
provider "aws" {
region = "us-west-2"
profile = "profile1"
}
provider "aws" {
region = "us-west-2"
profile = "profile2"
alias = "digi"
}
And in the module itself, the different provider is picked up like this:
resource "aws_route53_record" "dig_ns" {
provider = aws.digi
I’m trying to utilize terragrunt to deploy many modules. This becomes difficult since the above method no longer works, has anyone encountered this? If so, how have you got around this. I dont think Terragrunt supports multiple providers like this
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
I dont quite understand how tg can use different providers/regions(if at all )
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
@Brij S
few comments for you 1 is , route53 is not region dependent so if that’s the only use-case you don’t have to worry about it.
-
I try to make modules which are used for a single region, if I need them to be applied in a different region it will be a different apply
-
Using a structure like the following can help you with that:
├── envs
│ ├── aws
│ │ ├── dev
│ │ │ ├── eu-central-1
│ │ │ │ ├── applications
│ │ │ │ ├── infra
│ │ │ ├── eu-west-1
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
@maarten, yes r53 is not region specific, but it is account specific. I have a unique setup where I need to create a new zone and then take its NS records and insert them into a different zone in a different account. Hence the multiple providers
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
all of my modules are quite generic already like you mentioned. With TG - it seems like i can only use on provider so if I need to create edge acm certs in us-east-1 and all other resources in us-west-2 then it becomes a mystery
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
@Brij S could you delegate the zone to the other account instead ?
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
unfortunately, no
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
new zone in new acccount with NS records of said zone in old account
data:image/s3,"s3://crabby-images/3877f/3877fc1c6aed2b7d05b8928560115dabaa0ea513" alt="tamsky avatar"
yes r53 is not region specific, but it is account specific
Adding to the use case list for this is AWS govcloud[1].
govcloud’s Route53 service only allows creating private zones. Account-level delegations across the govcloud/commercial partition line is also not possible.
[1] https://docs.aws.amazon.com/govcloud-us/latest/UserGuide/govcloud-r53.html
Lists the differences for using Amazon Route 53 in the AWS GovCloud (US-West) Region compared to other AWS regions.
data:image/s3,"s3://crabby-images/5b7ba/5b7ba9a71cd30358540badeae2bd2b06b1e5c4e1" alt="slaughtr avatar"
I don’t see why that wouldn’t work, unless maybe you’re on an older version?
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
well, in the .hcl file you dont specify providers of any sort?
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
or any profiles
data:image/s3,"s3://crabby-images/5b7ba/5b7ba9a71cd30358540badeae2bd2b06b1e5c4e1" alt="slaughtr avatar"
True, but terragrunt is just applying terraform. So you should be able to leave your tf files more or less the same
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
hmm, im confused
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
the terragrunt docs mention only leaving .hcl files in the ‘live’ repo
data:image/s3,"s3://crabby-images/5b7ba/5b7ba9a71cd30358540badeae2bd2b06b1e5c4e1" alt="slaughtr avatar"
I have only done some light testing around multiple providers in my TF but TG didn’t seem to mind
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
so if my tg file looked like this
include {
path = find_in_parent_folders()
}
terraform {
source = "git::[email protected]:foo/modules.git//app"
}
inputs = {
zone_name = "domain.com"
comment = "Managed by Terraform"
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
where do you plugin multiple providers
data:image/s3,"s3://crabby-images/5b7ba/5b7ba9a71cd30358540badeae2bd2b06b1e5c4e1" alt="slaughtr avatar"
You put the multiple providers in your .tf files like you would normally
data:image/s3,"s3://crabby-images/5b7ba/5b7ba9a71cd30358540badeae2bd2b06b1e5c4e1" alt="slaughtr avatar"
Terragrunt is just a wrapper for terraform, it doesn’t need all that info
data:image/s3,"s3://crabby-images/5b7ba/5b7ba9a71cd30358540badeae2bd2b06b1e5c4e1" alt="slaughtr avatar"
So if you had [module.tf](http://module.tf)
with multiple providers before, just point TG at it and it should (probably) just work
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
@slaughtr heres my structure
├── global
│ ├── main.tf
│ └── terragrunt.hcl
├── terragrunt.hcl
└── us-east-1
├── main.tf
├── terragrunt.hcl
└── variables.tf
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
this issue arose when, the variables file in the us-east-1 folder wasnt enough to pick up the inputs from the global folder as you helped me with earlier
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
so i decided to do all .hcl, just like the examples in their docs
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
the main.tf in global has an output called zone_id (in the module itself). I setup the hcl file as you assisted me with as follows in the us-east-1 folder:
include {
path = find_in_parent_folders()
}
dependency "global" {
config_path = "../global"
mock_outputs = {
zone_id = "Z3P5QSUBK4POTI"
}
mock_outputs_allowed_terraform_commands = ["plan", "validate"]
}
inputs = {
zone_id = dependency.global.outputs.zone_id
}
then in the variables.tf file i created a var called zone_id
but it just picks up the mock value instead of the real created one
data:image/s3,"s3://crabby-images/5b7ba/5b7ba9a71cd30358540badeae2bd2b06b1e5c4e1" alt="slaughtr avatar"
The format I follow (and I guess I didn’t read/should ahve read more/something) is something like this:
├── module
│ ├── main.tf
│ ├── somecode.js
| └── variables.tf
└── us-east-1
├── terragrunt.hcl
├── module_tg
├── terragrunt.hcl
data:image/s3,"s3://crabby-images/5b7ba/5b7ba9a71cd30358540badeae2bd2b06b1e5c4e1" alt="slaughtr avatar"
Just a side point, so you know you can do it
data:image/s3,"s3://crabby-images/5b7ba/5b7ba9a71cd30358540badeae2bd2b06b1e5c4e1" alt="slaughtr avatar"
Oh if you have a mock value it will use that, you can remove it in production
data:image/s3,"s3://crabby-images/5b7ba/5b7ba9a71cd30358540badeae2bd2b06b1e5c4e1" alt="slaughtr avatar"
There might be a way to say “if not present use mock” but I’m not sure
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
yeah it has the
mock_outputs_allowed_terraform_commands = ["plan", "validate"]
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
but that doesnt work
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
it still picked up mock value when I ran apply-all
data:image/s3,"s3://crabby-images/5b7ba/5b7ba9a71cd30358540badeae2bd2b06b1e5c4e1" alt="slaughtr avatar"
Hmm, I think the -all
commands might follow a slightly different set of rules, don’t quote me on that. I never use them because I find they super conflate everything, and really it’s pointless til you’ve applied each thing individually because TG kinda sucks at dependency resolution
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
so how do you go about applying all the modules in seperate folders?
data:image/s3,"s3://crabby-images/5b7ba/5b7ba9a71cd30358540badeae2bd2b06b1e5c4e1" alt="slaughtr avatar"
I also don’t use mock outputs so I’m not sure what’s going on there. I’d recommend commenting it out for the moment
data:image/s3,"s3://crabby-images/5b7ba/5b7ba9a71cd30358540badeae2bd2b06b1e5c4e1" alt="slaughtr avatar"
I apply each module individually
data:image/s3,"s3://crabby-images/5b7ba/5b7ba9a71cd30358540badeae2bd2b06b1e5c4e1" alt="slaughtr avatar"
Generally I try not to change more than one module at a time anyway
data:image/s3,"s3://crabby-images/5b7ba/5b7ba9a71cd30358540badeae2bd2b06b1e5c4e1" alt="slaughtr avatar"
Back to your original query, though: you have terraform config that has multiple providers that worked in the past with just TF?
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
yes
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
i was trying to convert to using just .hcl, as per the docs
data:image/s3,"s3://crabby-images/5b7ba/5b7ba9a71cd30358540badeae2bd2b06b1e5c4e1" alt="slaughtr avatar"
So if you point at that in your source
and get your inputs and dependencies figured out it should just work
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
how does tg know to pick up credentials for a different provider?
data:image/s3,"s3://crabby-images/5b7ba/5b7ba9a71cd30358540badeae2bd2b06b1e5c4e1" alt="slaughtr avatar"
Can you point me to where in the docs it says that? I’ve not seen that rec before
data:image/s3,"s3://crabby-images/5b7ba/5b7ba9a71cd30358540badeae2bd2b06b1e5c4e1" alt="slaughtr avatar"
TG is just wrapping around terraform, so if terraform knows it you’re good
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
my module, has a resource that explicitly has a provider set for it like this
resource "aws_route53_record" "digital_ns" {
provider = aws.digi
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
in my main.tf file I have two providers, one with an alias of digi
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
however, if there is no tf file and only a .hcl file - how will tg know to use that profile and that alias etc
data:image/s3,"s3://crabby-images/5b7ba/5b7ba9a71cd30358540badeae2bd2b06b1e5c4e1" alt="slaughtr avatar"
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
Learn how to achieve DRY Terraform code and immutable infrastructure.
data:image/s3,"s3://crabby-images/5b7ba/5b7ba9a71cd30358540badeae2bd2b06b1e5c4e1" alt="slaughtr avatar"
Ah ok I think you may have misunderstood.
data:image/s3,"s3://crabby-images/5b7ba/5b7ba9a71cd30358540badeae2bd2b06b1e5c4e1" alt="slaughtr avatar"
In a separate repo, called, for example, live, you define the code for all of your environments, which now consists of just one terragrunt.hcl file per component
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
my modules are in a different repo
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
i am creating a live repo
data:image/s3,"s3://crabby-images/5b7ba/5b7ba9a71cd30358540badeae2bd2b06b1e5c4e1" alt="slaughtr avatar"
So you have your .tf files like normal, you point at them in the .hcl files.
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
like this
terraform {
# Deploy version v0.0.3 in stage
source = "git::[email protected]:foo/modules.git//app?ref=v0.0.3"
}
?
data:image/s3,"s3://crabby-images/5b7ba/5b7ba9a71cd30358540badeae2bd2b06b1e5c4e1" alt="slaughtr avatar"
Yup!
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
no thats not what im getting at
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
I havea module .. like the one you can find on terraform registry
data:image/s3,"s3://crabby-images/5b7ba/5b7ba9a71cd30358540badeae2bd2b06b1e5c4e1" alt="slaughtr avatar"
All TG is doing here is doing inputs/outputs for TF. It doesn’t control your providers or anything.
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
my root .hcl file
remote_state {
backend = "s3"
config = {
bucket = "test-terraform-state-us-west-2"
key = "${path_relative_to_include()}/terraform.tfstate"
region = "us-west-2"
encrypt = true
dynamodb_table = "test-lock-table-us-west-2"
profile = "profile1"
}
}
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
tg wont automatically assume to use profile1 for everything?
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
since all the child .hcl files inhert from this
data:image/s3,"s3://crabby-images/5b7ba/5b7ba9a71cd30358540badeae2bd2b06b1e5c4e1" alt="slaughtr avatar"
It will, yes. But using the provider
block in your tf will work as it used to. Just like tf uses whichever profile you’re using and then follows the directive of the provider block
data:image/s3,"s3://crabby-images/5b7ba/5b7ba9a71cd30358540badeae2bd2b06b1e5c4e1" alt="slaughtr avatar"
If you have a child .hcl that shouldn’t use profile1 at all you can not use the path = find_in_parent_folders()
bit
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
but then it wont use the remote state bucket?
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
also, let me try this out now, with the changes weve discussed. I think i’ll run into a problem with passing the output though - lets see
data:image/s3,"s3://crabby-images/5b7ba/5b7ba9a71cd30358540badeae2bd2b06b1e5c4e1" alt="slaughtr avatar"
Here’s my root terragrunt.hcl
using two accounts, if that helps
data:image/s3,"s3://crabby-images/5b7ba/5b7ba9a71cd30358540badeae2bd2b06b1e5c4e1" alt="slaughtr avatar"
Though I assume you’re not looking at dev vs prod necessarily, so that might not be the most helpful
data:image/s3,"s3://crabby-images/5b7ba/5b7ba9a71cd30358540badeae2bd2b06b1e5c4e1" alt="slaughtr avatar"
But it gives you an idea of conditionally changing profiles at that level
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
ok let me see
data:image/s3,"s3://crabby-images/5b7ba/5b7ba9a71cd30358540badeae2bd2b06b1e5c4e1" alt="slaughtr avatar"
To be clear I’m just doing dev and prod and applying the same resources to them conditionally based on an env var (which is sent in via an alias, I have tg
and tgprod
to be safe)
data:image/s3,"s3://crabby-images/5b7ba/5b7ba9a71cd30358540badeae2bd2b06b1e5c4e1" alt="slaughtr avatar"
TG can be a bit to wrap your head around, especially since 0.19 introduced the .hcl
files
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
yeah its a bit confusing
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
even going from TF -> TG
data:image/s3,"s3://crabby-images/5b7ba/5b7ba9a71cd30358540badeae2bd2b06b1e5c4e1" alt="slaughtr avatar"
Pre 0.19 it was much less confusing. Though now that I’ve got it all setup I much prefer the current method.
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
true, let me give this a go - i’ll message back on this thread tomorrow if i need any more assistance
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
thank you for all the help by the way!! much appreciated
data:image/s3,"s3://crabby-images/5b7ba/5b7ba9a71cd30358540badeae2bd2b06b1e5c4e1" alt="slaughtr avatar"
No problem, I know what a nightmare it can be trying to migrate. Hopefully it does the thing and you can focus on more fun stuff
data:image/s3,"s3://crabby-images/5b7ba/5b7ba9a71cd30358540badeae2bd2b06b1e5c4e1" alt="slaughtr avatar"
Feel free to throw a message at me if you still need help!
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
didnt work
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
its complaining about multiple providers with the same name
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
Error: Duplicate provider configuration
on provider.tf line 1:
1: provider "aws" {
A provider configuration for "aws" with alias "digital" was already given at
main.tf:6,1-15. Each configuration for the same provider must have a distinct
alias.
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
even though its only once..
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
.
├── global
│ ├── main.tf
│ └── terragrunt.hcl
├── terragrunt.hcl
└── us-east-1
├── main.tf
├── terragrunt.hcl
└── variables.tf
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
main.tf inside global is
provider "aws" {
region = "us-west-2"
profile = "profile1"
}
provider "aws" {
region = "us-west-2"
profile = "profile2"
alias = "digital"
}
terraform {
backend "s3" {}
}
data:image/s3,"s3://crabby-images/5b7ba/5b7ba9a71cd30358540badeae2bd2b06b1e5c4e1" alt="slaughtr avatar"
Hmm that’s weird, that should work afaik.
data:image/s3,"s3://crabby-images/5b7ba/5b7ba9a71cd30358540badeae2bd2b06b1e5c4e1" alt="slaughtr avatar"
One thing to look out for with TG is the terragrunt get -update
command doesn’t seem to work very well in 0.19, so when you make changes you often need to run a command to delete cached files:
alias tg-cache-list='find . -type d -name ".terragrunt-cache"'
alias tg-cache-del='find . -type d -name ".terragrunt-cache" -prune -exec rm -rf {} \;'
That’s from the tg docs somewhere. Catches me on occasion. There’s a chance something is cached
data:image/s3,"s3://crabby-images/5b7ba/5b7ba9a71cd30358540badeae2bd2b06b1e5c4e1" alt="slaughtr avatar"
Oh, uh on [provider.tf](http://provider.tf) line 1:
in your error…do you have a provider.tf file? that would cause problems if it’s also got a non-aliased provider in it
data:image/s3,"s3://crabby-images/97ef1/97ef18fefa665bee36840be5e2c259ae88e84174" alt="getSurreal avatar"
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
sorry about that
2020-01-10
2020-01-11
2020-01-17
data:image/s3,"s3://crabby-images/a25bb/a25bbe7dc97c91f827da346fc9f35c1c4c6cf230" alt="Milos Backonja avatar"
Hi Guys, do you know if I can use terragrunt command in before hooks?
before_hook "test" {
commands = ["init"]
execute = ["terragrunt", "apply", "-target=null_resource.rule", "-auto-approve"]
}
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
Isn’t that going to cause recursion issues?
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
depends on when the state is locked… i think it would work. does seem fragile though. but could be an interesting approach to dealing with the “count” cannot be computed style of error
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
would at least need to disable autoinit in the hook to avoid recursion, --terragrunt-no-auto-init
data:image/s3,"s3://crabby-images/a25bb/a25bbe7dc97c91f827da346fc9f35c1c4c6cf230" alt="Milos Backonja avatar"
Thanks guys, eventually I dropped approach with null resource and use External Data Source
2020-01-22
data:image/s3,"s3://crabby-images/8594a/8594a69461557911b7f3ff219888e8c20a10b156" alt="Chase Ward avatar"
@Chase Ward has joined the channel
2020-01-23
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
I’m having an issue where terragrunt ignores a providers assume role/iam role block when assuming a role and using the creds from that as env vars - has anyone dealt with this?
2020-01-24
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
@Brij S post what you have/what you problem is
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
I assume a role using aws-okta cli and use the env vars from that. I have a provider as follows
provider "aws" {
region = "us-west-2"
alias = "dig"
assume_role {
role_arn = "arn:aws:iam::xxxxxxxxxx:role/tf"
}
}
but this provider gets ignored and I get the following error in the cli:
Error: AccessDenied: User: arn:aws:sts::xxxxxxxxxxxx:assumed-role/acount-name-ReadWrite/user is not authorized to access this resource
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
At what point in the workflow is that happening? Are you using remote tfstate in s3? How is that configured?
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
Have had similar but need exact info.
2020-01-25
data:image/s3,"s3://crabby-images/039ba/039baa410ee95952c1abce9b6daf4cb43d62f76f" alt="Adrian avatar"
I have some extra var files defined and want to use some variables from this files in input for example region in container task definition, is this possible?
data:image/s3,"s3://crabby-images/67e68/67e683361c271c4e26e156c64a1a2d27db2b053d" alt="David avatar"
It is! What have you tried so far?
data:image/s3,"s3://crabby-images/039ba/039baa410ee95952c1abce9b6daf4cb43d62f76f" alt="Adrian avatar"
I found this thread https://github.com/gruntwork-io/terragrunt/issues/752
I've been reading documentation for terraform 0.12 in regards to handling env vars, and https://www.terraform.io/docs/configuration/variables.html states that: Some special rules apply to the -…
data:image/s3,"s3://crabby-images/039ba/039baa410ee95952c1abce9b6daf4cb43d62f76f" alt="Adrian avatar"
this is what i need
# stage/frontend-app/terragrunt.hcl
terraform {
source = "..."
}
# Include all settings from the root terragrunt.hcl file
include {
path = "${find_in_parent_folders()}"
}
inputs = {
aws_region = get_input("aws_region")
remote_state_bucket = get_input("remote_state_bucket")
instance_type = "t2.micro"
instance_count = 10
}
data:image/s3,"s3://crabby-images/039ba/039baa410ee95952c1abce9b6daf4cb43d62f76f" alt="Adrian avatar"
aws_region is defined in tfvars which is included in optional_var_files
data:image/s3,"s3://crabby-images/039ba/039baa410ee95952c1abce9b6daf4cb43d62f76f" alt="Adrian avatar"
how can I achieve this?
data:image/s3,"s3://crabby-images/039ba/039baa410ee95952c1abce9b6daf4cb43d62f76f" alt="Adrian avatar"
aws_region = get_input("aws_region")
2020-01-26
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
get_input isn’t a valid function.