<div dir="ltr">Thanks Amos: yes agree that I should have told forward proxy.<div><br><div>When I remove the originserver option from cache_peer, the forward proxy is working so which means the rewriter is not precluding from happening. Does that give any clue to us? <br></div><div><br></div><div>Moreover the reverse proxy is in next hop to the client and not in internet. Time being, we are ok to have insecure channel between client and squid. Do you have any sample config that that uses a parent proxy to do both forward/reverse proxy? Or do you see my config is good enough for this requirement.</div></div></div><div class="gmail_extra"><br><div class="gmail_quote">On Tue, Aug 7, 2018 at 9:07 PM, Amos Jeffries <span dir="ltr"><<a href="mailto:squid3@treenet.co.nz" target="_blank">squid3@treenet.co.nz</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><span class="">On 08/08/18 01:04, Hariharan Sethuraman wrote:<br>
> Hi,<br>
> <br>
> We have our company proxy and this is how the topology is expected to<br>
> look like for the deployment:<br>
> <br>
> Client<br>
> -------------------squid-host.<wbr>com---------------------------<wbr>company-proxy------------<wbr>Internet<br>
> <br>
> Now I need to allow reverse proxy(3128) for some request from the client<br>
> and tunnel (3129) as well.<br>
<br>
</span>This reads like you don't understand what either of those terms mean.<br>
<br>
Your proxies port 3129 is setup for forward-proxy traffic.<br>
<br>
"tunnel" is and action that can be done by clients. Also the term used<br>
to describe the *payload* of a CONNECT message. The action a<br>
forward-proxy performs when receiving a CONNECT is usually to setup a<br>
tunnel CONNECT-ion for non-HTTP use.<br>
<br>
Using port 3128 for reverse-proxy traffic is a very bad idea. That port<br>
is a well-known port and also reserved for explicit / forward-proxy traffic.<br>
<span class=""><br>
<br>
> <br>
> Configuration:<br>
> http_port 3128 accel allow-direct<br>
> http_port 3129<br>
> never_direct allow all<br>
> always_direct deny all<br>
> ...<br>
> cache_peer company-proxy parent 80 0 no-query no-digest<br>
> login=PASS originserver<br>
> url_rewrite_access allow all<br>
> url_rewrite_program /usr/bin/python ./rewriter_program.py<br>
> <br>
> Usecases:<br>
> <br>
> 1) Reverse proxy: Now I can successfully get the response for the query<br>
> like curl -X GET <a href="http://squid-host.com:3128/microsoftapi/api/something" rel="noreferrer" target="_blank">http://squid-host.com:3128/<wbr>microsoftapi/api/something</a>.<br>
> Basically I rewrite URL to <a href="https://microsft.com/api/something" rel="noreferrer" target="_blank">https://microsft.com/api/<wbr>something</a> and<br>
> through company-proxy I get the response successfully from e.g.,<br>
</span>> <a href="http://microsoft.com" rel="noreferrer" target="_blank">microsoft.com</a> <<a href="http://microsoft.com" rel="noreferrer" target="_blank">http://microsoft.com</a>>.<br>
<br>
Re-writing message URLs across the insecure / secure boundary is a very<br>
bad idea. All Cookies and other things in both message headers and<br>
payload content which are tied to either the TLS or the Origin state<br>
will be broken.<br>
<br>
The client thinks it is talking to an insecure server, and the server<br>
thinks it is connected to a secure client. They also have very different<br>
ideas about the Origin scope for stateful security things - especially<br>
when re-writing across domains like this. That means they each believe<br>
different range of actions are valid, and that impacts on what they<br>
expect the other agents behaviour to be in reaction to any given message.<br>
<span class=""><br>
<br>
> <br>
> 2) Tunnel: It fails when the client do a query like curl -x<br>
> <a href="http://squid-host.com:3129" rel="noreferrer" target="_blank">http://squid-host.com:3129</a> -X GET <a href="https://googlecloudapis.com/api/something" rel="noreferrer" target="_blank">https://googlecloudapis.com/<wbr>api/something</a><br>
> < HTTP/1.1 503 Service Unavailable<br>
> < Server: squid/3.5.20<br>
> < Mime-Version: 1.0<br>
> < Date: Tue, 07 Aug 2018 12:36:07 GMT<br>
> < Content-Type: text/html;charset=utf-8<br>
> < Content-Length: 3879<br>
> < X-Squid-Error: ERR_CANNOT_FORWARD 0<br>
> < Vary: Accept-Language<br>
> < Content-Language: en<br>
> <<br>
> * The requested URL returned error: 503<br>
> * CONNECT phase completed!<br>
</span>> * Connection #0 to host <a href="http://squidhostname.com" rel="noreferrer" target="_blank">squidhostname.com</a> <<a href="http://squidhostname.com" rel="noreferrer" target="_blank">http://squidhostname.com</a>><br>
<span class="">> left intact<br>
> Now, if I remove the origin server, the TUNNEL goes through and getting<br>
> the response but the reverse proxy fails.<br>
> <br>
<br>
</span>Please add the --verbose option to your curl test commands to see what<br>
is actually being sent to the proxy. Then test what your re-writer is<br>
causing to happen on those received URI.<br>
<br>
Note that all the re-writer does is change the URI. It does not change<br>
the method or other request details. If it produces an invalid or<br>
unreachable URI there is nothing Squid can do but present the client<br>
with an error.<br>
<span class=""><br>
<br>
<br>
> Could you let me know how I can handle both tunneling and reverse proxy<br>
> through same cache peer?<br>
<br>
</span>Both are already supported and work without any fancy setup. I think you<br>
are hitting something else which should become clearer when you see what<br>
curl is actually doing.<br>
<br>
Amos<br>
______________________________<wbr>_________________<br>
squid-users mailing list<br>
<a href="mailto:squid-users@lists.squid-cache.org">squid-users@lists.squid-cache.<wbr>org</a><br>
<a href="http://lists.squid-cache.org/listinfo/squid-users" rel="noreferrer" target="_blank">http://lists.squid-cache.org/<wbr>listinfo/squid-users</a><br>
</blockquote></div><br></div>