/[adm]/puppet/modules/apache/manifests/init.pp
ViewVC logotype

Contents of /puppet/modules/apache/manifests/init.pp

Parent Directory Parent Directory | Revision Log Revision Log


Revision 1634 - (show annotations) (download)
Tue May 24 09:41:53 2011 UTC (12 years, 10 months ago) by boklm
File size: 8273 byte(s)
change log filename for logrotate
1 class apache {
2
3 class base {
4 $php_date_timezone = "UTC"
5
6 package { "apache-mpm-prefork":
7 alias => apache,
8 ensure => installed
9 }
10
11 package { "apache-conf":
12 ensure => installed,
13 }
14
15 service { httpd:
16 alias => apache,
17 ensure => running,
18 subscribe => [ Package['apache-mpm-prefork'] ],
19 }
20
21 file { "customization.conf":
22 ensure => present,
23 path => "/etc/httpd/conf.d/customization.conf",
24 content => template("apache/customization.conf"),
25 require => Package["apache-conf"],
26 notify => Service["apache"],
27 owner => root,
28 group => root,
29 mode => 644,
30 }
31
32 file { "00_default_vhosts.conf":
33 path => "/etc/httpd/conf/vhosts.d/00_default_vhosts.conf",
34 ensure => "present",
35 owner => root,
36 group => root,
37 mode => 644,
38 notify => Service['apache'],
39 require => Package["apache-conf"],
40 content => template("apache/00_default_vhosts.conf")
41 }
42
43 }
44
45 class mod_php inherits base {
46 package { "apache-mod_php":
47 ensure => installed
48 }
49
50 file { "/etc/httpd/conf.d/mod_php.conf":
51 ensure => present,
52 owner => root,
53 group => root,
54 mode => 644,
55 require => Package['apache-conf'],
56 content => template('apache/mod_php.conf'),
57 notify => Service['apache'],
58 }
59 }
60
61 class mod_perl inherits base {
62 package { "apache-mod_perl":
63 ensure => installed
64 }
65 }
66
67 class mod_fcgid inherits base {
68 package { "apache-mod_fcgid":
69 ensure => installed
70 }
71 }
72
73 class mod_fastcgi inherits base {
74 package { "apache-mod_fastcgi":
75 ensure => installed
76 }
77 }
78
79 class mod_ssl inherits base {
80 file { "/etc/ssl/apache/":
81 ensure => directory
82 }
83
84 package { "apache-mod_ssl":
85 ensure => installed
86 }
87
88 file { "01_default_ssl_vhost.conf":
89 path => '/etc/httpd/conf/vhosts.d/01_default_ssl_vhost.conf',
90 ensure => "present",
91 owner => root,
92 group => root,
93 mode => 644,
94 notify => Service['apache'],
95 require => Package["apache-conf"],
96 content => template("apache/01_default_ssl_vhost.conf")
97 }
98 }
99
100 class mod_wsgi inherits base {
101 package { "apache-mod_wsgi":
102 ensure => installed
103 }
104
105 file { "/usr/local/lib/wsgi":
106 ensure => directory,
107 owner => root,
108 group => root,
109 mode => 644,
110 }
111
112 file { "/etc/httpd/conf.d/mod_wsgi.conf":
113 ensure => present,
114 owner => root,
115 group => root,
116 mode => 644,
117 require => Package['apache-conf'],
118 content => template('apache/mod_wsgi.conf'),
119 notify => Service['apache'],
120 }
121
122 }
123
124 class mod_proxy inherits base {
125 package { "apache-mod_proxy":
126 ensure => installed
127 }
128 }
129
130 class mod_public_html inherits base {
131 package { "apache-mod_public_html":
132 ensure => installed
133 }
134 }
135
136 class mod_deflate inherits base {
137 package { "apache-mod_deflate":
138 ensure => installed
139 }
140 }
141
142 define vhost_base($content = '',
143 $location = '/dev/null',
144 $use_ssl = false,
145 $vhost = false,
146 $aliases = {},
147 $server_aliases = [],
148 $access_logfile = false,
149 $error_logfile = false,
150 $options = [],
151 $enable_public_html = false) {
152 include apache::base
153 $httpd_logdir = "/var/log/httpd"
154 if ! $vhost {
155 $real_vhost = $name
156 } else {
157 $real_vhost = $vhost
158 }
159
160 if ! $access_logfile {
161 $real_access_logfile = "$httpd_logdir/$real_vhost-access_log"
162 } else {
163 $real_access_logfile = $access_logfile
164 }
165 if ! $error_logfile {
166 $real_error_logfile = "$httpd_logdir/$real_vhost-error_log"
167 } else {
168 $real_error_logfile = $error_logfile
169 }
170
171 if $use_ssl {
172 include apache::mod_ssl
173 if $wildcard_sslcert != 'true' {
174 openssl::self_signed_cert{ "$real_vhost":
175 directory => "/etc/ssl/apache/",
176 before => File["$filename"],
177 }
178 }
179 }
180
181 if $enable_public_html {
182 include apache::mod_public_html
183 }
184
185 $filename = "$name.conf"
186 file { "$filename":
187 path => "/etc/httpd/conf/vhosts.d/$filename",
188 ensure => "present",
189 owner => root,
190 group => root,
191 mode => 644,
192 notify => Service['apache'],
193 require => Package['apache-conf'],
194 content => template("apache/vhost_base.conf")
195 }
196 }
197
198 define vhost_redirect_ssl() {
199 vhost_base { "redirect_ssl_$name":
200 vhost => $name,
201 content => template("apache/vhost_ssl_redirect.conf")
202 }
203 }
204
205 define vhost_catalyst_app($script, $location = '', $process = 4, $use_ssl = false, $vhost = false) {
206
207 include apache::mod_fastcgi
208 vhost_base { $name:
209 vhost => $vhost,
210 use_ssl => $use_ssl,
211 content => template("apache/vhost_catalyst_app.conf")
212 }
213 }
214
215 define vhost_django_app($module = false, $module_path = false, $use_ssl = false, $aliases= {}) {
216 include apache::mod_wsgi
217 vhost_base { $name:
218 use_ssl => $use_ssl,
219 content => template("apache/vhost_django_app.conf"),
220 aliases => $aliases,
221 }
222
223 # module is a ruby reserved keyword, cannot be used in templates
224 $django_module = $module
225 file { "$name.wsgi":
226 path => "/usr/local/lib/wsgi/$name.wsgi",
227 ensure => "present",
228 owner => root,
229 group => root,
230 mode => 755,
231 notify => Service['apache'],
232 content => template("apache/django.wsgi")
233 }
234 }
235
236 define vhost_wsgi($wsgi_path, $aliases = {}, $server_aliases = []) {
237 include apache::mod_wsgi
238 vhost_base { $name:
239 aliases => $aliases,
240 server_aliases => $server_aliases,
241 content => template("apache/vhost_wsgi.conf")
242 }
243 }
244
245 define vhost_other_app($vhost_file) {
246 include apache::base
247 file { "$name.conf":
248 path => "/etc/httpd/conf/vhosts.d/$name.conf",
249 ensure => "present",
250 owner => root,
251 group => root,
252 mode => 644,
253 notify => Service['apache'],
254 require => Package['apache-conf'],
255 content => template($vhost_file)
256 }
257 }
258
259 define vhost_simple($location) {
260 include apache::base
261 vhost_base { $name:
262 location => $location,
263 }
264 }
265
266 define vhost_redirect($url,
267 $vhost = false,
268 $use_ssl = false) {
269 include apache::base
270 vhost_base { $name:
271 use_ssl => $use_ssl,
272 vhost => $vhost,
273 content => template("apache/vhost_redirect.conf"),
274 }
275 }
276
277 define vhost_reverse_proxy($url,
278 $vhost = false,
279 $use_ssl = false) {
280 include apache::mod_proxy
281 vhost_base { $name:
282 use_ssl => $use_ssl,
283 vhost => $vhost,
284 content => template("apache/vhost_reverse_proxy.conf")
285 }
286 }
287
288 define webapp_other($webapp_file) {
289 include apache::base
290 $webappname = $name
291 file { "webapp_$name.conf":
292 path => "/etc/httpd/conf/webapps.d/$webappname.conf",
293 ensure => "present",
294 owner => root,
295 group => root,
296 mode => 644,
297 notify => Service['apache'],
298 require => Package['apache-conf'],
299 content => template($webapp_file)
300 }
301 }
302 }

  ViewVC Help
Powered by ViewVC 1.1.30