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
|
define nginx::site(
$ensure = present,
$source = 'file',
$certbot = true
) {
case $source {
'file': {
file { "/etc/nginx/sites-available/$name":
source => "puppet:///modules/site_nginx/$name",
owner => "root",
group => "root",
mode => 0644,
ensure => $ensure,
notify => Service["nginx"],
require => File["/etc/nginx/sites-available"],
}
}
'template': {
file { "/etc/nginx/sites-available/$name":
content => template("nginx/$name.erb"),
owner => "root",
group => "root",
mode => 0644,
ensure => $ensure,
notify => Service["nginx"],
require => File["/etc/nginx/sites-available"],
}
}
'none': {
file { "/etc/nginx/sites-available/$name":
owner => "root",
group => "root",
mode => 0644,
ensure => $ensure,
notify => Service["nginx"],
require => File["/etc/nginx/sites-available"],
}
}
}
$link = $ensure ? {
present => "/etc/nginx/sites-available/$name",
default => absent,
}
# Symlink to enable proxy configuration
file { "/etc/nginx/sites-enabled/$name":
ensure => $link,
require => File["/etc/nginx/sites-enabled"],
notify => Service["nginx"],
}
if $certbot == true {
nginx::certbot { $name:
ensure => $ensure,
require => File["/etc/nginx/sites-enabled/$name"],
}
}
}
|