puppet 8.6.0-universal-darwin → 8.7.0-universal-darwin
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/Gemfile +6 -2
- data/Gemfile.lock +42 -38
- data/Rakefile +45 -22
- data/examples/hiera/README.md +68 -57
- data/examples/hiera/data/common.yaml +12 -0
- data/examples/hiera/data/dc1.yaml +6 -0
- data/examples/hiera/hiera.yaml +15 -0
- data/examples/hiera/modules/ntp/data/common.yaml +4 -0
- data/examples/hiera/modules/ntp/hiera.yaml +9 -0
- data/examples/hiera/modules/ntp/manifests/config.pp +16 -4
- data/examples/hiera/modules/ntp/templates/ntp.conf.epp +3 -0
- data/examples/hiera/modules/users/manifests/common.pp +7 -2
- data/examples/hiera/modules/users/manifests/dc1.pp +7 -2
- data/examples/hiera/site.pp +1 -1
- data/ext/project_data.yaml +0 -45
- data/lib/puppet/daemon.rb +1 -0
- data/lib/puppet/pops/loader/static_loader.rb +2 -2
- data/lib/puppet/pops/lookup/module_data_provider.rb +9 -9
- data/lib/puppet/provider/aix_object.rb +1 -1
- data/lib/puppet/provider/group/groupadd.rb +30 -9
- data/lib/puppet/provider/package/xbps.rb +127 -0
- data/lib/puppet/scheduler/splay_job.rb +9 -0
- data/lib/puppet/type/exec.rb +8 -0
- data/lib/puppet/util/command_line/trollop.rb +20 -2
- data/lib/puppet/util/rpm_compare.rb +1 -1
- data/lib/puppet/util/windows/com.rb +2 -2
- data/lib/puppet/version.rb +1 -1
- data/locales/puppet.pot +604 -600
- data/man/man5/puppet.conf.5 +2 -2
- data/man/man8/puppet-agent.8 +1 -1
- data/man/man8/puppet-apply.8 +1 -1
- data/man/man8/puppet-catalog.8 +1 -1
- data/man/man8/puppet-config.8 +1 -1
- data/man/man8/puppet-describe.8 +1 -1
- data/man/man8/puppet-device.8 +1 -1
- data/man/man8/puppet-doc.8 +1 -1
- data/man/man8/puppet-epp.8 +1 -1
- data/man/man8/puppet-facts.8 +1 -1
- data/man/man8/puppet-filebucket.8 +1 -1
- data/man/man8/puppet-generate.8 +1 -1
- data/man/man8/puppet-help.8 +1 -1
- data/man/man8/puppet-lookup.8 +1 -1
- data/man/man8/puppet-module.8 +1 -1
- data/man/man8/puppet-node.8 +1 -1
- data/man/man8/puppet-parser.8 +1 -1
- data/man/man8/puppet-plugin.8 +1 -1
- data/man/man8/puppet-report.8 +1 -1
- data/man/man8/puppet-resource.8 +1 -1
- data/man/man8/puppet-script.8 +1 -1
- data/man/man8/puppet-ssl.8 +1 -1
- data/man/man8/puppet.8 +2 -2
- metadata +23 -27
- data/examples/hiera/etc/hiera.yaml +0 -15
- data/examples/hiera/etc/hieradb/common.yaml +0 -3
- data/examples/hiera/etc/hieradb/dc1.yaml +0 -6
- data/examples/hiera/etc/hieradb/development.yaml +0 -2
- data/examples/hiera/etc/puppet.conf +0 -3
- data/examples/hiera/modules/data/manifests/common.pp +0 -4
- data/examples/hiera/modules/ntp/manifests/data.pp +0 -4
- data/examples/hiera/modules/ntp/templates/ntp.conf.erb +0 -3
- data/examples/hiera/modules/users/manifests/development.pp +0 -4
- data/tasks/benchmark.rake +0 -180
- data/tasks/cfpropertylist.rake +0 -15
- data/tasks/ci.rake +0 -24
- data/tasks/generate_ast_model.rake +0 -90
- data/tasks/generate_cert_fixtures.rake +0 -199
- data/tasks/manpages.rake +0 -67
- data/tasks/memwalk.rake +0 -195
- data/tasks/parallel.rake +0 -410
- data/tasks/parser.rake +0 -22
- data/tasks/yard.rake +0 -59
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 87e125da3b71dd69b02503160668ae64c6e6d575104627c859b36b0e847a4c77
|
4
|
+
data.tar.gz: 8ba56ba9b32f9a2da14736a8aab0cff97606dce021854d87e0231516c4935304
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 48ab80d4f16ef3fef119dd77e707ee092f0566d5d43e87fae6a7a4540d975bff5563fc70dd0ec80bc03da192950b06788fc41bdbf36f292ca0076428e51ec22b
|
7
|
+
data.tar.gz: acf53931c333506738716bb81cc1011779e080e3d4eb893562f6901bbff5c47feebf4550d378d4d0fed27b58b6875321f7bbe3e910bfc91b96eed75ff60d7fe9
|
data/Gemfile
CHANGED
@@ -12,7 +12,9 @@ def location_for(place, fake_version = nil)
|
|
12
12
|
end
|
13
13
|
end
|
14
14
|
|
15
|
-
# Make sure these gem requirements are in sync with the gempspec
|
15
|
+
# Make sure these gem requirements are in sync with the gempspec. Specifically,
|
16
|
+
# the runtime_dependencies in puppet.gemspec match the runtime dependencies here
|
17
|
+
# (like facter, semantic_puppet, and puppet-resource_api)
|
16
18
|
|
17
19
|
gem "facter", *location_for(ENV['FACTER_LOCATION'] || ["~> 4.3"])
|
18
20
|
gem "semantic_puppet", *location_for(ENV['SEMANTIC_PUPPET_LOCATION'] || ["~> 1.0"])
|
@@ -33,10 +35,12 @@ group(:features) do
|
|
33
35
|
# requires native ldap headers/libs
|
34
36
|
# gem 'ruby-ldap', '~> 0.9', require: false, platforms: [:ruby]
|
35
37
|
gem 'puppetserver-ca', '~> 2.0', require: false
|
38
|
+
gem 'CFPropertyList', ['>= 3.0.6', '< 4'], require: false
|
36
39
|
end
|
37
40
|
|
38
41
|
group(:test) do
|
39
|
-
|
42
|
+
# 1.16.0 - 1.16.2 are broken on Windows
|
43
|
+
gem 'ffi', '>= 1.15.5', '< 1.17.0', '!= 1.16.0', '!= 1.16.1', '!= 1.16.2', require: false
|
40
44
|
gem "json-schema", "~> 2.0", require: false
|
41
45
|
gem "rake", *location_for(ENV['RAKE_LOCATION'] || '~> 13.0')
|
42
46
|
gem "rspec", "~> 3.1", require: false
|
data/Gemfile.lock
CHANGED
@@ -1,8 +1,7 @@
|
|
1
1
|
PATH
|
2
2
|
remote: .
|
3
3
|
specs:
|
4
|
-
puppet (8.
|
5
|
-
CFPropertyList (~> 2.2)
|
4
|
+
puppet (8.7.0)
|
6
5
|
concurrent-ruby (~> 1.0)
|
7
6
|
deep_merge (~> 1.0)
|
8
7
|
facter (>= 4.3.0, < 5)
|
@@ -16,17 +15,18 @@ PATH
|
|
16
15
|
GEM
|
17
16
|
remote: https://artifactory.delivery.puppetlabs.net/artifactory/api/gems/rubygems/
|
18
17
|
specs:
|
19
|
-
CFPropertyList (
|
18
|
+
CFPropertyList (3.0.7)
|
19
|
+
base64
|
20
|
+
nkf
|
21
|
+
rexml
|
20
22
|
addressable (2.8.6)
|
21
23
|
public_suffix (>= 2.0.2, < 6.0)
|
22
|
-
apt_stage_artifacts (0.11.0)
|
23
|
-
docopt
|
24
24
|
artifactory (3.0.17)
|
25
25
|
ast (2.4.2)
|
26
26
|
base64 (0.2.0)
|
27
|
-
bigdecimal (3.1.
|
27
|
+
bigdecimal (3.1.8)
|
28
28
|
coderay (1.1.3)
|
29
|
-
concurrent-ruby (1.
|
29
|
+
concurrent-ruby (1.3.1)
|
30
30
|
crack (1.0.0)
|
31
31
|
bigdecimal
|
32
32
|
rexml
|
@@ -38,15 +38,16 @@ GEM
|
|
38
38
|
rake (>= 12.0.0, < 14.0.0)
|
39
39
|
docopt (0.6.1)
|
40
40
|
erubi (1.12.0)
|
41
|
-
facter (4.
|
41
|
+
facter (4.7.0)
|
42
42
|
hocon (~> 1.3)
|
43
|
-
thor (>= 1.0.1, <
|
44
|
-
faraday (2.9.
|
43
|
+
thor (>= 1.0.1, < 1.3)
|
44
|
+
faraday (2.9.1)
|
45
45
|
faraday-net_http (>= 2.0, < 3.2)
|
46
46
|
faraday-net_http (3.1.0)
|
47
47
|
net-http
|
48
|
-
fast_gettext (2.
|
49
|
-
|
48
|
+
fast_gettext (2.4.0)
|
49
|
+
prime
|
50
|
+
ffi (1.16.3)
|
50
51
|
forwardable (1.3.3)
|
51
52
|
gettext (3.4.9)
|
52
53
|
erubi
|
@@ -58,7 +59,7 @@ GEM
|
|
58
59
|
fast_gettext (~> 2.1)
|
59
60
|
gettext (~> 3.4)
|
60
61
|
locale
|
61
|
-
google-apis-core (0.
|
62
|
+
google-apis-core (0.15.0)
|
62
63
|
addressable (~> 2.5, >= 2.5.1)
|
63
64
|
googleauth (~> 1.9)
|
64
65
|
httpclient (>= 2.8.1, < 3.a)
|
@@ -66,22 +67,22 @@ GEM
|
|
66
67
|
representable (~> 3.0)
|
67
68
|
retriable (>= 2.0, < 4.a)
|
68
69
|
rexml
|
69
|
-
google-apis-iamcredentials_v1 (0.
|
70
|
-
google-apis-core (>= 0.
|
71
|
-
google-apis-storage_v1 (0.
|
72
|
-
google-apis-core (>= 0.
|
70
|
+
google-apis-iamcredentials_v1 (0.21.0)
|
71
|
+
google-apis-core (>= 0.15.0, < 2.a)
|
72
|
+
google-apis-storage_v1 (0.39.0)
|
73
|
+
google-apis-core (>= 0.15.0, < 2.a)
|
73
74
|
google-cloud-core (1.7.0)
|
74
75
|
google-cloud-env (>= 1.0, < 3.a)
|
75
76
|
google-cloud-errors (~> 1.0)
|
76
77
|
google-cloud-env (2.1.1)
|
77
78
|
faraday (>= 1.0, < 3.a)
|
78
79
|
google-cloud-errors (1.4.0)
|
79
|
-
google-cloud-storage (1.
|
80
|
+
google-cloud-storage (1.52.0)
|
80
81
|
addressable (~> 2.8)
|
81
82
|
digest-crc (~> 0.4)
|
82
83
|
google-apis-core (~> 0.13)
|
83
84
|
google-apis-iamcredentials_v1 (~> 0.18)
|
84
|
-
google-apis-storage_v1 (~> 0.
|
85
|
+
google-apis-storage_v1 (~> 0.38)
|
85
86
|
google-cloud-core (~> 1.6)
|
86
87
|
googleauth (~> 1.9)
|
87
88
|
mini_mime (~> 1.0)
|
@@ -93,10 +94,10 @@ GEM
|
|
93
94
|
os (>= 0.9, < 2.0)
|
94
95
|
signet (>= 0.16, < 2.a)
|
95
96
|
hashdiff (1.1.0)
|
96
|
-
hiera-eyaml (
|
97
|
-
highline
|
98
|
-
optimist
|
99
|
-
highline (
|
97
|
+
hiera-eyaml (4.1.0)
|
98
|
+
highline (~> 2.1)
|
99
|
+
optimist (~> 3.1)
|
100
|
+
highline (2.1.0)
|
100
101
|
hocon (1.4.0)
|
101
102
|
hpricot (0.8.6)
|
102
103
|
httpclient (2.8.3)
|
@@ -108,7 +109,7 @@ GEM
|
|
108
109
|
language_server-protocol (3.17.0.3)
|
109
110
|
locale (2.1.4)
|
110
111
|
memory_profiler (1.0.1)
|
111
|
-
method_source (1.
|
112
|
+
method_source (1.1.0)
|
112
113
|
mini_mime (1.1.5)
|
113
114
|
minitar (0.9)
|
114
115
|
msgpack (1.7.2)
|
@@ -116,10 +117,10 @@ GEM
|
|
116
117
|
mustache (1.1.1)
|
117
118
|
net-http (0.4.1)
|
118
119
|
uri
|
120
|
+
nkf (0.2.0)
|
119
121
|
optimist (3.1.0)
|
120
122
|
os (1.1.4)
|
121
|
-
packaging (0.
|
122
|
-
apt_stage_artifacts
|
123
|
+
packaging (0.120.0)
|
123
124
|
artifactory (~> 3)
|
124
125
|
csv (>= 3.1.5)
|
125
126
|
google-cloud-storage
|
@@ -127,7 +128,7 @@ GEM
|
|
127
128
|
rake (>= 12.3)
|
128
129
|
release-metrics
|
129
130
|
parallel (1.24.0)
|
130
|
-
parser (3.3.0
|
131
|
+
parser (3.3.2.0)
|
131
132
|
ast (~> 2.4.1)
|
132
133
|
racc
|
133
134
|
prime (0.1.2)
|
@@ -146,7 +147,7 @@ GEM
|
|
146
147
|
rake (13.2.1)
|
147
148
|
rdiscount (2.2.7.3)
|
148
149
|
rdoc (6.3.4.1)
|
149
|
-
regexp_parser (2.9.
|
150
|
+
regexp_parser (2.9.2)
|
150
151
|
release-metrics (1.1.0)
|
151
152
|
csv
|
152
153
|
docopt
|
@@ -155,7 +156,8 @@ GEM
|
|
155
156
|
trailblazer-option (>= 0.1.1, < 0.2.0)
|
156
157
|
uber (< 0.2.0)
|
157
158
|
retriable (3.1.2)
|
158
|
-
rexml (3.2.
|
159
|
+
rexml (3.2.8)
|
160
|
+
strscan (>= 3.0.9)
|
159
161
|
ronn (0.7.3)
|
160
162
|
hpricot (>= 0.8.2)
|
161
163
|
mustache (>= 0.7.0)
|
@@ -172,11 +174,11 @@ GEM
|
|
172
174
|
rspec-its (1.3.0)
|
173
175
|
rspec-core (>= 3.0.0)
|
174
176
|
rspec-expectations (>= 3.0.0)
|
175
|
-
rspec-mocks (3.13.
|
177
|
+
rspec-mocks (3.13.1)
|
176
178
|
diff-lcs (>= 1.2.0, < 2.0)
|
177
179
|
rspec-support (~> 3.13.0)
|
178
180
|
rspec-support (3.13.1)
|
179
|
-
rubocop (1.
|
181
|
+
rubocop (1.64.1)
|
180
182
|
json (~> 2.3)
|
181
183
|
language_server-protocol (>= 3.17.0)
|
182
184
|
parallel (~> 1.10)
|
@@ -187,8 +189,8 @@ GEM
|
|
187
189
|
rubocop-ast (>= 1.31.1, < 2.0)
|
188
190
|
ruby-progressbar (~> 1.7)
|
189
191
|
unicode-display_width (>= 2.4.0, < 3.0)
|
190
|
-
rubocop-ast (1.31.
|
191
|
-
parser (>= 3.3.0
|
192
|
+
rubocop-ast (1.31.3)
|
193
|
+
parser (>= 3.3.1.0)
|
192
194
|
rubocop-capybara (2.20.0)
|
193
195
|
rubocop (~> 1.41)
|
194
196
|
rubocop-factory_bot (2.25.1)
|
@@ -200,12 +202,12 @@ GEM
|
|
200
202
|
rubocop-ast (>= 1.31.1, < 2.0)
|
201
203
|
rubocop-rake (0.6.0)
|
202
204
|
rubocop (~> 1.0)
|
203
|
-
rubocop-rspec (2.
|
205
|
+
rubocop-rspec (2.30.0)
|
204
206
|
rubocop (~> 1.40)
|
205
207
|
rubocop-capybara (~> 2.17)
|
206
208
|
rubocop-factory_bot (~> 2.22)
|
207
209
|
rubocop-rspec_rails (~> 2.28)
|
208
|
-
rubocop-rspec_rails (2.28.
|
210
|
+
rubocop-rspec_rails (2.28.3)
|
209
211
|
rubocop (~> 1.40)
|
210
212
|
ruby-prof (1.7.0)
|
211
213
|
ruby-progressbar (1.13.0)
|
@@ -217,14 +219,15 @@ GEM
|
|
217
219
|
jwt (>= 1.5, < 3.0)
|
218
220
|
multi_json (~> 1.10)
|
219
221
|
singleton (0.2.0)
|
222
|
+
strscan (3.1.0)
|
220
223
|
text (1.3.1)
|
221
|
-
thor (1.
|
224
|
+
thor (1.2.2)
|
222
225
|
trailblazer-option (0.1.2)
|
223
226
|
uber (0.1.0)
|
224
227
|
unicode-display_width (2.5.0)
|
225
228
|
uri (0.13.0)
|
226
229
|
vcr (6.2.0)
|
227
|
-
webmock (3.23.
|
230
|
+
webmock (3.23.1)
|
228
231
|
addressable (>= 2.8.0)
|
229
232
|
crack (>= 0.3.2)
|
230
233
|
hashdiff (>= 0.4.0, < 2.0.0)
|
@@ -235,9 +238,10 @@ PLATFORMS
|
|
235
238
|
x86_64-linux
|
236
239
|
|
237
240
|
DEPENDENCIES
|
241
|
+
CFPropertyList (>= 3.0.6, < 4)
|
238
242
|
diff-lcs (~> 1.3)
|
239
243
|
facter (~> 4.3)
|
240
|
-
ffi (
|
244
|
+
ffi (>= 1.15.5, < 1.17.0, != 1.16.2, != 1.16.1, != 1.16.0)
|
241
245
|
gettext-setup (~> 1.0)
|
242
246
|
hiera-eyaml
|
243
247
|
hocon (~> 1.0)
|
data/Rakefile
CHANGED
@@ -1,27 +1,9 @@
|
|
1
|
-
#
|
2
|
-
RAKE_ROOT = File.dirname(__FILE__)
|
1
|
+
# frozen_string_literal: true
|
3
2
|
|
4
|
-
# We need access to the Puppet.version method
|
5
|
-
$LOAD_PATH.unshift(File.expand_path("lib"))
|
6
|
-
require 'puppet/version'
|
7
|
-
|
8
|
-
$LOAD_PATH << File.join(RAKE_ROOT, 'tasks')
|
9
|
-
|
10
|
-
begin
|
11
|
-
require 'rubygems'
|
12
|
-
require 'rubygems/package_task'
|
13
|
-
rescue LoadError
|
14
|
-
# Users of older versions of Rake (0.8.7 for example) will not necessarily
|
15
|
-
# have rubygems installed, or the newer rubygems package_task for that
|
16
|
-
# matter.
|
17
|
-
require 'rake/packagetask'
|
18
|
-
require 'rake/gempackagetask'
|
19
|
-
end
|
20
|
-
|
21
|
-
require 'rake'
|
22
3
|
require 'open3'
|
23
|
-
|
24
|
-
|
4
|
+
require 'rake'
|
5
|
+
require 'rubygems'
|
6
|
+
require 'rubygems/package_task'
|
25
7
|
|
26
8
|
if Rake.application.top_level_tasks.grep(/^(pl:|package:)/).any?
|
27
9
|
begin
|
@@ -45,6 +27,47 @@ task :default do
|
|
45
27
|
sh %{rake -T}
|
46
28
|
end
|
47
29
|
|
30
|
+
namespace :pl_ci do
|
31
|
+
desc 'Build puppet gems'
|
32
|
+
task :gem_build, [:gemspec] do |t, args|
|
33
|
+
args.with_defaults(gemspec: 'puppet.gemspec')
|
34
|
+
stdout, stderr, status = Open3.capture3(<<~END)
|
35
|
+
gem build #{args.gemspec} --platform x86-mingw32 && \
|
36
|
+
gem build #{args.gemspec} --platform x64-mingw32 && \
|
37
|
+
gem build #{args.gemspec} --platform universal-darwin && \
|
38
|
+
gem build #{args.gemspec}
|
39
|
+
END
|
40
|
+
if !status.exitstatus.zero?
|
41
|
+
puts "Error building #{args.gemspec}\n#{stdout} \n#{stderr}"
|
42
|
+
exit(1)
|
43
|
+
else
|
44
|
+
puts stdout
|
45
|
+
end
|
46
|
+
end
|
47
|
+
|
48
|
+
desc 'build the nightly puppet gems'
|
49
|
+
task :nightly_gem_build do
|
50
|
+
# this is taken from `rake package:nightly_gem`
|
51
|
+
extended_dot_version = %x{git describe --tags --dirty --abbrev=7}.chomp.tr('-', '.')
|
52
|
+
|
53
|
+
# we must create tempfile in the same directory as puppetg.gemspec, since
|
54
|
+
# it uses __dir__ to determine which files to include
|
55
|
+
require 'tempfile'
|
56
|
+
Tempfile.create('gemspec', __dir__) do |dst|
|
57
|
+
File.open('puppet.gemspec', 'r') do |src|
|
58
|
+
src.readlines.each do |line|
|
59
|
+
if line.match?(/version\s*=\s*['"][0-9.]+['"]/)
|
60
|
+
line = "spec.version = '#{extended_dot_version}'"
|
61
|
+
end
|
62
|
+
dst.puts line
|
63
|
+
end
|
64
|
+
end
|
65
|
+
dst.flush
|
66
|
+
Rake::Task['pl_ci:gem_build'].invoke(dst.path)
|
67
|
+
end
|
68
|
+
end
|
69
|
+
end
|
70
|
+
|
48
71
|
task :spec do
|
49
72
|
ENV["LOG_SPEC_ORDER"] = "true"
|
50
73
|
sh %{rspec #{ENV['TEST'] || ENV['TESTS'] || 'spec'}}
|
data/examples/hiera/README.md
CHANGED
@@ -1,91 +1,102 @@
|
|
1
|
-
A working demo of Hiera with YAML
|
1
|
+
A working demo of Hiera with YAML backend.
|
2
2
|
======================================================
|
3
3
|
|
4
4
|
This demo consists of:
|
5
5
|
|
6
|
-
|
7
|
-
|
8
|
-
|
9
|
-
|
10
|
-
* In Hiera data files a key called _classes_ that decides what to include on a node
|
6
|
+
- A **NTP** module that has defaults for *pool.ntp.org* servers
|
7
|
+
- A **YAML** data source in the *data/* directory where users can override data in yaml files
|
8
|
+
- A **Users** module that has a few manifests that simply notify that they are being included
|
9
|
+
- In Hiera data files a key called **classes** that decides what to include on a node
|
11
10
|
|
12
11
|
Below various usage scenarios can be tested using this module.
|
13
12
|
|
14
|
-
The examples below assume you
|
15
|
-
|
13
|
+
The examples below assume you:
|
14
|
+
- Have the puppet-agent already installed
|
15
|
+
- You have this repository cloned from github
|
16
|
+
- Are running these commands from within the *examples/hiera* directory as cwd.
|
16
17
|
|
17
18
|
Module from forge with module defaults
|
18
19
|
--------------------------------------
|
19
20
|
|
20
|
-
|
21
|
-
|
22
|
-
*
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
$
|
27
|
-
|
28
|
-
|
29
|
-
|
21
|
+
- Comment out lines 6-8 of [data/common.yaml](data/common.yaml#L6-8) to avoid overrides used further in the example
|
22
|
+
- Run a `puppet apply` to create a */tmp/ntp.conf* file containing the two *pool.ntp.org* addresses
|
23
|
+
- The *users::common* class should also be present in your catalog
|
24
|
+
|
25
|
+
```shell
|
26
|
+
$ sed -i '6,8 s/^/#/' data/common.yaml
|
27
|
+
$ puppet apply site.pp --hiera_config=hiera.yaml --modulepath=modules
|
28
|
+
Notice: Compiled catalog for node.corp.com in environment production in 0.04 seconds
|
29
|
+
Notice: Adding users::common
|
30
|
+
Notice: /Stage[main]/Users::Common/Notify[Adding users::common]/message: defined 'message' as 'Adding users::common'
|
31
|
+
Notice: /Stage[main]/Ntp::Config/File[/tmp/ntp.conf]/ensure: defined content as '{sha256}949c7247dbe0870258c921418cc8b270afcc57e1aa6f9d9933f306009ede60d0'
|
32
|
+
Notice: Applied catalog in 0.02 seconds
|
30
33
|
$ cat /tmp/ntp.conf
|
31
34
|
server 1.pool.ntp.org
|
32
35
|
server 2.pool.ntp.org
|
33
|
-
|
36
|
+
```
|
34
37
|
|
35
38
|
Site wide override data in _data::common_
|
36
39
|
-----------------------------------------
|
37
40
|
|
38
|
-
|
39
|
-
*
|
40
|
-
|
41
|
-
|
42
|
-
|
43
|
-
$
|
44
|
-
|
45
|
-
|
41
|
+
- Remove the comments on lines 6-8 of [data/common.yaml](data/common.yaml#L6-8)
|
42
|
+
- Run a `puppet apply` to update */tmp/ntp.conf* to contain the two *ntp.example.com* addresses
|
43
|
+
- The *users::common* class should also be present in your catalog
|
44
|
+
|
45
|
+
```shell
|
46
|
+
$ sed -i '6,8 s/^#//' data/common.yaml
|
47
|
+
$ puppet apply site.pp --hiera_config=hiera.yaml --modulepath=modules
|
48
|
+
Notice: Compiled catalog for node.corp.com in environment production in 0.04 seconds
|
49
|
+
Notice: Adding users::common
|
50
|
+
Notice: /Stage[main]/Users::Common/Notify[Adding users::common]/message: defined 'message' as 'Adding users::common'
|
51
|
+
Notice: /Stage[main]/Ntp::Config/File[/tmp/ntp.conf]/content: content changed '{sha256}949c7247dbe0870258c921418cc8b270afcc57e1aa6f9d9933f306009ede60d0' to '{sha256}28ced955a8ed9efd7514b2364fe378ba645ab947f26e8c0b4d84e8368f1257a0'
|
52
|
+
Notice: Applied catalog in 0.02 seconds
|
46
53
|
$ cat /tmp/ntp.conf
|
47
54
|
server ntp1.example.com
|
48
55
|
server ntp2.example.com
|
49
|
-
|
56
|
+
```
|
50
57
|
|
51
58
|
Fact driven overrides for location=dc1
|
52
59
|
--------------------------------------
|
53
60
|
|
54
|
-
|
55
|
-
|
56
|
-
|
57
|
-
|
58
|
-
|
59
|
-
|
60
|
-
|
61
|
-
|
62
|
-
|
61
|
+
- Override the location fact to `dc1` to demonstrate *data/dc1.yaml* overrides the *ntp::config::ntpservers* values in *data/common.yaml*
|
62
|
+
- `dc1` nodes will
|
63
|
+
- have the *users::common* and *users::dc1* in their catalogs
|
64
|
+
- */tmp/ntp.conf* will contain the two *ntp.dc1.example.com* addresses
|
65
|
+
- Show that the nodes in `dc2` would use the site-wide defaults
|
66
|
+
|
67
|
+
```shell
|
68
|
+
$ FACTER_location=dc1 puppet apply site.pp --hiera_config=hiera.yaml --modulepath=modules
|
69
|
+
Notice: Compiled catalog for node.corp.com in environment production in 0.04 seconds
|
70
|
+
Notice: Adding users::dc1
|
71
|
+
Notice: /Stage[main]/Users::Dc1/Notify[Adding users::dc1]/message: defined 'message' as 'Adding users::dc1'
|
72
|
+
Notice: Adding users::common
|
73
|
+
Notice: /Stage[main]/Users::Common/Notify[Adding users::common]/message: defined 'message' as 'Adding users::common'
|
74
|
+
Notice: /Stage[main]/Ntp::Config/File[/tmp/ntp.conf]/content: content changed '{sha256}28ced955a8ed9efd7514b2364fe378ba645ab947f26e8c0b4d84e8368f1257a0' to '{sha256}39227f1cf8d09623d2e66b6622af2e8db01ab26f77a5a2e6d6e058d0977f369b'
|
75
|
+
Notice: Applied catalog in 0.02 seconds
|
63
76
|
$ cat /tmp/ntp.conf
|
64
77
|
server ntp1.dc1.example.com
|
65
78
|
server ntp2.dc1.example.com
|
66
|
-
|
67
|
-
|
68
|
-
Now simulate a machine in
|
69
|
-
does not include the
|
70
|
-
|
71
|
-
|
72
|
-
$ FACTER_location=dc2 puppet apply --
|
73
|
-
|
74
|
-
|
75
|
-
|
79
|
+
```
|
80
|
+
|
81
|
+
Now simulate a machine in `dc2`, because there is no data for `dc2` it uses the site wide defaults and
|
82
|
+
does not include the *users::dc1* class anymore
|
83
|
+
|
84
|
+
```shell
|
85
|
+
$ FACTER_location=dc2 puppet apply site.pp --hiera_config=hiera.yaml --modulepath=modules
|
86
|
+
Notice: Compiled catalog for node.corp.com in environment production in 0.04 seconds
|
87
|
+
Notice: Adding users::common
|
88
|
+
Notice: /Stage[main]/Users::Common/Notify[Adding users::common]/message: defined 'message' as 'Adding users::common'
|
89
|
+
Notice: /Stage[main]/Ntp::Config/File[/tmp/ntp.conf]/content: content changed '{sha256}39227f1cf8d09623d2e66b6622af2e8db01ab26f77a5a2e6d6e058d0977f369b' to '{sha256}28ced955a8ed9efd7514b2364fe378ba645ab947f26e8c0b4d84e8368f1257a0'
|
90
|
+
Notice: Applied catalog in 0.02 seconds
|
76
91
|
$ cat /tmp/ntp.conf
|
77
92
|
server ntp1.example.com
|
78
93
|
server ntp2.example.com
|
79
|
-
|
94
|
+
```
|
80
95
|
|
81
|
-
You could create override data in the following places for a machine in
|
96
|
+
You could create override data in the following places for a machine in *location=dc2*, they will be searched in this order and the first one with data will match.
|
82
97
|
|
83
|
-
|
84
|
-
|
85
|
-
|
86
|
-
* class data::production
|
87
|
-
* class data::common
|
88
|
-
* class ntp::config::data
|
89
|
-
* class ntp::data
|
98
|
+
- file data/dc2.yaml
|
99
|
+
- file data/<environment>.yaml
|
100
|
+
- file data/common.yaml
|
90
101
|
|
91
|
-
In this example due to the presence of
|
102
|
+
In this example due to the presence of *common.yaml* that declares *ntpservers* the classes will never be searched, it will have precedence.
|
@@ -0,0 +1,15 @@
|
|
1
|
+
---
|
2
|
+
version: 5
|
3
|
+
defaults:
|
4
|
+
datadir: data
|
5
|
+
data_hash: yaml_data
|
6
|
+
|
7
|
+
hierarchy:
|
8
|
+
- name: 'Per Location'
|
9
|
+
path: "%{facts.location}.yaml"
|
10
|
+
|
11
|
+
- name: 'Per Environment'
|
12
|
+
path: "%{facts.environment}.yaml"
|
13
|
+
|
14
|
+
- name: 'Common Data'
|
15
|
+
path: 'common.yaml'
|
@@ -1,6 +1,18 @@
|
|
1
|
-
#
|
2
|
-
|
3
|
-
|
4
|
-
|
1
|
+
# @summary Manage /tmp/ntp.conf file
|
2
|
+
#
|
3
|
+
# Given an array of ntpservers, manage the /tmp/ntp.conf file
|
4
|
+
#
|
5
|
+
# @example
|
6
|
+
# include ntp::config
|
7
|
+
#
|
8
|
+
# @param ntpservers
|
9
|
+
# An array of ntpserver(s) that should be present in the conf file
|
10
|
+
class ntp::config(
|
11
|
+
Array[String[1], 1] $ntpservers = undef,
|
12
|
+
) {
|
13
|
+
|
14
|
+
file { '/tmp/ntp.conf':
|
15
|
+
content => epp('ntp/ntp.conf.epp')
|
5
16
|
}
|
17
|
+
|
6
18
|
}
|
@@ -1,4 +1,9 @@
|
|
1
|
-
#
|
1
|
+
# @summary Notify to demonstrate users::common in catalog
|
2
|
+
#
|
3
|
+
# A common Class that all examples should include
|
4
|
+
#
|
5
|
+
# @example
|
6
|
+
# include users::common
|
2
7
|
class users::common {
|
3
|
-
notify{'Adding users::common': }
|
8
|
+
notify { 'Adding users::common': }
|
4
9
|
}
|
@@ -1,4 +1,9 @@
|
|
1
|
-
#
|
1
|
+
# @summary Notify to demonstrate users::dc1 in catalog
|
2
|
+
#
|
3
|
+
# A Class that should be present in dc1 node(s) catalog
|
4
|
+
#
|
5
|
+
# @example
|
6
|
+
# include users::dc1
|
2
7
|
class users::dc1 {
|
3
|
-
notify{'Adding users::dc1': }
|
8
|
+
notify { 'Adding users::dc1': }
|
4
9
|
}
|
data/examples/hiera/site.pp
CHANGED