#terraform-0_12 (2020-03)
Discuss upgrading to terraform 0.12
Archive: https://archive.sweetops.com/terraform-0_12/
2020-03-13
data:image/s3,"s3://crabby-images/44902/449029945fc1a4b20fc4380407df7a1de709e0f8" alt="curious deviant avatar"
Hello, I have a multi-account setup wherein my domain (myexampledomain.com)is registered in ACCOUNT A and I need to create a subdomain in ACCOUNT B (I have created a HZ for (myexampledomain.com) . and need to add a subdomain say (sub.myexampledomain.com). I am using DNS Validation for AWS cert and figured that DNS validation needs to add an entry in ACCOUNT A. I setup a cross account role in ACCOUNT A and corresponding permissions in ACCOUNTB. However the terraform (0.12) is unable to assume role. I can atleast assume role via aws cli. What am I missing ?
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
Use multiple providers
data:image/s3,"s3://crabby-images/44902/449029945fc1a4b20fc4380407df7a1de709e0f8" alt="curious deviant avatar"
Thanks I did and specified the provider with assume-role in the dns_cert_validation resource. It fails though
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
Need to see some code to debug more. Have done exactly this using multi provider before and had it working
data:image/s3,"s3://crabby-images/44902/449029945fc1a4b20fc4380407df7a1de709e0f8" alt="curious deviant avatar"
Running the following code as a user in ACCOUNTB that can assume the role in ACCOUNTA
provider "aws" {
region = "us-east-1"
version = ">= 2.11"
}
provider "aws" {
region = "us-east-1"
alias = "cert"
assume_role {
role_arn = "arn:aws:iam::ACCOUNTA:role/cross-account-role-for-r53"
}
}
resource "aws_route53_record" "cert_validation" {
name = aws_acm_certificate.cert.domain_validation_options.0.resource_record_name
type = aws_acm_certificate.cert.domain_validation_options.0.resource_record_type
zone_id = var.accountA_hostedzone_id
records = [aws_acm_certificate.cert.domain_validation_options.0.resource_record_value]
ttl = 60
allow_overwrite = true
provider = aws.cert
}
data:image/s3,"s3://crabby-images/a4baf/a4bafe7bcb724c44537f08dff5d5670c7a97e9e0" alt="matthew.king avatar"
Can I ask a dumb question? if I have existing terraform code, is there an easy way to convert it to a module so it can be used over and over again?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
any TF code can be a module. For example:
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
this is TF code to create VPC https://github.com/cloudposse/terraform-aws-vpc/blob/master/main.tf
Terraform Module that defines a VPC with public/private subnets across multiple AZs with Internet Gateways - cloudposse/terraform-aws-vpc
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
and this is how it’s used as a module https://github.com/cloudposse/terraform-aws-eks-cluster/blob/master/examples/complete/main.tf#L29
Terraform module for provisioning an EKS cluster. Contribute to cloudposse/terraform-aws-eks-cluster development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
the VPC code has variables.tf, and when you instantiate the module, you provide values for the variables
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
and you also propagate the outputs so the top-level module could see and use them https://github.com/cloudposse/terraform-aws-eks-cluster/blob/master/examples/complete/outputs.tf#L11
Terraform module for provisioning an EKS cluster. Contribute to cloudposse/terraform-aws-eks-cluster development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/a4baf/a4bafe7bcb724c44537f08dff5d5670c7a97e9e0" alt="matthew.king avatar"
Thank you so very much for the help
2020-03-16
2020-03-17
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
Any ways to keep the ordering of a map?
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
map("year", "string", "month", "string", "day", "string", "hour", "string")
{
"day" = "string"
"hour" = "string"
"month" = "string"
"year" = "string"
}
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
I think you would need to maintain order in a list of key values
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
Aye, figured so, thanks!
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
2020-03-19
data:image/s3,"s3://crabby-images/a4baf/a4bafe7bcb724c44537f08dff5d5670c7a97e9e0" alt="matthew.king avatar"
I’m looking at combining three different things, one enabling cloud-watch cloud-trail, two creating the aws_kms_key, and three pushing those notifications to slack. Best way would be to just combine them all into seperate modules correct?
2020-03-24
data:image/s3,"s3://crabby-images/e471b/e471bc22e77bf7730ed2046efb99c305a4f8df4f" alt="btai avatar"
anyone getting this when deprovisioning an eks cluster:
Error: Cycle: module.eks_cluster.output.endpoint, kubernetes_cluster_role_binding.auditboard_admin_cluster_admin (destroy), kubernetes_service_account.auditboard_admin (destroy), module.eks_cluster.aws_eks_cluster.default (destroy), module.eks_cluster.local.certificate_authority_data_list, module.eks_cluster.local.certificate_authority_data_list_internal, module.eks_cluster.local.certificate_authority_data_map, module.eks_cluster.local.certificate_authority_data, module.eks_cluster.output.certificate_authority_data, provider.kubernetes, kubernetes_config_map.aws_auth (destroy)
data:image/s3,"s3://crabby-images/e471b/e471bc22e77bf7730ed2046efb99c305a4f8df4f" alt="btai avatar"
fixed. crazy how often time passes by and some of your terraform configuration code you have can go stale (and the hacky workaround is now broken and fixed with the correct way of doing things :P)
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Yup
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Btw we have updated our EKS cluster module this week
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
More improvements coming.
data:image/s3,"s3://crabby-images/e471b/e471bc22e77bf7730ed2046efb99c305a4f8df4f" alt="btai avatar"
I just updated mine, was able to get rid of some TODO comments explaining workarounds and linking to previously open terraform issues
2020-03-25
data:image/s3,"s3://crabby-images/a4baf/a4bafe7bcb724c44537f08dff5d5670c7a97e9e0" alt="matthew.king avatar"
I’m trying to implement the aws cloudtrail cloudwatch alarms terraform and when I run it, I receive the following error
data:image/s3,"s3://crabby-images/a4baf/a4bafe7bcb724c44537f08dff5d5670c7a97e9e0" alt="matthew.king avatar"
Error: Creating/Updating CloudWatch Log Metric Filter failed: ResourceNotFoundException: The specified log group does not exist.
on alarms.tf line 76, in resource "aws_cloudwatch_log_metric_filter" "default":
76: resource "aws_cloudwatch_log_metric_filter" "default" {
2020-03-26
data:image/s3,"s3://crabby-images/46ad0/46ad000ac65c545f2179c3f9059d58efe0ea0ac7" alt="sweetops avatar"
Anyone know if there’s a cleaner way to do this var.branch == "master" ? "${var.service}" : (var.branch == "staging" ? "${var.service}" : (var.branch == "compliance" ? "${var.service}" : "${var.service}-${var.branch}"))
data:image/s3,"s3://crabby-images/46ad0/46ad000ac65c545f2179c3f9059d58efe0ea0ac7" alt="sweetops avatar"
something like var.branch == "master||staging||compliance" ? "${var.service}"
?
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
contains()
?
data:image/s3,"s3://crabby-images/46ad0/46ad000ac65c545f2179c3f9059d58efe0ea0ac7" alt="sweetops avatar"
well, I hesitate to use contains in case the word in somewhere in the else
name
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
it matchs a value against a list of values and returns true/false
data:image/s3,"s3://crabby-images/46ad0/46ad000ac65c545f2179c3f9059d58efe0ea0ac7" alt="sweetops avatar"
so it would be an exact match?
data:image/s3,"s3://crabby-images/46ad0/46ad000ac65c545f2179c3f9059d58efe0ea0ac7" alt="sweetops avatar"
Oh I see that now
data:image/s3,"s3://crabby-images/46ad0/46ad000ac65c545f2179c3f9059d58efe0ea0ac7" alt="sweetops avatar"
determines whether a given list or set contains a given single value as one of its elements.
data:image/s3,"s3://crabby-images/46ad0/46ad000ac65c545f2179c3f9059d58efe0ea0ac7" alt="sweetops avatar"
yeah this would work
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
contains(["master", "staging", "compliance"], var.branch) ? var.service : "${var.service}-${var.branch}"
data:image/s3,"s3://crabby-images/46ad0/46ad000ac65c545f2179c3f9059d58efe0ea0ac7" alt="sweetops avatar"
I could probably clean it up even more keep the list outside of that yeah?
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
not sure i wholly got your branching right, but something like that
data:image/s3,"s3://crabby-images/46ad0/46ad000ac65c545f2179c3f9059d58efe0ea0ac7" alt="sweetops avatar"
yeah you’ve got the idea
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
absolutely, yes, can keep the list in a separate local/var
data:image/s3,"s3://crabby-images/46ad0/46ad000ac65c545f2179c3f9059d58efe0ea0ac7" alt="sweetops avatar"
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
locals {
default_branch_mapping = var.service
branch_mapping = {
"foobar" = var.service + "-" + var.branch
"compliance" = var.service + "-" + var.branch
}
my_name = lookup(local.branch_mapping, var.branch, local.default_branch_mapping)
}
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@sweetops wouldn’t something like this work?
2020-03-27
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Adding @discourse_forum bot
data:image/s3,"s3://crabby-images/437c5/437c5f7ff80749c4e31740314c290186d75e89b6" alt="discourse_forum avatar"
@discourse_forum has joined the channel
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Hrm….
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Maybe it’s time we archive this channel as terraform 0.12 is more or less the norm now?
2020-03-30
data:image/s3,"s3://crabby-images/b82ef/b82efa31774b02e0495c3fd9593957af087dfba0" alt="Joe Presley avatar"
Can you rename it for v0.13 release?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
haha, ya maybe that’s the right thing to do
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
though I think better to start a clean channel with no history for 0.13
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
any eta’s on when 0.13 is actual?
2020-03-31
data:image/s3,"s3://crabby-images/b82ef/b82efa31774b02e0495c3fd9593957af087dfba0" alt="Joe Presley avatar"
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Alright, gonna archive this channel to reduce confusion. When 0.13 is eminent and if it comes with tons of breaking changes like 0.12 (hoping not!) we’ll create a new one.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
archived the channel