Basic Auth
Scott Stewart
scott.stewart at nbtsolutions.com
Sun Jun 3 17:00:59 CEST 2012
Hi Hugo,
-I did as you suggested as added the 'pass' for requests asking for
authentication. And sure enough, it started asking for the
authentication--however it doesnt stop asking for the authentication--it
never seems to authenticate. I know the auth works, because I can access
it without going through varnish and it works fine. Any idea what could be
the problem here?
FWIW, The auth is not a typical basic auth, but a basic auth against an
ldap using the apache and the mod_ldapns_auth
On Wed, May 30, 2012 at 3:50 PM, Scott Stewart <
scott.stewart at nbtsolutions.com> wrote:
> Hi
>
> I have a newly minted varnish (and a newly minted varnish user myself)
> install that has two backends, as spec'ed in this vcl (below).
>
> The "wms1" has no auth on it.
>
> The "default" backend is a Apache server with basic auth, but no one is
> getting asked to authenticate. My understanding was the out of the box
> config for varnish would not cache those authentication required pages, but
> no one is being asked for a username/password
>
> What am I doing wrong here? The app works perfectly otherwise.
>
>
>
> # This is a basic VCL configuration file for varnish. See the vcl(7)
> # man page for details on VCL syntax and semantics.
> #
> # Default backend definition. Set this to point to your content
> # server.
> #
> backend default {
> .host = "127.0.0.1";
> .port = "8081";
> }
>
> backend wms1 {
> .host = "example.com";
> .port = "80";
> }
>
> sub vcl_recv {
>
> if (req.http.host ~ "^(mapsdev\.)example\.com" && req.url~ "^/wms") {
> set req.http.host = "maps.example.com";
> set req.url = regsub(req.url, "^/wms", "/wms");
> set req.backend = wms1;
> if (req.request == "GET" && req.http.cookie)
> {
> unset req.http.cookie;
> }
> }
> if (req.http.host ~ "^(mapsdev\.)?example\.com" && req.url~ "^/app/") {
> set req.url = regsub(req.url, "^/app/", "/flol/admin_2/public/");
> remove req.http.X-Forwarded-For;
> set req.http.X-Forwarded-For = client.ip;
> }
>
> sub vcl_fetch {
> set beresp.ttl = 72h; // default ttl 72 hours
> if (req.http.Authorization)
> {
> return(hit_for_pass);
> }
> }
>
> #
> # Below is a commented-out copy of the default VCL logic. If you
> # redefine any of these subroutines, the built-in logic will be
> # appended to your code.
> # sub vcl_recv {
> # if (req.restarts == 0) {
> # if (req.http.x-forwarded-for) {
> # set req.http.X-Forwarded-For =
> # req.http.X-Forwarded-For + ", " + client.ip;
> # } else {
> # set req.http.X-Forwarded-For = client.ip;
> # }
> # }
> # if (req.request != "GET" &&
> # req.request != "HEAD" &&
> # req.request != "PUT" &&
> # req.request != "POST" &&
> # req.request != "TRACE" &&
> # req.request != "OPTIONS" &&
> # req.request != "DELETE") {
> # /* Non-RFC2616 or CONNECT which is weird. */
> # return (pipe);
> # }
> # if (req.request != "GET" && req.request != "HEAD") {
> # /* We only deal with GET and HEAD by default */
> # return (pass);
> # }
> # if (req.http.Authorization || req.http.Cookie) {
> # /* Not cacheable by default */
> # return (pass);
> # }
> # return (lookup);
> # }
> #
> # sub vcl_pipe {
> # # Note that only the first request to the backend will have
> # # X-Forwarded-For set. If you use X-Forwarded-For and want to
> # # have it set for all requests, make sure to have:
> # # set bereq.http.connection = "close";
> # # here. It is not set by default as it might break some broken web
> # # applications, like IIS with NTLM authentication.
> # return (pipe);
> # }
> #
> # sub vcl_pass {
> # return (pass);
> # }
> #
> # sub vcl_hash {
> # hash_data(req.url);
> # if (req.http.host) {
> # hash_data(req.http.host);
> # } else {
> # hash_data(server.ip);
> # }
> # return (hash);
> # }
> #
> # sub vcl_hit {
> # return (deliver);
> # }
> #
> # sub vcl_miss {
> # return (fetch);
> # }
> #
> # sub vcl_fetch {
> # if (beresp.ttl <= 0s ||
> # beresp.http.Set-Cookie ||
> # beresp.http.Vary == "*") {
> # /*
> # * Mark as "Hit-For-Pass" for the next 2 minutes
> # */
> # set beresp.ttl = 120 s;
> # return (hit_for_pass);
> # }
> # return (deliver);
> # }
> #
> # sub vcl_deliver {
> # return (deliver);
> # }
> #
> # sub vcl_error {
> # set obj.http.Content-Type = "text/html; charset=utf-8";
> # set obj.http.Retry-After = "5";
> # synthetic {"
> # <?xml version="1.0" encoding="utf-8"?>
> # <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
> # "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
> # <html>
> # <head>
> # <title>"} + obj.status + " " + obj.response + {"</title>
> # </head>
> # <body>
> # <h1>Error "} + obj.status + " " + obj.response + {"</h1>
> # <p>"} + obj.response + {"</p>
> # <h3>Guru Meditation:</h3>
> # <p>XID: "} + req.xid + {"</p>
> # <hr>
> # <p>Varnish cache server</p>
> # </body>
> # </html>
> # "};
> # return (deliver);
> # }
> #
> # sub vcl_init {
> # return (ok);
> # }
> #
> # sub vcl_fini {
> # return (ok);
> # }
>
>
--
Scott Stewart
Principal
NBT Solutions LLC
phone: (757)941-5110
email: scott.stewart at nbtsolutions.com
website:www.nbtsolutions.com
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <https://www.varnish-cache.org/lists/pipermail/varnish-misc/attachments/20120603/27aaf737/attachment.html>
More information about the varnish-misc
mailing list