1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
|
# Redirect VHost to redirect hosts
# 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 redirect to. 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_partial => 'apache/vhosts/redirect/partial.erb',
domain => $domain,
path => 'really_absent',
path_is_webdir => true,
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,
}
}
|