#terraform-aws-modules (2019-04)
Terraform Modules
Discussions related to https://github.com/terraform-aws-modules
Archive: https://archive.sweetops.com/terraform-aws-modules/
2019-04-01
data:image/s3,"s3://crabby-images/1621c/1621c70949e59d65bdd56b6da03bc4bd6a62cdf7" alt="Mike Nock avatar"
Morning all. Sorry if this is the wrong channel but: Would anyone happen to know if this module can be used to dynamically create 255 /24 subnets? https://github.com/cloudposse/terraform-aws-dynamic-subnets/
Terraform module for public and private subnets provisioning in existing VPC - cloudposse/terraform-aws-dynamic-subnets
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
better to use #terraform since this channel is for https://github.com/terraform-aws-modules/
Collection of Terraform AWS modules supported by the community - Terraform AWS modules
data:image/s3,"s3://crabby-images/1621c/1621c70949e59d65bdd56b6da03bc4bd6a62cdf7" alt="Mike Nock avatar"
Ah, gotcha. Thanks Erik!
data:image/s3,"s3://crabby-images/dc599/dc599f630ad796b13061bde9cc98c680735421b3" alt="Vidhi Virmani avatar"
Hello terraformers, I am using this eks module https://github.com/terraform-aws-modules/terraform-aws-vpc and recieving this error
Error: module.eks_cluster.aws_eks_cluster.this: vpc_config.0: invalid or unknown key: endpoint_private_access
Terraform module which creates VPC resources on AWS - terraform-aws-modules/terraform-aws-vpc
data:image/s3,"s3://crabby-images/dc599/dc599f630ad796b13061bde9cc98c680735421b3" alt="Vidhi Virmani avatar"
Can anyone help?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
@Vidhi Virmani i think you are using https://github.com/terraform-aws-modules/terraform-aws-eks, ping @antonbabenko for help with the module
A Terraform module to create an Elastic Kubernetes (EKS) cluster and associated worker instances on AWS. - terraform-aws-modules/terraform-aws-eks
data:image/s3,"s3://crabby-images/dc599/dc599f630ad796b13061bde9cc98c680735421b3" alt="Vidhi Virmani avatar"
Thanks @Andriy Knysh (Cloud Posse). I have messaged him.
2019-04-02
data:image/s3,"s3://crabby-images/dbcd5/dbcd587c3e2d0abf98b340377097a708d915ab49" alt="antonbabenko avatar"
Open an issue in that repo and maybe someone will be able to help with EKS module.
data:image/s3,"s3://crabby-images/908e0/908e047829a334ae81285b49bd79cf30644d5ba9" alt="wave"
data:image/s3,"s3://crabby-images/73029/73029a7e61c7e3bfc1ff4f8b1d44aa03b9f79940" alt="Pablo Costa avatar"
Try to update the aws provider: “terraform init -upgrade” because endpoint private access is a recent feature
2019-04-03
data:image/s3,"s3://crabby-images/1f112/1f1120d7c318c548190b06c33109a6e54d94c908" alt="Igor avatar"
@antonbabenko Is there a way to add custom providers to terraform-aws-atlantis without making a new atlantis image?
data:image/s3,"s3://crabby-images/dbcd5/dbcd587c3e2d0abf98b340377097a708d915ab49" alt="antonbabenko avatar"
Do you mean terraform providers which you can use in your terraform configs?
data:image/s3,"s3://crabby-images/1f112/1f1120d7c318c548190b06c33109a6e54d94c908" alt="Igor avatar"
Yes
data:image/s3,"s3://crabby-images/dbcd5/dbcd587c3e2d0abf98b340377097a708d915ab49" alt="antonbabenko avatar"
You can call custom command/script (https://www.runatlantis.io/docs/custom-workflows.html#custom-init-plan-apply-commands) which will download providers before running terraform plan
Atlantis: Terraform Pull Request Automation
data:image/s3,"s3://crabby-images/dbcd5/dbcd587c3e2d0abf98b340377097a708d915ab49" alt="antonbabenko avatar"
but I think embedding them into an image is good option if you are not going to change them very often.
data:image/s3,"s3://crabby-images/1f112/1f1120d7c318c548190b06c33109a6e54d94c908" alt="Igor avatar"
I thought of that, but concluded it’s too hacky.. haha
data:image/s3,"s3://crabby-images/dbcd5/dbcd587c3e2d0abf98b340377097a708d915ab49" alt="antonbabenko avatar"
agree
data:image/s3,"s3://crabby-images/1f112/1f1120d7c318c548190b06c33109a6e54d94c908" alt="Igor avatar"
2019-04-04
data:image/s3,"s3://crabby-images/1124d/1124df8012da3f84fd609777378572e3893b10c4" alt="Edd avatar"
Hey folks, I’m trying to use this module - https://registry.terraform.io/modules/cloudposse/cloudfront-s3-cdn/aws/0.7.0 - and am encountering a CORS error when Terraform is setting up the S3 bucket
data:image/s3,"s3://crabby-images/1124d/1124df8012da3f84fd609777378572e3893b10c4" alt="Edd avatar"
* module.cloudfront-s3-cdn.aws_s3_bucket.origin: 1 error(s) occurred:
* aws_s3_bucket.origin: Error putting S3 CORS: MalformedXML: The XML you provided was not well-formed or did not validate against our published schema
status code: 400, request id: B49313C1B360E967, host id: 9CNDQqYA3/F0FAXlsFPIYVhAAJZoYiYQrBo/sZ1K8ZohYGgSNNJVYL3FOCDUB0fCs+wq4JftevE=
2019-04-07
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Hey @Edd this channel is for https://github.com/terraform-aws-modules/
Collection of Terraform AWS modules supported by the community - Terraform AWS modules
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
maybe try #terraform
2019-04-08
data:image/s3,"s3://crabby-images/17c19/17c198162babe5ef0242fce2ead5561b10cc8803" alt="cabrinha avatar"
anyone ever use this module? https://github.com/terraform-aws-modules/terraform-aws-security-group/tree/v2.16.0
in the readme example, they’re passing in a VPC ID as a CIDR block for a security group rule
module "db_computed_merged_sg" {
# omitted for brevity
computed_ingress_cidr_blocks = ["10.10.0.0/16", "${data.aws_security_group.default.id}", "${module.vpc.vpc_id}"]
number_of_computed_ingress_cidr_blocks = 3
}
but I’m having some issue doing the same
Terraform module which creates EC2-VPC security groups on AWS - terraform-aws-modules/terraform-aws-security-group
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
@cabrinha just briefly looking at the code above (I did not use the module), looks like both "${data.aws_security_group.default.id}", "${module.vpc.vpc_id}"
do not return CIDR blocks - they return IDs
data:image/s3,"s3://crabby-images/17c19/17c198162babe5ef0242fce2ead5561b10cc8803" alt="cabrinha avatar"
exactly, so im wondering if its supposed to be possible to pass in a VPC ID into the module
data:image/s3,"s3://crabby-images/17c19/17c198162babe5ef0242fce2ead5561b10cc8803" alt="cabrinha avatar"
maybe i should just open an issue asking that question
data:image/s3,"s3://crabby-images/b75ae/b75ae6c678fe3cb0ea44f19911ce47d490a4bb36" alt="Noah Kernis avatar"
Hi all, I have a question about this module (let me know if I am asking in the wrong channel!) https://github.com/cloudposse/terraform-aws-ecs-web-app?ref=tags/0.5.0 . Is there a way to create a task definition with multiple images defined? It seems possible via this module - https://github.com/cloudposse/terraform-aws-ecs-container-definition/blob/master/examples/multiple_definitions/main.tf - but this is being used by the terraform-aws-ecs-web-app
and I believe I can’t pass directly to it. Thank you for any and all help?
Terraform module that implements a web app on ECS and supports autoscaling, CI/CD, monitoring, ALB integration, and much more. - cloudposse/terraform-aws-ecs-web-app
Terraform module to generate well-formed JSON documents (container definitions) that are passed to the aws_ecs_task_definition Terraform resource - cloudposse/terraform-aws-ecs-container-definition
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
hi @Noah Kernis let’s move to #terraform
data:image/s3,"s3://crabby-images/b75ae/b75ae6c678fe3cb0ea44f19911ce47d490a4bb36" alt="Noah Kernis avatar"
@Andriy Knysh (Cloud Posse) moving there
2019-04-09
data:image/s3,"s3://crabby-images/17c19/17c198162babe5ef0242fce2ead5561b10cc8803" alt="cabrinha avatar"
I feel like we should be able to override certain tags/names
data:image/s3,"s3://crabby-images/17c19/17c198162babe5ef0242fce2ead5561b10cc8803" alt="cabrinha avatar"
like namespace
– this means nothing to me or my org
data:image/s3,"s3://crabby-images/17c19/17c198162babe5ef0242fce2ead5561b10cc8803" alt="cabrinha avatar"
but it turns out the name of the DNS record created is affected by this and I have no control over that DNS name
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
in the end, the cloudposse modules are designed to be internally consistent
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
due to limitations of the HCL language, we cannot easily accommodate the differences in naming conventions
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
(for example, environment vs stage)
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
this is quite opinionated, but is the only way we’ve been able to manage writing 140+ terraform modules that work relatively well together
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
why not use the established convention namespace-stage-name
? what’s wrong with using `namespace? It could be your org name or abbreviation, or just something else specific to your use-case
data:image/s3,"s3://crabby-images/17c19/17c198162babe5ef0242fce2ead5561b10cc8803" alt="cabrinha avatar"
i feel like it could be easy to override the tags or leave them out
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
(nothing is easy when the change means percolating it out to 140 repositories = 140+ pull requests)
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
so the main reason of doing that is to have consistent and globally unique names for ALL AWS resources
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
especially for global resources like S3 buckets
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
where you can easily have naming conflicts
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
so by using everything consistently, we usually eliminate the possibilities of conflicts (on global resources as well)
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
when you automate everything, naming global AWS resources is difficult
data:image/s3,"s3://crabby-images/17c19/17c198162babe5ef0242fce2ead5561b10cc8803" alt="cabrinha avatar"
data:image/s3,"s3://crabby-images/17c19/17c198162babe5ef0242fce2ead5561b10cc8803" alt="cabrinha avatar"
thats fine and makes sense
data:image/s3,"s3://crabby-images/17c19/17c198162babe5ef0242fce2ead5561b10cc8803" alt="cabrinha avatar"
i guess i can still add my own additional tags
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
so why not use the same patterns to name ALL resources? it’s easy to automate w/o thinking about it
data:image/s3,"s3://crabby-images/17c19/17c198162babe5ef0242fce2ead5561b10cc8803" alt="cabrinha avatar"
i just dont like that this EFS module created a DNS record prefixed with eg-
data:image/s3,"s3://crabby-images/17c19/17c198162babe5ef0242fce2ead5561b10cc8803" alt="cabrinha avatar"
eg-$my_env-$my_name-efs.$my_domain
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
so that’s a great name however, a CNAME to your service discovery domain would be even nicer
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
the e.g.
is for “Example given”
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
we default to that ugly prefix so users change it
data:image/s3,"s3://crabby-images/17c19/17c198162babe5ef0242fce2ead5561b10cc8803" alt="cabrinha avatar"
i’d love to have service discovery here, we’re working on that
data:image/s3,"s3://crabby-images/17c19/17c198162babe5ef0242fce2ead5561b10cc8803" alt="cabrinha avatar"
yeah so … changing it…
data:image/s3,"s3://crabby-images/17c19/17c198162babe5ef0242fce2ead5561b10cc8803" alt="cabrinha avatar"
why can i change but not omit?
data:image/s3,"s3://crabby-images/17c19/17c198162babe5ef0242fce2ead5561b10cc8803" alt="cabrinha avatar"
i just want $my_env-$my_name-efs.$my_domain
as the cname
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
I think in current versions of terraform-null-label
we don’t enforce the namespace
, however, it’s not been percolated out
data:image/s3,"s3://crabby-images/17c19/17c198162babe5ef0242fce2ead5561b10cc8803" alt="cabrinha avatar"
perhaps i could open a PR
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
that said, from a consistency perspective, i don’t like it since it leads to inconsistency and while that works in smaller infrastructures it falls apart at scale.
data:image/s3,"s3://crabby-images/17c19/17c198162babe5ef0242fce2ead5561b10cc8803" alt="cabrinha avatar"
a naming convention is a naming convention … as long as it’s consistent, it can be xyz-efs.$my_domain
– users should be able to create their own conventions
data:image/s3,"s3://crabby-images/17c19/17c198162babe5ef0242fce2ead5561b10cc8803" alt="cabrinha avatar"
Terraform Module to define a consistent naming convention by (namespace, stage, name, [attributes]) - cloudposse/terraform-null-label
data:image/s3,"s3://crabby-images/17c19/17c198162babe5ef0242fce2ead5561b10cc8803" alt="cabrinha avatar"
not sure if this is where i’m supposed to be looking
data:image/s3,"s3://crabby-images/17c19/17c198162babe5ef0242fce2ead5561b10cc8803" alt="cabrinha avatar"
I’d like to update the terraform-null-label version in order to be able to omit the “namespace” parameter.
data:image/s3,"s3://crabby-images/17c19/17c198162babe5ef0242fce2ead5561b10cc8803" alt="cabrinha avatar"
Ah, perhaps the real fix is here: https://github.com/cloudposse/terraform-aws-route53-cluster-hostname
data:image/s3,"s3://crabby-images/17c19/17c198162babe5ef0242fce2ead5561b10cc8803" alt="cabrinha avatar"
I’m not sure I’m understanding how all these modules are chained together, but I think it’s understood what I’m trying to do.
data:image/s3,"s3://crabby-images/17c19/17c198162babe5ef0242fce2ead5561b10cc8803" alt="cabrinha avatar"
actually, by setting namespace
to an empty string, it works!
2019-04-10
data:image/s3,"s3://crabby-images/17c19/17c198162babe5ef0242fce2ead5561b10cc8803" alt="cabrinha avatar"
BUT
data:image/s3,"s3://crabby-images/17c19/17c198162babe5ef0242fce2ead5561b10cc8803" alt="cabrinha avatar"
I still would like complete control over the DNS name that gets created. Why not offer that to users of the module and if nothing is set, it’ll use the defaults currently in place?
data:image/s3,"s3://crabby-images/17c19/17c198162babe5ef0242fce2ead5561b10cc8803" alt="cabrinha avatar"
I feel like there should just be simple way to override the naming of these things.
data:image/s3,"s3://crabby-images/17c19/17c198162babe5ef0242fce2ead5561b10cc8803" alt="cabrinha avatar"
From looking at the code, it’s kind of hard to tell how the DNS CNAME is going to come out the other end.
data:image/s3,"s3://crabby-images/17c19/17c198162babe5ef0242fce2ead5561b10cc8803" alt="cabrinha avatar"
@Erik Osterman (Cloud Posse) @Andriy Knysh (Cloud Posse) what do you think? https://github.com/cloudposse/terraform-aws-efs/pull/25
The creation of the EFS volume's CNAME is currently out of user's control. This change proposes the option to allow users to set their own DNS name for the volume. If no name is set, fallba…
data:image/s3,"s3://crabby-images/17c19/17c198162babe5ef0242fce2ead5561b10cc8803" alt="cabrinha avatar"
If you guys want me to update the docs and stuff like that just lmk if we can move this forward.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
@cabrinha thanks, reviewed the PR
data:image/s3,"s3://crabby-images/17c19/17c198162babe5ef0242fce2ead5561b10cc8803" alt="cabrinha avatar"
data:image/s3,"s3://crabby-images/17c19/17c198162babe5ef0242fce2ead5561b10cc8803" alt="cabrinha avatar"
SO nice to be able to get an option added to this module within the cours of a couple hours!
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
next time, let’s do it in #terraform
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
this channel is for https://github.com/terraform-aws-modules/
Collection of Terraform AWS modules supported by the community - Terraform AWS modules
data:image/s3,"s3://crabby-images/17c19/17c198162babe5ef0242fce2ead5561b10cc8803" alt="cabrinha avatar"
will do
2019-04-24
data:image/s3,"s3://crabby-images/70efc/70efc463a4c17a4d6479da0b1b8c178a37655f7b" alt="Roger Gomez avatar"
Hi, is there any option on terraform-aws-cloudtrail
to configure a trail for an organization?
data:image/s3,"s3://crabby-images/70efc/70efc463a4c17a4d6479da0b1b8c178a37655f7b" alt="Roger Gomez avatar"
For all member accounts of that organization, the option is_organization_trail
on the aws_cloudtrail
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
@Roger Gomez https://github.com/cloudposse/terraform-aws-cloudtrail was created before AWS added CloudTrail for organizations
Terraform module to provision an AWS CloudTrail and an encrypted S3 bucket with versioning to store CloudTrail logs - cloudposse/terraform-aws-cloudtrail
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
you can open a PR to add is_organization_trail
data:image/s3,"s3://crabby-images/70efc/70efc463a4c17a4d6479da0b1b8c178a37655f7b" alt="Roger Gomez avatar"
ok, I will do that, thanks, working on it now
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
let’s move to #terraform , this channel is for https://github.com/terraform-aws-modules/
Collection of Terraform AWS modules supported by the community - Terraform AWS modules