#atlantis (2020-05)
Discuss the Atlantis (<http://runatlantis.io | runatlantis.io>) |
**Archive: ** https://archive.sweetops.com/atlantis/
2020-05-01
data:image/s3,"s3://crabby-images/7cceb/7ccebae740ff89e6d33ed042435902fb78501008" alt="Padarn avatar"
Hi guys - I’m wondering if anyone has advice for setting up an Atlantis to manage multiple environments (dev/stg/prd) within the same AWS account (cannot split them unfortunately): Unclear to me right now how to manage permissions for users so the environments are isolated (based on AWS)
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
interesting
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I just set it up for one account per environment
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
but the catch is that the TF repo is for both envs, stage and prod
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
so I started freaking out when I realize that people can access the prod state but….it was not possible since the S3 bucket lives in another account
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
so in your case is a bit harder
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
you could deploy 3 different atlantis with 3 different web hooks and 3 different repos
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
and then by instance profile restrict which remote state they can use
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I’m assuming you are using remote state
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
otherwise restricting using the githib groups could be another way but that is on the clouposse repo
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
is a fork of atlantis
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
then you can name a team that can run the apply
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
and only that team can do it
data:image/s3,"s3://crabby-images/7cceb/7ccebae740ff89e6d33ed042435902fb78501008" alt="Padarn avatar"
When I looked at the clouposse module it looked like it did not support gitlab, am I wrong in thinking that?
data:image/s3,"s3://crabby-images/7cceb/7ccebae740ff89e6d33ed042435902fb78501008" alt="Padarn avatar"
generally your idea of 3 Atlantis makes sense - the only drawback of this is not having a clear way to actually write an instance profile that can’t touch prd resources
data:image/s3,"s3://crabby-images/7cceb/7ccebae740ff89e6d33ed042435902fb78501008" alt="Padarn avatar"
the state yes, but I guess you could manually import a prd instance then destroy it?
data:image/s3,"s3://crabby-images/7cceb/7ccebae740ff89e6d33ed042435902fb78501008" alt="Padarn avatar"
have considered using an approach like this: https://docs.aws.amazon.com/iot/latest/developerguide/tagging-iot-iam.html
You can apply tag-based resource-level permissions in the IAM policies you use for AWS IoT API actions. This gives you better control over what resources a user can create, modify, or use. You use the Condition element (also called the Condition
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I haver seen that
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
you could do TAG base access
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
data:image/s3,"s3://crabby-images/ae79f/ae79fdf2eb20dcd5f6ee275ebff29079ef1ce03f" alt="attachment image"
Recently, AWS enabled tags on IAM principals (users and roles). The main benefit of this new feature is that you’ll be able to author a single policy to grant access to individual resources and you’ll no longer need to update your policies for each new resource that you add. In other words, you can now […]
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
ABACs are called
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
Attribute base access
data:image/s3,"s3://crabby-images/7cceb/7ccebae740ff89e6d33ed042435902fb78501008" alt="Padarn avatar"
Oh nice.. that seems like quite a good solution
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
are they in different VPCs ?
data:image/s3,"s3://crabby-images/7cceb/7ccebae740ff89e6d33ed042435902fb78501008" alt="Padarn avatar"
yes.. we’ve done what we can with the one account restriction
data:image/s3,"s3://crabby-images/7cceb/7ccebae740ff89e6d33ed042435902fb78501008" alt="Padarn avatar"
do you have a specific reference for the cloudposse groups approach, not clear to me from their github repo what they’ve done in the fork
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
one sec
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
by the way : https://sweetops.slack.com/archives/CDKPAK81Z/p1587861631054200?thread_ts=1587160463.053900&cid=CDKPAK81Z
We have the same setup where we have an Atlantis in each account. For accounts that handle multiple environments we went with separate directories and try to follow a strict process of only making changes in one environment in a given PR.
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
- Add
.travis.yml
* Addgh-team-whitelist
command line argument * Addgh-team-whitelist
command line argument * Make description line length shorter than 120 chars * Make descript…
data:image/s3,"s3://crabby-images/7cceb/7ccebae740ff89e6d33ed042435902fb78501008" alt="Padarn avatar"
awesome, tanks a bunch
data:image/s3,"s3://crabby-images/7cceb/7ccebae740ff89e6d33ed042435902fb78501008" alt="Padarn avatar"
I’ll go through in detail
data:image/s3,"s3://crabby-images/7cceb/7ccebae740ff89e6d33ed042435902fb78501008" alt="Padarn avatar"
thanks a lot for the help, will let you know how I get on
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
no problem, I hope this help
2020-05-03
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
@Padarn I was deploying and enabling for the first time Atlantis for our team and and when I was testing I realize of a somewhat huge
problem!!!, my repos are like terraform-team-rds
and we define the environments by .tfvars
files and then we call -var-file
and that is how we can initialize the environments so if the sam repo for all environments so if I deploy another atlantis in the prod account then the repo is going to have two
webhooks so it will receive from the same events
plan or
apply` commands and then both atlantis server will populate the PR, one with a successful run and the other one with a incomplete run, which is far from ideal since the PR will get polluted
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
So there is I think two ways to do this : one is to maybe set a webhook that only send events on releases for prod and then do apply but I have no idea if that will work and the other way it costs $6 bucks a month and is to use WAF to parse the POST payload of the webhook and look form something and block it if it does not contain that magic word, that in my case I set it up to be environment: staging
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
after doing this the staging atlantis only received the events that need to process
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
not the best solution but it was very easy to setup, if atlantis could deal with this will be ideal
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
having to move to having modules per environment will not be fun
data:image/s3,"s3://crabby-images/7cceb/7ccebae740ff89e6d33ed042435902fb78501008" alt="Padarn avatar"
By this do you mean a repo per environment?
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
yes
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
so that each repo have it’s own webhook
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
and the amount of repos will be crazy
data:image/s3,"s3://crabby-images/7cceb/7ccebae740ff89e6d33ed042435902fb78501008" alt="Padarn avatar"
This is a good point (I hadn’t worked on this in the weekend). I am using gitlab, and there is one possible simple solution: https://gitlab.com/gitlab-org/gitlab-foss/-/merge_requests/19513. It Is possible to filter webhooks based on the branch
What does this MR do? Allow for filtering of project webhooks by branch as requested per https://gitlab.com/gitlab-org/gitlab-ce/issues/20338 Scope: - ability to specify a single branch name in a form…
data:image/s3,"s3://crabby-images/7cceb/7ccebae740ff89e6d33ed042435902fb78501008" alt="Padarn avatar"
but, it seems like (from what I can see) this only filters for “push events” with is not ideal
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
push events and not comments
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
mmmm
data:image/s3,"s3://crabby-images/7cceb/7ccebae740ff89e6d33ed042435902fb78501008" alt="Padarn avatar"
it looks a bit like using this: https://www.runatlantis.io/docs/repo-level-atlantis-yaml.html#enabling-atlantis-yaml
Atlantis: Terraform Pull Request Automation
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
i do that already
Atlantis: Terraform Pull Request Automation
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
staging-us-east-2:
plan:
steps:
- run: rm -rf .terraform
- init:
extra_args: [-backend-config=staging-backend-us-east-2.tfvars]
- plan:
extra_args: [-var-file=staging-us-east-2.tfvars]
data:image/s3,"s3://crabby-images/7cceb/7ccebae740ff89e6d33ed042435902fb78501008" alt="Padarn avatar"
what if you add something like :
autoplan:
when_modified: ["*stg.tf", "../modules/**stg.tf"]
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
ahhhhhhh…..
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I missed that
data:image/s3,"s3://crabby-images/7cceb/7ccebae740ff89e6d33ed042435902fb78501008" alt="Padarn avatar"
not totally sure this will work, but may do
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
yes, that could work too
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
but in my case I will still have two webhooks
data:image/s3,"s3://crabby-images/7cceb/7ccebae740ff89e6d33ed042435902fb78501008" alt="Padarn avatar"
right, but one of them may not actually trigger anything
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
correct
data:image/s3,"s3://crabby-images/7cceb/7ccebae740ff89e6d33ed042435902fb78501008" alt="Padarn avatar"
(hopefully)
data:image/s3,"s3://crabby-images/7cceb/7ccebae740ff89e6d33ed042435902fb78501008" alt="Padarn avatar"
I wonder if there is a way to do something like assume role
before the different workflows
data:image/s3,"s3://crabby-images/7cceb/7ccebae740ff89e6d33ed042435902fb78501008" alt="Padarn avatar"
that would simplify this
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
you could run aws-vault
in the init step
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
and apply step
data:image/s3,"s3://crabby-images/7cceb/7ccebae740ff89e6d33ed042435902fb78501008" alt="Padarn avatar"
ah yeah.. that might be enough
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
like the way they show to run Terragrunt and custom workflows
data:image/s3,"s3://crabby-images/7cceb/7ccebae740ff89e6d33ed042435902fb78501008" alt="Padarn avatar"
I think what I’m going to try later today (I’m in Singapore, so guessing not the same time zone) is one atlantis with assume roles for env
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
you will need to package aws-vault plus .aws
config dir in the container
data:image/s3,"s3://crabby-images/7cceb/7ccebae740ff89e6d33ed042435902fb78501008" alt="Padarn avatar"
where do you run atlantis btw? on fargate?
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
data:image/s3,"s3://crabby-images/7cceb/7ccebae740ff89e6d33ed042435902fb78501008" alt="Padarn avatar"
you could define a workflow only for staging for your staging intance
data:image/s3,"s3://crabby-images/7cceb/7ccebae740ff89e6d33ed042435902fb78501008" alt="Padarn avatar"
but this setup is getting pretty messy
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
@Erik Osterman (Cloud Posse) is this still in the cloudposse fork https://github.com/runatlantis/atlantis/pull/310
This allows setting different configs for different instances of atlantis, which is useful when wanting to run different servers for production and staging. Our use case is to have separate product…
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
Looks like now that this guys are in hashicorp, they are not so willing to improve Atlantis
This allows setting different configs for different instances of atlantis, which is useful when wanting to run different servers for production and staging. Our use case is to have separate product…
data:image/s3,"s3://crabby-images/7cceb/7ccebae740ff89e6d33ed042435902fb78501008" alt="Padarn avatar"
hmm thats a shame
data:image/s3,"s3://crabby-images/7cceb/7ccebae740ff89e6d33ed042435902fb78501008" alt="Padarn avatar"
what is in the fork that you need not existing in the main branch?
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
Github group whitelist
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I don’t know if it works for gitlab
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
Basically only certain groups can do apply
data:image/s3,"s3://crabby-images/7cceb/7ccebae740ff89e6d33ed042435902fb78501008" alt="Padarn avatar"
Ah okay. Yeah I’m going with the fargate setup currently. but some minor blockers around getting my config to work
data:image/s3,"s3://crabby-images/7cceb/7ccebae740ff89e6d33ed042435902fb78501008" alt="Padarn avatar"
was planning on just using codeowners
for that
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
Github does not have code owners I believe
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
We’d like to use multiple Altantis servers, with each running local to its provider’s resources. The problem with this (design 1) is that both Atlantis servers would respond to the webhooks receive…
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
it was abandon
data:image/s3,"s3://crabby-images/7cceb/7ccebae740ff89e6d33ed042435902fb78501008" alt="Padarn avatar"
Oh … sad
data:image/s3,"s3://crabby-images/7cceb/7ccebae740ff89e6d33ed042435902fb78501008" alt="Padarn avatar"
Wondering if there is any real alternative
data:image/s3,"s3://crabby-images/7cceb/7ccebae740ff89e6d33ed042435902fb78501008" alt="Padarn avatar"
(except terraform enterprise)
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
atlantis have like 300 forks
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I guess a lot of people have think some options are lacking..
data:image/s3,"s3://crabby-images/7cceb/7ccebae740ff89e6d33ed042435902fb78501008" alt="Padarn avatar"
data:image/s3,"s3://crabby-images/7cceb/7ccebae740ff89e6d33ed042435902fb78501008" alt="Padarn avatar"
either the Atlantis devs have really dropped the ball here or people just don’t understand open source
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
lol
2020-05-04
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
If a terraform module (module UP) is updated, is there a way for atlantis or something else to rerun a terraform plan
for a module (module DOWN) that depends on UP ?
data:image/s3,"s3://crabby-images/039ba/039baa410ee95952c1abce9b6daf4cb43d62f76f" alt="Adrian avatar"
try terragrunt-atlantis-config
it will generate atlantis.yaml according to your HCL dependencies
data:image/s3,"s3://crabby-images/039ba/039baa410ee95952c1abce9b6daf4cb43d62f76f" alt="Adrian avatar"
omg sorry for that it terragrunt not terraform
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
would this work if a module was referenced using a git source as well ?
data:image/s3,"s3://crabby-images/039ba/039baa410ee95952c1abce9b6daf4cb43d62f76f" alt="Adrian avatar"
Don’t know
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
need some help, mostly cloudposse guys since I use their fork : I’m defining this as my atlantis.yaml
version: 2
projects:
- name: staging-us-east-2
dir: .
workflow: staging-us-east-2
terraform_version: v0.12.24
autoplan:
when_modified:
- "*.tf"
enabled: false
- name: production-us-east-2
dir: .
workflow: production-us-east-2
terraform_version: v0.12.24
autoplan:
when_modified:
- "prod.txt"
enabled: false
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I created a PR that does not have the "prod.txt"
file but when I run atlantis plan -p production-us-east-2
atlantis goes and runs the the plan
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I’m trying to avoid that by using the prod.txt
file as a feature enable flag kind off
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
is that possible ?
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
does the file have to exist in order for this to work ?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
this is just for autoplan
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
when you run the command, it will be executed
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
(Cloud Posse fork, the latest version, does not have any new features except we added GitHub Team whitelist to detect if a user has permissions to run the atlantis commands. For all other features, you can ask in the atlantis Slack)
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I thought when_modified
will work even if autoplan is disabled
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
probably not, you can look into the atlantis code
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I’m not so versed in golang yet
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
what problem are you trying to solve?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
you want atlantis to run diff workflows for staging and prod when diff files are modified?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
and you are using one repo?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
suggest you create a folder conf
and add staging.tfvars
and prod.tfvars
in it
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
sorry I made a mistake
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
if you modify the main module, both staging and prod will run
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
if you modify only e.g. staging.tfvars
, then only the staging atlantis would run
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
one aws account per environment, one atlantis server per aws account
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
one repo for all environments?
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
yes
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
so you need to separate prod config from staging config
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
they should not be in [variables.tf](http://variables.tf)
for all environments
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I run them like this, this is the server config
staging-us-west-2:
plan:
steps:
- run: rm -rf .terraform
- init:
extra_args: [-backend-config=staging-backend-us-west-2.tfvars]
- plan:
extra_args: [-var-file=staging-us-west-2.tfvars]
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
only the code (logic) is common for all
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
the idea was that we could test config changes of the main module in staging without triggering a prod even to the prod atlantis
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
that is what we usually do
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
so one repo terraform-aws-rds
for multiple environments and we have different .tfvars
and backen-configs
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
for example
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
but that should work
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
you already disabled autoplan
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
when you run atlantis plan -p production-us-east-2
, only prod should run
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
yes but by repo is for multiple environments so I haver multiple webhooks
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
one point from the same repo to the staginmg atlantis and another to the prod atlantis
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I want the staging atlantis to ignore the productions
workflows
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
so I thought I could use :
version: 2
projects:
- name: staging-us-east-2
dir: .
workflow: staging-us-east-2
terraform_version: v0.12.24
autoplan:
when_modified:
- "*.tf"
enabled: false
- name: production-us-east-2
dir: .
workflow: production-us-east-2
terraform_version: v0.12.24
autoplan:
when_modified:
- "prod.txt"
enabled: false
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
and so I create a PR, then go and run manually atlantis plan -p staging-use-east-2
then once approved then I run atlantis apply
and after is tested, I can user the same PR or a new PR , modify the prod.txt
file and then run atlantis plan -p production-use-east-2
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
but what I really wanted was that the atlantis in staging ignore any call to production workflows
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
to avoid this :
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 want to avoid having devs to be able to run atlantis plan against prod and getting those errors in the comments
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
since the atlantis servers are separated is not a security concern
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
is just more annoying that anything
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
you are talking about two diff things. If you run those atlantis plan xxxxxxxx
commands manually, then it should run only the workflow specified in the command (prod or staging)
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
for the autoplan, enable it, then make each autoplan (prod and staging) depend on diff tfvars
files
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
autoplan:
when_modified:
- "*.tf"
- "prod.tfvars"
enabled: true
autoplan:
when_modified:
- "*.tf"
- "staging.tfvars"
enabled: true
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
in this case, if you update the module(s), both autoplans will run and show the changes
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
if you update the settings for e.g. staging, only the staging autoplan will run
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I prefer to run autoplan manually than automatically but I will try this
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
do you know if the when_modified array is like an AND for every item ?
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
like *.tf
AND prod.tfvars
need to change for it to trigger ?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
It’s OR
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
If you modify the code, then *.tf will trigger both
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
If you modify settings for one environment, only one should trigger
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
ok I see
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
thanks a lot
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
well, yesterday I realize how stupid I’m and why I never thought about having two separated atlantis-repo-config.yaml
files, one for the altantis in prod, one for the atlantis in staging
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
that will solve this issue
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
that’s a good idea
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
each one could be configured and allowed to do only specific things
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
exactly
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
and I can still do the specific files so that it does not comment back to the repo saying that that project does not exist
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
etc
data:image/s3,"s3://crabby-images/b1503/b15031c86ac37a59480633c711c0a17fb12baf0a" alt="zeid.derhally avatar"
This is what we do, we have Atlantis look for a configuration file that matches the env name. We have a patched version of Atlantis that does this. We still get the extra status checks showing up in the PR, but I think some of that is fixed in the latest version of Atlantis
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
if you use a WAF rule you can avoid the calls from github to altantis base on some text in the payload post from the webhook but if you can deal with the extra status then that is cheaper
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I saw a delete old messages option or something in the new version
data:image/s3,"s3://crabby-images/b1503/b15031c86ac37a59480633c711c0a17fb12baf0a" alt="zeid.derhally avatar"
They added the –silence-vcs-status-no-plans flag that silences VCS commit status when autoplan finds no projects to plan
data:image/s3,"s3://crabby-images/b1503/b15031c86ac37a59480633c711c0a17fb12baf0a" alt="zeid.derhally avatar"
Haven’t tried it yet
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
can you share your repo and altantis yaml ?
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I mean a piece of it
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
ohh but you said you have a patched version, what patches do you have ?
data:image/s3,"s3://crabby-images/b1503/b15031c86ac37a59480633c711c0a17fb12baf0a" alt="zeid.derhally avatar"
to support different Atlantis configs was a quick hack. We set an env variable that tells Atlantis what config file to load
data:image/s3,"s3://crabby-images/b1503/b15031c86ac37a59480633c711c0a17fb12baf0a" alt="zeid.derhally avatar"
So in the repo we have 3 Atlantis config files, prod.yaml dev.yaml sandbox.yaml.
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
ahhh ok I know the feature request you are altking
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
that it never got merged
data:image/s3,"s3://crabby-images/b1503/b15031c86ac37a59480633c711c0a17fb12baf0a" alt="zeid.derhally avatar"
Yeah, that PR did it the better way but it requires lots of changes. Ours is like 5 lines of code
data:image/s3,"s3://crabby-images/b1503/b15031c86ac37a59480633c711c0a17fb12baf0a" alt="zeid.derhally avatar"
We were thinking of reimplementing that PR and submitting it again
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
can you share the code ?
data:image/s3,"s3://crabby-images/b1503/b15031c86ac37a59480633c711c0a17fb12baf0a" alt="zeid.derhally avatar"
Terraform Pull Request Automation. Contribute to mediwareinc/atlantis-1 development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/b1503/b15031c86ac37a59480633c711c0a17fb12baf0a" alt="zeid.derhally avatar"
It’s in the multi-env branch
data:image/s3,"s3://crabby-images/b1503/b15031c86ac37a59480633c711c0a17fb12baf0a" alt="zeid.derhally avatar"
Terraform Pull Request Automation. Contribute to mediwareinc/atlantis-1 development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
NO Fing way……..
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
how can someone deny to merge that?
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
if you create the pull request and starts huge discussion and it takes months to merge, I will just flip the table
data:image/s3,"s3://crabby-images/b1503/b15031c86ac37a59480633c711c0a17fb12baf0a" alt="zeid.derhally avatar"
I think that PR you linked should have been included, not sure why they rejected it
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
but you solution is totally valid too
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
for people that can deploy multiple altlantis
data:image/s3,"s3://crabby-images/b1503/b15031c86ac37a59480633c711c0a17fb12baf0a" alt="zeid.derhally avatar"
We are going to update to the latest Atlantis next week and try our change with the –silence-vcs-status-no-plans flag
data:image/s3,"s3://crabby-images/b1503/b15031c86ac37a59480633c711c0a17fb12baf0a" alt="zeid.derhally avatar"
But ultimately would like to get something submitted back to atlantis
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I’m kinda concern with the project because both guys work for hashicorp
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
basically getting pay to have a conflict of interest
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
they should hand over the project
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
So I think I came up with a way to authenticate github users specific for terraform applies using a file in /home/atlantis/users
with 444
permissions.
https://github.com/nitrocode/atlantis
questions:
- ~
how do i restrict the atlantis user in the docker container to ONLY be able to read the file and NOT append the file~. i am whitelisting repos that have access to atlantis plans. on top of that, how do i only allow repo level workflow overrides for a subset of the whitelisted repos? - is there a way to perform a different function if a specific tf resource is detected ?
- using a custom workflow, can I use the @ sign to tag specific people ?
Basic terraform cicd setup using atlantis. Contribute to nitrocode/atlantis development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
For 1) I tested it locally using docker run --user atlantis -it 2febd567f15e bash
after chowning to root:atlantis
which allowed reading users
but not writing / appending
Basic terraform cicd setup using atlantis. Contribute to nitrocode/atlantis development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
atlantis has a global config file. It does not answer all the questions or allow you to config everything you asked, but might help
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
# <https://www.runatlantis.io/docs/configuring-atlantis.html>
# <https://www.runatlantis.io/docs/server-configuration.html>
# <https://www.runatlantis.io/docs/server-side-repo-config.html>
# <https://www.runatlantis.io/docs/repo-level-atlantis-yaml.html>
# repos lists the config for specific repos
repos:
# id can either be an exact repo ID or a regex.
# If using a regex, it must start and end with a slash
# Repo ID's are of the form {VCS hostname}/{org}/{repo name}
- id: github.com/xxxxxxx/yyyyyyyyy
# apply_requirements sets the Apply Requirements for all repos that match
apply_requirements: [approved]
# allowed_overrides specifies which keys can be overridden by this repo in
# its atlantis.yaml file
allowed_overrides: [apply_requirements, workflow]
# allow_custom_workflows defines whether this repo can define its own
# workflows. If false (default), the repo can only use server-side defined workflows
allow_custom_workflows: true
2020-05-05
2020-05-07
2020-05-11
2020-05-12
2020-05-14
2020-05-16
data:image/s3,"s3://crabby-images/7cceb/7ccebae740ff89e6d33ed042435902fb78501008" alt="Padarn avatar"
anyone have an example of a minimal terraform policy that Atlantis needs for AWS?
data:image/s3,"s3://crabby-images/7cceb/7ccebae740ff89e6d33ed042435902fb78501008" alt="Padarn avatar"
I’m trying to figure out how to get tag based permissions to work, and my original lenient policy is a bit had to prune
2020-05-18
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
minimal Atlantis policy is minimal policy for what you are wanting Atlantis to apply…
data:image/s3,"s3://crabby-images/7cceb/7ccebae740ff89e6d33ed042435902fb78501008" alt="Padarn avatar"
Haha yes, true, but in my experience terraform needs quite a few permissions just to do basic operations, even just for state refresh
data:image/s3,"s3://crabby-images/7cceb/7ccebae740ff89e6d33ed042435902fb78501008" alt="Padarn avatar"
another question on similar topic: Is anyway using something like an OAuth server infront of Atlantis ?
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
To do a state refresh it needs read access to the things you want to manage to it
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
Yes, I believe CloudPosse (may??) do this
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
@Padarn https://github.com/cloudposse/terraform-aws-ecs-atlantis is opinionated but contains the resources you will need
Terraform module for deploying Atlantis as an ECS Task - cloudposse/terraform-aws-ecs-atlantis
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Yep, this has support for that, but it’s a beast of a module
Terraform module for deploying Atlantis as an ECS Task - cloudposse/terraform-aws-ecs-atlantis
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
data:image/s3,"s3://crabby-images/7cceb/7ccebae740ff89e6d33ed042435902fb78501008" alt="Padarn avatar"
thanks guys - I was using the other terraform on fargate module, will go through this one
2020-05-19
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
https://github.com/marketplace/actions/hashicorp-setup-terraform
This is getting closer to Atlantis
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
Pretty cool. Does it only work with terraform cloud and enterprise or also for other backends?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
This works with terraform open source
data:image/s3,"s3://crabby-images/7cceb/7ccebae740ff89e6d33ed042435902fb78501008" alt="Padarn avatar"
if you have TF enterprise you probably don’t need this?
data:image/s3,"s3://crabby-images/7cceb/7ccebae740ff89e6d33ed042435902fb78501008" alt="Padarn avatar"
I was under the impression they offered integrations of many build tools
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
someone must be working in an atlantis feature complete clone, right…..?
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I heard a rumour
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
Isn’t the guy that started atlantis ilya working directly got hashicorp? Wouldn’t he be the one working on this as well?
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
both guys are working for hashicorp
2020-05-21
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
using default server workflow and custom repo workflow but only my defined directory has terraform run. all undefined directories in custom repo workflow do not use default workflow.
version: 3
projects:
- name: secrets
dir: secrets
workflow: secrets
workflows:
secrets:
plan:
steps:
- init
- run: make diff
- plan
apply:
steps:
- run: "echo 'Apply is disabled for now."
am I missing something simple ?
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
thread start
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
do i need to define both of these in my repo config ?
- id: "/.*/"
workflow: default
- name: secrets
dir: secrets
workflow: secrets
even tho my server config has this already ?
- id: "/.*/"
workflow: default
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
which for of atlantis are you using ?
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
using runatlantis/atlantis:v0.12.0
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
looks like the latest version
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
you need to allow custom workflows if you are defining workflows in your repo config
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
otherwise is not going to pick them up
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
it does pick it up for my custom workflow, just not for my not defined modules. this is my atlantis server config
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
repos:
- # apply config to repos matching this regex
id: /.*/
allow_custom_workflows: true
allowed_overrides:
- apply_requirements
- workflow
apply_requirements:
- approved
workflow: default
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
that should apply to all repos
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
it should but after i added a repo level config that i shared above, it seemed to only allow the custom one to work
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
the others i have to manually run atlantis plan -d mytfdir
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
mmm so is the autoplan you are expecting it to run?
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
yessir
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I hate autoplan so I disable every time
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
autoplan does have a default for the files it tracks
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
“/.tf”*
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 can type two *
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
freaking annoying slack
2020-05-28
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I’m going to have to fork cloudposse
atlantis to fix my needs so I was wondering how can I build my fork ?
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
@Andriy Knysh (Cloud Posse) I was trying make dist and got a bunch of errors, I’m wondering how you guys run the build ?
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I have no idea what I’m doing…. lol
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
make build-service
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
which is CGO_ENABLED=0 GOOS=linux GOARCH=amd64 go build -v -o atlantis .
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
and that exploded
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
CGO_ENABLED=0 GOOS=linux GOARCH=amd64 go build -v -o atlantis .
github.com/atlantis/vendor/github.com/runatlantis/atlantis/server/events/vcs
# github.com/atlantis/vendor/github.com/runatlantis/atlantis/server/events/vcs
vendor/github.com/runatlantis/atlantis/server/events/vcs/gitlab_client.go:168:54: not enough arguments in call to g.Client.MergeRequests.GetMergeRequest
have (string, int)
want (interface {}, int, *gitlab.GetMergeRequestsOptions, ...gitlab.OptionFunc)
vendor/github.com/runatlantis/atlantis/server/events/vcs/gitlab_client.go:199:54: not enough arguments in call to g.Client.MergeRequests.GetMergeRequest
have (string, int)
want (interface {}, int, *gitlab.GetMergeRequestsOptions, ...gitlab.OptionFunc)
make: *** [build-service] Error 2
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
do I have to have a specific version of go ?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
i tested it with 1.11 and 1.2 before, now I have 1.13.1, all works
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
are you building `
runatlantis/atlantis
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
or CloudPosse repo?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
runatlantis prob have made a lot of changes since the last time we forked it
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
cloudposse repo
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
make sure you copy it into <GOPATH>/src/github.com/runatlantis/atlantis
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
b/c all imports are using runatlantis
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
that’s how Go works
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
golang 101 lol
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
this looks better
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
github.com/runatlantis/atlantis/vendor/github.com/aws/aws-sdk-go/aws/defaults
github.com/runatlantis/atlantis/vendor/github.com/aws/aws-sdk-go/service/sts
github.com/runatlantis/atlantis/vendor/github.com/aws/aws-sdk-go/service/s3
github.com/runatlantis/atlantis/vendor/github.com/aws/aws-sdk-go/aws/credentials/stscreds
github.com/runatlantis/atlantis/vendor/github.com/aws/aws-sdk-go/aws/session
github.com/runatlantis/atlantis/vendor/github.com/hashicorp/go-getter
github.com/runatlantis/atlantis/vendor/github.com/runatlantis/atlantis/server/events/terraform
github.com/runatlantis/atlantis/vendor/github.com/runatlantis/atlantis/server/events/runtime
make: *** [build-service] Error 2
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
at least it did more stuff
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I moved to runatlantis/atlantis
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
and in there I run make build-service
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
better but not quite
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
~/workspace/Go/src/github.com/runatlantis/atlantis(git:master)❱✔≻ make build-service 39.3s Thu 28 May 17:33:50 2020
CGO_ENABLED=0 GOOS=linux GOARCH=amd64 go build -v -o atlantis .
github.com/runatlantis/atlantis/server/events/vcs/common
github.com/runatlantis/atlantis/server/logging
github.com/runatlantis/atlantis/server/recovery
github.com/runatlantis/atlantis/server/static
github.com/runatlantis/atlantis/server/events/yaml/valid
github.com/runatlantis/atlantis/testdrive
github.com/runatlantis/atlantis/server/events/terraform
github.com/runatlantis/atlantis/server/events/models
github.com/runatlantis/atlantis/server/events/yaml/raw
github.com/runatlantis/atlantis/server/events/db
github.com/runatlantis/atlantis/server/events/vcs/bitbucketserver
github.com/runatlantis/atlantis/server/events/vcs/bitbucketcloud
github.com/runatlantis/atlantis/server/events/locking
github.com/runatlantis/atlantis/server/events/webhooks
github.com/runatlantis/atlantis/server/events/vcs
github.com/runatlantis/atlantis/server/events/runtime
# github.com/runatlantis/atlantis/server/events/vcs
server/events/vcs/gitlab_client.go:168:54: not enough arguments in call to g.Client.MergeRequests.GetMergeRequest
have (string, int)
want (interface {}, int, *gitlab.GetMergeRequestsOptions, ...gitlab.OptionFunc)
server/events/vcs/gitlab_client.go:199:54: not enough arguments in call to g.Client.MergeRequests.GetMergeRequest
have (string, int)
want (interface {}, int, *gitlab.GetMergeRequestsOptions, ...gitlab.OptionFunc)
github.com/runatlantis/atlantis/server/events/yaml
make: *** [build-service] Error 2
❰jamengual❙~/workspace/Go/src/github.com/runatlantis/atlantis(git:master)❱✘≻
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
my ultimate goal is to patch current atlantis with the github code you guys did and add the atlantis.yaml specific settings I need
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
but for now building cloudposse fork will be great
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
so I ended up downloading lates atlantis src
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
compiled
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
added few thing worked
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
and I decided to add the code from PR #30 from cloudposse
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
after a few fixes
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
compiled
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I deployed
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
but I’m stuck
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
fo whatever reason it keeps saying : Error: User @jamengual does not have permissions to execute 'plan' command.
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
which is checkUserPermissions
returning false
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
but I do not know why yet
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
any pointers @Andriy Knysh (Cloud Posse)
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
this is the bit of code is doing the call
/ Check if the user who commented has the permissions to execute the 'plan' or 'apply' commands
ok, err := e.checkUserPermissions(baseRepo, user, parseResult.Command)
if err != nil {
e.Logger.Err("unable to comment on pull request: %s", err)
return
}
if !ok {
e.commentUserDoesNotHavePermissions(baseRepo, pullNum, user, parseResult.Command)
e.respond(w, logging.Warn, http.StatusForbidden, "User @%s does not have permissions to execute '%s' command", user.Username, parseResult.Command.Name.String())
return
}
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
@jose.amengual did you specify the parameter gh-team-whitelist
?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
what Add gh-team-whitelist command line argument Use bigger atlantis logo on the web pages why Improved security Explicitly specify GitHub teams and operations (plan, apply) that the members of …
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
and then did you add your user to the whitelisted team (on GitHub)?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
the code in this PR https://github.com/cloudposse/atlantis/pull/30 makes gh-team-whitelist
param optional. If not specified at all, the default functionality is in place. If specified, then the code checks if the user is in a whitelisted team. If not, the error is thrown
what Add gh-team-whitelist command line argument Use bigger atlantis logo on the web pages why Improved security Explicitly specify GitHub teams and operations (plan, apply) that the members of …
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
yes I did
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
basically I had atlantis already running with cloudposse fork
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
and then I I forked latest and added your code
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
and deployed to the same fargate task
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I have everything in Parameter store
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I added debug too
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
did you use the correct format for gh-team-whitelist
?
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
hds-team:plan,hds-team:apply
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
(looks like you did since you used CP fork before)
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I’m part of that team
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I used the terraform atlantis module from you guys
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
it is weird, I can run help and that , it does not crash or anything, plus returns my user correctly
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
well… atlantis made a lot of changes, and GitHub made a lot of changes. If you copy the code correctly and it does not work, then something has been changed in the GitHub API
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
somehow something in team_whitelist_checker.go does not work
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
if you run our fork now, does it work?
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I can roll back, one sec
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
somehow something in team_whitelist_checker.go does not work
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
that is my theory
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
we made changes a few times as well b/c GitHub kept changing some API
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
ohhhhh so maybe I did not push those updates ?????
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I did this : https://github.com/cloudposse/atlantis/pull/30/files
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
(don’t know )
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I checked like 40 times
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
after #30 I do not see anything about github
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
in situations like this, and since you are modifying the code anyway, would be great to update the version number and display it on the screen (I think it’s displayed)
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
so you can know for sure which version got deployed
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
GitOps for Teams (experimental hard fork of atlantis) - cloudposse/atlantis
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
mmmm
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I see :
2020-05-29 18:15:42
2020/05/30 01:15:42+0000 [INFO] server.go:462 server: Atlantis started - listening on port 4141
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
yes so I have a custom version
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
atlantis version 8.9m Fri 29 May 20:34:46 2020
atlantis 0.12.0-multienv-debug1
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I see the same if I docker build locally
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I wonder if I could shot the version on fargate logs
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
you should see the version in the UI, in the bottom-right corner
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I added this too https://github.com/cloudposse/atlantis/pull/32/files
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
which I though it was the problem
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
the ui…ok let me check I have not used the UI ever
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
mmm the ui is 503…..
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
the ui is on /?
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
ok, listener rule error , it shows my version
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
v0.12.0-multienv-debug0
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
so at least I know is the one I compiled
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
and this was updated too
func (g *GithubClient) GetTeamNamesForUser(repo models.Repo, user models.User) ([]string, error) {
var teamNames []string
opts := &github.ListOptions{}
org := repo.Owner
for {
teams, resp, err := g.client.Teams.ListTeams(g.ctx, org, opts)
if err != nil {
return nil, err
}
for _, t := range teams {
membership, _, err := g.client.Teams.GetTeamMembership(g.ctx, t.GetID(), user.Username)
if err == nil && membership != nil {
if *membership.State == "active" && (*membership.Role == "member" || *membership.Role == "maintainer") {
teamNames = append(teamNames, t.GetName())
}
}
}
if resp.NextPage == 0 {
break
}
opts.Page = resp.NextPage
}
return teamNames, nil
}
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
GitOps for Teams (experimental hard fork of atlantis) - cloudposse/atlantis
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
do you see this error Error: User @jamengual does not have permissions to execute 'plan' command
as GitHub comment?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
also, you sure that the user is a member of the team, and the team name is correct?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
and also, is our version working for you?
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
yes I do see it as a github comment
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
yes I’m a member of that team and the team is correct
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
you version was working ok but my need is that I use one repo for all environment so I deploy and atlantis per AWS account and without the option to define a custom atlantis.yaml
it does not work for me so I added https://github.com/runatlantis/atlantis/compare/master...mediwareinc:multienv-0.11.0
Terraform Pull Request Automation. Contribute to runatlantis/atlantis development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
which is very very simple and fit my needs
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
but I really like the team whitelist option and that is why I’m here
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
so it’s the same team whitelist code in both repos, one is working, the other is not
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
correct
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
Unless I missed something
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
and the code gets executed and checks for team membership
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
as fas as I can tell
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
so 1) you missed something; 2) atlantis made other changes that affected it; 3) you are using new GitHub API that changed the logic (they did it in the past)
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I’m not a go experts by any means but I was thinking to add e.Logger.Err
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
one of the 3 but I think 3 is unlikely because this was working with cloudposse fork and I did not change anything related to apis for github
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
since our fork does not use Go modules (was not in atlantis at the time), and the new atlantis uses Go modules, the GitHub APi could be completely different
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
(the sad thing is, w/o Go modules it was not possible to pin it to a particular version)
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
so you alway get the latest
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
but new atlantis uses Go modules so you can see what version you are using
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
you alway get the latest - if you don’t use Go modules, which was created to fix those issues
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I see ok
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
as I said, w/o Go modules it was aways the latest version, and GitHub updated the API a few times and broke our code
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
with Go modules in the latest atlantis, they pinned it to a particular version, but.. that version could be new with some API changes from GitHub (just an idea)
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
so you think when I did go get [github.com/runatlantis/atlantis](http://github.com/runatlantis/atlantis)
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
ad then go build I got a version of the github client api that is not compatible ?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
might be
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
we had such issue before
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
not saying that they change the API all the time, but they did, and broke our code
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I’m running my version now using ngrok and using chamber to populate the ENV variables to my local
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
so I can debug faster
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
intersting
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I added this :
// checkUserPermissions checks if the user has permissions to execute the command
func (e *EventsController) checkUserPermissions(repo models.Repo, user models.User, cmd *events.CommentCommand) (bool, error) {
if cmd.Name == models.ApplyCommand || cmd.Name == models.PlanCommand {
teams, err := e.VCSClient.GetTeamNamesForUser(repo, user)
if err != nil {
return false, err
}
e.Logger.Err("PEPE teams: ", teams)
ok := e.TeamWhitelistChecker.IsCommandAllowedForAnyTeam(teams, cmd.Name.String())
if !ok {
return false, nil
}
}
return true, nil
}
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
e.Logger.Err("PEPE teams: ", teams)
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
mmm there is some sensitive information on all this
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
basically
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
[EROR] events_controller.go:585 server: PEPE teams: %!(EXTRA []string=[Ops Team Product Engineering Employees terraform-atlantis])
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
terrafom-atlantis
is a team
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
but the other is the description of the ream not the team name
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
no wait….those are the names
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
they just have spaces
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
we did not test teams with spaces
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
that is it
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I added terraform-atlantis
to the team whitelist
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
and now is working
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
but where is hds-team
in the list?
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
yes it was
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
and it did work with the cloudposse fork
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
atlantis_gh_team_whitelist = hds-team:plan,hds-team:apply,terraform-atlantis:plan
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
what do you mean “it was”? it’s not in the list [Ops Team Product Engineering Employees terraform-atlantis]
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I mangled the output
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
so you are not part of that team
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
sorry
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
PEPE teams: %!(EXTRA []string=[IQ Ops HDS Team Product Engineering Employees terraform-atlantis])
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
HDS Team
is that team
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
and I’m part of it
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
ok so…….
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
HDS Team:plan,hds-team:apply
that works
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
so this must be something to do with the the github client response that is now not passing some sort of alternated name for the team ?
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I guess a team with a name with space will be converted to something else ?
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I’m trying to understand why it worked with the cloudposse fork before
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
@Andriy Knysh (Cloud Posse) do you happen to know if there is a way to shortcircuit
atlantis execution after the call to ParseRepoCfg
I was trying to stop atlantis if :
if projectName != "" && yaml.AtlantisYAMLFilename != "atlantis.yaml" {
return
}
OR by using a new env variable ATLANTIS_MULTISERVER
but I’m not familiar with the code and after many hours the plan command keeps executing
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
my guess that whatever I do it will have to be in the Event controller but I’m not so sure anymore
2020-05-29
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
this is strange. i have a specific workflow for a specific tf module to overwrite the terraform version yet it still uses the default.
version: 3
projects:
- name: secrets
dir: secrets
workflow: secrets
terraform_version: v0.12.25
workflows:
secrets:
plan:
steps:
- init
- run: make diff
- plan
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
then i see this in github
�[31m
�[1m�[31mError: �[0m�[0m�[1mError loading state: state snapshot was created by Terraform v0.12.25, which is newer than current v0.12.24; upgrade to Terraform v0.12.25 or greater to work with this state�[0m
�[0m�[0m�[0m
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
im using atlantis 12 and i dont believe the new 13 that was just released fixes this, according to their changelog
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
any idea what im doing wrong ? or is this a bug ?
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
the init
seems to work but the make diff
which calls terraform refresh
seems to use the default terraform instead of the terraform_version
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
perhaps v0.12.25
needs to be 0.12.25
according to this
Atlantis: Terraform Pull Request Automation
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
this is interesting too
https://github.com/runatlantis/atlantis/issues/910
Looks like @lkysow says to use
- run: terraform$ATLANTIS_TERRAFORM_VERSION plan
so perhaps i need to do that in my Makefile to use the correct version of terraform …
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
terraform_version
in atlantis workflow never worked for us as well
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
in my make diff, i changed it so my Makefile uses the $ATLANTIS_TERRAFORM_VERSION
, not sure what else to do
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
wish atlantis could be smart enough to check the tfstate, get the correct version, and use the same version in the state
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
dude youre right, WTF, tested it out and that env variable wasnt even filled
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
so i guess im not allowed to use Makefile
targets in my run
atlantis command if it requires a non default terraform version
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
My repo level atlantis.yaml version: 3 projects: - name: secrets dir: secrets workflow: secrets terraform_version: v0.12.25 workflows: secrets: plan: steps: - init - run: make diff - plan secrets d…
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
yes it’s like that
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
you can fork it and improve
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
Using v12 My repo level atlantis.yaml version: 3 projects: - name: secrets dir: secrets workflow: secrets terraform_version: v0.12.25 workflows: secrets: plan: steps: - init - run: make diff - plan…
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
atlantis, when using repo configs, is using the PR branch’s config instead of the one in master. this wasn’t clear to me and was confusing.