Merge pull request #316 from edvinasme/archlinux

Add Archlinux support
This commit is contained in:
James Fryman 2014-05-16 13:14:49 +02:00
commit 5cb8ea8fa8
7 changed files with 60 additions and 22 deletions

View file

@ -11,7 +11,7 @@ This module manages NGINX configuration.
### Requirements ### Requirements
* Puppet-2.7.0 or later * Puppet-2.7.0 or later
* Ruby-1.9.3 or later (Support for Ruby-1.8.7 is not guaranteed. YMMV). * Ruby-1.9.3 or later (Support for Ruby-1.8.7 is not guaranteed. YMMV).
### Install and bootstrap an NGINX instance ### Install and bootstrap an NGINX instance
@ -74,7 +74,7 @@ To create only a HTTPS vhost, set `ssl => true` and also set `listen_port` to th
Locations require specific settings depending on whether they should be included in the HTTP, HTTPS or both vhosts. Locations require specific settings depending on whether they should be included in the HTTP, HTTPS or both vhosts.
#### HTTP only vhost (default) #### HTTP only vhost (default)
If you only have a HTTP vhost (i.e. `ssl => false` on the vhost) maks sure you don't set `ssl => true` on any location you associate with the vhost. If you only have a HTTP vhost (i.e. `ssl => false` on the vhost) make sure you don't set `ssl => true` on any location you associate with the vhost.
#### HTTP and HTTPS vhost #### HTTP and HTTPS vhost
If you set `ssl => true` and also set `listen_port` and `ssl_port` to different values on the vhost you will need to be specific with the location settings since you will have a HTTP vhost listening on `listen_port` and a HTTPS vhost listening on `ssl_port`: If you set `ssl => true` and also set `listen_port` and `ssl_port` to different values on the vhost you will need to be specific with the location settings since you will have a HTTP vhost listening on `listen_port` and a HTTPS vhost listening on `ssl_port`:
@ -202,7 +202,7 @@ define web::nginx_ssl_with_redirect (
} else { } else {
$tmp_www_root = $www_root $tmp_www_root = $www_root
} }
nginx::resource::vhost { "${name}.${::domain} ${name}": nginx::resource::vhost { "${name}.${::domain} ${name}":
ensure => present, ensure => present,
listen_port => 443, listen_port => 443,
@ -211,32 +211,32 @@ define web::nginx_ssl_with_redirect (
location_cfg_append => $location_cfg_append, location_cfg_append => $location_cfg_append,
index_files => [ 'index.php' ], index_files => [ 'index.php' ],
ssl => true, ssl => true,
ssl_cert => 'puppet:///modules/sslkey/whildcard_mydomain.crt', ssl_cert => 'puppet:///modules/sslkey/wildcard_mydomain.crt',
ssl_key => 'puppet:///modules/sslkey/whildcard_mydomain.key', ssl_key => 'puppet:///modules/sslkey/wildcard_mydomain.key',
} }
if $php { if $php {
nginx::resource::location { "${name}_root": nginx::resource::location { "${name}_root":
ensure => present, ensure => present,
ssl => true, ssl => true,
ssl_only => true, ssl_only => true,
vhost => "${name}.${::domain} ${name}", vhost => "${name}.${::domain} ${name}",
www_root => "${full_web_path}/${name}/", www_root => "${full_web_path}/${name}/",
location => '~ \.php$', location => '~ \.php$',
index_files => ['index.php', 'index.html', 'index.htm'], index_files => ['index.php', 'index.html', 'index.htm'],
proxy => undef, proxy => undef,
fastcgi => "127.0.0.1:${backend_port}", fastcgi => "127.0.0.1:${backend_port}",
fastcgi_script => undef, fastcgi_script => undef,
location_cfg_append => { location_cfg_append => {
fastcgi_connect_timeout => '3m', fastcgi_connect_timeout => '3m',
fastcgi_read_timeout => '3m', fastcgi_read_timeout => '3m',
fastcgi_send_timeout => '3m' fastcgi_send_timeout => '3m'
} }
} }
} }
} }
``` ```
# Call class web::nginx_ssl_with_redirect # Call class web::nginx_ssl_with_redirect

View file

@ -102,8 +102,8 @@ class nginx (
validate_string($proxy_cache_keys_zone) validate_string($proxy_cache_keys_zone)
validate_string($proxy_cache_max_size) validate_string($proxy_cache_max_size)
validate_string($proxy_cache_inactive) validate_string($proxy_cache_inactive)
if ($fastcgi_cache_path != false) { if ($fastcgi_cache_path != false) {
validate_string($fastcgi_cache_path) validate_string($fastcgi_cache_path)
} }
if (!is_integer($fastcgi_cache_levels)) { if (!is_integer($fastcgi_cache_levels)) {

View file

@ -49,6 +49,12 @@ class nginx::package(
before => Anchor['nginx::package::end'], before => Anchor['nginx::package::end'],
} }
} }
'archlinux': {
class { 'nginx::package::archlinux':
require => Anchor['nginx::package::begin'],
before => Anchor['nginx::package::end'],
}
}
'Solaris': { 'Solaris': {
class { 'nginx::package::solaris': class { 'nginx::package::solaris':
package_name => $package_name, package_name => $package_name,

View file

@ -0,0 +1,25 @@
# Class: nginx::package::archlinux
#
# This module manages NGINX package installation on Archlinux based systems
#
# Parameters:
#
# There are no default parameters for this class.
#
# Actions:
#
# Requires:
#
# Sample Usage:
#
# This class file is not called directly
class nginx::package::archlinux(
$package_name = 'nginx',
$package_ensure = 'present'
) {
package { $package_name:
ensure => $package_ensure,
}
}

View file

@ -78,7 +78,12 @@ class nginx::params {
} }
$nx_pid = $::kernel ? { $nx_pid = $::kernel ? {
/(?i-mx:linux)/ => '/var/run/nginx.pid', /(?i-mx:linux)/ => $::osfamily ? {
# archlinux has hardcoded pid in service file to /run/nginx.pid, setting
# it will prevent nginx from starting
/(?i-mx:archlinux)/ => false,
default => '/var/run/nginx.pid',
},
/(?i-mx:sunos)/ => '/var/run/nginx.pid', /(?i-mx:sunos)/ => '/var/run/nginx.pid',
} }
@ -93,14 +98,16 @@ class nginx::params {
default => 'webservd', default => 'webservd',
} }
$nx_daemon_user = $::osfamily ? { $nx_daemon_user = $::osfamily ? {
/(?i-mx:archlinux)/ => 'http',
/(?i-mx:redhat|suse|gentoo|linux)/ => 'nginx', /(?i-mx:redhat|suse|gentoo|linux)/ => 'nginx',
/(?i-mx:debian)/ => 'www-data', /(?i-mx:debian)/ => 'www-data',
/(?i-mx:solaris)/ => $solaris_nx_daemon_user, /(?i-mx:solaris)/ => $solaris_nx_daemon_user,
} }
} else { } else {
warning('$::osfamily not defined. Support for $::operatingsystem is deprecated') warning('$::osfamily not defined. Support for $::operatingsystem is deprecated')
warning("Please upgrade from factor ${::facterversion} to >= 1.7.2") warning("Please upgrade from facter ${::facterversion} to >= 1.7.2")
$nx_daemon_user = $::operatingsystem ? { $nx_daemon_user = $::operatingsystem ? {
/(?i-mx:archlinux)/ => 'http',
/(?i-mx:debian|ubuntu)/ => 'www-data', /(?i-mx:debian|ubuntu)/ => 'www-data',
/(?i-mx:fedora|rhel|redhat|centos|scientific|suse|opensuse|amazon|gentoo|oraclelinux)/ => 'nginx', /(?i-mx:fedora|rhel|redhat|centos|scientific|suse|opensuse|amazon|gentoo|oraclelinux)/ => 'nginx',
/(?i-mx:solaris)/ => 'webservd', /(?i-mx:solaris)/ => 'webservd',

View file

@ -3,7 +3,7 @@ worker_processes <%= @worker_processes %>;
worker_rlimit_nofile <%= @worker_rlimit_nofile %>; worker_rlimit_nofile <%= @worker_rlimit_nofile %>;
error_log <%= @nginx_error_log %>; error_log <%= @nginx_error_log %>;
pid <%= scope.lookupvar('nginx::params::nx_pid')%>; <% if scope.lookupvar('nginx::params::nx_pid') != false %>pid <%= scope.lookupvar('nginx::params::nx_pid')%>;<% end -%>
events { events {
worker_connections <%= @worker_connections -%>; worker_connections <%= @worker_connections -%>;

View file

@ -1,5 +1,5 @@
proxy_redirect <%= @proxy_redirect %>; proxy_redirect <%= @proxy_redirect %>;
client_max_body_size <%= @client_max_body_size %>; client_max_body_size <%= @client_max_body_size %>;
client_body_buffer_size <%= scope.lookupvar('nginx::params::nx_client_body_buffer_size') %>; client_body_buffer_size <%= scope.lookupvar('nginx::params::nx_client_body_buffer_size') %>;
proxy_connect_timeout <%= scope.lookupvar('nginx::params::nx_proxy_connect_timeout') %>; proxy_connect_timeout <%= scope.lookupvar('nginx::params::nx_proxy_connect_timeout') %>;
proxy_send_timeout <%= scope.lookupvar('nginx::params::nx_proxy_send_timeout') %>; proxy_send_timeout <%= scope.lookupvar('nginx::params::nx_proxy_send_timeout') %>;