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
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
|
# create webdir
define apache::vhost::webdir(
$ensure = present,
$path = 'absent',
$owner = root,
$group = apache,
$mode = 0640,
$run_mode = 'normal',
$manage_docroot = true,
$documentroot_owner = root,
$documentroot_group = apache,
$documentroot_mode = 0640,
$documentroot_recurse = false
){
$real_path = $path ? {
'absent' => $operatingsystem ? {
openbsd => "/var/www/htdocs/${name}",
default => "/var/www/vhosts/${name}"
},
default => "${path}"
}
if ($run_mode =~ /^(static\-|proxy\-)?itk$/) and ($mode == '0640'){
$real_mode = 0644
} else {
$real_mode = $mode
}
$documentroot = "${real_path}/www"
$logdir = "${real_path}/logs"
if $owner == 'apache' {
if $apache_default_user == '' {
$real_owner = $operatingsystem ? {
openbsd => 'www',
debian => 'www-data',
default => $owner
}
} else {
$real_owner = $apache_default_user
}
} else {
$real_owner = $owner
}
if $group == 'apache' {
if $apache_default_group == '' {
$real_group = $operatingsystem ? {
openbsd => 'www',
debian => 'www-data',
default => $group
}
} else {
$real_group = $apache_default_group
}
} else {
$real_group = $group
}
if $documentroot_owner == 'apache' {
if $apache_default_user == '' {
$real_documentroot_owner = $operatingsystem ? {
openbsd => 'www',
debian => 'www-data',
default => $documentroot_owner
}
} else {
$real_documentroot_owner = $apache_default_user
}
} else {
$real_documentroot_owner = $documentroot_owner
}
if $documentroot_group == 'apache' {
if $apache_default_group == '' {
$real_documentroot_group = $operatingsystem ? {
openbsd => 'www',
debian => 'www-data',
default => $documentroot_group
}
} else {
$real_documentroot_group = $apache_default_group
}
} else {
$real_documentroot_group = $documentroot_group
}
case $ensure {
absent: {
if $manage_docroot {
$managed_directories = [ "$real_path", "${real_path}/private", "$logdir", "$documentroot" ]
} else {
$managed_directories = [ "$real_path", "${real_path}/private", "$logdir" ]
}
file{$managed_directories:
ensure => absent,
purge => true,
recurse => true,
force => true,
}
}
default: {
file{"$real_path":
ensure => directory,
owner => $real_owner, group => $real_group, mode => $real_mode;
}
if $manage_docroot {
file{"$documentroot":
ensure => directory,
recurse => $documentroot_recurse,
owner => $real_documentroot_owner, group => $real_documentroot_group, mode => $documentroot_mode;
}
}
file{"$logdir":
ensure => directory,
owner => $real_documentroot_owner, group => $real_documentroot_group, mode => 0660;
}
case $operatingsystem {
centos: { include apache::logrotate::centos::vhosts }
}
file{"${real_path}/private":
ensure => directory,
owner => $real_documentroot_owner, group => $real_documentroot_group, mode => 0600;
}
}
}
}
|