diff options
author | mh <mh@immerda.ch> | 2010-11-01 19:07:39 +0100 |
---|---|---|
committer | mh <mh@immerda.ch> | 2010-11-01 19:07:39 +0100 |
commit | 4b3a940b7396fcc7f0412eecf524c96580fa953b (patch) | |
tree | 3cd75e1abf25651a11942376d394cb1e27a8ce55 /manifests/vhost/proxy.pp | |
parent | 6a9fd8470b18c8b9b16f7b517004a09cbf9c9247 (diff) |
add possibility to proxy vhosts
Diffstat (limited to 'manifests/vhost/proxy.pp')
-rw-r--r-- | manifests/vhost/proxy.pp | 52 |
1 files changed, 52 insertions, 0 deletions
diff --git a/manifests/vhost/proxy.pp b/manifests/vhost/proxy.pp new file mode 100644 index 0000000..c0a00ff --- /dev/null +++ b/manifests/vhost/proxy.pp @@ -0,0 +1,52 @@ +# Proxy VHost +# Parameters: +# +# - ensure: wether this vhost is `present` or `absent` +# - domain: the domain to redirect (*name*) +# - domainalias: A list of whitespace seperated domains to redirect +# - target_url: the url to be proxied. Note: We don't want http://example.com/foobar only example.com/foobar +# - server_admin: the email that is shown as responsible +# - ssl_mode: wether this vhost supports ssl or not +# - false: don't enable ssl for this vhost (default) +# - true: enable ssl for this vhost +# - force: enable ssl and redirect non-ssl to ssl +# - only: enable ssl only +# +# logmode: +# +# - default: Do normal logging to CustomLog and ErrorLog +# - nologs: Send every logging to /dev/null +# - anonym: Don't log ips for CustomLog, send ErrorLog to /dev/null +# - semianonym: Don't log ips for CustomLog, log normal ErrorLog +# +define apache::vhost::redirect( + $ensure = present, + $domain = 'absent', + $domainalias = 'absent', + $target_url, + $server_admin = 'absent', + $logmode = 'default', + $ssl_mode = false +){ + # create vhost configuration file + # we use the options field as the target_url + ::apache::vhost::template{$name: + ensure => $ensure, + template_mode => 'proxy', + domain => $domain, + domainalias => $domainalias, + server_admin => $server_admin, + logpath => $operatingsystem ? { + openbsd => '/var/www/logs', + centos => '/var/log/httpd', + default => '/var/log/apache2' + }, + logmode => $logmode, + allow_override => $allow_override, + run_mode => 'normal', + mod_security => false, + options => $target_url, + ssl_mode => $ssl_mode, + } +} + |