aboutsummaryrefslogtreecommitdiffstats
path: root/config/varnish3
diff options
context:
space:
mode:
authordjgel <marcioc.antao@gmail.com>2012-06-26 11:58:07 -0300
committerdjgel <marcioc.antao@gmail.com>2012-06-26 11:58:07 -0300
commite46559b162e884b50f936ea38aa1d0e81cfe2c35 (patch)
treefa55864078c21bf844dd51ca2e6cf769b53ac88d /config/varnish3
parent1047008dc92dd10dc1c929e4b676bb02d733ac58 (diff)
downloadpfsense-packages-e46559b162e884b50f936ea38aa1d0e81cfe2c35.tar.gz
pfsense-packages-e46559b162e884b50f936ea38aa1d0e81cfe2c35.tar.bz2
pfsense-packages-e46559b162e884b50f936ea38aa1d0e81cfe2c35.zip
change req.url and req.http.host to work url to backend :
https://www.varnish-cache.org/docs/master/tutorial/advanced_backend_servers.html
Diffstat (limited to 'config/varnish3')
-rw-r--r--config/varnish3/varnish.inc14
1 files changed, 11 insertions, 3 deletions
diff --git a/config/varnish3/varnish.inc b/config/varnish3/varnish.inc
index 9e78d41f..03aadc67 100644
--- a/config/varnish3/varnish.inc
+++ b/config/varnish3/varnish.inc
@@ -5,6 +5,7 @@
part of pfSense (http://www.pfSense.com)
Copyright (C) 2010 Scott Ullrich <sullrich@gmail.com>
Copyright (C) 2011 Marcello Coutinho
+ Copyright (C) 2012 Márcio Carlos Antão
All rights reserved.
*/
/* ========================================================================== */
@@ -129,8 +130,7 @@ function varnish_get_url_mappings_txt() {
if($url['grace'])
$directo_grace_time.=($url['grace']=="0s"?"return(pass);":"set req.grace=".$url['grace'].";");
$fieldtype = ($url['fieldtype']?$url['fieldtype']:"==");
- $req=($url['directorurl2']?"url":"http.host");
- $director_prefix=($url['directorurl'] && $url['directorurl2']?"^http://":"");
+ $director_prefix=($url['directorurl'] && $url['directorurl2']?"^http://":"");
#check url
if ( $url['directorurl'] || $url['directorurl2'] || $catch_all == "unset" ){
if ( $url['directorurl']== "" && $url['directorurl2']== "" ){
@@ -142,7 +142,15 @@ function varnish_get_url_mappings_txt() {
else{
if(!$isfirst)
$urlmappings .= "\telse ";
- $urlmappings .= "if (req.$req $fieldtype ".'"'.$url['directorurl'].$url['directorurl2'].'") {'."\n";
+ if(!$url['directorurl']) {
+ $urlmappings .= "if (req.url $fieldtype ".'"^'.$url['directorurl2'].'") {'."\n";
+ }
+ else if (!$url['directorurl2']) {
+ $urlmappings .= "if (req.http.host $fieldtype ".'"'.$url['directorurl'].'") {'."\n";
+ }
+ else {
+ $urlmappings .= "if (req.http.host $fieldtype ".'"'.$url['directorurl'].'"'." && req.url $fieldtype ".'"^'.$url['directorurl2'].'") {'."\n";
+ }
#check failover
$urlbackend = "\t\t\tset req.backend = ".$url['directorname'].";";
if ($url['failover'] && $url['failover'] != $url['directorname']){