<div dir="ltr">Hello,<div><br></div><div>The expected result is to have variables such as "<a href="http://block-domain.com">block-domain.com</a>" set for 15min once vsthrottle triggers, then later checked if defined. The vsthrottle trigger works, but I'm not having any luck setting and checking for the variables - they're always blank. Example vcl:</div><div><br></div><div>vcl_recv {</div><div><div>  if (client.ip ~ cloudflare) {</div><div>  Â  Â  Â  var.set("ip",req.http.CF-Connecting-IP);</div><div>  Â  Â  Â  var.set("src","cloud");</div><div>  } elseif (client.ip ~ sucuri) {</div><div>  Â  Â  Â  var.set("ip",req.http.X-Sucuri-ClientIP);</div><div>  Â  Â  Â  var.set("src","sucuri");</div><div>  } elseif (client.ip ~ incapsula) {</div><div>  Â  Â  Â  var.set("ip",req.http.Incap-Client-IP);</div><div>  Â  Â  Â  var.set("src","incapsula");</div><div><br></div><div>  } else {</div><div>  Â  Â  Â  var.set("ip",client.ip);</div><div>  Â  Â  Â  var.set("src","direct");</div><div>  }</div></div><div>  Â  Â  Â  if (vsthrottle.is_denied(req.http.Host, 20, 5s) || (var.get("block-" + req.http.Host))) { # Here I'm trying to trigger on "<a href="http://block-domain.com">block-domain.com</a>", but it's not working<br></div><div><div>  Â  Â  Â  Â  Â  Â  Â  unset req.http.Cookie;<br></div><div>  Â  Â  Â  Â  Â  Â  Â  unset req.http.User-Agent;</div><div>  Â  Â  Â  Â  Â  Â  Â  unset req.http.Pragma;</div><div>  Â  Â  Â  Â  Â  Â  Â  unset req.http.Cache-Control;</div><div>  Â  Â  Â  Â  Â  Â  Â  set req.http.Attack = "ByHost " + req.http.Host + " (" + var.get("src") + ")";</div><div>  Â  Â  Â  Â  Â  Â  Â  set req.ttl = 15m;</div><div>  Â  Â  Â  Â  Â  Â  Â  var.set_duration("block-" + req.http.Host,15m); # This is where I'm trying to set the variable "<a href="http://block-domain.com">block-domain.com</a>"</div><div>  Â  Â  Â  Â  Â  Â  Â  set req.http.Attack-Debug = var.get("block-" + req.http.Host); # And again here for some debugging</div><div>  Â  Â  Â  Â  Â  Â  Â  return (hash);</div><div>  Â  Â  Â  }</div></div><div>}</div><div><br></div><div>vcl_deliver {<br></div><div><div>  Â  Â  Â  if (req.http.Attack) {</div><div>  Â  Â  Â  Â  set resp.http.Attack-Debug = req.http.Attack-Debug;</div><div>  Â  Â  Â  Â  set resp.http.Attack = req.http.Attack;</div><div>  Â  Â  Â  }</div></div><div>}<br></div><div><br></div><div><br></div><div>however Attack-Debug is always blank, thoughts?</div><div><br></div><div><div>* Â  << Request Â >> 431527 Â  Â </div><div>- Â  Begin Â  Â  Â  Â  Â req 431526 rxreq</div><div>- Â  Timestamp Â  Â  Â Start: 1467223441.362702 0.000000 0.000000</div><div>- Â  Timestamp Â  Â  Â Req: 1467223441.362702 0.000000 0.000000</div><div>- Â  ReqStart Â  Â  Â  11.22.33.44 62758</div><div>- Â  ReqMethod Â  Â  Â HEAD</div><div>- Â  ReqURL Â  Â  Â  Â  /</div><div>- Â  ReqProtocol Â  Â HTTP/1.1</div><div>- Â  ReqHeader Â  Â  Â User-Agent: curl/7.19.7 (x86_64-redhat-linux-gnu) libcurl/7.19.7 NSS/3.21 Basic ECC zlib/1.2.3 libidn/1.18 libssh2/1.4.2</div><div>- Â  ReqHeader Â  Â  Â Accept: */*</div><div>- Â  ReqHeader Â  Â  Â Host: <a href="http://zhtest.com">zhtest.com</a></div><div>- Â  ReqHeader Â  Â  Â X-Forwarded-For: 11.22.33.44</div><div>- Â  VCL_call Â  Â  Â  RECV</div><div>- Â  VCL_acl Â  Â  Â  Â NO_MATCH cloudflare</div><div>- Â  VCL_acl Â  Â  Â  Â NO_MATCH sucuri</div><div>- Â  VCL_acl Â  Â  Â  Â NO_MATCH incapsula</div><div>- Â  ReqUnset Â  Â  Â  User-Agent: curl/7.19.7 (x86_64-redhat-linux-gnu) libcurl/7.19.7 NSS/3.21 Basic ECC zlib/1.2.3 libidn/1.18 libssh2/1.4.2</div><div>- Â  ReqHeader Â  Â  Â Attack: ByHost <a href="http://zhtest.com">zhtest.com</a> (direct)</div><div>- Â  ReqHeader Â  Â  Â Attack-Debug: </div><div>- Â  VCL_return Â  Â  hash</div><div>- Â  VCL_call Â  Â  Â  HASH</div><div>- Â  VCL_return Â  Â  lookup</div><div>- Â  Hit Â  Â  Â  Â  Â  Â 329457</div><div>- Â  VCL_call Â  Â  Â  HIT</div><div>- Â  ReqHeader Â  Â  Â X-Cache-Keep: 300.000</div><div>- Â  ReqHeader Â  Â  Â X-Cache-TTL-Remaining: 110.641</div><div>- Â  ReqHeader Â  Â  Â X-Cache-Age: 189.359</div><div>- Â  ReqHeader Â  Â  Â Cache: HIT</div><div>- Â  VCL_return Â  Â  deliver</div><div>- Â  RespProtocol Â  HTTP/1.1</div><div>- Â  RespStatus Â  Â  200</div><div>- Â  RespReason Â  Â  OK</div><div>- Â  RespHeader Â  Â  Date: Wed, 29 Jun 2016 18:03:51 GMT</div><div>- Â  RespHeader Â  Â  Server: Apache</div><div>- Â  RespHeader Â  Â  Link: <<a href="http://zhtest.com/wp-json/">http://zhtest.com/wp-json/</a>>; rel="<a href="https://api.w.org/">https://api.w.org/</a>"</div><div>- Â  RespHeader Â  Â  X-Frame-Options: SAMEORIGIN</div><div>- Â  RespHeader Â  Â  Strict-Transport-Security: max-age=31536000; includeSubDomains</div><div>- Â  RespHeader Â  Â  Content-Length: 7702</div><div>- Â  RespHeader Â  Â  Content-Type: text/html; charset=UTF-8</div><div>- Â  RespHeader Â  Â  x-url: /</div><div>- Â  RespHeader Â  Â  X-Varnish: 431527 329457</div><div>- Â  RespHeader Â  Â  Age: 9</div><div>- Â  RespHeader Â  Â  Via: 1.1 varnish-v4</div><div>- Â  VCL_call Â  Â  Â  DELIVER</div><div>- Â  RespUnset Â  Â  Â x-url: /</div><div>- Â  RespHeader Â  Â  Cache: HIT</div><div>- Â  RespHeader Â  Â  Cache-Hits: 1156</div><div>- Â  RespHeader Â  Â  Attack-Debug: </div><div>- Â  RespHeader Â  Â  Attack: ByHost <a href="http://zhtest.com">zhtest.com</a> (direct)</div><div>- Â  RespUnset Â  Â  Â Server: Apache</div><div>- Â  RespUnset Â  Â  Â X-Varnish: 431527 329457</div><div>- Â  RespUnset Â  Â  Â Via: 1.1 varnish-v4</div><div>- Â  VCL_return Â  Â  deliver</div><div>- Â  Timestamp Â  Â  Â Process: 1467223441.362767 0.000065 0.000065</div><div>- Â  RespHeader Â  Â  Accept-Ranges: bytes</div><div>- Â  Debug Â  Â  Â  Â  Â "RES_MODE 0"</div><div>- Â  RespHeader Â  Â  Connection: keep-alive</div><div>- Â  Timestamp Â  Â  Â Resp: 1467223441.362802 0.000100 0.000036</div><div>- Â  ReqAcct Â  Â  Â  Â 172 0 172 409 0 409</div><div>- Â  End </div></div><div><br></div></div><div class="gmail_extra"><br><div class="gmail_quote">On Wed, Jun 29, 2016 at 11:14 AM, Guillaume Quintard <span dir="ltr"><<a href="mailto:guillaume@varnish-software.com" target="_blank">guillaume@varnish-software.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr">Hi,<div><br></div><div>What do you mean by "work"? What's the expected result, and what is the actual result?</div></div><div class="gmail_extra"><br clear="all"><div><div data-smartmail="gmail_signature"><div dir="ltr"><div>-- <br></div>Guillaume Quintard<br></div></div></div>
<br><div class="gmail_quote"><div><div class="h5">On Wed, Jun 29, 2016 at 8:17 AM, Andrei <span dir="ltr"><<a href="mailto:lagged@gmail.com" target="_blank">lagged@gmail.com</a>></span> wrote:<br></div></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div><div class="h5"><div dir="ltr">Hello,<div><br></div><div>I'm currently working on forcing cached results using vsthrottle vs dropping requests, but for some reason (I probably did it wrong :) I can't get var.get/var.set_duration to work. The vcl_recv snippet is as follows, any input is greatly appreciated:</div><div><br></div><div><div>sub vcl_recv {</div><div>  Â  Â  Â  if (vsthrottle.is_denied(req.http.Host, 500, 5s) || (var.get("block-" + req.http.Host))) {<br></div><div>  Â  Â  Â  Â  Â  Â  Â  # The vsthrottle rate limit definitely triggers - confirmed later with "Attack" header</div><div>  Â  Â  Â  Â  Â  Â  Â  unset req.http.Cookie;</div><div>  Â  Â  Â  Â  Â  Â  Â  unset req.http.User-Agent;</div><div>  Â  Â  Â  Â  Â  Â  Â  unset req.http.Pragma;</div><div>  Â  Â  Â  Â  Â  Â  Â  unset req.http.Cache-Control;</div><div>  Â  Â  Â  Â  Â  Â  Â  set req.http.Attack = "ByHost: " + req.http.Host;</div><div>  Â  Â  Â  Â  Â  Â  Â  set req.ttl = 15m;</div><div>  Â  Â  Â  Â  Â  Â  Â  var.set_duration("block-" + req.http.Host,15m);</div><div>  Â  Â  Â  Â  Â  Â  Â  return (hash);</div><div>  Â  Â  Â  }</div><div>[..]<br></div><div>}</div></div></div>
<br></div></div>_______________________________________________<br>
varnish-misc mailing list<br>
<a href="mailto:varnish-misc@varnish-cache.org" target="_blank">varnish-misc@varnish-cache.org</a><br>
<a href="https://www.varnish-cache.org/lists/mailman/listinfo/varnish-misc" rel="noreferrer" target="_blank">https://www.varnish-cache.org/lists/mailman/listinfo/varnish-misc</a><br></blockquote></div><br></div>
</blockquote></div><br></div>