#terraform (2021-09)
Discussions related to Terraform or Terraform Modules
Archive: https://archive.sweetops.com/terraform/
2021-09-01
data:image/s3,"s3://crabby-images/daf2f/daf2fea5b8c6f0023ce9fca916352ee62c98b3d1" alt="Michael Dizon avatar"
having a weird issue setting up sso
with iam-primary-roles
, after authenticating with google workspace, leaap opens the aws console. i’m not sure where the misconfiguration is, but my user isn’t getting the arn:aws:iam::XXXXXXXXXXXX:role/xyz-gbl-identity-admin
role assignment. i’m also not sure if i’m supposed to use the idp from the root account or from the identity account. any help is appreciated!
data:image/s3,"s3://crabby-images/0fd98/0fd985ce0b5932d9e94bf208cb4bf974fa5a11c2" alt="Andrea Cavagna avatar"
Hi are you using AWS Single Sign-on or a federated role with Google workspace?
data:image/s3,"s3://crabby-images/daf2f/daf2fea5b8c6f0023ce9fca916352ee62c98b3d1" alt="Michael Dizon avatar"
a federated role w/ google
data:image/s3,"s3://crabby-images/0fd98/0fd985ce0b5932d9e94bf208cb4bf974fa5a11c2" alt="Andrea Cavagna avatar"
This is the doc about your use case:
https://docs.leapp.cloud/use-cases/aws_iam_role/#aws-iam-federated-role
required items are:
• session Alias: a fancy name
• roleArn: the role arn you need to federate access to
• Identity Provider arn: It’s in the IAM service under Identity Providers
• SAML Url: the url of the SAML app connected to google workspace
Leapp is a tool for developers to manage, secure, and gain access to any cloud. From setting up your access data to activating a session, Leapp can help manage the underlying assets to let you use your provider CLI or SDK seamlessy.
data:image/s3,"s3://crabby-images/daf2f/daf2fea5b8c6f0023ce9fca916352ee62c98b3d1" alt="Michael Dizon avatar"
data:image/s3,"s3://crabby-images/e6209/e6209fb441ae1a71cc9575744231254abff00850" alt="OliverS avatar"
On the topic of version tracking of iac, such that only resources in plan get new tag, I found, amazingly, it should be possible to do with https://registry.terraform.io/providers/hashicorp/aws/latest/docs/guides/resource-tagging#ignoring-changes-in-all-resources. I’m going to try this:
locals {
iac_version = ...get git short hash...
}
provider "aws" {
...
default_tags {
tags = {
IAC_Version = local.iac_version
}
}
ignore_tags {
keys = ["IAC_Version"]
}
}
data:image/s3,"s3://crabby-images/99f14/99f142c769556c4d75482d90487388acdad54bf3" alt="cool-doge"
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
fascinating!
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
ok, please report back.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
I’ve struggled to see a use-case for provider default tags b/c we use null-label and tag all of our resources explicitly.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
but I would like to use this if it works in our root modules.
data:image/s3,"s3://crabby-images/62ea3/62ea3a0f57be2a1b9349cb1d798270aab599c544" alt="Alex Jurkiewicz avatar"
You can use a var for this, but not a data source or resource. Because provider is instantiated before any resources or data sources run
data:image/s3,"s3://crabby-images/62ea3/62ea3a0f57be2a1b9349cb1d798270aab599c544" alt="Alex Jurkiewicz avatar"
It’s a nice idea though. I wanted to use Yor for this, but found it quite buggy. This approach would get you 80% of the way for 5% of the effort
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
provider default_tags are kinda nice as aws and the aws provider add support for tagging more types of resources… you can at least get the default tags on those resources without an update to the module, which can also serve as a notification that, hey, the module needs an update
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
but the current implementation of default_tags leaves a bit to be desired, between errors on duplicate tags and persistent diffs
data:image/s3,"s3://crabby-images/62ea3/62ea3a0f57be2a1b9349cb1d798270aab599c544" alt="Alex Jurkiewicz avatar"
Thanks for this idea Oliver. I replaced our complex WIP integration of Yor with something much simpler. The Terraform CD platform we use (Spacelift) provides a bunch of variables automatically, so just have to take advantage of them:
provider "aws" {
default_tags {
tags = {
iac_repo = var.spacelift_repository
iac_path = var.spacelift_project_root
iac_commit = var.spacelift_commit_sha
iac_branch = var.spacelift_commit_branch
}
}
}
variable "spacelift_repository" {
type = string
description = "Auto-computed by Spacelift."
}
variable "spacelift_project_root" {
type = string
description = "Auto-computed by Spacelift."
}
variable "spacelift_commit_sha" {
type = string
description = "Auto-computed by Spacelift."
}
variable "spacelift_commit_branch" {
type = string
description = "Auto-computed by Spacelift."
}
data:image/s3,"s3://crabby-images/62ea3/62ea3a0f57be2a1b9349cb1d798270aab599c544" alt="Alex Jurkiewicz avatar"
Correction to the above. Having every update to any resource cause every resource to get modified in the plan was very annoying. We dropped iac_commit
data:image/s3,"s3://crabby-images/e6209/e6209fb441ae1a71cc9575744231254abff00850" alt="OliverS avatar"
@Alex Jurkiewicz @Erik Osterman (Cloud Posse) you forgot to use ignore_tags
so obviously you get everything modified, that’s what I explained during the office hours. Ignore-tags will configure the provider to ignore the tag when determining *which* resources to update. Only resources that need updating for some other reason will get the new value of the tag. Look at my original example. It has it.
data:image/s3,"s3://crabby-images/62ea3/62ea3a0f57be2a1b9349cb1d798270aab599c544" alt="Alex Jurkiewicz avatar"
i saw that, but it seemed a little magic for me
data:image/s3,"s3://crabby-images/62ea3/62ea3a0f57be2a1b9349cb1d798270aab599c544" alt="Alex Jurkiewicz avatar"
very clever idea tho
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Ignore-tags will configure the provider to ignore the tag when determining *which* resources to update. Only resources that need updating for some other reason will get the new value of the tag.
now i get it. yes, clever indeed.
2021-09-02
data:image/s3,"s3://crabby-images/44902/449029945fc1a4b20fc4380407df7a1de709e0f8" alt="curious deviant avatar"
Hello !
I am maintaining state in S3 and using DynamoDB for state locking. I had to make a manual change to the state file. I successfully uploaded the updated state file. But running any tf
command errors out now due to the md5
digest of the new uploaded file not matching the entry in the DynamoDb table. Looks like the solution is to update the digest manually in the table corresponding to the backend entry. Just wanted to be sure that there isn’t indeed another way to have terraform regenerate/repopulate DynamoDb with the updated md5
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
easy button is to just delete the item from the dynamodb and let terraform auto-generate it
data:image/s3,"s3://crabby-images/78701/78701e63b3ea513290fca8a066c55cba3d3cb90b" alt="this"
data:image/s3,"s3://crabby-images/44902/449029945fc1a4b20fc4380407df7a1de709e0f8" alt="curious deviant avatar"
data:image/s3,"s3://crabby-images/ec353/ec3535e108fbc268969a94f899595cdc6b30d8f4" alt="Tom Vaughan avatar"
I am using the tfstate-backend module and noticed some add behavior. This is only when using a single s3 bucket to hold multiple state files. For example, bucket is named tf-state and state file for VPC would be in tf-state/vpc, RDS state file would be in tf-state/rds. The issue is the s3 bucket tag Name gets updated to whatever is set in the module name parameter. What ends up happening is when VPC is created the Name tag would be set as vpc but when RDS is created the tag is updated to rds. This may be by design but is there any way to override this and explicitly set the tag value to something else other than what is set as name in the module?
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
Can you override it using tags input var?
data:image/s3,"s3://crabby-images/ec353/ec3535e108fbc268969a94f899595cdc6b30d8f4" alt="Tom Vaughan avatar"
@RB Yes, but it also updates the dynamoDB tag name. Is there any way to limit this to only the s3 bucket?
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
Ah no i don’t believe so. You’d have to submit a pr to tag resources differently
data:image/s3,"s3://crabby-images/ec353/ec3535e108fbc268969a94f899595cdc6b30d8f4" alt="Tom Vaughan avatar"
OK, thanks!
2021-09-03
data:image/s3,"s3://crabby-images/f3462/f34620b0c624b9c1fc64003cc7b50d8290cdcff3" alt="AugustasV avatar"
I would like to use aws_lb data file arn_suffix, but receive this error aws_lb | Data Sources | hashicorp/aws | Terraform Registry I could see that option in resource atributes aws_lb | Resources | hashicorp/aws | Terraform Registry
Error: Value for unconfigurable attribute
on ../../modules/deployment/data_aws_lb.tf line 3, in data "aws_lb" "lb":
3: arn_suffix = var.arn_suffix
Can't configure a value for "arn_suffix": its value will be decided
automatically based on the result of applying this configuration.
data:image/s3,"s3://crabby-images/6bcb5/6bcb53303b5e7bc88ad648e0e77395748e33de6e" alt="Markus Muehlberger avatar"
Only values in Argument Reference can be supplied. Values in Attributes Reference are available to read only from the resource and can’t be set.
data:image/s3,"s3://crabby-images/840f2/840f20f95264f61befe3a4f5d9f7a85f08f3726c" alt="Release notes from terraform avatar"
v1.0.6 1.0.6 (September 03, 2021) ENHANCEMENTS: backend/s3: Improve SSO handling and add new endpoints in the AWS SDK (#29017) BUG FIXES: cli: Suppress confirmation prompt when initializing with the -force-copy flag and migrating state between multiple workspaces. (<a href=”https://github.com/hashicorp/terraform/issues/29438“…
AWS SSO is used in many organizations to authenticate users for access to their AWS accounts. It's the same scale organizations that would very likely also use Terraform to manage their infrast…
The -force-copy flag to init should automatically migrate state. Previously this was not applied to one case: when migrating from a backend with multiple workspaces to another backend supporting mu…
data:image/s3,"s3://crabby-images/fcdc0/fcdc082ca5c426ae7a83f63c34dd4cae258c8b47" alt="Steve Wade (swade1987) avatar"
does anyone know a good module for AWS budgets before I created my own?
data:image/s3,"s3://crabby-images/4046c/4046c9a66489ed9e71b43297bcec3a8d14cc2a90" alt="Mohamed Habib avatar"
Hi guys recently I’ve been thinking of ways to make my terraform code DRY within a project, and avoid having to wire outputs from some modules to other modules. I came up with a pattern similar to “dependency injection” using terraform data blocks. Keen to hear your thoughts on this? And also curious how do folks organise their large terraform codebases? https://github.com/diggerhq/infragenie/
decompose your terraform with dependency injection - GitHub - diggerhq/infragenie: decompose your terraform with dependency injection
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
Nifty
decompose your terraform with dependency injection - GitHub - diggerhq/infragenie: decompose your terraform with dependency injection
2021-09-05
data:image/s3,"s3://crabby-images/9161e/9161edea81ff66e90024c81cbe86097a6a1334da" alt="Rhys Davies avatar"
Hey guys, quick q: When using Terraform to manage your AWS account, how do you or you team deploy containers to ECS? Are you using Terraform to do it or some other process to create/update containerdefinitions?
data:image/s3,"s3://crabby-images/2ba4c/2ba4c862fb6f67f8701004281ba5028106dba6a8" alt="Zach avatar"
The answer is largely “it depends” based on a few factors. Is the service in question considered “part of the infrastructure” such as a log aggregation system? In that case you might manage it entirely by terraform and specify upgrades to image tags and specs via module versioning and variables. If its part of your actual application layer you can do the same thing but this could get in the way of your app teams managing their own deploys, and then you’re using terraform to deploy software; or you can have terraform deploy an initial dummy container definition that uses a sort of ‘hello world’ service while ignoring any further changes to the Task Definition, and allow your CI/CD system to push new definitions directly to ECS.
data:image/s3,"s3://crabby-images/9161e/9161edea81ff66e90024c81cbe86097a6a1334da" alt="Rhys Davies avatar"
Yeah it’s application layer, using Terraform to apply updates by tagging images, and passing the image tags to terraform as var. I had no idea about about https://www.terraform.io/docs/language/meta-arguments/lifecycle.html#ignore_changes if that’s what you are referring to? This seems like a really great solution because with this small change to our ECS services I could hand over the container deploy to something like https://circleci.com/docs/2.0/ecs-ecr/ which seems like an attractive solution.
The meta-arguments in a lifecycle block allow you to customize resource behavior.
How to use CircleCI to deploy to AWS ECS from ECR
data:image/s3,"s3://crabby-images/2ba4c/2ba4c862fb6f67f8701004281ba5028106dba6a8" alt="Zach avatar"
https://registry.terraform.io/modules/trussworks/ecs-service/aws/latest here’s an example module
data:image/s3,"s3://crabby-images/9161e/9161edea81ff66e90024c81cbe86097a6a1334da" alt="Rhys Davies avatar"
Awesome! Thanks so much for your help
data:image/s3,"s3://crabby-images/a4350/a4350f51873f0b62abec1493ddf92e3c2b5b2797" alt="NeuroWinter avatar"
Good morning all!
I have a few quick questions - I think I am doing something wrong because I have not seen anyone else talk about this but here goes! -
I have been trying to use cloudposse/cloudfront-s3-cdn/aws
in github actions to set up the infrastructure for my static site, and I have faced a few issues.
The first was when I was trying to create the cert for the site within main.tf, as per the examples in the README.md but I was getting an error about the zone_id being “”.
I solved that by supplying the cert arn manually.
Now I face the problem of after running terraform and applying the config via github actions, on the next run I get “Error creating S3 bucket: BucketAlreadyOwnedByYou” and it looks like it is trying to create everything again, even though it has been deployed and I can see all the pieces in the aws console. Here is a gist of my main.tf: https://gist.github.com/NeuroWinter/2e1877909ce06bd4ae2719b7d004f721
data:image/s3,"s3://crabby-images/62ea3/62ea3a0f57be2a1b9349cb1d798270aab599c544" alt="Alex Jurkiewicz avatar"
Sounds like you don’t have a backend set up to store your statefile
data:image/s3,"s3://crabby-images/62ea3/62ea3a0f57be2a1b9349cb1d798270aab599c544" alt="Alex Jurkiewicz avatar"
Terraform creates a JSON file after running apply that contains details of all infrastructure that was created. It uses this file on subsequent runs to know which infra it has already created.
Most commonly this is stored in S3 using the S3 backend. Read the docs for more info on how to configure this.
To repair your deployment it will take some tedious surgery, btw. The simplest approach would be to manually delete any resource that Terraform claims is in the way, so it can recreate them. (Once your state is set up)
data:image/s3,"s3://crabby-images/a4350/a4350f51873f0b62abec1493ddf92e3c2b5b2797" alt="NeuroWinter avatar"
Ahh that makes a lot of sense thank you @Alex Jurkiewicz ! I will read up on the docs on how to do that
data:image/s3,"s3://crabby-images/bbec5/bbec5f21883df64e68d4fa4983cba8fd08280d00" alt="Jeb Cole avatar"
Understanding what the statefile is and what terraform does with it (not too complicated) is important
2021-09-06
data:image/s3,"s3://crabby-images/e40d3/e40d3c2ce8d08ad27a1eaca0e9babbdf6611143c" alt="David avatar"
Hi folks - I appear to be having an issue with the following module: https://github.com/cloudposse/terraform-aws-ecs-alb-service-task
╷
│ Error: Invalid value for module argument
│
│ on main.tf line 40, in module "ecs_alb_service_task":
│ 40: volumes = var.volumes
│
│ The given value is not suitable for child module variable "volumes" defined at .terraform/modules/ecs_alb_service_task/variables.tf:226,1-19: element 0: attributes "efs_volume_configuration" and "host_path" are required.
╵
The above is the error message I get when performing a Terraform plan
The section of code which it is complaining about looks like this:
dynamic "volume" {
for_each = var.volumes
content {
host_path = lookup(volume.value, "host_path", null)
name = volume.value.name
dynamic "docker_volume_configuration" {
for_each = lookup(volume.value, "docker_volume_configuration", [])
content {
autoprovision = lookup(docker_volume_configuration.value, "autoprovision", null)
driver = lookup(docker_volume_configuration.value, "driver", null)
driver_opts = lookup(docker_volume_configuration.value, "driver_opts", null)
labels = lookup(docker_volume_configuration.value, "labels", null)
scope = lookup(docker_volume_configuration.value, "scope", null)
}
}
dynamic "efs_volume_configuration" {
for_each = lookup(volume.value, "efs_volume_configuration", [])
content {
file_system_id = lookup(efs_volume_configuration.value, "file_system_id", null)
root_directory = lookup(efs_volume_configuration.value, "root_directory", null)
transit_encryption = lookup(efs_volume_configuration.value, "transit_encryption", null)
transit_encryption_port = lookup(efs_volume_configuration.value, "transit_encryption_port", null)
dynamic "authorization_config" {
for_each = lookup(efs_volume_configuration.value, "authorization_config", [])
content {
access_point_id = lookup(authorization_config.value, "access_point_id", null)
iam = lookup(authorization_config.value, "iam", null)
}
}
}
}
}
}
With vars for var.volumes declared like this:
variable "volumes" {
type = list(object({
host_path = string
name = string
docker_volume_configuration = list(object({
autoprovision = bool
driver = string
driver_opts = map(string)
labels = map(string)
scope = string
}))
efs_volume_configuration = list(object({
file_system_id = string
root_directory = string
transit_encryption = string
transit_encryption_port = string
authorization_config = list(object({
access_point_id = string
iam = string
}))
}))
}))
description = "Task volume definitions as list of configuration objects"
default = []
}
I am passing in the following:
volumes = [
{
name = "etc"
docker_volume_configuration = {
scope = "shared"
autoprovision = true
}
},
{
name = "log"
host_path = "/var/log/hello"
},
{
name = "opt"
docker_volume_configuration = {
scope = "shared"
autoprovision = true
}
},
]
If I update the module variables file in my .terraform folder to:
variable "volumes" {
type = list(object({
#host_path = string
#name = string
#docker_volume_configuration = list(object({
# autoprovision = bool
# driver = string
# driver_opts = map(string)
# labels = map(string)
# scope = string
#}))
#efs_volume_configuration = list(object({
# file_system_id = string
# root_directory = string
# transit_encryption = string
# transit_encryption_port = string
# authorization_config = list(object({
# access_point_id = string
# iam = string
# }))
#}))
}))
description = "Task volume definitions as list of configuration objects"
default = []
}
This applies no problem, any ideas or will I submit a bug
Terraform module which implements an ECS service which exposes a web service via ALB. - GitHub - cloudposse/terraform-aws-ecs-alb-service-task: Terraform module which implements an ECS service whic…
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
@David every key in the object has to be set or terraform will error out. this is a limitation in terraform itself.
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
@David see the optional experiment
Terraform module authors and provider developers can use detailed type constraints to validate the inputs of their modules and resources.
data:image/s3,"s3://crabby-images/e40d3/e40d3c2ce8d08ad27a1eaca0e9babbdf6611143c" alt="David avatar"
i think i tried this, let me try again
data:image/s3,"s3://crabby-images/e40d3/e40d3c2ce8d08ad27a1eaca0e9babbdf6611143c" alt="David avatar"
yeah i tried setting the values to null
data:image/s3,"s3://crabby-images/e40d3/e40d3c2ce8d08ad27a1eaca0e9babbdf6611143c" alt="David avatar"
volumes = [
{
name = "etc"
host_path = null
docker_volume_configuration = {
scope = "shared"
autoprovision = true
},
efs_volume_configuration = {
file_system_id = null
root_directory = null
transit_encryption = null
transit_encryption_port = null
authorization_config = {
access_point_id = null
iam = null
}
}
},
{
name = "log"
host_path = "/var/log/hello"
docker_volume_configuration = {
scope = null
autoprovision = null
},
efs_volume_configuration = {
file_system_id = null
root_directory = null
transit_encryption = null
transit_encryption_port = null
authorization_config = {
access_point_id = null
iam = null
}
}
},
{
name = "opt"
host_path = null
docker_volume_configuration = {
scope = "shared"
autoprovision = true
},
efs_volume_configuration = {
file_system_id = null
root_directory = null
transit_encryption = null
transit_encryption_port = null
authorization_config = {
access_point_id = null
iam = null
}
}
},
]
data:image/s3,"s3://crabby-images/e40d3/e40d3c2ce8d08ad27a1eaca0e9babbdf6611143c" alt="David avatar"
but just moans about this:
│ Error: Invalid value for module argument
│
│ on main.tf line 40, in module "ecs_alb_service_task":
│ 40: volumes = var.volumes
│
│ The given value is not suitable for child module variable "volumes" defined at .terraform/modules/ecs_alb_service_task/variables.tf:226,1-19: element 0: attribute "docker_volume_configuration": list of object required.
╵
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
typically, a list of objects can be zeroed using []
. a singular object can be passed as null
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
you’re giving docker_volume_configuration
a map instead of a list
this
docker_volume_configuration = {
scope = "shared"
autoprovision = true
},
should be
docker_volume_configuration = [{
scope = "shared"
autoprovision = true
}],
see
attribute "docker_volume_configuration": list of object required.
data:image/s3,"s3://crabby-images/e40d3/e40d3c2ce8d08ad27a1eaca0e9babbdf6611143c" alt="David avatar"
didn’t spot the [] and {}
data:image/s3,"s3://crabby-images/e40d3/e40d3c2ce8d08ad27a1eaca0e9babbdf6611143c" alt="David avatar"
volumes = [
{
name = "etc"
host_path = null
efs_volume_configuration = []
docker_volume_configuration = [{
autoprovision = true
driver = null
driver_opts = null
labels = null
scope = "shared"
}]
},
{
name = "log"
host_path = "/var/log/gitlab"
efs_volume_configuration = []
docker_volume_configuration = []
},
{
name = "opt"
host_path = null
docker_volume_configuration = [{
autoprovision = true
scope = "shared"
driver = null
driver_opts = null
labels = null
}]
efs_volume_configuration = []
},
]
data:image/s3,"s3://crabby-images/e40d3/e40d3c2ce8d08ad27a1eaca0e9babbdf6611143c" alt="David avatar"
this works
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
Nice, glad you got it working!
data:image/s3,"s3://crabby-images/e40d3/e40d3c2ce8d08ad27a1eaca0e9babbdf6611143c" alt="David avatar"
me too, i really appreciate the help
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
Np!
data:image/s3,"s3://crabby-images/7d498/7d49897a50ba93641526067b4e2aed68fb2b8d5a" alt="Tony C avatar"
I’m having a similar issue as this one, but I’m trying to use efs_volume_configuration
instead of docker_volume_configuration
. I am correctly passing the docker config as an empty list to avoid the problem of a required option, but then when I go to apply, I get the following error:
Error: ClientException: When the volume parameter is specified, only one volume configuration type should be used.
So, Terraform requires me to pass both configurations, but even when one is empty, it’s complaining that both are provided. Is there any way around this problem? @RB any ideas?
data:image/s3,"s3://crabby-images/7d498/7d49897a50ba93641526067b4e2aed68fb2b8d5a" alt="Tony C avatar"
the volumes block:
volumes = [{
name = "html"
host_path = "/usr/share/nginx/html"
docker_volume_configuration = []
efs_volume_configuration = [{
file_system_id = dependency.efs.outputs.id
root_directory = "/home/user/www"
transit_encryption = "ENABLED"
transit_encryption_port = 2999
authorization_config = []
}]
}]
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
Try setting docker_volume_configuration to null instead
data:image/s3,"s3://crabby-images/7d498/7d49897a50ba93641526067b4e2aed68fb2b8d5a" alt="Tony C avatar"
@RB no bueno:
Error: Invalid dynamic for_each value
on .terraform/modules/ecs-service/main.tf line 70, in resource "aws_ecs_task_definition" "default":
70: for_each = lookup(volume.value, "docker_volume_configuration", [])
|----------------
| volume.value is object with 4 attributes
Cannot use a null value in for_each.
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
could you create a ticket with a minimum viable reproducible example in the https://github.com/cloudposse/terraform-aws-ecs-container-definition repo ? doing this would be easier to debug locally.
if this is truly the case, then the issue may be with the terraform resource itself because it should respect passing in null as if the param is not passed in. if it’s not honoring that, then the terraform golang resource in the aws provider is to blame rather than the module itself
Terraform module to generate well-formed JSON documents (container definitions) that are passed to the aws_ecs_task_definition Terraform resource - GitHub - cloudposse/terraform-aws-ecs-container-…
data:image/s3,"s3://crabby-images/7d498/7d49897a50ba93641526067b4e2aed68fb2b8d5a" alt="Tony C avatar"
will do
data:image/s3,"s3://crabby-images/7d498/7d49897a50ba93641526067b4e2aed68fb2b8d5a" alt="Tony C avatar"
@RB the volumes variable is in ecs-service
not aws-ecs-container-definition
. are you sure you want me to submit the issue in the latter?
data:image/s3,"s3://crabby-images/7d498/7d49897a50ba93641526067b4e2aed68fb2b8d5a" alt="Tony C avatar"
or maybe i’m not understanding the distinction between volumes_from
in the container definition module and volumes
in the service module
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
the ecs service module feeds it into the container definition module
data:image/s3,"s3://crabby-images/7d498/7d49897a50ba93641526067b4e2aed68fb2b8d5a" alt="Tony C avatar"
ok so i can just use my volumes
arg verbatim as the value for volumes_from
in my reproducer?
data:image/s3,"s3://crabby-images/7d498/7d49897a50ba93641526067b4e2aed68fb2b8d5a" alt="Tony C avatar"
appears not. can i give you a reproducer that uses ecs-service
?
data:image/s3,"s3://crabby-images/7d498/7d49897a50ba93641526067b4e2aed68fb2b8d5a" alt="Tony C avatar"
I’m using terraform-aws-ecs-alb-service-task
data:image/s3,"s3://crabby-images/7d498/7d49897a50ba93641526067b4e2aed68fb2b8d5a" alt="Tony C avatar"
issue submitted: https://github.com/cloudposse/terraform-aws-ecs-container-definition/issues/147
thanks for your help, RB
Describe the Bug I'm trying to use an EFS volume in an ECS service definition. The volumes variable is defined such that one has to supply a value for both the efs_volume_configuration and dock…
2021-09-07
data:image/s3,"s3://crabby-images/06f4d/06f4d473b5178a0cdb9aa17d4dc1ecec53a57536" alt="O K avatar"
Hi All! How long approximately should it take to deploy AWS MSK? I use this module https://registry.terraform.io/modules/cloudposse/msk-apache-kafka-cluster/aws/latest and I deployment is passed 20 min already and still nothing. Any feedback please?
module.kafka.aws_msk_cluster.default[0]: Still creating... [26m0s elapsed]
module.kafka.aws_msk_cluster.default[0]: Still creating... [26m10s elapsed]
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
It does take a while
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
data:image/s3,"s3://crabby-images/06f4d/06f4d473b5178a0cdb9aa17d4dc1ecec53a57536" alt="O K avatar"
Thank you!
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
Note that it’s not the module but the aws msk itself
data:image/s3,"s3://crabby-images/06f4d/06f4d473b5178a0cdb9aa17d4dc1ecec53a57536" alt="O K avatar"
I see, do we need to specify zone_id
or this os optional parameter?
data:image/s3,"s3://crabby-images/06f4d/06f4d473b5178a0cdb9aa17d4dc1ecec53a57536" alt="O K avatar"
Terraform module to provision AWS MSK. Contribute to cloudposse/terraform-aws-msk-apache-kafka-cluster development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/4046c/4046c9a66489ed9e71b43297bcec3a8d14cc2a90" alt="Mohamed Habib avatar"
yup MSK takes ages to be ready
data:image/s3,"s3://crabby-images/06f4d/06f4d473b5178a0cdb9aa17d4dc1ecec53a57536" alt="O K avatar"
I see, do we need to specify zone_id
or this os optional parameter?
please suggest regarding this question
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
All the module arguments are shown in the readme. On the far right, it shows required yes or no
data:image/s3,"s3://crabby-images/06f4d/06f4d473b5178a0cdb9aa17d4dc1ecec53a57536" alt="O K avatar"
data:image/s3,"s3://crabby-images/c383a/c383a05c31298e45c1c7dd056f10ee59e08417ee" alt="Wira avatar"
Hello, I am currently using this terraform module https://registry.terraform.io/modules/cloudposse/elastic-beanstalk-environment/aws/latest to create a worker environment. But I can’t find how to configure custom endpoint for the worker daemon to post the sqs queue.
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
Is there a terraform resource that can provide a custom endpoint? I don’t see one :(
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
Only one i can see is the environment resources endpoint url as an attribute but i don’t see a way to modify it like in the picture above
data:image/s3,"s3://crabby-images/c383a/c383a05c31298e45c1c7dd056f10ee59e08417ee" alt="Wira avatar"
I am actually not too familiar with terraform. But after I looked here https://registry.terraform.io/providers/hashicorp/aws/latest/docs/resources/elastic_beanstalk_environment , I don’t think so
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
There may be an open pull request in the aws provider? If not, they need all the contributions they can get :)
data:image/s3,"s3://crabby-images/f9865/f9865f3d4e421dd840f4c2ad0086f10b2f2e34ee" alt="Yoni Leitersdorf (Indeni Cloudrail) avatar"
Have you seen https://www.theregister.com/2021/09/07/hashicorp_pause/ ? Thoughts on this?
data:image/s3,"s3://crabby-images/93eaf/93eaf8e646a3a14c8faa59a28eebe8886da71254" alt="attachment image"
A pause on community-submitted PRs
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
bummed, but glad they’re at least up front about it
data:image/s3,"s3://crabby-images/93eaf/93eaf8e646a3a14c8faa59a28eebe8886da71254" alt="attachment image"
A pause on community-submitted PRs
data:image/s3,"s3://crabby-images/9161e/9161edea81ff66e90024c81cbe86097a6a1334da" alt="Rhys Davies avatar"
Time to apply to Hashi
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
ya, so curious what the back story is here…
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
have they have some recent departures?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
have they reached some tipping point?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
have they had some incident reported and need to pause all contributions (E.g. like what happened to the linux kernel)?
data:image/s3,"s3://crabby-images/f9865/f9865f3d4e421dd840f4c2ad0086f10b2f2e34ee" alt="Yoni Leitersdorf (Indeni Cloudrail) avatar"
I wonder where we can get more information about this? Any people you can get some commentary on this?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
have they taken some time to pause and regroup on how to scale engineering of open source at this scale?
data:image/s3,"s3://crabby-images/f9865/f9865f3d4e421dd840f4c2ad0086f10b2f2e34ee" alt="Yoni Leitersdorf (Indeni Cloudrail) avatar"
It’s really interesting to look at this in light of Docker’s issues in the open source world: https://www.infoworld.com/article/3632142/how-docker-broke-in-half.html
data:image/s3,"s3://crabby-images/ab4ae/ab4aecaab525d44b4bd3641fe630721d2858a6ae" alt="attachment image"
The game changing container company is a shell of its former self. What happened to one of the hottest enterprise technology businesses of the cloud era?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
I doubt we can get anyone to comment publicly on it.
data:image/s3,"s3://crabby-images/9161e/9161edea81ff66e90024c81cbe86097a6a1334da" alt="Rhys Davies avatar"
Not hugely forthcoming in the Reddit threads that I’ve been reading, but it seems that they are growing faster than they are hiring, compounded with some loses in the Terraform department coupled with normal PTO/Vacay overhead
data:image/s3,"s3://crabby-images/9161e/9161edea81ff66e90024c81cbe86097a6a1334da" alt="Rhys Davies avatar"
Posted in r/Terraform by u/The-Sentinel • 60 points and 22 comments
data:image/s3,"s3://crabby-images/9161e/9161edea81ff66e90024c81cbe86097a6a1334da" alt="Rhys Davies avatar"
I was reading a Tweet from Mitchell too, but I can’t find it now
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
@gooeyblob This is only for core which should not be noticeable to any end users since providers are the main source of external contribution and there is no change in policy there. This allows our core team to focus a bit more while we hire to fill the team more.
data:image/s3,"s3://crabby-images/9161e/9161edea81ff66e90024c81cbe86097a6a1334da" alt="Rhys Davies avatar"
he was basically trying to downplay the situation
data:image/s3,"s3://crabby-images/9161e/9161edea81ff66e90024c81cbe86097a6a1334da" alt="Rhys Davies avatar"
data:image/s3,"s3://crabby-images/9161e/9161edea81ff66e90024c81cbe86097a6a1334da" alt="Rhys Davies avatar"
Basically it looks like Silicon Valley is hot af right now if you have Terraform skill, they literally cannot hire fast enough because everyone is hiring again after the pandemic and it’s feeding frenzy
data:image/s3,"s3://crabby-images/9161e/9161edea81ff66e90024c81cbe86097a6a1334da" alt="Rhys Davies avatar"
I wasn’t joking when I said it’s time to apply to Hashicorp, maybe it’s time to work for a big company…
data:image/s3,"s3://crabby-images/9161e/9161edea81ff66e90024c81cbe86097a6a1334da" alt="Rhys Davies avatar"
I also think that a lot of companies haven’t really figured out working full remotely yet, it’s possible that they are having a people issue as well as a resourcing block which is slowing things down
data:image/s3,"s3://crabby-images/9161e/9161edea81ff66e90024c81cbe86097a6a1334da" alt="Rhys Davies avatar"
I notice that their SF office isn’t listed on any job listings and they are all fully remote..
data:image/s3,"s3://crabby-images/9161e/9161edea81ff66e90024c81cbe86097a6a1334da" alt="Rhys Davies avatar"
Looking at cashflow Hashi is 5.2B valuation, 8 years old, Series E of 175m, so they have fuel in the tank to hire with even if Series E and not revenue positive denotes that they are having trouble monetizing their products
data:image/s3,"s3://crabby-images/f9865/f9865f3d4e421dd840f4c2ad0086f10b2f2e34ee" alt="Yoni Leitersdorf (Indeni Cloudrail) avatar"
I think Hashi was mostly remote even pre-pandemic. I agree that the market is hot and it’s hard to find good people. There’s a lot of cash running around.
data:image/s3,"s3://crabby-images/bbec5/bbec5f21883df64e68d4fa4983cba8fd08280d00" alt="Jeb Cole avatar"
It’s the remote pool that is getting drained hardest now that so many tech companies have been pushed to go remote
data:image/s3,"s3://crabby-images/4046c/4046c9a66489ed9e71b43297bcec3a8d14cc2a90" alt="Mohamed Habib avatar"
could it be a cashflow issue?
data:image/s3,"s3://crabby-images/c3b77/c3b771955f21fa5eda0bfa1d1024182be6ccc11f" alt="Andrew Nazarov avatar"
The fresh one on the subject https://twitter.com/mitchellh/status/1435674131257651201?s=20
Sharing an update to the recent speculation around Terraform and community contributions. The gist is: we’re growing a ton, this temporary pause is localized to a single team (of many), and Terraform Providers are completely unchanged and unaffected. https://www.hashicorp.com/blog/terraform-community-contributions
data:image/s3,"s3://crabby-images/c3b77/c3b771955f21fa5eda0bfa1d1024182be6ccc11f" alt="Andrew Nazarov avatar"
Sharing a brief update on Terraform and community contributions, given some recent noise. TL;DR: Terraform is continuing to grow rapidly, we are scaling the team, and we welcome contributions. Also we are hiring! https://www.hashicorp.com/blog/terraform-community-contributions
data:image/s3,"s3://crabby-images/304f3/304f3552ebab9249a1c54f171b9454445e82dcb1" alt="Kyle Johnson avatar"
Is there any existing solution for generating KMS policies that enable the interop with various AWS services?
Some services need actions others don’t such as kms:CreateGrant
. CloudTrail audits will flag that action being granted to services which don’t need it.
Seems like there ought to be a module for creating these policies which already knows the details of individual action requirements vs recreating policies from AWS docs on every project
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
dealing with exactly this right now, for cloudtrail, config, and guardduty. such a pain to figure out the kms policy and bucket policy!!
data:image/s3,"s3://crabby-images/62ea3/62ea3a0f57be2a1b9349cb1d798270aab599c544" alt="Alex Jurkiewicz avatar"
I started work on creating canned policies for every service in a PR for the cloudposse key module, but I am no longer actively working on it
data:image/s3,"s3://crabby-images/62ea3/62ea3a0f57be2a1b9349cb1d798270aab599c544" alt="Alex Jurkiewicz avatar"
If you wanted to improve everyone’s life a little bit, it might be a good launchpad
2021-09-08
data:image/s3,"s3://crabby-images/23935/239350eb34c40aabaa5b8d39f50b1e5d205c4294" alt="Mohammed Yahya avatar"
• Terraform is not currently reviewing Community Pull Requests: HashiCorp has acknowledged that it is currently understaffed and is unable to review public PRs.
•
Terraform enables you to safely and predictably create, change, and improve infrastructure. It is an open source tool that codifies APIs into declarative configuration files that can be shared amongst team members, treated as code, edited, reviewed, and versioned. - Be explicit that community PR review is currently paused · hashicorp/terraform@6562466
data:image/s3,"s3://crabby-images/23935/239350eb34c40aabaa5b8d39f50b1e5d205c4294" alt="Mohammed Yahya avatar"
Terraform enables you to safely and predictably create, change, and improve infrastructure. It is an open source tool that codifies APIs into declarative configuration files that can be shared amongst team members, treated as code, edited, reviewed, and versioned. - Be explicit that community PR review is currently paused · hashicorp/terraform@6562466
data:image/s3,"s3://crabby-images/04c43/04c434c72c17a213fa95dc57defba0a6cef2b79a" alt="conzymaher avatar"
Only applies to terraform core
data:image/s3,"s3://crabby-images/04c43/04c434c72c17a213fa95dc57defba0a6cef2b79a" alt="conzymaher avatar"
Not providers
data:image/s3,"s3://crabby-images/23935/239350eb34c40aabaa5b8d39f50b1e5d205c4294" alt="Mohammed Yahya avatar"
I see.
data:image/s3,"s3://crabby-images/04c43/04c434c72c17a213fa95dc57defba0a6cef2b79a" alt="conzymaher avatar"
Lets see how it plays out but I’m not particularly worried
data:image/s3,"s3://crabby-images/23935/239350eb34c40aabaa5b8d39f50b1e5d205c4294" alt="Mohammed Yahya avatar"
For core I guess yes, maybe they don’t want specific features added by community - example terraform add command, but not sure why
data:image/s3,"s3://crabby-images/04c43/04c434c72c17a213fa95dc57defba0a6cef2b79a" alt="conzymaher avatar"
data:image/s3,"s3://crabby-images/b3138/b31380172431fb9a27bf4d7801168a0f91c8814b" alt="attachment image"
We recently added a note to the HashiCorp Terraform contribution guidelines and this blog provides additional clarity and context for our community and commercial customers.
data:image/s3,"s3://crabby-images/8df3b/8df3b7c19f12d2950e1367766349d2336c94f737" alt="Saichovsky avatar"
Hello,
We have a aws_directory_service_directory
resource defined in a service, which creates a security group that allows ports 1024-65535 to be accessible from 0.0.0.0/0 and this is getting flagged by security hub because AWS CIS standards to not recommend allowing ingress from 0.0.0.0/0 for TCP port 3389.
My question is on how to restrict some of the rules in the resultant SG that gets created by the aws_directory_service_directory
resource. How do you remediate this using terraform?
data:image/s3,"s3://crabby-images/49247/4924735130c3558e142e6b840faa2585ac6c3000" alt="mfridh avatar"
Anyone here using tfexec
/ tfinstall
? https://github.com/hashicorp/terraform-exec
2021/09/08 13:15:58 error running Init: fork/exec /tmp/tfinstall354531296/terraform: not a directory
I feel like there are a few lies in this code here …
This one for example: https://github.com/hashicorp/terraform-exec/blob/v0.14.0/tfexec/terraform.go#L62-L74
data:image/s3,"s3://crabby-images/49247/4924735130c3558e142e6b840faa2585ac6c3000" alt="mfridh avatar"
As usual… nothing to see here. oh, funny :smile: … Yeah it was all a lie.
I had given a file instead of a directory as its workingDir
.
And the error message was very confusing because it didn’t report THAT variable as “not a directory”
data:image/s3,"s3://crabby-images/10c5f/10c5f18510e11e73457c5af38950444503b0d326" alt="SlackBot avatar"
This message was deleted.
data:image/s3,"s3://crabby-images/edcf7/edcf757b928ec1262d9aca7f31f648c28ea88a62" alt="Tomek avatar"
:wave: I have the following public subnet resource:
resource "aws_subnet" "public_subnet" {
for_each = {
"${var.aws_region}a" = "172.16.1.0"
"${var.aws_region}b" = "172.16.2.0"
"${var.aws_region}c" = "172.16.3.0"
}
vpc_id = aws_vpc.vpc.id
cidr_block = "${each.value}/24"
availability_zone = each.key
map_public_ip_on_launch = true
}
I want to reference the subnets in an ALB resource I’m creating. At the moment this looks like:
subnet_ids = [
aws_subnet.public_subnet["us-east-1a"].id,
aws_subnet.public_subnet["us-east-1b"].id,
aws_subnet.public_subnet["us-east-1c"].id
]
Is there a way to wildcard the above? I tried aws_subnet.public_subnet.*.id
which doesn’t work because I think the for each object is a map. What is the proper way to handle this?
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
data:image/s3,"s3://crabby-images/edcf7/edcf757b928ec1262d9aca7f31f648c28ea88a62" alt="Tomek avatar"
data:image/s3,"s3://crabby-images/840f2/840f20f95264f61befe3a4f5d9f7a85f08f3726c" alt="Release notes from terraform avatar"
v1.1.0-alpha20210908 1.1.0 (Unreleased) UPGRADE NOTES: Terraform on macOS now requires macOS 10.13 High Sierra or later; Older macOS versions are no longer supported. The terraform graph command no longer supports -type=validate and -type=eval options. The validate graph is always the same as the plan graph anyway, and the “eval” graph was just an implementation detail of the terraform console command. The default behavior of creating a plan graph should be a reasonable replacement for both of the removed graph…
2021-09-09
data:image/s3,"s3://crabby-images/fcdc0/fcdc082ca5c426ae7a83f63c34dd4cae258c8b47" alt="Steve Wade (swade1987) avatar"
does anyone know of an IAM policy that will let people view the SSM parameters names and thats it? I don’t want them to be able to see the values.
data:image/s3,"s3://crabby-images/49247/4924735130c3558e142e6b840faa2585ac6c3000" alt="mfridh avatar"
“Secret” values would usually be encrypted using a KMS key. So by controlling access to the KMS key could be enough if your intentions is to hide only the encrypted values.
Otherwise, the only thing you can give would be ssm:DescribeParameters
I think.
https://docs.aws.amazon.com/systems-manager/latest/userguide/sysman-paramstore-access.html
Restrict access to Systems Manager parameters by using IAM policies.
data:image/s3,"s3://crabby-images/4fe9f/4fe9facc48d5b5889bb0233a7645874059f18fc5" alt="Aleksandr Fofanov avatar"
just give them ssm:DescribeParameters
permission
they will be able to list and view individual parameters metadata but not the values
data:image/s3,"s3://crabby-images/fcdc0/fcdc082ca5c426ae7a83f63c34dd4cae258c8b47" alt="Steve Wade (swade1987) avatar"
data:image/s3,"s3://crabby-images/1f764/1f7642102f6ffa32b21194baea1ef17281af4a3f" alt="Pierre-Yves avatar"
I had a lot of tags to deploy, and not all resources support tagging .
to be effective in the process and after trying many option to trigger command on *.tf changes.
I finally use watch terraform validate
( inotifywait
don’t seems to work on wsl + vscode )
data:image/s3,"s3://crabby-images/3b987/3b987a779ed84fe1e44d2450ae1fb3ba3fc08d39" alt="deepak kumar avatar"
Hi People, I am creating ecs service using tf 0.11.7 I have set the network_mode default to “bridge” for the ecs task definition but the module can be reused with different network_mode such as “awsvpc”. Since tf 0.11.* doesn’t support dynamic block , I need to find out a way to achieve dynamic block to set arguments such as network_configurations(based on the network_mode) Using locals I guess it can be achieved .Is there any other way to do it in tf 0.11.*?
data:image/s3,"s3://crabby-images/65abe/65abeec1637af13876edb28ff253db69acdcd8cb" alt="Grummfy avatar"
You can use terraspace / terragrunt / other to do that, but I would advise to update a bit the version of terraform …
data:image/s3,"s3://crabby-images/fcdc0/fcdc082ca5c426ae7a83f63c34dd4cae258c8b47" alt="Steve Wade (swade1987) avatar"
has anyone managed to get terraform with when using federated SSO with AWS and leveraging an assume-role in the terraform configuration?
data:image/s3,"s3://crabby-images/0fd98/0fd985ce0b5932d9e94bf208cb4bf974fa5a11c2" alt="Andrea Cavagna avatar"
I think you can manage this situation with Leapp Leap manages also the assume role from federated
data:image/s3,"s3://crabby-images/04c43/04c434c72c17a213fa95dc57defba0a6cef2b79a" alt="conzymaher avatar"
Have you used https://github.com/99designs/aws-vault
A vault for securely storing and accessing AWS credentials in development environments - GitHub - 99designs/aws-vault: A vault for securely storing and accessing AWS credentials in development envi…
data:image/s3,"s3://crabby-images/0fd98/0fd985ce0b5932d9e94bf208cb4bf974fa5a11c2" alt="Andrea Cavagna avatar"
I started an open-source project to manage multi-account access in multi-cloud. It is a Desktop App that Manages IAM Users, IAM federated roles, IAM chained roles and automatically retrieving all the AWS SSO roles. Also, It secures credentials by managing the credentials file on your behalf and generates a profile with short-lived credentials only when needed. If you are interested in the idea, look at the guide made by Nuru:
https://docs.cloudposse.com/howto/geodesic/authenticate-with-leapp/
A vault for securely storing and accessing AWS credentials in development environments - GitHub - 99designs/aws-vault: A vault for securely storing and accessing AWS credentials in development envi…
data:image/s3,"s3://crabby-images/04c43/04c434c72c17a213fa95dc57defba0a6cef2b79a" alt="conzymaher avatar"
Its an awesome tool. I am using it for interacting with dozens of AWS accounts whether its IAM users + MFA or AWS SSO
data:image/s3,"s3://crabby-images/edcf7/edcf757b928ec1262d9aca7f31f648c28ea88a62" alt="Tomek avatar"
ooof, I just corrupted my local state file and lost the state of a bunch of resources in my terraform (backup was corrupted to ). I don’t actually care about the resources, is there a way I can force terraform to destroy the resources that map to my terraform code and reapply?
data:image/s3,"s3://crabby-images/62ea3/62ea3a0f57be2a1b9349cb1d798270aab599c544" alt="Alex Jurkiewicz avatar"
No. Run Terraform apply repeatedly and manually delete the resources it says are in the way. But this doesn’t work in all cases. If you had eg S3 buckets it IAM resources with a name prefix specified instead of a name, they will be missed
data:image/s3,"s3://crabby-images/edcf7/edcf757b928ec1262d9aca7f31f648c28ea88a62" alt="Tomek avatar"
i was afraid of this
data:image/s3,"s3://crabby-images/edcf7/edcf757b928ec1262d9aca7f31f648c28ea88a62" alt="Tomek avatar"
well first thing i’m doing is switching to versioned s3 backend
data:image/s3,"s3://crabby-images/62ea3/62ea3a0f57be2a1b9349cb1d798270aab599c544" alt="Alex Jurkiewicz avatar"
Good idea
data:image/s3,"s3://crabby-images/8cbd4/8cbd4255bb4eeab6f52669a7b2904f1ac5589f08" alt="pjaudiomv avatar"
Backup the bucket too :), learned that one after a coworker deleted said versioned bucket
data:image/s3,"s3://crabby-images/04c43/04c434c72c17a213fa95dc57defba0a6cef2b79a" alt="conzymaher avatar"
ooof
2021-09-10
data:image/s3,"s3://crabby-images/a5b46/a5b46ba101a3d63e1e54bd6e179208e782e98051" alt="emem avatar"
hey guys anyone ever implemented a description on what terraform is applying on the approval stage in codepipeline. Like i can see what my terraform is planing in the terraform plan stage and i would like to pass this to details to my approval stage but approval does not support artifact atrtibute. Anyone found a solution for this before
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
We’re using Spacelift which does that. If you learn hwo to do it with codepipeline, lmk!
data:image/s3,"s3://crabby-images/d9fff/d9fff15a0d62764224d79174cda70ad96f3a2e66" alt="Nikola Milic avatar"
How do I access the ARN of the created resource in the sibling modules belonging to same main.tf file? I want to create IAM user, and ECR resource that need’s that user’s ARN (Check line 22). How to reference variables?
data:image/s3,"s3://crabby-images/8cbd4/8cbd4255bb4eeab6f52669a7b2904f1ac5589f08" alt="pjaudiomv avatar"
Check the outputs of the user module then you would reference it prefixed with module and the name ex. module.gitlab_user.user_arn
data:image/s3,"s3://crabby-images/d9fff/d9fff15a0d62764224d79174cda70ad96f3a2e66" alt="Nikola Milic avatar"
Thanks @pjaudiomv
data:image/s3,"s3://crabby-images/8cbd4/8cbd4255bb4eeab6f52669a7b2904f1ac5589f08" alt="pjaudiomv avatar"
Yes this explains modules and accessing their values https://www.terraform.io/docs/language/modules/syntax.html section Accessing Module Output Values
Modules allow multiple resources to be grouped together and encapsulated.
data:image/s3,"s3://crabby-images/8cbd4/8cbd4255bb4eeab6f52669a7b2904f1ac5589f08" alt="pjaudiomv avatar"
All of the cloudposse modules reference the inputs/outputs on the respective GitHub repo https://github.com/cloudposse/terraform-aws-iam-system-user#outputs
Terraform Module to Provision a Basic IAM System User Suitable for CI/CD Systems (E.g. TravisCI, CircleCI) - GitHub - cloudposse/terraform-aws-iam-system-user: Terraform Module to Provision a Basic…
data:image/s3,"s3://crabby-images/b2a92/b2a92e03879d6cf74f740e6fb517dc6095db0fa4" alt="Cameron Pope avatar"
Hello - First of all, thank you for having so many wonderful Terraform modules. I have a question about the aws-ecs-web-app
module and task definitions. It seems like neither setting for ignore_changes_task_definition
does quite what I need, so I sense I am ‘doing it wrong’, but I am struggling to find the happy path to doing the right thing.
When I update by pushing new code to Github, and then run terraform apply
the module wants to switch the task definition back to the previous version. Setting ignore_changes_task_definition
to True
fixes that, but if I want to update the container size or environment variables, then those changes do not get picked up.
It seems like the underlying problem is my way of doing things (managing the Task Definition via Terraform) is coupling Terraform and the CI/CD process too tightly, and that either Terraform or CodeBuild should ‘own’ the Task Definition, but not both. I don’t see a clean way to create the Task Definition during the Build phase and set it during the deploy phase. The standard ECS deployment takes the currently-running task definition and updates the image uri. It looks like one needs to use CodeDeploy to do anything more advanced.
I don’t think I’m the first person to want Terraform not to change the revision unless I’ve made changes to the task definition on the Terraform side. How do others handle this? Or is my use-case outside of what the aws-ecs-web-app
module is designed for?
If you made it here, thank you for reading!
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
I would use the web app module more as a reference for how to tie all the other modules together
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
you’ll quickly find yourself wanting to make changes
data:image/s3,"s3://crabby-images/b2a92/b2a92e03879d6cf74f740e6fb517dc6095db0fa4" alt="Cameron Pope avatar"
Thank you for the response - that was my sense. It is great to have a working end-to-end example, and it made it easy to set up a Github -> ECS pipeline.
Interestingly, after about a year, the only thing that we’re really missing for our use-case is the ability to generate task definitions after a successful container build. The web-app module got us almost 100% of the way there, and for that I’m grateful.
data:image/s3,"s3://crabby-images/14b26/14b2688abddd721e4a7a3792fbfe1235ec56c56b" alt="Nick Kocharhook avatar"
@Cameron Pope can you say a bit more about how you solved this problem? I’m running into the same conflict between CI/CD (Codefresh in my case) and Terraform. When ignore_changes_task_definition
is on (which it is by default), I’m still getting Terraform wanting to update the task definition to a new revision with the sha256 of the new image as the tag, compared to the GitHub short rev for the CD. This breaks the web app deploy. :disappointed:
I think everything would be fine if it just honored the variable and actually ignored changes to the service’s task_definition
. I don’t have a lot of changes to the instance count planned. I can’t figure out why it’s not honoring the setting.
2021-09-11
2021-09-12
2021-09-13
data:image/s3,"s3://crabby-images/fcdc0/fcdc082ca5c426ae7a83f63c34dd4cae258c8b47" alt="Steve Wade (swade1987) avatar"
anyone hooked in the identity provider for EKS yet? any gothcas I should be aware of?
data:image/s3,"s3://crabby-images/9161e/9161edea81ff66e90024c81cbe86097a6a1334da" alt="Rhys Davies avatar"
Hey guys I’m writing the Terraform for a new AWS ECS Service, I want to deploy 6 (but effectively n
) similar container definitions in my task definition. What’s the recommended way of looping a data structure (a dict, or list of lists) and creating container_definitions?
- Is it supposed to be done with a JSON file and a
data "template_file"
block with some sort of comprehension? - I’ve found https://registry.terraform.io/providers/hashicorp/aws/latest/docs/data-sources/ecs_container_definition but it doesn’t have any parameters for
command
which is the part between the container definitions that needs to differ slightly - https://github.com/cloudposse/terraform-aws-ecs-container-definition I’ve also found this, not sure if anyone here has had any experience with it? I was going to experiment
for_each
ing with it to create 6 container_defs I can thenmerge()
in myresource "task_definition"
- is this the right sort of approach?
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
I believe you want option 3
data:image/s3,"s3://crabby-images/9161e/9161edea81ff66e90024c81cbe86097a6a1334da" alt="Rhys Davies avatar"
Just out of interest, can I just do this?
data:image/s3,"s3://crabby-images/9161e/9161edea81ff66e90024c81cbe86097a6a1334da" alt="Rhys Davies avatar"
celery_queues = {
1 : ["queue1"],
2 : ["queue2", "blah", "default"],
...
}
resource "aws_ecs_task_definition" "celery" {
for_each = local.celery_queues
family = "celery"
requires_compatibilities = ["FARGATE"]
cpu = "4096"
memory = "8192"
network_mode = "awsvpc"
execution_role_arn = module.ecs_cluster.task_role_arn
container_definitions = jsonencode([
{
name = "celery_${each.key}",
image = blah,
command = ["celery", ${each.value}],
environment = blah,
essential = true,
logConfiguration = {
logDriver = "awslogs",
options = {
awslogs-group = log_group_name,
awslogs-region = log_group_region,
awslogs-stream-prefix = log_group_prefix
}
},
healthCheck = {
command = ["CMD-SHELL", "pipenv run celery -A my_proj inspect ping"],
interval = 10,
timeout = 60,
retries = 5,
startPeriod = 60
}
}
])
}
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
Ya that would work too
data:image/s3,"s3://crabby-images/9161e/9161edea81ff66e90024c81cbe86097a6a1334da" alt="Rhys Davies avatar"
awesome thanks for the help, I’m a devops of one, its so good to have somewhere to work through a solution!
data:image/s3,"s3://crabby-images/0297e/0297e55200a6171774913e3674c3cb37afa19e9a" alt="Bhavik Patel avatar"
data:image/s3,"s3://crabby-images/9161e/9161edea81ff66e90024c81cbe86097a6a1334da" alt="Rhys Davies avatar"
Thanks in advance for any help
data:image/s3,"s3://crabby-images/9a6f0/9a6f00b9eb351b57eb0abd3c1c66fbcf3110f489" alt="othman issa avatar"
Hello everyone, I have a question what is the best way to connect TF module with API ?
data:image/s3,"s3://crabby-images/62ea3/62ea3a0f57be2a1b9349cb1d798270aab599c544" alt="Alex Jurkiewicz avatar"
AWS API Gateway?
data:image/s3,"s3://crabby-images/62ea3/62ea3a0f57be2a1b9349cb1d798270aab599c544" alt="Alex Jurkiewicz avatar"
Or something else
data:image/s3,"s3://crabby-images/9a6f0/9a6f00b9eb351b57eb0abd3c1c66fbcf3110f489" alt="othman issa avatar"
I was reading in TF doc HTTP API
2021-09-14
data:image/s3,"s3://crabby-images/10c5f/10c5f18510e11e73457c5af38950444503b0d326" alt="SlackBot avatar"
This message was deleted.
data:image/s3,"s3://crabby-images/6105d/6105d9d76662a50bab5753d6d076f5ecf9a82b37" alt="greg n avatar"
good afternoon guys, I think I’ve found a version issue with cloudposse/terraform-aws-ecs-web-app (version = “~> 0.65.2”). Is this a legit upper version limit or perhaps just versions.tf a bit out of date? Thanks
tf -version
Terraform v1.0.2
on linux_amd64
Your version of Terraform is out of date! The latest version
is 1.0.6. You can update by downloading from <https://www.terraform.io/downloads.html>
- services_api_assembly.this in .terraform/modules/services_api_assembly.this
╷
│ Error: Unsupported Terraform Core version
│
│ on .terraform/modules/services_api_alb.alb.access_logs.s3_bucket.this/versions.tf line 2, in terraform:
│ 2: required_version = ">= 0.12.0, < 0.14.0"
│
│ Module module.services_api_alb.module.alb.module.access_logs.module.s3_bucket.module.this (from git::<https://github.com/cloudposse/terraform-null-label.git?ref=tags/0.19.2>) does not support Terraform version 1.0.2. To
│ proceed, either choose another supported Terraform version or update this version constraint. Version constraints are normally set for good reason, so updating the constraint may lead to other errors or unexpected behavior.
╵
╷
│ Error: Unsupported Terraform Core version
│
│ on .terraform/modules/services_api_alb.alb.access_logs.this/versions.tf line 2, in terraform:
│ 2: required_version = ">= 0.12.0, < 0.14.0"
│
│ Module module.services_api_alb.module.alb.module.access_logs.module.this (from git::<https://github.com/cloudposse/terraform-null-label.git?ref=tags/0.19.2>) does not support Terraform version 1.0.2. To proceed, either choose
│ another supported Terraform version or update this version constraint. Version constraints are normally set for good reason, so updating the constraint may lead to other errors or unexpected behavior.
╵
╷
│ Error: Unsupported Terraform Core version
│
│ on .terraform/modules/services_api_alb.alb.default_target_group_label/versions.tf line 2, in terraform:
│ 2: required_version = ">= 0.12.0, < 0.14.0"
│
│ Module module.services_api_alb.module.alb.module.default_target_group_label (from git::<https://github.com/cloudposse/terraform-null-label.git?ref=tags/0.19.2>) does not support Terraform version 1.0.2. To proceed, either
│ choose another supported Terraform version or update this version constraint. Version constraints are normally set for good reason, so updating the constraint may lead to other errors or unexpected behavior.
╵
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
post here and we’ll get it promptly reviewed
data:image/s3,"s3://crabby-images/22d1c/22d1c0efdf33b830ff64464d772f7a49be07ae7d" alt="Richard Quadling avatar"
The versions.tf for v0.65.2 https://github.com/cloudposse/terraform-aws-ecs-web-app/blob/master/versions.tf says
terraform {
required_version = ">= 0.13.0"
required_providers {
aws = {
source = "hashicorp/aws"
version = ">= 3.34"
}
}
}
Which all looks good. What is the source of the services_api_alb module?
data:image/s3,"s3://crabby-images/6105d/6105d9d76662a50bab5753d6d076f5ecf9a82b37" alt="greg n avatar"
it’s
source = "cloudposse/alb/aws"
version = "0.23.0"
context = module.this.context
`
data:image/s3,"s3://crabby-images/22d1c/22d1c0efdf33b830ff64464d772f7a49be07ae7d" alt="Richard Quadling avatar"
https://registry.terraform.io/modules/cloudposse/alb/aws/latest is 0.35.3, so you are quite a way behind.
data:image/s3,"s3://crabby-images/d9fff/d9fff15a0d62764224d79174cda70ad96f3a2e66" alt="Nikola Milic avatar"
For some reason, ec2 instance does not have public dns assigned, even though it’s part of the public subnet? What could be the case?
data:image/s3,"s3://crabby-images/f423c/f423c8e850268e533a4e86e173d6f4a9a3b27039" alt="managedkaos avatar"
During the cretion of the resource, did you specify to attach a public IP? even if the subnet is public, if the default setting for the subnet is to NOT assign a public IP, instances won’t get one. (AFAIK)
data:image/s3,"s3://crabby-images/d9fff/d9fff15a0d62764224d79174cda70ad96f3a2e66" alt="Nikola Milic avatar"
Yeah i was under the impression that on was the default. Thanks, i think that solved it
data:image/s3,"s3://crabby-images/f423c/f423c8e850268e533a4e86e173d6f4a9a3b27039" alt="managedkaos avatar"
2021-09-15
data:image/s3,"s3://crabby-images/840f2/840f20f95264f61befe3a4f5d9f7a85f08f3726c" alt="Release notes from terraform avatar"
v1.0.7 1.0.7 (September 15, 2021) BUG FIXES: core: Remove check for computed attributes which is no longer valid with optional structural attributes (#29563) core: Prevent object types with optional attributes from being instantiated as concrete values, which can lead to failures in type comparison (<a…
The config is already validated, and does not need to be checked again in AssertPlanValid, so we can just remove the check which conflicts with the new optional nested attribute types. Add some mor…
2021-09-16
data:image/s3,"s3://crabby-images/863b6/863b6f5ab63796d578d4e810a611e72658d54606" alt="Vikram Yerneni avatar"
Fellas, Is there a way to add a condition when adding S3 bucket/folder level permissions here at: https://github.com/cloudposse/terraform-aws-iam-s3-user
For example, I want to give like this string query:
{
"Sid": "AllowStatement3",
"Action": ["s3:ListBucket"],
"Effect": "Allow",
"Resource": ["arn:aws:s3:::DOC-EXAMPLE-BUCKET"],
"Condition":{"StringLike":{"s3:prefix":["media/*"]}}
}
2021-09-17
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
spamming channels: https://tech.loveholidays.com/enforcing-best-practice-on-self-serve-infrastructure-with-terraform-atlantis-and-policy-as-code-911f4f8c3e00
data:image/s3,"s3://crabby-images/61ae6/61ae66550e9011b3f711850e8bffffdf029a7309" alt="attachment image"
Here at loveholidays we are heavily dependant on Terraform. All of our Google Cloud infrastructure is managed using Terraform, along with a…
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
i really wish it were easier to extend atlantis to additional source code hosts. would be fantastic if it worked with codecommit
data:image/s3,"s3://crabby-images/61ae6/61ae66550e9011b3f711850e8bffffdf029a7309" alt="attachment image"
Here at loveholidays we are heavily dependant on Terraform. All of our Google Cloud infrastructure is managed using Terraform, along with a…
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
as in one multiple atlantis one repo?
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
no, just as in developing the code to support new source code hosts. last time i looked, it was a bit of a spaghetti mess touching all sorts of core internal parts
2021-09-18
data:image/s3,"s3://crabby-images/31b58/31b58b6f34dfe43c626c1abcdabe0541e2a898cc" alt="Ozzy Aluyi avatar"
Hello Guys, I’m trying to create parameters in AWS SSM- any ideas/solution will be much appreciated.
data:image/s3,"s3://crabby-images/31b58/31b58b6f34dfe43c626c1abcdabe0541e2a898cc" alt="Ozzy Aluyi avatar"
data "aws_ssm_parameter" "rds_master_password" {
name = "/grafana/GF_RDS_MASTER_PASSWORD"
with_decryption = "true"
}
resource "aws_ssm_parameter" "rds_master_password" {
name = "/grafana/GF_RDS_MASTER_PASSWORD"
description = "The parameter description"
type = "SecureString"
value = data.aws_ssm_parameter.rds_master_password.value
}
resource "aws_ssm_parameter" "GF_SERVER_ROOT_URL" {
name = "/grafana/GF_SERVER_ROOT_URL"
type = "String"
value = "https://${var.dns_name}"
}
resource "aws_ssm_parameter" "GF_LOG_LEVEL" {
name = "/grafana/GF_LOG_LEVEL"
type = "String"
value = "INFO"
}
resource "aws_ssm_parameter" "GF_INSTALL_PLUGINS" {
name = "/grafana/GF_INSTALL_PLUGINS"
type = "String"
value = "grafana-worldmap-panel,grafana-clock-panel,jdbranham-diagram-panel,natel-plotly-panel"
}
resource "aws_ssm_parameter" "GF_DATABASE_USER" {
name = "/grafana/GF_DATABASE_USER"
type = "String"
value = "root"
}
resource "aws_ssm_parameter" "GF_DATABASE_TYPE" {
name = "/grafana/GF_DATABASE_TYPE"
type = "String"
value = "mysql"
}
resource "aws_ssm_parameter" "GF_DATABASE_HOST" {
name = "/grafana/GF_DATABASE_HOST"
type = "String"
value = "${aws_rds_cluster.grafana.endpoint}:3306"
}
data:image/s3,"s3://crabby-images/31b58/31b58b6f34dfe43c626c1abcdabe0541e2a898cc" alt="Ozzy Aluyi avatar"
Error: Error describing SSM parameter (/grafana/GF_RDS_MASTER_PASSWORD): ParameterNotFound:
│
│ with module.Grafana_terraform.data.aws_ssm_parameter.rds_master_password,
│ on Grafana_terraform/ssm.tf line 1, in data "aws_ssm_parameter" "rds_master_password":
│ 1: data "aws_ssm_parameter" "rds_master_password" {
│
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
Looks like you don’t have the parameter created and so your data source is failing to pull it
data:image/s3,"s3://crabby-images/31b58/31b58b6f34dfe43c626c1abcdabe0541e2a898cc" alt="Ozzy Aluyi avatar"
@RB thanks. Sorted now.
data:image/s3,"s3://crabby-images/f423c/f423c8e850268e533a4e86e173d6f4a9a3b27039" alt="managedkaos avatar"
@Ozzy Aluyi you have a conflict with the data and resource for the parameter named rds_master_password
On line 1, you are trying to read it as data. and on line 5 you are trying to create it as a resource.
If its already created and you just want to read it, remove the resource "aws_ssm_parameter" "rds_master_password" {…
section.
If you are trying to create it, remove the data "aws_ssm_parameter" "rds_master_password" {...
section.
Of course, if you are reading it, you will need to find a way to get the value into place. In summary, you can’t have a data resource that calls on itself.
If you are trying to create and store a password, consider using the random_password
resource and storing the result of that in the parameter.
https://registry.terraform.io/providers/hashicorp/random/latest/docs/resources/password
data:image/s3,"s3://crabby-images/daf2f/daf2fea5b8c6f0023ce9fca916352ee62c98b3d1" alt="Michael Dizon avatar"
hey guys, i am a little confused about what dns_gbl_delegated
refers to in eks-iam
https://github.com/cloudposse/terraform-aws-components/blob/master/modules/eks-iam/tfstate.tf#L51
Opinionated, self-contained Terraform root modules that each solve one, specific problem - terraform-aws-components/tfstate.tf at master · cloudposse/terraform-aws-components
data:image/s3,"s3://crabby-images/daf2f/daf2fea5b8c6f0023ce9fca916352ee62c98b3d1" alt="Michael Dizon avatar"
is delegated-dns
supposed to be added to the global env as well as regional?
data:image/s3,"s3://crabby-images/daf2f/daf2fea5b8c6f0023ce9fca916352ee62c98b3d1" alt="Michael Dizon avatar"
i modified the remote state for dns_gbl_delegated
to point to primary-dns
– not sure if that’s going to cause any issues later on
data:image/s3,"s3://crabby-images/31b58/31b58b6f34dfe43c626c1abcdabe0541e2a898cc" alt="Ozzy Aluyi avatar"
@managedkaos thanks for the solution. the random_password
will make more sense,
2021-09-19
data:image/s3,"s3://crabby-images/0c2a3/0c2a39176cfaf6b69c6c0f18c7e39c948273dfc2" alt="MrAtheist avatar"
Would like some assistance with the following error with fargate task. It seems like the stuff inside container_definitions
isnt being registered at all… im getting all sorts of error saying args not found when they are clearly within the template. EDIT: terraform state show data.template_file.main
got all the right args in the json.
Fargate only supports network mode 'awsvpc'.
Fargate requires that 'cpu' be defined at the task level.
resource "aws_ecs_task_definition" "main" {
family = "${var.app_name}-app"
execution_role_arn = aws_iam_role.ecs_task_execution_role.arn
#network_mode = "awsvpc"
requires_compatibilities = ["FARGATE"]
#cpu = var.fargate_cpu
#memory = var.fargate_memory
container_definitions = data.template_file.main.rendered
}
data "template_file" "main" {
template = file("./templates/ecs/main_app.json.tpl")
vars = {
app_name = var.app_name
app_image = var.app_image
container_port = var.container_port
app_port = var.app_port
fargate_cpu = var.fargate_cpu
fargate_memory = var.fargate_memory
aws_region = var.aws_region
}
}
# ./templates/ecs/main_app.json.tpl
[
{
"name": "${app_name}",
"image": "${app_image}",
"cpu": ${fargate_cpu},
"memory": ${fargate_memory},
"logConfiguration": {
"logDriver": "awslogs",
"options": {
"awslogs-group": "/ecs/${app_name}",
"awslogs-region": "${aws_region}",
"awslogs-stream-prefix": "ecs"
}
},
"portMappings": [
{
"containerPort": ${container_port},
"hostPort": ${app_port}
}
]
}
]
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
Try using this module
https://github.com/cloudposse/terraform-aws-ecs-container-definition
Terraform module to generate well-formed JSON documents (container definitions) that are passed to the aws_ecs_task_definition Terraform resource - GitHub - cloudposse/terraform-aws-ecs-container-…
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
data:image/s3,"s3://crabby-images/7580d/7580db708596c96e1b7f7ef7338247447b84c8ce" alt="Pedro Santana avatar"
Hello folks, Im trying to use [AWS MQ Module](https://github.com/cloudposse/terraform-aws-mq-broker) but it look
s to have a issue on Benchmark Infraestructure Security. However i cant see what
s kind of issues it is on github page. Anyone can explain this for me ?
Terraform module for provisioning an AmazonMQ broker - GitHub - cloudposse/terraform-aws-mq-broker: Terraform module for provisioning an AmazonMQ broker
2021-09-20
data:image/s3,"s3://crabby-images/863b6/863b6f5ab63796d578d4e810a611e72658d54606" alt="Vikram Yerneni avatar"
Fellas, is there a way to create multiple users with the module//github.com/cloudposse/terraform-aws-iam-s3-user> I tried to add a variable for creating multiple users, but its not picking up as two users instead its combining into one//github.com/cloudposse/terraform-aws-iam-s3-user/blob/master/examples/complete/fixtures.us-west-1.tfvars#L9>
data:image/s3,"s3://crabby-images/863b6/863b6f5ab63796d578d4e810a611e72658d54606" alt="Vikram Yerneni avatar"
It ended up doing like this:
~ user = "user1" -> "user1user2" # forces replacement
data:image/s3,"s3://crabby-images/863b6/863b6f5ab63796d578d4e810a611e72658d54606" alt="Vikram Yerneni avatar"
This is the tfvars entry
iam_user_name = "user1, user2"
data:image/s3,"s3://crabby-images/863b6/863b6f5ab63796d578d4e810a611e72658d54606" alt="Vikram Yerneni avatar"
Any clue here fellas @channel
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
can you reference that module more than once - once for each user ?
data:image/s3,"s3://crabby-images/863b6/863b6f5ab63796d578d4e810a611e72658d54606" alt="Vikram Yerneni avatar"
I basically pulled this module into our gitlab and referred it as a child module from my parent module.
data:image/s3,"s3://crabby-images/863b6/863b6f5ab63796d578d4e810a611e72658d54606" alt="Vikram Yerneni avatar"
Not sure how can I add one more reference again within the same parent module Ronak
data:image/s3,"s3://crabby-images/863b6/863b6f5ab63796d578d4e810a611e72658d54606" alt="Vikram Yerneni avatar"
If I add on multiple references in my parent module like this
# CloudPosse Module for creating AWS IAM User along with S3 Permissions
module "aws-iam-s3-user" {
count = var.aws-iam-s3-user_enabled ? 1 : 0
source = "[email protected]:qomplx/engineering/infrastructure/terraform-modules/terraform-cloudposse-aws-iam-s3-user.git"
name = var.iam_user_name
s3_actions = var.s3_actions
s3_resources = var.s3_resources
}
It will be complicated when the time comes for 50 - 100 users.
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
you would need to do a for_each
like this
# CloudPosse Module for creating AWS IAM User along with S3 Permissions
module "aws_iam_s3_user" {
for_each = var.aws-iam-s3-user_enabled ? toset(var.users) : 0
source = "cloudposse/iam-s3-user/aws"
version = "0.15.3"
name = each.key
s3_actions = var.s3_actions
s3_resources = var.s3_resources
}
then you can pass in var.users = ["user1", "user2"]
something like that would work
data:image/s3,"s3://crabby-images/863b6/863b6f5ab63796d578d4e810a611e72658d54606" alt="Vikram Yerneni avatar"
Sure, let me try this option…
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
note: for best practices
• i renamed the module name so it uses underscores instead of dashes
• i set the source and version so its pinned
data:image/s3,"s3://crabby-images/863b6/863b6f5ab63796d578d4e810a611e72658d54606" alt="Vikram Yerneni avatar"
Unserstood…
data:image/s3,"s3://crabby-images/863b6/863b6f5ab63796d578d4e810a611e72658d54606" alt="Vikram Yerneni avatar"
Testing this for_each method…
data:image/s3,"s3://crabby-images/863b6/863b6f5ab63796d578d4e810a611e72658d54606" alt="Vikram Yerneni avatar"
It ended up with this output Ronak
│ Error: Invalid value for input variable
209│
210│ on ./terraform.tfvars line 34:
211│ 34: users = ["user1", "user2"]
212│
213│ The given value is not valid for variable "users": string required.
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
You need to create a variable
data:image/s3,"s3://crabby-images/863b6/863b6f5ab63796d578d4e810a611e72658d54606" alt="Vikram Yerneni avatar"
Actually hang on
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
Or a local
data:image/s3,"s3://crabby-images/863b6/863b6f5ab63796d578d4e810a611e72658d54606" alt="Vikram Yerneni avatar"
I actually created a variable for users and passed the values after your change
data:image/s3,"s3://crabby-images/863b6/863b6f5ab63796d578d4e810a611e72658d54606" alt="Vikram Yerneni avatar"
And I ended up with The given value is not valid for variable "users": string required.
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
Change the variable type to list
data:image/s3,"s3://crabby-images/863b6/863b6f5ab63796d578d4e810a611e72658d54606" alt="Vikram Yerneni avatar"
aah ok ok
data:image/s3,"s3://crabby-images/863b6/863b6f5ab63796d578d4e810a611e72658d54606" alt="Vikram Yerneni avatar"
one sec
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
It might help to do some terraform tutorials to pick up the basics
data:image/s3,"s3://crabby-images/863b6/863b6f5ab63796d578d4e810a611e72658d54606" alt="Vikram Yerneni avatar"
Yeah, I am not an expert in TF… Learning as I go. And in this case, instead of 1 for for_each condition a set ([]) and few other changes worked
data:image/s3,"s3://crabby-images/863b6/863b6f5ab63796d578d4e810a611e72658d54606" alt="Vikram Yerneni avatar"
Thanks Ronak for the inputs here. Appreceate it
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
data:image/s3,"s3://crabby-images/863b6/863b6f5ab63796d578d4e810a611e72658d54606" alt="Vikram Yerneni avatar"
Hi Ronak, can I bother you for one more question I am having here while dealing with this module?
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
data:image/s3,"s3://crabby-images/863b6/863b6f5ab63796d578d4e810a611e72658d54606" alt="Vikram Yerneni avatar"
Sure then…
My question here is, since I got the creation multiple users sorted out, I am trying to give permissions for an individual user for a specific S3 resource. But the problem here is when I give multiple S3 resources (under s3_resources
), all users are getting the permissions applied for all S3 resources by default.
In my case, basically I want to target an individual user for an individual S3 resource.
data:image/s3,"s3://crabby-images/863b6/863b6f5ab63796d578d4e810a611e72658d54606" alt="Vikram Yerneni avatar"
I am missing the logic on how to get to this objective here Ronak using this module…
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
couldnt you use something like module.aws_iam_s3_user.user-1
to reference a specific user ?
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
or perhaps im misunderstanding
data:image/s3,"s3://crabby-images/863b6/863b6f5ab63796d578d4e810a611e72658d54606" alt="Vikram Yerneni avatar"
Basically, this is how my setup is: main.tf
iam_user_name = local.iam_user_name
s3_actions = var.s3_actions
s3_resources = local.s3_resources
aws-iam-s3-user_enabled = var.aws-iam-s3-user_enabled
locals {
s3_resources = ["S3 bucket 1", "S3 bucket 2"]
iam_user_name = ["IAM User 1", "IAM User 2"]
}
And the tfvars file has the S3:actions (get object)
So whats happening here is, all IAM Users are getting permissions on all S3 buckets. So, I am trying to tag basically IAM user 1 with only S3 bucket 1 only and IAM user 2 with S3 bucket 2 and so on….
data:image/s3,"s3://crabby-images/863b6/863b6f5ab63796d578d4e810a611e72658d54606" alt="Vikram Yerneni avatar"
In the above code, I need to link each iam_user_name
with a specific s3_resources
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
i thnk you may want this zipmap function https://www.terraform.io/docs/language/functions/zipmap.html
The zipmap function constructs a map from a list of keys and a corresponding list of values.
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
zipmap(local.iam_user_name, local.s3_resources)
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
that will create a mapping of the user to the s3 resource
data:image/s3,"s3://crabby-images/863b6/863b6f5ab63796d578d4e810a611e72658d54606" alt="Vikram Yerneni avatar"
Ok, I am gonna try to work with this zipmap
Function and will let u know if i find a solution
data:image/s3,"s3://crabby-images/863b6/863b6f5ab63796d578d4e810a611e72658d54606" alt="Vikram Yerneni avatar"
Thanks again Ronak
data:image/s3,"s3://crabby-images/863b6/863b6f5ab63796d578d4e810a611e72658d54606" alt="Vikram Yerneni avatar"
I used a key/value pair to match the iam user and s3 buckets Ronak….
data:image/s3,"s3://crabby-images/863b6/863b6f5ab63796d578d4e810a611e72658d54606" alt="Vikram Yerneni avatar"
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
Awesome!
data:image/s3,"s3://crabby-images/345c8/345c81d6b5a7449dc4baaa7e9fd0d2ea065da02e" alt="David avatar"
Hi, all. I’m trying to use cloudposse/terraform-aws-cloudfront-s3-cdn
in a module with an existing origin bucket managed in a higher level block using cloudposse/terraform-aws-s3-bucket
. I’m getting a continual change cycle where the CDN module sets the origin bucket policy, but then the S3 module goes in and wants to re-write the policy. I’m not sure how to address this. Is there a way to get the S3 module to ignore_changes on the bucket policy or pass in the CDN OAI policy bits so that they’re not stomped on by S3 module runs?
data:image/s3,"s3://crabby-images/345c8/345c81d6b5a7449dc4baaa7e9fd0d2ea065da02e" alt="David avatar"
FYI, I addressed this via copying out the bucket policy and hard coding it into the s3-bucket module. This is exceptionally gross, but it lets my applys proceed.
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
:wave: Anyone know if possible to ignore_changes
to an attribute in a dynamic block? Doesn’t seem so.
2021-09-21
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
Anyone building self-hosted GitHub Action Runners using terraform? I found this module, which looks pretty reasonable… https://github.com/philips-labs/terraform-aws-github-runner
Terraform module for scalable GitHub action runners on AWS - GitHub - philips-labs/terraform-aws-github-runner: Terraform module for scalable GitHub action runners on AWS
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
Yes, I’ve come across this one. It’s very nice!
Terraform module for scalable GitHub action runners on AWS - GitHub - philips-labs/terraform-aws-github-runner: Terraform module for scalable GitHub action runners on AWS
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
We use a similar but smaller one at cloudposse
https://github.com/cloudposse/terraform-aws-components/tree/master/modules/github-runners
Opinionated, self-contained Terraform root modules that each solve one, specific problem - terraform-aws-components/modules/github-runners at master · cloudposse/terraform-aws-components
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
oh nice! in case you didn’t see it, support for ephemeral (one-time) runners was just released, https://github.blog/changelog/2021-09-20-github-actions-ephemeral-self-hosted-runners-new-webhooks-for-auto-scaling/
data:image/s3,"s3://crabby-images/2d934/2d93447a1f420ae1a228da48bfd9377bba76fefd" alt="attachment image"
GitHub Actions: Ephemeral self-hosted runners & new webhooks for auto-scaling
data:image/s3,"s3://crabby-images/abcbf/abcbf43fc3d244b8d096856d18273c7929497956" alt="Frank avatar"
What is considered a “best practice” when dealing with many projects that are mostly similar in setup / configuration? A lot of our projects share ~90-95% of the same setup approach (e.g. VPC + ALB + ECS + RDS + Redis + SES + ACM + SSM) and only differ slightly (some have no Redis or no RDS, or additional parameters assigned to the ECS instance).
For each project we currently have separate Git repositories and the current approach when new infrastructures needs to be built that all Terraform code for one of the other projects is copied in and modified accordingly (mostly replacing vars, adding in some additional ECS Secrets / Parameters etc). This is fairly quick to do and is also flexible as we can simply add or remove things we do (not) need.
But it doesn’t feel like the most optimal approach. It’s also somewhat of a PITA if a change has to be made across all projects.
A few idea’s that spring to mind to address this:
- Create a Terraform “app” module where we can toggle components using variables (e.g.
redis_enable = false
), use this as only module and add in optional custom extra’s (e.g. a project that needs a service not covered by theapp
module) - Use
Atmos
(but this appears to be pretty much the same way by copy/pasting) I’m eager to learn how others are doing this.
data:image/s3,"s3://crabby-images/daf2f/daf2fea5b8c6f0023ce9fca916352ee62c98b3d1" alt="Michael Dizon avatar"
+1 for Atmos
data:image/s3,"s3://crabby-images/1e7fb/1e7fb012e9114db9a49ef4fb0140243909a277f1" alt="Matt Gowie avatar"
Problem with the single App module is that you’ll run into your root module being too large, which can be a huge pain due to large blast radius and a host of other annoying problems.
I’d suggest atmos and the SweetOps workflow as well. It is copying + pasting using vendir
, so it follows a defined pattern and ensures that you don’t end up drifting your components (root modules) from one another. You’ll need to make that a policy at your org, but that shouldn’t be too hard: “No one updates components locally — updates only go upstream and then they’re updated in the consuming project via vendir”.
You could also look into potentially consolidating all your git repos and then each of your environments / projects just becomes another Stack file.
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
Yeah, I’ve stayed away from a single app module but have a similar issue. Lots of same but slightly different modules to compose a service. One way could be to have a “template” terraform repo that creates the real service repo based on some vars. Not sure how I feel about this. Plenty of tools out there for templating same but different services
data:image/s3,"s3://crabby-images/abcbf/abcbf43fc3d244b8d096856d18273c7929497956" alt="Frank avatar"
Thanks @Matt Gowie!
The root module being too large is definitely a problem.
Yesterday - before I asked this question - I was experimenting with building one but I wanted everything to be toggle-able (ecs on/off, redis on/off, acm cert on/off, rds on/off etc) but even after tinkering on it for ~2 hours it already became quite complex with a large number of enabled
/count
/try()
etc.
Looking into Atmos
has been on my backlog ever since its demo in Office Hours a few months ago. Good excuse to spend some time on that now I guess :-)
I did find https://github.com/cloudposse/atmos/blob/master/example/vendir.yml and https://github.com/cloudposse/terraform-aws-components which seems like a good starting point.
Universal Tool for DevOps and Cloud Automation (works with terraform, helm, helmfile, istioctl, etc) - atmos/vendir.yml at master · cloudposse/atmos
Opinionated, self-contained Terraform root modules that each solve one, specific problem - GitHub - cloudposse/terraform-aws-components: Opinionated, self-contained Terraform root modules that each…
data:image/s3,"s3://crabby-images/1e7fb/1e7fb012e9114db9a49ef4fb0140243909a277f1" alt="Matt Gowie avatar"
@Frank Start with https://docs.cloudposse.com/ — I wrote those up earlier this year and they cover a good intro of what you can do and how it all works out. Would be great to hear any feedback as well!
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Keep in mind that with atmos you get import
functionality, so you can define the stack and then import it to rapidly deploy. However, there’s a lot of other architectural decisions we make in how we design our modules/components that ensures it works very well for us.
data:image/s3,"s3://crabby-images/abcbf/abcbf43fc3d244b8d096856d18273c7929497956" alt="Frank avatar"
Excellent, thanks. It’s quite a shift from how we’re doing things right now but its a better approach for maintaining many projects. And of course being able to onboard new customers/environments even faster.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Yes, agreed - it’s a shift that may require some juggling.
data:image/s3,"s3://crabby-images/80373/8037326232faccc0c2ecbf3328a31f4ffed41906" alt="Ryan Ryke avatar"
has anyone been able to get the terraform-aws-ecs-web-app to work with for_each
it seems to be cranky with the embedded provider configuration in the github-webhooks module. https://github.com/cloudposse/terraform-github-repository-webhooks/blob/master/main.tf
Terraform module to provision webhooks on a set of GitHub repositories - terraform-github-repository-webhooks/main.tf at master · cloudposse/terraform-github-repository-webhooks
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I have been a contributor for that module
Terraform module to provision webhooks on a set of GitHub repositories - terraform-github-repository-webhooks/main.tf at master · cloudposse/terraform-github-repository-webhooks
data:image/s3,"s3://crabby-images/80373/8037326232faccc0c2ecbf3328a31f4ffed41906" alt="Ryan Ryke avatar"
The Terraform configuration must be valid before initialization so that
Terraform can determine which modules and providers need to be installed.
╷
│ Error: Module module.apps.module.web_app.module.ecs_codepipeline.module.github_webhooks contains provider configuration
│
│ Providers cannot be configured within modules using count, for_each or depends_on.
data:image/s3,"s3://crabby-images/80373/8037326232faccc0c2ecbf3328a31f4ffed41906" alt="Ryan Ryke avatar"
yeah i think im in there somewhere also
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
there was a conversation about moving the provider out of the module
data:image/s3,"s3://crabby-images/80373/8037326232faccc0c2ecbf3328a31f4ffed41906" alt="Ryan Ryke avatar"
would be bueno, can you link me to that ?
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I mean internally
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
so the way I used it is that I added the provider in my module and that will take precedence over the cloudposse module
data:image/s3,"s3://crabby-images/80373/8037326232faccc0c2ecbf3328a31f4ffed41906" alt="Ryan Ryke avatar"
but will that get rid of the error… the provider is still there
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
the reason why it was there was that you could use the anonymous API or credentials pass through the GITHUB_ ENV variables which the provider can read
data:image/s3,"s3://crabby-images/80373/8037326232faccc0c2ecbf3328a31f4ffed41906" alt="Ryan Ryke avatar"
right, would be nice if it just needed to be defined in the root
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
send a PR, I can approve it
data:image/s3,"s3://crabby-images/80373/8037326232faccc0c2ecbf3328a31f4ffed41906" alt="Ryan Ryke avatar"
yeah i think it fundamentally changes the codepipeline module
data:image/s3,"s3://crabby-images/80373/8037326232faccc0c2ecbf3328a31f4ffed41906" alt="Ryan Ryke avatar"
not sure anyone would be too happy with that change
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
it is a pretty bad practice to set the provider in a submodule
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
what I did was to use the ecs-web-app module but I set the github stufff outside of that module
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
the access for codepipeline can be done after the fact and it will still work
data:image/s3,"s3://crabby-images/80373/8037326232faccc0c2ecbf3328a31f4ffed41906" alt="Ryan Ryke avatar"
yeah, none of that will work with a for_each loop
data:image/s3,"s3://crabby-images/80373/8037326232faccc0c2ecbf3328a31f4ffed41906" alt="Ryan Ryke avatar"
data:image/s3,"s3://crabby-images/80373/8037326232faccc0c2ecbf3328a31f4ffed41906" alt="Ryan Ryke avatar"
this is what i need https://github.com/hashicorp/terraform/issues/24476
Use-cases I'd like to be able to provision the same set of resources in multiple regions a for_each on a module. However, looping over providers (which are tied to regions) is currently not sup…
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
yes
data:image/s3,"s3://crabby-images/62a5e/62a5e34972ae7ac85a1e649350883d61306e0659" alt="András Sándor avatar"
Following up on this question, I’m having the same issue, and wondering if anyone has a workaround. I’m using ecs-web-app module, that calls codepipeline child module, which in turn calls github webhooks child module. I get the following error
│ Error: Module module.ecs_web_app.module.ecs_codepipeline.module.github_webhooks contains provider configuration │ │ Providers cannot be configured within modules using count, for_each or │ depends_on.
I’m using codestar connections so would not need the webhooks module at all. Any way to disable github webooks module from ecs-web-app? My only idea right now is to have all these modules in a local source and modify them to get rid of the validation error.
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
that module is opinionated and uses github so you could disable the webhook and do it yourself
data:image/s3,"s3://crabby-images/80373/8037326232faccc0c2ecbf3328a31f4ffed41906" alt="Ryan Ryke avatar"
@András Sándor i forked it https://github.com/itsacloudlife/terraform-aws-ecs-web-app-no-pipeline
Terraform module that implements a web app on ECS and supports autoscaling, CI/CD, monitoring, ALB integration, and much more.
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I have use that module with no codepipeline before but if you want to support other products PRs are welcome
data:image/s3,"s3://crabby-images/80373/8037326232faccc0c2ecbf3328a31f4ffed41906" alt="Ryan Ryke avatar"
im not sure if they updated it but the github provider in the codepipeline sub module is what busted it
data:image/s3,"s3://crabby-images/80373/8037326232faccc0c2ecbf3328a31f4ffed41906" alt="Ryan Ryke avatar"
even when i disable the sub-module it’s still cranky
2021-09-22
data:image/s3,"s3://crabby-images/15e14/15e147ebea45d62d0e2f0df394b8f94ba8a2cde9" alt="R Dha avatar"
any good resources to learn terraform for gcp?
data:image/s3,"s3://crabby-images/a2e84/a2e8465124e1c2794b4fa6a80410f20b52d1dd06" alt="ByronHome avatar"
HI everyone :hand:,
I have weird behavior with s3 terraform resource. Specifically with this aws_s3_bucket_object
.
I have a local property array list, containing a .csv values, and I need to create a s3 object for each element array list value.
This is my terraform code:
local{
foo_values = [
{
"name" = "foo_a"
"content" = <<-EOT
var_1,var_2,var_3,var_4
value_1,value_2,value_3,value_4
EOT
},
{
"name" = "foo_b"
"content" = <<-EOT
var_1,var_2,var_3,var_4
value_1,value_2,value_3,value_4
EOT
}
]
}
aws_s3_bucket_object
resource "aws_s3_bucket_object" "ob" {
bucket = aws_s3_bucket.b.id
count = length(local.foo_values)
key = "${local.foo_values[count.index].name}.csv"
content = local.foo_values[count.index].content
content_type = "text/csv"
}
When i apply it locally, all works fine, and then when i try to make a terraform plan it give me a No changes. Infrastructure is up-to-date
message
My coworkers tried to make a terraform plan and they got the same
message.
But, when I launch a terraform plan into Codebuild container, with the same terraform version and with no code changes. The terraform plan give me this changes to apply.
data:image/s3,"s3://crabby-images/a2e84/a2e8465124e1c2794b4fa6a80410f20b52d1dd06" alt="ByronHome avatar"
The atrr content
of aws_s3_bucket_object
makes a diff in terraform tfstate when the code has not been modified. And this only appear when run terraform plan on CodeBuild context. If run locally all is ok.
¿Does anyone know what I’m doing wrong?.
I am using terraform version = 0.12.29
Thanks!!
data:image/s3,"s3://crabby-images/fcdc0/fcdc082ca5c426ae7a83f63c34dd4cae258c8b47" alt="Steve Wade (swade1987) avatar"
looking for some advise if possible … i have a go binary called rds-to-s3-exporter
it needs to run as a lambda in each account, I have two options here
- Add the binary as a zip file to an core s3 bucket
- Push a docker image to a core ECR registry however on both occasions I need to make changes to their the bucket policy or registry policy when we create a new account.
does anyone have a nice way to do this?
data:image/s3,"s3://crabby-images/f9865/f9865f3d4e421dd840f4c2ad0086f10b2f2e34ee" alt="Yoni Leitersdorf (Indeni Cloudrail) avatar"
Are all accounts in the same organization?
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
run the lambda centrally, using assume-role to gain access to other accounts?
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
as part of the new account process, create an s3 bucket in the account, push the binary there, and create the lambda in the account?
data:image/s3,"s3://crabby-images/fcdc0/fcdc082ca5c426ae7a83f63c34dd4cae258c8b47" alt="Steve Wade (swade1987) avatar"
my other option is using a gitlab release for the binary and then using a local provisioner in the module to get the zip file
data:image/s3,"s3://crabby-images/fcdc0/fcdc082ca5c426ae7a83f63c34dd4cae258c8b47" alt="Steve Wade (swade1987) avatar"
this way i don’t need to worry about how many accounts we create as this will just work regardless
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
a gitlab release… that would be an interesting provider datasource… have the provider retrieve the binary instead of a local provisioner…
data:image/s3,"s3://crabby-images/fcdc0/fcdc082ca5c426ae7a83f63c34dd4cae258c8b47" alt="Steve Wade (swade1987) avatar"
For speed I’m think of just using a local provisioner trying to work out how to obtain it though as the glab binary requires interaction
data:image/s3,"s3://crabby-images/840f2/840f20f95264f61befe3a4f5d9f7a85f08f3726c" alt="Release notes from terraform avatar"
v1.1.0-alpha20210922 1.1.0 (Unreleased) UPGRADE NOTES: Terraform on macOS now requires macOS 10.13 High Sierra or later; Older macOS versions are no longer supported. The terraform graph command no longer supports -type=validate and -type=eval options. The validate graph is always the same as the plan graph anyway, and the “eval” graph was just an implementation detail of the terraform console command. The default behavior of creating a plan graph should be a reasonable replacement for both of the removed graph…
data:image/s3,"s3://crabby-images/7bda2/7bda22f3a49bb8e1f2a102ca8405ad8f119c7818" alt="Kevin Neufeld(PayByPhone) avatar"
Question: Curious to know if someone has a solution to bootstrap RDS Postgres for IAM authentication, specifically creating and granting the IAM user in the database?
for more context: https://aws.amazon.com/premiumsupport/knowledge-center/rds-postgresql-connect-using-iam/
data:image/s3,"s3://crabby-images/f9865/f9865f3d4e421dd840f4c2ad0086f10b2f2e34ee" alt="Yoni Leitersdorf (Indeni Cloudrail) avatar"
Can you explain what the gap is? Technically, you set iam_database_authentication_enabled
to true on the aws_db_instance
data:image/s3,"s3://crabby-images/f9865/f9865f3d4e421dd840f4c2ad0086f10b2f2e34ee" alt="Yoni Leitersdorf (Indeni Cloudrail) avatar"
On the IAM role front, this is what we do:
# IAM Policy: allow DB auth
resource "aws_iam_role_policy" "db-auth" {
count = length(local.psql_users)
name = "db-auth"
role = element(local.roles, count.index)
policy = <<-EOF
{
"Version": "2012-10-17",
"Statement": [
{
"Sid": "DBpermissions",
"Effect": "Allow",
"Action": [
"rds-db:connect"
],
"Resource": [
"arn:aws:rds-db:${var.aws_region}:${var.aws_account}:dbuser:${module.rds.rds_resource_id}/${element(local.psql_users, count.index)}"
]
}
]
}
EOF
}
data:image/s3,"s3://crabby-images/7bda2/7bda22f3a49bb8e1f2a102ca8405ad8f119c7818" alt="Kevin Neufeld(PayByPhone) avatar"
@Yoni Leitersdorf (Indeni Cloudrail) maybe I missed the ease of it but how are you populating the local user?
CREATE USER iamuser WITH LOGIN;
GRANT rds_iam TO iamuser;
currently teams are doing this manually. local-exec provisioner requires connectivity and access which our gitlab runner do not have. Wondering what others do, before I dive this.
data:image/s3,"s3://crabby-images/f9865/f9865f3d4e421dd840f4c2ad0086f10b2f2e34ee" alt="Yoni Leitersdorf (Indeni Cloudrail) avatar"
Ah yes, we use the local-exec to do it.
data:image/s3,"s3://crabby-images/fae68/fae68ef6d65ecb3e38809cc5ccb1e419e4f5b29d" alt="mrwacky avatar"
How are folks dealing with the braindeadedness that is TF 0.14+ .terraform.lock.hcl
files ? We have a pretty large set of Terraform roles/modules, and boy what a pain to manage & upgrade a zillion different .terraform.lock.hcl
files..
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
using terragrunt, i just delete it using hooks, but also add it to .gitignore…
before_hook "terraform_lock" {
commands = ["init"]
execute = ["rm", "-f", ".terraform.lock.hcl"]
}
after_hook "terraform_lock" {
commands = concat(get_terraform_commands_that_need_locking(), ["init"])
execute = ["rm", "-f", "${get_terragrunt_dir()}/.terraform.lock.hcl"]
}
data:image/s3,"s3://crabby-images/fae68/fae68ef6d65ecb3e38809cc5ccb1e419e4f5b29d" alt="mrwacky avatar"
Ha, yes, @Gabe is trying to get me to just git ignore them …
data:image/s3,"s3://crabby-images/fae68/fae68ef6d65ecb3e38809cc5ccb1e419e4f5b29d" alt="mrwacky avatar"
I wish they had some sort of hierarchical method like .gitconfig
so I could populate the list once per git repository…
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
for CI, we do also already zip up a pinned terraform binary and provider cache, and host the zip. then before execution, retrieve and extract the bundle. so not too much concern about the supply chain risks that the lock is trying to protect you from…
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@mrwacky like **/.terraform.lock.hcl
?
data:image/s3,"s3://crabby-images/62ea3/62ea3a0f57be2a1b9349cb1d798270aab599c544" alt="Alex Jurkiewicz avatar"
How do you manage that Loren?
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
you mean the bundle @Alex Jurkiewicz? currently still using terraform-bundle. eventually we’ll switch to terraform providers mirror
. wrapped in a make target
data:image/s3,"s3://crabby-images/fae68/fae68ef6d65ecb3e38809cc5ccb1e419e4f5b29d" alt="mrwacky avatar"
@Erik Osterman (Cloud Posse) - yup
data:image/s3,"s3://crabby-images/fae68/fae68ef6d65ecb3e38809cc5ccb1e419e4f5b29d" alt="mrwacky avatar"
I have worked up a disgusting shell script to regenerate all of them as quickly as possible.
data:image/s3,"s3://crabby-images/fae68/fae68ef6d65ecb3e38809cc5ccb1e419e4f5b29d" alt="mrwacky avatar"
I mean – I wish Terraform would walk up the filesystem tree to find .terraform.lock.hcl
similar to how git
searches for .gitignore
files.. Then I could have as few as 1 lockfile per repo
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
data:image/s3,"s3://crabby-images/f3346/f334630a1fd721c305932c4fdd5f24425aa53b6d" alt="Valter Silva avatar"
Hi All, I’ve started using the following module in one of my customers as a quickstart. We are making some modifications to meet our requirements. We’ve added the LICENSE
file but I can’t find the NOTICE
file as stated in the README.md
file. By not having a NOTICE
file I believe we need to add a header to our *tf
files, correct?
https://github.com/cloudposse/terraform-aws-ecs-alb-service-task
data:image/s3,"s3://crabby-images/62ea3/62ea3a0f57be2a1b9349cb1d798270aab599c544" alt="Alex Jurkiewicz avatar"
Not quite sure what you are thinking of, but the Apache Software Licence is permissive. If you fork the module, you can do whatever you want, except strip the CloudPosse copyright
data:image/s3,"s3://crabby-images/f3346/f334630a1fd721c305932c4fdd5f24425aa53b6d" alt="Valter Silva avatar"
I was under the impression that we must keep the LICENSE
file and add the CloudPosse copyright as header
for every file
data:image/s3,"s3://crabby-images/62ea3/62ea3a0f57be2a1b9349cb1d798270aab599c544" alt="Alex Jurkiewicz avatar"
do you want to relicense your fork? What you describe might be necessary in that case. But the simplest approach is to fork and change nothing about the license, commit your changes on top of the existing files
data:image/s3,"s3://crabby-images/fae68/fae68ef6d65ecb3e38809cc5ccb1e419e4f5b29d" alt="mrwacky avatar"
Your changes are too custom to send back as a PR to the cloudposse version?
data:image/s3,"s3://crabby-images/f3346/f334630a1fd721c305932c4fdd5f24425aa53b6d" alt="Valter Silva avatar"
2021-09-23
data:image/s3,"s3://crabby-images/9457b/9457b64e646640ca658d084aca1d141dbb62984a" alt="Dustin Lee avatar"
Hello, anybody hitting the issue with multiple MX Records on https://github.com/cloudposse/terraform-cloudflare-zone, getting stopped due to duplicate object error’s
Terraform module to provision a CloudFlare zone with DNS records, Argo, Firewall filters and rules - GitHub - cloudposse/terraform-cloudflare-zone: Terraform module to provision a CloudFlare zone w…
data:image/s3,"s3://crabby-images/9457b/9457b64e646640ca658d084aca1d141dbb62984a" alt="Dustin Lee avatar"
i think the object key may need to pull in the priority into the key id to differentiate
data:image/s3,"s3://crabby-images/9457b/9457b64e646640ca658d084aca1d141dbb62984a" alt="Dustin Lee avatar"
i changed the local.records to pull it in … bit hacky i got lost down the rabbit hole with the if logic and formatting if the record.priority was present, went with the try() instead seems to work cloudflare must throw it away if it doesn’t make sense
data:image/s3,"s3://crabby-images/62ea3/62ea3a0f57be2a1b9349cb1d798270aab599c544" alt="Alex Jurkiewicz avatar"
data:image/s3,"s3://crabby-images/62ea3/62ea3a0f57be2a1b9349cb1d798270aab599c544" alt="Alex Jurkiewicz avatar"
I think use of try
here makes sense. You could also do something with lookup
and coalesce
, but try
seems like a good simple fit
data:image/s3,"s3://crabby-images/9457b/9457b64e646640ca658d084aca1d141dbb62984a" alt="Dustin Lee avatar"
i think i’d prefer to have it that it checks for the record.priority and creat the record if exists, than just blat in a default and send it to cloudflare and hope they don’t stop taking it, if it’s not appropriate down the track what you reckon ?
data:image/s3,"s3://crabby-images/62ea3/62ea3a0f57be2a1b9349cb1d798270aab599c544" alt="Alex Jurkiewicz avatar"
I don’t know this module, from what I can see of your change you only changed the key used by items in local.records
. But it seems you are now talking about changing the records this module creates also? I can’t comment on that, I don’t know enough
data:image/s3,"s3://crabby-images/9457b/9457b64e646640ca658d084aca1d141dbb62984a" alt="Dustin Lee avatar"
Some records have a priority and some don’t, the try() will throw in a default value and it will be sent to cloudflare. Cloudflare take it and probably just don’t anything with for that record type.
data:image/s3,"s3://crabby-images/9457b/9457b64e646640ca658d084aca1d141dbb62984a" alt="Dustin Lee avatar"
i’ll play with it and see how it goes
data:image/s3,"s3://crabby-images/9457b/9457b64e646640ca658d084aca1d141dbb62984a" alt="Dustin Lee avatar"
2021-09-24
data:image/s3,"s3://crabby-images/d49a4/d49a494244cf33785cf7ec884631f180fbc7d705" alt="Jakub Igła avatar"
Hi Folks, I’m using your s3-website module, but whenever I try to run terraform plan
the data source data "aws_iam_policy_document" "default"
gets refreshed with different output and it messes up my plan, which should produce “no chanfges”. I’m on latest terraform, the module version is 0.17.1
. In the thread I’m attaching what it produces.
data:image/s3,"s3://crabby-images/d49a4/d49a494244cf33785cf7ec884631f180fbc7d705" alt="Jakub Igła avatar"
data "aws_iam_policy_document" "default" {
~ id = "3597815271" -> (known after apply)
~ json = jsonencode(
{
- Statement = [
- {
- Action = "s3:GetObject"
- Effect = "Allow"
- Principal = {
- AWS = "*"
}
- Resource = "arn:aws:s3:::sandbox.example.com/*"
- Sid = ""
},
]
- Version = "2012-10-17"
}
) -> (known after apply)
- version = "2012-10-17" -> null
~ statement {
- effect = "Allow" -> null
- not_actions = [] -> null
- not_resources = [] -> null
# (2 unchanged attributes hidden)
# (1 unchanged block hidden)
}
}
data:image/s3,"s3://crabby-images/d49a4/d49a494244cf33785cf7ec884631f180fbc7d705" alt="Jakub Igła avatar"
and that’s how I invoke it:
module "this_s3_website" {
source = "cloudposse/s3-website/aws"
version = "0.17.1"
context = module.this.context
logs_enabled = true
encryption_enabled = false
hostname = var.hostname
parent_zone_id = var.parent_zone_id
}
data:image/s3,"s3://crabby-images/d49a4/d49a494244cf33785cf7ec884631f180fbc7d705" alt="Jakub Igła avatar"
I did some troubleshooting and the data "aws_iam_policy_document"
gets “rebuilt” on every terraform plan
only when I have
provider "aws" {
default_tags {
tags = ...
}
}
If I remove it, the plan is correct - No changes. Your infrastructure matches the configuration.
Is it something to raise a bug for?
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
that’s a bug with the provider’s default_tags parameter
data:image/s3,"s3://crabby-images/139a7/139a7152f9e5ef6f76743f966d03911ac4c72a1b" alt="Almondovar avatar"
Hi all, in our terraform, we got environments
and we differentiate between the different envs by using different variables.
So far so good, but what happens when we don’t want the terraform code to be exactly the same in all envs?
For example, in dev
i want to do waf filter by ip’s in staging
i need to combine ip’s & urls and this is changing the terraform code and of course its trying to apply this code everywhere and not only in one specific env.
Is there any way to make some programmatic intelligence behind the tf like
if env = dev then run code A
elseif env = stage run code B
elseif env = prod run code C
thanks.
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
Could be a nifty tool … https://github.com/im2nguyen/rover
Interactive Terraform visualization. State and configuration explorer. - GitHub - im2nguyen/rover: Interactive Terraform visualization. State and configuration explorer.
data:image/s3,"s3://crabby-images/65abe/65abeec1637af13876edb28ff253db69acdcd8cb" alt="Grummfy avatar"
nice, does it support multiple state file? a replacement for terraboard?
data:image/s3,"s3://crabby-images/23c9d/23c9d2624af80405934b730b50bead715ecedad1" alt="Alyson avatar"
Hi, it looks like the desired_size variable from the eks-node-group module is not working.
Anyone else going through this?
terraform-aws-eks-node-group - Version 0.26.0 Terraform v0.14.11
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
the input var is passed to the local ng
map which is then passed in as scaling_config
in the aws_eks_node_group
resource
Terraform module to provision an EKS Node Group. Contribute to cloudposse/terraform-aws-eks-node-group development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
data:image/s3,"s3://crabby-images/23c9d/23c9d2624af80405934b730b50bead715ecedad1" alt="Alyson avatar"
Initial desired number of worker nodes (external changes ignored)
Does the desired_size variable only work when we create the nodes? After creating the nodes, this variable no longer works. That’s right?
data:image/s3,"s3://crabby-images/23c9d/23c9d2624af80405934b730b50bead715ecedad1" alt="Alyson avatar"
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
data:image/s3,"s3://crabby-images/10c5f/10c5f18510e11e73457c5af38950444503b0d326" alt="SlackBot avatar"
This message was deleted.
data:image/s3,"s3://crabby-images/fcdc0/fcdc082ca5c426ae7a83f63c34dd4cae258c8b47" alt="Steve Wade (swade1987) avatar"
is there a way to fire a cloudwatch event ad-hoc?
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
change the cron to run every 10 min and check
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
you can do a aws ecs task-run
command i believe
data:image/s3,"s3://crabby-images/fcdc0/fcdc082ca5c426ae7a83f63c34dd4cae258c8b47" alt="Steve Wade (swade1987) avatar"
i am getting this …
There was an error while saving rule cron-re-dev-pe-sbx-lambda-monthly-snapshots-to-s3-eu-west-1.
Details: 1 validation error detected: Value 'AWSEvents_cron-re-dev-pe-sbx-lambda-monthly-snapshots-to-s3-eu-west-1_terraform-20210924172025276000000001' at 'statementId' failed to satisfy constraint: Member must have length less than or equal to 100.
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
✗ echo 'AWSEvents_cron-re-dev-pe-sbx-lambda-monthly-snapshots-to-s3-eu-west-1_terraform-20210924172025276000000001' | wc -c
107
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
you need to reduce the number of chars of that name
data:image/s3,"s3://crabby-images/fcdc0/fcdc082ca5c426ae7a83f63c34dd4cae258c8b47" alt="Steve Wade (swade1987) avatar"
my rule is called [cron-re-dev-pe-sbx-lambda-monthly-snapshots-to-s3-eu-west-1](https://eu-west-1.console.aws.amazon.com/cloudwatch/home?region=eu-west-1#rules:name=cron-re-dev-pe-sbx-lambda-monthly-snapshots-to-s3-eu-west-1)
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
it looks like it’s prefixing AWSEvents_
to it and suffixing it with _terraform-20210924172025276000000001
which increases your name which goes over the max chars
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
are you using a name_prefix
instead of a name
argument on the resource ?
data:image/s3,"s3://crabby-images/fcdc0/fcdc082ca5c426ae7a83f63c34dd4cae258c8b47" alt="Steve Wade (swade1987) avatar"
name
data:image/s3,"s3://crabby-images/fcdc0/fcdc082ca5c426ae7a83f63c34dd4cae258c8b47" alt="Steve Wade (swade1987) avatar"
resource "aws_cloudwatch_event_rule" "weekly" {
count = var.schedule == "weekly" ? 1 : 0
name = "cron-${var.database_name}-lambda-weekly-snapshots-to-s3-${data.aws_region.current.name}"
description = "Cron to start the lambda that exports ${var.database_name} snapshots to S3 every Monday at 10am."
schedule_expression = "cron(0 10 ** MON *)"
}
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
make the name less descriptive and rely on the description field…?
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
you could put two rules, one that triggers one time now…
data:image/s3,"s3://crabby-images/fcdc0/fcdc082ca5c426ae7a83f63c34dd4cae258c8b47" alt="Steve Wade (swade1987) avatar"
its weird that it was created fine
data:image/s3,"s3://crabby-images/fcdc0/fcdc082ca5c426ae7a83f63c34dd4cae258c8b47" alt="Steve Wade (swade1987) avatar"
its when i tried to change it that it didn’t like it
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
i find it odd that it’s using that random terraform suffix without you using a name_prefix
data:image/s3,"s3://crabby-images/fcdc0/fcdc082ca5c426ae7a83f63c34dd4cae258c8b47" alt="Steve Wade (swade1987) avatar"
is there a recommended way to alert on a failed lambda invocation?
2021-09-25
data:image/s3,"s3://crabby-images/d8c06/d8c0686eb8c459be711881b026d562e3fa974657" alt="Joaquin Menchaca avatar"
SweetOps is no longer using helmfile? Is terraform used instead for k8s/helm? Any issues w/ current APi not supported w/ k8s provider, e.g. Ingress?
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
we’ve been using helm_release recently
https://registry.terraform.io/providers/hashicorp/helm/latest/docs/resources/release
we’ve converted a few of the helm files and haven’t noticed any glaring issues so far
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
yea, we’re mostly using terraform’s helm provider now natively
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Create helm release and common aws resources like an eks iam role - GitHub - cloudposse/terraform-aws-helm-release: Create helm release and common aws resources like an eks iam role
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
or where we’re deep in with helmfile for backing-services, we’ve started using the helmfile provider for terraform.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
for CD, we’re mostly investing in helm + argocd
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
there’s nothing wrong with helmfile, it’s just we were able to consolidate without giving up too much.
2021-09-26
data:image/s3,"s3://crabby-images/139a7/139a7152f9e5ef6f76743f966d03911ac4c72a1b" alt="Almondovar avatar"
Hi all, i am trying to use the and_statement
to combine different statements (we need to combine ip filtering with url).
The issue is that from the documentation is not clear if the and_statement
block should include inside it the statement
argument, or the opposite, the statement
block should include inside it the and_statement
argument:
I tried several ways of composing the code, can please someone tell me what i am doing wrong?
resource "aws_wafv2_web_acl" "alb_waf" {
name = "ALB-WAF"
description = "ALB"
scope = "REGIONAL"
default_action {
block {}
}
rule {
name = "allow-specific-ips"
priority = 1
action {
allow {}
}
statement {
and_statement {
ip_set_reference_statement {
arn = aws_wafv2_ip_set.ipset.arn
}
regex_pattern_set_reference_statement {
arn = aws_wafv2_regex_pattern_set.staging_regex.arn
}
} # and_statement
} # statement block
error code
Error: Unsupported block type
on main.tf line 56, in resource "aws_wafv2_web_acl" "alb_waf":
56: regex_pattern_set_reference_statement {
Blocks of type "regex_pattern_set_reference_statement" are not expected here.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
cc: @Ben Smith (Cloud Posse)
data:image/s3,"s3://crabby-images/f5393/f5393a0c9f0ffb642ee72180de2073dea1f5d863" alt="Ben Smith (Cloud Posse) avatar"
Hi @Almondovar, I agree these docs can be terribly confusing. So it looks like the rule{}
must contain a statement{}
which itself can contain a and_statement
, then within the and_statement
it can contain multiple statements
to join by and.
something like:
resource "aws_wafv2_web_acl" "alb_waf" {
name = "ALB-WAF"
description = "ALB"
scope = "REGIONAL"
default_action {
block {}
}
rule {
name = "allow-specific-ips"
priority = 1
action {
allow {}
}
statement {
and_statement {
statement {
ip_set_reference_statement {
arn = "aws_wafv2_ip_set.ipset.arn"
}
}
statement {
regex_pattern_set_reference_statement {
arn = "aws_wafv2_regex_pattern_set.staging_regex.arn"
text_transformation {
priority = 0
type = ""
}
}
}
}
# and_statement
}
# statement block
visibility_config {
cloudwatch_metrics_enabled = false
metric_name = null
sampled_requests_enabled = false
}
}
visibility_config {
cloudwatch_metrics_enabled = false
metric_name = null
sampled_requests_enabled = false
}
}
Another option for WAF rules would be to create them through AWS Firewall manager under WAF / WAF_v2 Policies
data:image/s3,"s3://crabby-images/f5393/f5393a0c9f0ffb642ee72180de2073dea1f5d863" alt="Ben Smith (Cloud Posse) avatar"
Note the above won’t just work as visibility config has to be set properly. but that should atleast help with the format of the rules
data:image/s3,"s3://crabby-images/393bc/393bccf74260bf8111a7c988a36a747eba2b7977" alt="Fizz avatar"
Try statement -> and_statement-> statement -> ip_set_reference_statement
data:image/s3,"s3://crabby-images/139a7/139a7152f9e5ef6f76743f966d03911ac4c72a1b" alt="Almondovar avatar"
thank you very much Fizz
2021-09-27
data:image/s3,"s3://crabby-images/55fa6/55fa6efe42ef9cc2f76d0cc8f6218c9dd178b784" alt="Ben Kero avatar"
Hi all. I’m not sure if this is the right place but I’m looking for a review for a PR I made to one of the Cloudposse Terraform AWS modules: https://github.com/cloudposse/terraform-aws-cloudtrail-s3-bucket/pull/54
what Allows the policy variable to be used in a useful way to set a custom S3 bucket policy Conditionally the data resource for the unused default bucket policy why Issue #19 outlines why this i…
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
cc @Ben Smith (Cloud Posse)
what Allows the policy variable to be used in a useful way to set a custom S3 bucket policy Conditionally the data resource for the unused default bucket policy why Issue #19 outlines why this i…
data:image/s3,"s3://crabby-images/55fa6/55fa6efe42ef9cc2f76d0cc8f6218c9dd178b784" alt="Ben Kero avatar"
Thanks Erik. I see an approval and tests passing. Now it needs merged.
data:image/s3,"s3://crabby-images/62ea3/62ea3a0f57be2a1b9349cb1d798270aab599c544" alt="Alex Jurkiewicz avatar"
I also have a PR needing review please https://github.com/cloudposse/terraform-aws-rds-cluster/pull/119
Fixes errors like: Error: error creating RDS cluster: InvalidParameterCombination: Cannot specify user name for instance cluster replication cluster
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
cc @Yonatan Koren
Fixes errors like: Error: error creating RDS cluster: InvalidParameterCombination: Cannot specify user name for instance cluster replication cluster
data:image/s3,"s3://crabby-images/62ea3/62ea3a0f57be2a1b9349cb1d798270aab599c544" alt="Alex Jurkiewicz avatar"
2021-09-28
data:image/s3,"s3://crabby-images/23c9d/23c9d2624af80405934b730b50bead715ecedad1" alt="Alyson avatar"
I am getting timeout when creating an eks cluster using module 0.43.2.
Terraform module for provisioning an EKS cluster. Contribute to cloudposse/terraform-aws-eks-cluster development by creating an account on GitHub.
2021-09-29
data:image/s3,"s3://crabby-images/840f2/840f20f95264f61befe3a4f5d9f7a85f08f3726c" alt="Release notes from terraform avatar"
v1.0.8 1.0.8 (September 29, 2021) BUG FIXES: cli: Check required_version as early as possibly during init so that version incompatibility can be reported before errors about new syntax (#29665) core: Don’t plan to remove orphaned resource instances in refresh-only plans (<a href=”https://github.com/hashicorp/terraform/issues/29640“…
Our current check of required_version happens after parsing the configuration, which may not be possible if new configuration constructs have been added to the language since the declared required_…
When planning in refresh-only mode, we must not remove orphaned resources due to changed count or for_each values from the planned state. This was previously happening because we failed to pass thr…
2021-09-30
data:image/s3,"s3://crabby-images/334be/334be9a7546b0e2999fea3f1bfa760b4590418e4" alt="Vlad Ionescu (he/him) avatar"
AWS just launched a new Cloud Control API ( 1 single CRUD API for AWS resources) and Terraform has a new provider for it (links still WIP I guess?): https://aws.amazon.com/blogs/aws/announcing-aws-cloud-control-api/
data:image/s3,"s3://crabby-images/440b0/440b0b9a50f3f360be9b097095c9d15f8f7d6f70" alt="attachment image"
Today, I am happy to announce the availability of AWS Cloud Control API a set of common application programming interfaces (APIs) that are designed to make it easy for developers to manage their AWS and third-party services. AWS delivers the broadest and deepest portfolio of cloud services. Builders leverage these to build any type of […]
data:image/s3,"s3://crabby-images/334be/334be9a7546b0e2999fea3f1bfa760b4590418e4" alt="Vlad Ionescu (he/him) avatar"
Link to the new provider: https://github.com/hashicorp/terraform-provider-awscc
Hasicorp blog yet to be posted
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
yeah that thing seems incredibly aspirational. we’ll see.
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
docs indicate it depends on cloudformation resource support. i guess it’s nice to have that exposed natively (best of both worlds!), but that support hasn’t always moved quickly…
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
i’m curious if the awscc provider accepts the same authentication mechanisms and configuration settings as the aws provider… can i pass a profile? a role_arn? credential_process? how do i override endpoints?
data:image/s3,"s3://crabby-images/e6209/e6209fb441ae1a71cc9575744231254abff00850" alt="OliverS avatar"
(Just saw the previous post about AWS Cloud Control) Being based on CloudFormation, I wonder how much of that bleeds through, esp since CF now supports stop-on-exception and resume-from-last-exception maybe TF interface to AWS Cloud Control API is ok.
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
i’m figuring we’ll see more multi-provider modules for a bit… things the aws provider does, things the awscc provider does… not loving that idea
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
registry docs went live recently, answering some of my questions on authentication… https://registry.terraform.io/providers/hashicorp/awscc/latest/docs#authentication
data:image/s3,"s3://crabby-images/2aef5/2aef5a17c3a3a17707602e405bee87c307755ca6" alt="lucaslu avatar"
hello folks, im very newbie on devops culture. so i was figuring if docker and terraform do the same job and why use terraform instead of docker who has a bigger marketshare, sorry if i was rough but im just a beginner trying to catch what is better to learn by now days
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
they are orthogonal. learn both.
data:image/s3,"s3://crabby-images/e6209/e6209fb441ae1a71cc9575744231254abff00850" alt="OliverS avatar"
@lucaslu they are very different:
• with terraform you write code the describes infrastructure resources like load balancers, security groups, virtual private clouds, etc
• with docker you build and run docker “images” in “containers” an image is like a snapshot of a mini linux environment and the container is like the computer running that linux Normally you need both: You will use terraform to setup resources that will be used to run docker containers, such as AWS ECS or EKS (or Azure AKS or Google GKE), databases, message queues, etc.
data:image/s3,"s3://crabby-images/2aef5/2aef5a17c3a3a17707602e405bee87c307755ca6" alt="lucaslu avatar"
thank u so much for the explanation OliverS
data:image/s3,"s3://crabby-images/e6209/e6209fb441ae1a71cc9575744231254abff00850" alt="OliverS avatar"
You’re welcome, good luck!
data:image/s3,"s3://crabby-images/0c2a3/0c2a39176cfaf6b69c6c0f18c7e39c948273dfc2" alt="MrAtheist avatar"
hey ya’ll, not sure if it’s possible, but heres a tiny problem im hitting…
1> Someone deployed some tf stuff from local, state file is stored in s3 2> Presumably this someone got thrown under the bus and didnt have a chance to push the iac, assuming iac is lost 3> The actual resources went thru some manual hell… and i would like to restore/revert back to the original state based on the json
is this possible? something to do with tainting…?
data:image/s3,"s3://crabby-images/62ea3/62ea3a0f57be2a1b9349cb1d798270aab599c544" alt="Alex Jurkiewicz avatar"
terraform will do this automatically
data:image/s3,"s3://crabby-images/62ea3/62ea3a0f57be2a1b9349cb1d798270aab599c544" alt="Alex Jurkiewicz avatar"
it will make the cloud infra look like what your local code specifies
data:image/s3,"s3://crabby-images/62ea3/62ea3a0f57be2a1b9349cb1d798270aab599c544" alt="Alex Jurkiewicz avatar"
eg, you have a stack which creates an rds instance of type r5.4xlarge. Someone comes along and changes the instance’s type to t3.small If you re-ran terraform, it would detect this change and propose changing the size back to r5.4xl
data:image/s3,"s3://crabby-images/0c2a3/0c2a39176cfaf6b69c6c0f18c7e39c948273dfc2" alt="MrAtheist avatar"
hmm maybe u missed the point where i dont have the actual tf code
data:image/s3,"s3://crabby-images/0c2a3/0c2a39176cfaf6b69c6c0f18c7e39c948273dfc2" alt="MrAtheist avatar"
i only have the state file
data:image/s3,"s3://crabby-images/0c2a3/0c2a39176cfaf6b69c6c0f18c7e39c948273dfc2" alt="MrAtheist avatar"
still doable u think?
data:image/s3,"s3://crabby-images/62ea3/62ea3a0f57be2a1b9349cb1d798270aab599c544" alt="Alex Jurkiewicz avatar"
oh. that’s not really possible
data:image/s3,"s3://crabby-images/62ea3/62ea3a0f57be2a1b9349cb1d798270aab599c544" alt="Alex Jurkiewicz avatar"
you can read the statefile and attempt to write the configuration it describes, by hand
data:image/s3,"s3://crabby-images/62ea3/62ea3a0f57be2a1b9349cb1d798270aab599c544" alt="Alex Jurkiewicz avatar"
well, I guess there is one other approach.
If you try and apply a blank configuration with this statefile, it will propose deleting every resource. You could copy and paste the resource definitions it proposes deleting into your local configuration. That will speed things up. If there were no modules involved..
data:image/s3,"s3://crabby-images/0c2a3/0c2a39176cfaf6b69c6c0f18c7e39c948273dfc2" alt="MrAtheist avatar"
hmm i’ll give this magic a shot
data:image/s3,"s3://crabby-images/0c2a3/0c2a39176cfaf6b69c6c0f18c7e39c948273dfc2" alt="MrAtheist avatar"
it’s complaining already…
Error: Provider configuration not present
To work with aws_route_table_association.public[2] its original provider
configuration at provider["registry.terraform.io/-/aws"] is required, but it
has been removed. This occurs when a provider configuration is removed while
objects created by that provider still exist in the state. Re-add the provider
configuration to destroy aws_route_table_association.public[2], after which
you can remove the provider configuration again.
data:image/s3,"s3://crabby-images/62ea3/62ea3a0f57be2a1b9349cb1d798270aab599c544" alt="Alex Jurkiewicz avatar"
you’ll need to add the aws provider at least
data:image/s3,"s3://crabby-images/0c2a3/0c2a39176cfaf6b69c6c0f18c7e39c948273dfc2" alt="MrAtheist avatar"
yes i did
provider "aws" {
shared_credentials_file = "~/.aws/credentials"
profile = "iac_hello_world" # CHANGE ME
region = "us-east-1"
}
data:image/s3,"s3://crabby-images/62ea3/62ea3a0f57be2a1b9349cb1d798270aab599c544" alt="Alex Jurkiewicz avatar"
ah. the original code was using a much older terraform version
data:image/s3,"s3://crabby-images/62ea3/62ea3a0f57be2a1b9349cb1d798270aab599c544" alt="Alex Jurkiewicz avatar"
you have to update the provider address from
registry.terraform.io/-/aws
to
registry.terraform.io/hashicorp/aws
data:image/s3,"s3://crabby-images/62ea3/62ea3a0f57be2a1b9349cb1d798270aab599c544" alt="Alex Jurkiewicz avatar"
there is a command to do it in your statefile automatically, but I forget it. You might be able to find it. Or you can edit the statefile manually
data:image/s3,"s3://crabby-images/0c2a3/0c2a39176cfaf6b69c6c0f18c7e39c948273dfc2" alt="MrAtheist avatar"
as in cli from tf?
data:image/s3,"s3://crabby-images/62ea3/62ea3a0f57be2a1b9349cb1d798270aab599c544" alt="Alex Jurkiewicz avatar"
yes
data:image/s3,"s3://crabby-images/0c2a3/0c2a39176cfaf6b69c6c0f18c7e39c948273dfc2" alt="MrAtheist avatar"
The terraform state replace-provider
command replaces the provider for resources in the Terraform state.
data:image/s3,"s3://crabby-images/62ea3/62ea3a0f57be2a1b9349cb1d798270aab599c544" alt="Alex Jurkiewicz avatar"
something like terraform state replace-providers -/aws hashicorp/aws
data:image/s3,"s3://crabby-images/62ea3/62ea3a0f57be2a1b9349cb1d798270aab599c544" alt="Alex Jurkiewicz avatar"
yup!
data:image/s3,"s3://crabby-images/0c2a3/0c2a39176cfaf6b69c6c0f18c7e39c948273dfc2" alt="MrAtheist avatar"
magic…
data:image/s3,"s3://crabby-images/0c2a3/0c2a39176cfaf6b69c6c0f18c7e39c948273dfc2" alt="MrAtheist avatar"
thanks, at least i see it plans to destroy everything now…
data:image/s3,"s3://crabby-images/0c2a3/0c2a39176cfaf6b69c6c0f18c7e39c948273dfc2" alt="MrAtheist avatar"
ok it turns out this is a vpc stack, and it appears that some NAT got deleted already… so in this case i guess theres no chance of bringing it back?
data:image/s3,"s3://crabby-images/e6209/e6209fb441ae1a71cc9575744231254abff00850" alt="OliverS avatar"
If the IAC is lost, you need to recreate it from scratch and bring the existing resources under its management.
You could loop over the items in the state file and auto create entries in a main.tf. Have a look at terraformer also, as it will generate a skeleton tf file, you will use the existing state file to tell it what to import.
Once all of the existing infra is back under tf management, you will have create definitions for the resources that have been deleted, you will have to use terraform state show NAME
and guess the spec that will recreate the missing resources.
data:image/s3,"s3://crabby-images/0c2a3/0c2a39176cfaf6b69c6c0f18c7e39c948273dfc2" alt="MrAtheist avatar"
let me give it a whirl