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

Proxy served on all (sub)domains #18

Open
hacker1024 opened this issue Jan 30, 2018 · 6 comments
Open

Proxy served on all (sub)domains #18

hacker1024 opened this issue Jan 30, 2018 · 6 comments
Labels
unplanned Issue may be resolved in future, but is not a priority

Comments

@hacker1024
Copy link

hacker1024 commented Jan 30, 2018

Here's my caddyfile (I have to use port 443 for other reasons, but this happens on any port):

pi:443 {
    tls off
}
proxy.website.com:443 {
    forwardproxy {
        basicauth username password
        serve_pac config.pac
    }
    tls off
}

pi is my server's hostname in my LAN. A proxy is hosted at proxy.website.com, which is what should be happening. The problem is, it's also hosted on port 443 on any other domain. This Caddyfile is just one example. No matter what I try, I can't only host the proxy on one domain, no matter the port or domain.

Another example:

website.com:80 {
    root websiteroot
    ext html htm
}
proxy.website.com:80 {
    forwardproxy {
        basicauth username password
    }
}

Here, a webpage won't get served at website.com:80.
Instead, a proxy will. this makes it impossible to have a proxy served only on a subdomain, on the same port.

@sergeyfrolov
Copy link
Member

@hacker1024
This is a known (to developers) limitation and it has to do how Caddy matches requests to websites.
While forwardproxying, the only place where website name shows up is Subject Name Indication during TLS handshake. After the tls handshake, it's just CONNECT somesite.com HTTP/1.1 OR GET anothersite.com HTTP/1.1.
For any use-case, other than forwardproxy (which came around last August), Caddy doesn't need to keep track of which SNI was used for which TLS connection, and thus was designed to simply match requests where they should go, as they come. Other webservers share this behavior. So what we've done, when we added forwardproxy, is that whenever forwardproxy is on, Caddy will match all unmatched requests into the forwardproxying chain. Hence, your issue.
As a result, fixing this issue would require (potentially substantial) changes in Caddy's core to make sure incoming requests have context that includes original SNI. I, as author of forwardproxy, do not know whether @mholt (Caddy author) would be happy for this to happen. If you describe your use-case and why it's important for forwardproxy to only work with single SNI, that might help.

@mholt
Copy link
Member

mholt commented Jan 31, 2018

Sergey is right.

... although technically, Caddy does already (uniquely) hold onto the TLS ClientHello info for MITM detection for each HTTPS request. It doesn't currently hold onto the SNI information but we could potentially add it.

Anyway, it's not out of the question.

@hacker1024
Copy link
Author

I see. In the meantime, perhaps an error or warning could show when someone tries to do what I've done?

@mholt
Copy link
Member

mholt commented Feb 2, 2018

Perhaps we could introduce a -sni-first flag (as in #12), except by this issue the flag would also disable forwardproxy's "fallback" behavior. In other words, without the -sni-first flag, the forwardproxy plugin tells Caddy to "fall back" to the site of the forwardproxy when the Host header doesn't match any site definitions. This is how it already works. But if we use -sni-first then we would have to disable that, since we would match on SNI to find the site definition that applies to that request, then consume the Host header with forwardproxy.

It's a bit of a hack, and very, very niche use, and we'd have to consider on the implications for probe resistance. Feedback and critique welcome.

@jim3ma
Copy link
Contributor

jim3ma commented Feb 4, 2018

I think the -sni-first disables the forwardproxy's "fallback" behavior is not matter.

When proxy traffic comes with -sni-first, caddy knows it is for the proxy site(which configured with forwardproxy).

While currently the fallback method is just a workaround. We should consider a perfect solution.
With -sni-first, forwardproxy should register with the site and the CONNECT method for catching the proxy traffic and this can resolve this issue.
Without -sni-first, it seems that fallback is the only way.

@sergeyfrolov sergeyfrolov added the unplanned Issue may be resolved in future, but is not a priority label Jun 15, 2018
@jerry-wolf
Copy link

Now we should be able to do this.

@forward_proxy {
	var {http.request.tls.server_name} example.com
	not host example.com
}
route @forward_proxy {
	forward_proxy
}

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
unplanned Issue may be resolved in future, but is not a priority
Projects
None yet
Development

No branches or pull requests

5 participants