From 2a5e81feb5e086415d5bd5b6856184ad68351219 Mon Sep 17 00:00:00 2001 From: Lee Packham Date: Thu, 12 Jun 2014 10:08:59 +0100 Subject: [PATCH 1/2] Revert "Added ngnix::resources::upstream::member" Upstream members can no longer be exported and collected. The change in #331 was fundamentally broken. I have therefore reverted it as it shouldn't of been merged. Essentially you can't use ensure with this change - meaning you can no longer REMOVE an nginx config from the system - which is part of the tests and also sane module practice. The idea was nice - but the implementation broke things. This reverts back to a good state, without modifying any tests where tests pass again with the recent commits. This reverts commit ebf3e4e58e206be63509c50c1b96d4d115a43a8a. --- manifests/resource/upstream.pp | 40 +++------------- manifests/resource/upstream/member.pp | 48 ------------------- .../{upstream_header.erb => upstream.erb} | 3 ++ templates/conf.d/upstream_member.erb | 1 - templates/conf.d/upstream_members.erb | 2 - 5 files changed, 9 insertions(+), 85 deletions(-) delete mode 100644 manifests/resource/upstream/member.pp rename templates/conf.d/{upstream_header.erb => upstream.erb} (79%) delete mode 100644 templates/conf.d/upstream_member.erb delete mode 100644 templates/conf.d/upstream_members.erb diff --git a/manifests/resource/upstream.pp b/manifests/resource/upstream.pp index 7317201..920aff9 100644 --- a/manifests/resource/upstream.pp +++ b/manifests/resource/upstream.pp @@ -4,7 +4,6 @@ # # Parameters: # [*members*] - Array of member URIs for NGINX to connect to. Must follow valid NGINX syntax. -# If omitted, individual members should be defined with nginx::resource::upstream::member # [*ensure*] - Enables or disables the specified location (present|absent) # [*upstream_cfg_prepend*] - It expects a hash with custom directives to put before anything else inside upstream # [*upstream_fail_timeout*] - Set the fail_timeout for the upstream. Default is 10 seconds - As that is what Nginx does normally. @@ -39,58 +38,31 @@ # upstream_cfg_prepend => $my_config, # } define nginx::resource::upstream ( - $members = undef, + $members, $ensure = 'present', $upstream_cfg_prepend = undef, $upstream_fail_timeout = '10s', ) { - if $members != undef { - validate_array($members) - } + validate_array($members) validate_re($ensure, '^(present|absent)$', "${ensure} is not supported for ensure. Allowed values are 'present' and 'absent'.") if ($upstream_cfg_prepend != undef) { validate_hash($upstream_cfg_prepend) } - Concat { + File { owner => 'root', group => 'root', mode => '0644', } - concat { "/etc/nginx/conf.d/${name}-upstream.conf": + file { "/etc/nginx/conf.d/${name}-upstream.conf": ensure => $ensure ? { 'absent' => absent, - 'file' => present, - default => present, + default => 'file', }, + content => template('nginx/conf.d/upstream.erb'), notify => Class['nginx::service'], } - - # Uses: $name, $upstream_cfg_prepend - concat::fragment { "${name}_upstream_header": - target => "/etc/nginx/conf.d/${name}-upstream.conf", - order => 10, - content => template('nginx/conf.d/upstream_header.erb'), - } - - if $members != undef { - # Uses: $members, $upstream_fail_timeout - concat::fragment { "${name}_upstream_members": - target => "/etc/nginx/conf.d/${name}-upstream.conf", - order => 50, - content => template('nginx/conf.d/upstream_members.erb'), - } - } else { - # Collect exported members: - Nginx::Resource::Upstream::Member <<| upstream == $name |>> - } - - concat::fragment { "${name}_upstream_footer": - target => "/etc/nginx/conf.d/${name}-upstream.conf", - order => 90, - content => "}\n", - } } diff --git a/manifests/resource/upstream/member.pp b/manifests/resource/upstream/member.pp deleted file mode 100644 index f5f3e0a..0000000 --- a/manifests/resource/upstream/member.pp +++ /dev/null @@ -1,48 +0,0 @@ -# Define: nginx::resources::upstream::member -# -# Creates an upstream member inside the upstream block. Export this resource -# in all upstream member servers and collect them on the NGINX server. -# -# -# Requirements: -# Requires storeconfigs on the Puppet Master to export and collect resources -# -# -# Parameters: -# [*upstream*] - The name of the upstream resource -# [*server*] - Hostname or IP of the upstream member server -# [*port*] - Port of the listening service on the upstream member -# [*upstream_fail_timeout*] - Set the fail_timeout for the upstream. Default is 10 seconds -# -# -# Examples: -# -# Exporting the resource on a upstream member server: -# -# @@nginx::resource::upstream::member { $::fqdn: -# upstream => 'proxypass', -# server => $::ipaddress, -# port => '3000', -# } -# -# -# Collecting the resource on the NGINX server: -# -# nginx::resource::upstream { 'proxypass': -# ensure => present, -# } -# -define nginx::resource::upstream::member ( - $upstream, - $server, - $port = '80', - $upstream_fail_timeout = '10s', -) { - - # Uses: $server, $port, $upstream_fail_timeout - concat::fragment { "${upstream}_upstream_member_${name}": - target => "/etc/nginx/conf.d/${upstream}-upstream.conf", - order => 40, - content => template('nginx/conf.d/upstream_member.erb'), - } -} diff --git a/templates/conf.d/upstream_header.erb b/templates/conf.d/upstream.erb similarity index 79% rename from templates/conf.d/upstream_header.erb rename to templates/conf.d/upstream.erb index 6b7f448..a96121a 100644 --- a/templates/conf.d/upstream_header.erb +++ b/templates/conf.d/upstream.erb @@ -10,3 +10,6 @@ upstream <%= @name %> { <% end -%> <% end -%> <% end -%><% end -%> + <% @members.each do |i| %> + server <%= i %> fail_timeout=<%= @upstream_fail_timeout %>;<% end %> +} diff --git a/templates/conf.d/upstream_member.erb b/templates/conf.d/upstream_member.erb deleted file mode 100644 index 081177b..0000000 --- a/templates/conf.d/upstream_member.erb +++ /dev/null @@ -1 +0,0 @@ - server <%= @server %>:<%= @port %> fail_timeout=<%= @upstream_fail_timeout %>; diff --git a/templates/conf.d/upstream_members.erb b/templates/conf.d/upstream_members.erb deleted file mode 100644 index d7a2dda..0000000 --- a/templates/conf.d/upstream_members.erb +++ /dev/null @@ -1,2 +0,0 @@ - <% @members.each do |i| %> - server <%= i %> fail_timeout=<%= @upstream_fail_timeout %>;<% end %> From 8e5c2ce278b0b5dfee2902dff104d37d8236811a Mon Sep 17 00:00:00 2001 From: Lee Packham Date: Thu, 12 Jun 2014 10:20:36 +0100 Subject: [PATCH 2/2] Use librarian-puppet < 1.1.0 1.1.0 is broken - 1.0.3 works fine. --- .travis/Gemfile | 2 +- Gemfile | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/.travis/Gemfile b/.travis/Gemfile index 252d396..1402364 100644 --- a/.travis/Gemfile +++ b/.travis/Gemfile @@ -2,7 +2,7 @@ source 'https://rubygems.org' group :rake do gem 'puppetlabs_spec_helper' - gem 'librarian-puppet' + gem 'librarian-puppet', '<1.1.0' gem 'open3_backport', :platforms => :ruby_18 gem 'json', :platforms => :ruby_18 end diff --git a/Gemfile b/Gemfile index 26c7d4a..c8ff77b 100644 --- a/Gemfile +++ b/Gemfile @@ -7,7 +7,7 @@ group :rake do gem 'puppet-lint', '>=0.1.12' gem 'puppetlabs_spec_helper' gem 'puppet-blacksmith' - gem 'librarian-puppet' + gem 'librarian-puppet', '<1.1.0' gem 'rspec-system-puppet', :require => false gem 'rspec-system-serverspec', :require => false end