#atlantis (2020-08)
Discuss the Atlantis (<http://runatlantis.io | runatlantis.io>) |
**Archive: ** https://archive.sweetops.com/atlantis/
2020-08-09
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
has anyone used atlantis 0.14.0’s feature to turn atlantis into a bot instead of using a github user ?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
can you elaborate?
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
https://github.com/runatlantis/atlantis/blob/master/CHANGELOG.md
shows that you can now install atlantis as a github app
see: https://www.runatlantis.io/docs/access-credentials.html#github-app
Atlantis: Terraform Pull Request Automation
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
ive installed it as an app and now integrating the pem into the dockerfile. wish it was easier to setup by passing the pem as a string in the environment variable
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
oof… i keep getting bad credentials
from atlantis now
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
Igot it to work! woo. another pita
https://github.com/terraform-aws-modules/terraform-aws-atlantis/issues/147
I started this ticket because I was struggling to get this to work. I finally did get this to work and rewrote the issue to try to make this easier using the module… I'd like to use an atlant…
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
ohhh cool, I wanted to test this too, how hard it was?
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
any tricks?
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
See that issue. It was difficult to setup cause that module doesn’t support it
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
I tried to put in as much information as possible to make it clear what could be done to update the module to make it easier
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I use the cloudposse module but is definitely applicable
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
thanks for the info
2020-08-10
2020-08-14
data:image/s3,"s3://crabby-images/a7014/a7014b9d82fe69322028f29de7058ec3f433b410" alt="Andrew Mackett avatar"
I’m a huge fan of Atlantis and have implemented and used it to great success in the last 2 companies I’ve worked for.
I’ve just started at a new company where things are a bit messy; multiple terraform repos, 2 different home made ‘wrappers’ similar to terragrunt, with some changes being made through Jenkins pipeline and some made from engineers laptops (all with remote state).
I thought this would be a good chance to see what other people are doing before I go down the path of demoing and discussing what Atlantis can do.
Does anybody have any blogs/videos/slides/ideas about alternatives for Terraform deployment? Thanks!
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
Oof. I went down this road recently by trying to sell just terraform cicd. Once i sold people on that idea, that’s when i brought up atlantis.
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
I still can’t get them to allow atlantis applies tho so people still do applies locally but at least the plans are in github prs as comments
data:image/s3,"s3://crabby-images/a7014/a7014b9d82fe69322028f29de7058ec3f433b410" alt="Andrew Mackett avatar"
I feel bad for you @RB that sounds tough.
I’m lucky that I don’t need to sell the idea, they are very much on board with CI/CD. I just need to improve the process. There are varying levels of terraform experience and different engineering teams are each free to do their own thing, which will make it harder and harder to give support over time.
My intention is to make the test and deployment my team does as simple and smart as possible so that we can offer it to our other engineering teams and they’ll want to use it over their own custom creations.
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
No need to feel bad haha. I’m slowly getting them to embrace the applies by showing them how it brings value in specific repos. Soon I’ll be able to release it across the org. At least, that’s the dream
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
Yep same here. Eng teams are free to do whatever. What ends up happening is a lot of copy pasta and lack of consistencies
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
I like your idea of a poc and then showing it to your company. I’m sure that will turn heads and people will hopefully gravitate to the path of least resistance
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
what version did you used the last time @Andrew Mackett?
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
0.14 atlantis have some cool new features that you might want to take advantage
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I have a fork of it with some features to make it work with multiple altantis for the same repo etc if you have a need for that
data:image/s3,"s3://crabby-images/a7014/a7014b9d82fe69322028f29de7058ec3f433b410" alt="Andrew Mackett avatar"
@jose.amengual That’s a good question and I cannot remember the answer. Looking at the change log I suspect it was 0.11 or 0.12.
I just noticed the --hide-prev-plan-comments
flag in 0.12 - that would have been so useful! Cannot believe I missed that!
The atlantis unlock
command in 0.14 is another feature I’d been missing.
data:image/s3,"s3://crabby-images/a7014/a7014b9d82fe69322028f29de7058ec3f433b410" alt="Andrew Mackett avatar"
Previously I had CircleCI running checks like terraform validate
and terraform fmt
before Atlantis would be able to apply.
Does anybody do that with a custom workflow in Atlantis? My current thinking is that if I’m going to use something like CircleCI to run tests, it’s probably not much more effort to do the plan and apply there as well.
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I guess you can even do this with github actions but Atlantis give you more features
2020-08-15
2020-08-16
data:image/s3,"s3://crabby-images/1f56f/1f56ffd63d6a7249b7f50ce533ad1fd0d08692be" alt="Sean Turner avatar"
Hey all, I’ve just deployed atlantis in fargate using the module. What do I need to do exactly to allow fargate to assume the role in my TF code?
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
assume role into another account ?
data:image/s3,"s3://crabby-images/1f56f/1f56ffd63d6a7249b7f50ce533ad1fd0d08692be" alt="Sean Turner avatar"
Same account, doing a POC for now.
data:image/s3,"s3://crabby-images/1f56f/1f56ffd63d6a7249b7f50ce533ad1fd0d08692be" alt="Sean Turner avatar"
The below is from my PR. I gave the ECS task role the admin access policy to get things working. According to policy simulator, the ECS role can assume ROLE_NAME
in the below.
Error: error configuring Terraform AWS Provider: IAM Role (arn:aws:iam::ACCOUNT:role/ROLE_NAME) cannot be assumed.
There are a number of possible causes of this - the most common are:
* The credentials used in order to assume the role are invalid
* The credentials do not have appropriate permission to assume the role
* The role ARN is not valid
Error: NoCredentialProviders: no valid providers in chain. Deprecated.
For verbose messaging see aws.Config.CredentialsChainVerboseErrors
data:image/s3,"s3://crabby-images/877e4/877e4fdfac807c5f49a7b8f92502b9bf1fba5c59" alt="kexue.wang avatar"
How about if not used the instance profile? I have the same issue on K8s Pod. (instance profile of Node profile I’m try to avoid, replaced as ServiceAccountIAM to assume) but it won’t work.
data:image/s3,"s3://crabby-images/1f56f/1f56ffd63d6a7249b7f50ce533ad1fd0d08692be" alt="Sean Turner avatar"
¯_(ツ)_/¯
data:image/s3,"s3://crabby-images/1f56f/1f56ffd63d6a7249b7f50ce533ad1fd0d08692be" alt="Sean Turner avatar"
I don’t remember anymore sorry
data:image/s3,"s3://crabby-images/1f56f/1f56ffd63d6a7249b7f50ce533ad1fd0d08692be" alt="Sean Turner avatar"
Ah, if you’re not using instance profile, you need to provide a role arn to assume I believe
2020-08-17
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
in the same account it does not have to assume role, it uses an instance profile
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
so you do not need to provide a role arn
data:image/s3,"s3://crabby-images/1f56f/1f56ffd63d6a7249b7f50ce533ad1fd0d08692be" alt="Sean Turner avatar"
Cool, that worked! Thanks
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
np
2020-08-25
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
anyone got oidc working with atlantis on an aws alb ? we’re using okta with the following settings
issuer = "<https://company.okta.com/>"
token_endpoint = "<https://company.okta.com/oauth2/default/v1/token>"
user_info_endpoint = "<https://company.okta.com/oauth2/default/v1/userinfo>"
authorization_endpoint = "<https://company.okta.com/oauth2/default/v1/authorize>"
authentication_request_extra_params = {}
is this correct ? we created a Web integration with OpenID Connect to get a client_id and client_secret
and
allow_unauthenticated_access = true
allow_github_webhooks = true
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
we’re using okta fyi
data:image/s3,"s3://crabby-images/b1503/b15031c86ac37a59480633c711c0a17fb12baf0a" alt="zeid.derhally avatar"
I don’t know if that is correct but please let us know if you figure it. We are using okta as well
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
looks pretty handy. hoping to get it solved by today.
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
this worked for me
alb_authenticate_oidc = {
issuer = "${local.oidc_base_url}"
token_endpoint = "${local.oidc_base_url}/oauth2/v1/token"
authorization_endpoint = "${local.oidc_base_url}/oauth2/v1/authorize"
user_info_endpoint = "${local.oidc_base_url}/oauth2/v1/userinfo"
authentication_request_extra_params = {}
client_id = ""
client_secret = ""
on_unauthenticated_request = "authenticate"
session_timeout = 300
}
where oidc_base_url = "<https://youraccountname.okta.com>"
data:image/s3,"s3://crabby-images/b1503/b15031c86ac37a59480633c711c0a17fb12baf0a" alt="zeid.derhally avatar"
how does this work with the github webhook events?
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
# allow unauthenticated access from github
# This adds an additional listener rule to bypass the oidc authentication above
allow_unauthenticated_access = true
allow_github_webhooks = true
2020-08-26
data:image/s3,"s3://crabby-images/68def/68defb4533102ec517dec916602bd6a41a10b1f4" alt="Adrian Navarrete avatar"
Hi all, I am using this module https://registry.terraform.io/modules/terraform-aws-modules/atlantis/aws/2.23.0 thanks to @antonbabenko, for setting up Atlantis with Gitlab, it works fine when the the load balancer is external, but as soon as I change it to be internal is not reachable from the internet and therefore from Gitlab servers. Do you know if this module supports or what I can do for being able to use the internal ALB and being reachable from gitlab servers / the internet ? Many thanks in advance.
data:image/s3,"s3://crabby-images/9f311/9f311d34548988bf0ae5abf436f4df9de656f7bf" alt="nutellinoit avatar"
You can use external NLB and put some:
Hi all, I am using this module https://registry.terraform.io/modules/terraform-aws-modules/atlantis/aws/2.23.0 thanks to @antonbabenko, for setting up Atlantis with Gitlab, it works fine when the the load balancer is external, but as soon as I change it to be internal is not reachable from the internet and therefore from Gitlab servers. Do you know if this module supports or what I can do for being able to use the internal ALB and being reachable from gitlab servers / the internet ? Many thanks in advance.
data:image/s3,"s3://crabby-images/9f311/9f311d34548988bf0ae5abf436f4df9de656f7bf" alt="nutellinoit avatar"
data:image/s3,"s3://crabby-images/9f311/9f311d34548988bf0ae5abf436f4df9de656f7bf" alt="nutellinoit avatar"
to filter only traffic coming from gitlab
data:image/s3,"s3://crabby-images/9f311/9f311d34548988bf0ae5abf436f4df9de656f7bf" alt="nutellinoit avatar"
ah wait sorry, it’s not kubernetes
data:image/s3,"s3://crabby-images/9f311/9f311d34548988bf0ae5abf436f4df9de656f7bf" alt="nutellinoit avatar"
nevermind
2020-08-27
2020-08-28
data:image/s3,"s3://crabby-images/c026c/c026c40f70a7f82cb6d39db55ade6f8b7e803e7e" alt="cytopia avatar"
Does anybody have a solution for deleting projects via Atlantis, once the pull request is open (which deletes a bunch of files)?
Background:
I am using terragrunt and each directory represents a project which creates various resources. If I am deleting this directory and create a pull request, Atlantis obviously isn’t able to do a terraform/terragrunt destroy
on those, as the directories don’t exist anymore.
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
you could run a custom worflow step that you run before deleting files
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
and you can run multiples comands including terraform destroy
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
you just can’t delete files without cleaning resources from the state
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@jose.amengual is right, that once the files are gone, it’s not going to work easily to destroy since the files are needed to know what to destroy :smiley:
instead, open a no-op PR, and run something like atlantis plan -destroy
data:image/s3,"s3://crabby-images/c026c/c026c40f70a7f82cb6d39db55ade6f8b7e803e7e" alt="cytopia avatar"
@Erik Osterman (Cloud Posse) @jose.amengual how would I define this in atlantis.yaml
. I’ve searched their online documentation and did not find any key for destroy
to hook in.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
You don’t define it in the yaml, it’s an arg you pass when you run the chatops.
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"
also, others say they have trouble using it with terragrunt
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
data:image/s3,"s3://crabby-images/c026c/c026c40f70a7f82cb6d39db55ade6f8b7e803e7e" alt="cytopia avatar"
Thanks for the info
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
is this already hidden somewhere in the documentation?
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
How are people using Atlantis to remove resources? say I deploy resources via Atlantis into my cloud provider, and I now want to manage the full life cycle of that resource. Do I run an Atlantis de…
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
interesting comments
2020-08-31
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
if anyone uses the terraform-aws-atlantis module to launch atlantis in fargate, does anyone have interest in turning atlantis into a github bot instead of a github user?
i wrote up this pr and hoping to get more reviews / upvotes if possible
https://github.com/terraform-aws-modules/terraform-aws-atlantis/pull/151
Description See https://www.runatlantis.io/docs/access-credentials.html#generating-an-access-token This is a new feature as of 0.14.0 This PR closes #147 Motivation and Context It's much better…
data:image/s3,"s3://crabby-images/b1503/b15031c86ac37a59480633c711c0a17fb12baf0a" alt="zeid.derhally avatar"
How would this work when you need to have one Atlantis per account?
Description See https://www.runatlantis.io/docs/access-credentials.html#generating-an-access-token This is a new feature as of 0.14.0 This PR closes #147 Motivation and Context It's much better…
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
One atlantis per account? I guess my question is, why wouldn’t you have a single Atlantis that has permissions to assume a role in multiple accounts?
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
But if you already have one Atlantis per account, then i suppose you’d require an atlantis bot per account
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
Btw the above pr would allow for either a github user or bot. It maintains backwards compatibility with the current module.
data:image/s3,"s3://crabby-images/b1503/b15031c86ac37a59480633c711c0a17fb12baf0a" alt="zeid.derhally avatar"
It’s one GitHub bot account but we do one Atlantis per account for security reasons
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
Ah i see. Interesting use case
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I have the same use case as you @zeid.derhally and I will be working on this in about a week
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I already have multiple Atlantis and now I want to set up the github bot as @RB did so we will see how it goes
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
My change just got merged so feel free to try it out. Reach out if you hit any snags
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
awesome