Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Azure DevOps Service Hook Source? #3

Closed
jpreese opened this issue Mar 23, 2020 · 6 comments
Closed

Azure DevOps Service Hook Source? #3

jpreese opened this issue Mar 23, 2020 · 6 comments

Comments

@jpreese
Copy link

jpreese commented Mar 23, 2020

@mcdafydd

Oh the joys of a lack of a direct messaging mechanism, hopefully this reaches you :)

You've obviously done a lot of work with Atlantis and Azure DevOps, are you familiar with the origin IP address for AzDO's service hooks? We're in the process of rolling out Atlantis for AzDO, but the instance is behind a firewall and there doesn't seem to be a whole lot of documentation on configuring networking to allow services to accept requests from AzDO.

Based on your original PR (runatlantis#719) -- I'm seeing 20.23.242.132 in the logs. This also seems to be consistent with some testing I did where I grabbed the source IP from a test connection.

@mcdafydd
Copy link
Owner

mcdafydd commented Mar 23, 2020

Great that you're working on rolling this out! I haven't tried to re-evaluate if there's a more restrictive set of sources available recently, so I'm relying on Azure NSGs with source addresses of all the AzureCloud.<region> (ie: AzureCloud.eastus, AzureCloud.centralus) service tags for my Atlantis VM's region, the US. That seems to work and is acceptable for now, obviously alongside TLS and basic auth.

Of course I'd prefer a much smaller set of something like what we have for hosted build agents.

@jpreese
Copy link
Author

jpreese commented Mar 24, 2020

We're running this in Kubernetes, but thats still in a VNET with an NSG. You're saying that the AzureCloud service tags include Azure DevOps? Because that would be pretty solid.

@mcdafydd
Copy link
Owner

Yes, those service tags appear to work fine. We've been running this for about 6 months now with a small, mildly active team. I haven't noticed any service hook logs showing webhooks that timed out. I think I recall getting this notion from this section in the docs, following the geography comment. The AzureCloud tags seem to cover all the same IP ranges.

@jpreese
Copy link
Author

jpreese commented Mar 24, 2020

Ok awesome! I'll bring that up on this side of the fence and see if we can get these opened. Thanks again!

@jpreese jpreese closed this as completed Mar 24, 2020
@jpreese jpreese reopened this Mar 29, 2020
@jpreese
Copy link
Author

jpreese commented Mar 29, 2020

@mcdafydd One small bit of clarification as there seems to be some conflicting bits of information. In your implementation, did you have to create a Public IP resource in order for Azure to talk to your Atlantis instance? Or is it possible to just have an Internal loadbalancer/NSG that allows the AzureCloud tag? The NSG Inbound/Outbound are getting painful to figure out.

Additionally, if you're into blogging, you should totally do a writeup of your implementation. There is no information out there about Atlantis + DevOps. I planned on doing one after our roll out, but I would read yours right this very second if it existed.

@mcdafydd
Copy link
Owner

Hi @jpreese - Yes, you'll need a public IP for Azure Devops to find your Atlantis URL, and it will need to be resolvable in your Internet-facing DNS. For me, the path looked something like this:

Azure Devops webhook to https://<atlantis URL>:4141/events
  -> Azure public IP 
  -> Multiple inbound allow NSG rules with
    -> one source address service tag per rule for AzureCloud.westus and all the other United States regions
    -> dest. port 4141/tcp
    -> dest. internal vNet IP of Atlantis

So you could definitely use an Azure public load balancer for that.

I haven't done much looking into the outbound rules, but I see that dev.azure.com resolves to 13.107.42.20 at the moment, and that does happen to match one of the documented public IPs here.

Another thing I might recommend is using something like an Nginx proxy or maybe https://github.com/pusher/oauth2_proxy to add authentication to the lock screen page. This was discussed on the Atlantis issues as well.

I haven't done much blogging, but I appreciate the suggestion! I may try to put one together.

Oh, and if you want to DM me, I setup a Twitter profile just for that purpose here:

https://twitter.com/mcdafydd

Good luck!

@jpreese jpreese closed this as completed Apr 4, 2020
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants