From 1e6f9dc93c1bd9f998cb3ec7fddc22003faf9547 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Guzm=C3=A1n=20Bras=C3=B3?= Date: Wed, 3 Oct 2012 18:16:18 -0300 Subject: [PATCH] Added listen_options and ipv6_listen_options feature * Allows to set exta option to listen directives like 'default'. * This won't change on ipv6 listen template the option ipv6only=on. --- manifests/resource/vhost.pp | 5 +++++ templates/vhost/vhost_header.erb | 4 ++-- 2 files changed, 7 insertions(+), 2 deletions(-) diff --git a/manifests/resource/vhost.pp b/manifests/resource/vhost.pp index 58dcf93..6475311 100644 --- a/manifests/resource/vhost.pp +++ b/manifests/resource/vhost.pp @@ -6,10 +6,13 @@ # [*ensure*] - Enables or disables the specified vhost (present|absent) # [*listen_ip*] - Default IP Address for NGINX to listen with this vHost on. Defaults to all interfaces (*) # [*listen_port*] - Default IP Port for NGINX to listen with this vHost on. Defaults to TCP 80 +# [*listen_options*] - Extra options for listen directive like 'default' to catchall. Undef by default. # [*ipv6_enable*] - BOOL value to enable/disable IPv6 support (false|true). Module will check to see if IPv6 # support exists on your system before enabling. # [*ipv6_listen_ip*] - Default IPv6 Address for NGINX to listen with this vHost on. Defaults to all interfaces (::) # [*ipv6_listen_port*] - Default IPv6 Port for NGINX to listen with this vHost on. Defaults to TCP 80 +# [*ipv6_listen_options*] - Extra options for listen directive like 'default' to catchall. Template will allways add ipv6only=on. +# While issue jfryman/puppet-nginx#30 is discussed, default value is 'default'. # [*index_files*] - Default index files for NGINX to read when traversing a directory # [*proxy*] - Proxy server(s) for the root location to connect to. Accepts a single value, can be used in # conjunction with nginx::resource::upstream @@ -38,9 +41,11 @@ define nginx::resource::vhost( $ensure = 'enable', $listen_ip = '*', $listen_port = '80', + $listen_options = undef, $ipv6_enable = false, $ipv6_listen_ip = '::', $ipv6_listen_port = '80', + $ipv6_listen_options = 'default', $ssl = false, $ssl_cert = undef, $ssl_key = undef, diff --git a/templates/vhost/vhost_header.erb b/templates/vhost/vhost_header.erb index 99228c2..22f7e06 100644 --- a/templates/vhost/vhost_header.erb +++ b/templates/vhost/vhost_header.erb @@ -1,8 +1,8 @@ server { - listen <%= listen_ip %>; + listen <%= listen_ip %>:<%= listen_port %> <% if @listen_options %><%= listen_options %><% end %>; <% # check to see if ipv6 support exists in the kernel before applying %> <% if ipv6_enable == 'true' && (defined? ipaddress6) %> - listen [<%= ipv6_listen_ip %>]:<%= ipv6_listen_port %> default ipv6only=on; + listen [<%= ipv6_listen_ip %>]:<%= ipv6_listen_port %> <% if @ipv6_listen_options %><%= ipv6_listen_options %><% end %> ipv6only=on; <% end %> server_name <%= rewrite_www_to_non_www ? name.gsub(/^www\./, '') : server_name.join(" ") %>; access_log <%= scope.lookupvar('nginx::params::nx_logdir')%>/<%= name %>.access.log;