puppet 8.1.0-universal-darwin → 8.3.1-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 +1 -1
- data/Gemfile.lock +39 -45
- data/ext/project_data.yaml +2 -2
- data/lib/puppet/application/doc.rb +1 -1
- data/lib/puppet/application/ssl.rb +42 -7
- data/lib/puppet/application.rb +5 -1
- data/lib/puppet/defaults.rb +17 -5
- data/lib/puppet/face/config.rb +1 -1
- data/lib/puppet/face/epp.rb +2 -2
- data/lib/puppet/face/module/list.rb +2 -2
- data/lib/puppet/face/parser.rb +1 -1
- data/lib/puppet/functions/split.rb +28 -1
- data/lib/puppet/http/client.rb +12 -5
- data/lib/puppet/http/service/ca.rb +25 -0
- data/lib/puppet/indirector/facts/facter.rb +1 -1
- data/lib/puppet/indirector/file_bucket_file/file.rb +1 -1
- data/lib/puppet/indirector/indirection.rb +1 -1
- data/lib/puppet/info_service/task_information_service.rb +1 -1
- data/lib/puppet/module_tool.rb +1 -1
- data/lib/puppet/network/formats.rb +3 -3
- data/lib/puppet/network/http/memory_response.rb +1 -1
- data/lib/puppet/node/environment.rb +6 -4
- data/lib/puppet/parameter/value_collection.rb +1 -1
- data/lib/puppet/parser/files.rb +4 -3
- data/lib/puppet/parser/functions.rb +1 -1
- data/lib/puppet/pops/evaluator/deferred_resolver.rb +20 -3
- data/lib/puppet/pops/loader/loader_paths.rb +4 -4
- data/lib/puppet/pops/lookup/explainer.rb +1 -1
- data/lib/puppet/pops/lookup/hiera_config.rb +1 -1
- data/lib/puppet/pops/model/factory.rb +1 -1
- data/lib/puppet/pops/model/tree_dumper.rb +1 -1
- data/lib/puppet/pops/parser/epp_support.rb +1 -1
- data/lib/puppet/pops/parser/evaluating_parser.rb +1 -1
- data/lib/puppet/pops/parser/pn_parser.rb +1 -1
- data/lib/puppet/pops/pn.rb +1 -1
- data/lib/puppet/pops/serialization/json_path.rb +1 -1
- data/lib/puppet/pops/time/timespan.rb +4 -4
- data/lib/puppet/pops/types/ruby_generator.rb +2 -2
- data/lib/puppet/pops/types/string_converter.rb +6 -6
- data/lib/puppet/pops/types/type_formatter.rb +2 -2
- data/lib/puppet/pops/types/types.rb +1 -1
- data/lib/puppet/provider/nameservice/directoryservice.rb +2 -2
- data/lib/puppet/provider/package/apt.rb +1 -1
- data/lib/puppet/provider/package/dnf.rb +1 -1
- data/lib/puppet/provider/package/yum.rb +1 -1
- data/lib/puppet/provider/user/directoryservice.rb +1 -1
- data/lib/puppet/reference/configuration.rb +1 -1
- data/lib/puppet/reference/indirection.rb +1 -1
- data/lib/puppet/reports.rb +1 -1
- data/lib/puppet/ssl/oids.rb +2 -0
- data/lib/puppet/ssl/ssl_provider.rb +1 -1
- data/lib/puppet/ssl/state_machine.rb +60 -9
- data/lib/puppet/transaction/report.rb +1 -1
- data/lib/puppet/type/filebucket.rb +1 -1
- data/lib/puppet/util/diff.rb +1 -1
- data/lib/puppet/util/execution.rb +9 -4
- data/lib/puppet/util/inifile.rb +2 -2
- data/lib/puppet/util/monkey_patches.rb +18 -0
- data/lib/puppet/util/package/version/rpm.rb +1 -1
- data/lib/puppet/util/provider_features.rb +1 -1
- data/lib/puppet/util/selinux.rb +1 -1
- data/lib/puppet/util/windows/access_control_entry.rb +1 -1
- data/lib/puppet/util/windows/access_control_list.rb +1 -1
- data/lib/puppet/util/windows/adsi.rb +9 -2
- data/lib/puppet/util/windows/error.rb +1 -1
- data/lib/puppet/util/windows/file.rb +2 -2
- data/lib/puppet/util/windows/process.rb +1 -1
- data/lib/puppet/util/windows/sid.rb +4 -2
- data/lib/puppet/util.rb +2 -3
- data/lib/puppet/version.rb +1 -1
- data/lib/puppet/x509/cert_provider.rb +13 -2
- data/locales/puppet.pot +106 -74
- data/man/man5/puppet.conf.5 +16 -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 +5 -1
- data/man/man8/puppet.8 +2 -2
- data/spec/fixtures/ssl/127.0.0.1-key.pem +107 -107
- data/spec/fixtures/ssl/127.0.0.1.pem +52 -51
- data/spec/fixtures/ssl/bad-basic-constraints.pem +56 -56
- data/spec/fixtures/ssl/bad-int-basic-constraints.pem +53 -53
- data/spec/fixtures/ssl/ca.pem +54 -54
- data/spec/fixtures/ssl/crl.pem +26 -26
- data/spec/fixtures/ssl/ec-key.pem +11 -11
- data/spec/fixtures/ssl/ec.pem +33 -32
- data/spec/fixtures/ssl/encrypted-ec-key.pem +12 -12
- data/spec/fixtures/ssl/encrypted-key.pem +108 -108
- data/spec/fixtures/ssl/intermediate-agent-crl.pem +26 -26
- data/spec/fixtures/ssl/intermediate-agent.pem +56 -56
- data/spec/fixtures/ssl/intermediate-crl.pem +29 -29
- data/spec/fixtures/ssl/intermediate.pem +53 -53
- data/spec/fixtures/ssl/oid-key.pem +107 -107
- data/spec/fixtures/ssl/oid.pem +51 -50
- data/spec/fixtures/ssl/pluto-key.pem +107 -107
- data/spec/fixtures/ssl/pluto.pem +52 -51
- data/spec/fixtures/ssl/renewed.pem +67 -0
- data/spec/fixtures/ssl/request-key.pem +107 -107
- data/spec/fixtures/ssl/request.pem +50 -48
- data/spec/fixtures/ssl/revoked-key.pem +107 -107
- data/spec/fixtures/ssl/revoked.pem +51 -50
- data/spec/fixtures/ssl/signed-key.pem +107 -107
- data/spec/fixtures/ssl/signed.pem +49 -48
- data/spec/fixtures/ssl/tampered-cert.pem +51 -50
- data/spec/fixtures/ssl/tampered-csr.pem +50 -48
- data/spec/fixtures/ssl/unknown-127.0.0.1-key.pem +107 -107
- data/spec/fixtures/ssl/unknown-127.0.0.1.pem +50 -49
- data/spec/fixtures/ssl/unknown-ca-key.pem +107 -107
- data/spec/fixtures/ssl/unknown-ca.pem +54 -54
- data/spec/integration/application/agent_spec.rb +27 -27
- data/spec/integration/application/apply_spec.rb +14 -0
- data/spec/integration/http/client_spec.rb +16 -0
- data/spec/integration/type/exec_spec.rb +13 -0
- data/spec/lib/puppet/test_ca.rb +3 -10
- data/spec/lib/puppet_spec/verbose.rb +10 -1
- data/spec/unit/agent_spec.rb +2 -9
- data/spec/unit/application/ssl_spec.rb +49 -0
- data/spec/unit/defaults_spec.rb +2 -40
- data/spec/unit/file_system/path_pattern_spec.rb +15 -0
- data/spec/unit/functions/split_spec.rb +6 -0
- data/spec/unit/http/service/ca_spec.rb +71 -0
- data/spec/unit/info_service_spec.rb +1 -1
- data/spec/unit/ssl/certificate_signer_spec.rb +17 -0
- data/spec/unit/ssl/ssl_provider_spec.rb +21 -1
- data/spec/unit/ssl/state_machine_spec.rb +75 -3
- data/spec/unit/util/execution_spec.rb +1 -0
- data/spec/unit/util/monkey_patches_spec.rb +42 -0
- data/spec/unit/util/windows/adsi_spec.rb +25 -0
- data/spec/unit/x509/cert_provider_spec.rb +23 -0
- data/tasks/generate_cert_fixtures.rake +4 -0
- metadata +7 -3
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: d51ea29c50817dfb98273a22e10809cabc461017bed352035b000b29fcdb81bd
|
4
|
+
data.tar.gz: 4fef0c63a2a0c6d3be51e7b5f969ca85b8be50a58623badb4dc8efd10b488954
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 111d4cebd83393c97a92fc40a09f441bedaac2bca73a0e8b51e793dfacf1bf8de1754c9d0a1aa1a165d49618e3332c460f2e290f025b4ca97b9b6fdfd7d23da9
|
7
|
+
data.tar.gz: cae4b82154cca6f2c2aa3a8c19f94306061020b3fa94bc206170491b98777aa8602bd065d0a577135ad1a461da4e3ba29893e52e87f5cc3a824d6f7a96e3ace7
|
data/Gemfile
CHANGED
@@ -36,7 +36,7 @@ group(:features) do
|
|
36
36
|
end
|
37
37
|
|
38
38
|
group(:test) do
|
39
|
-
gem "ffi", require: false
|
39
|
+
gem "ffi", '1.15.5', require: false
|
40
40
|
gem "json-schema", "~> 2.0", require: false
|
41
41
|
gem "rake", *location_for(ENV['RAKE_LOCATION'] || '~> 13.0')
|
42
42
|
gem "rspec", "~> 3.1", require: false
|
data/Gemfile.lock
CHANGED
@@ -1,21 +1,7 @@
|
|
1
|
-
GIT
|
2
|
-
remote: https://github.com/puppetlabs/packaging
|
3
|
-
revision: 87a3396077f06e2341ad19e6fcd15f7c14ec02f9
|
4
|
-
branch: 1.0.x
|
5
|
-
specs:
|
6
|
-
packaging (0)
|
7
|
-
apt_stage_artifacts
|
8
|
-
artifactory (~> 3)
|
9
|
-
csv (>= 3.1.5)
|
10
|
-
google-cloud-storage
|
11
|
-
googleauth
|
12
|
-
rake (>= 12.3)
|
13
|
-
release-metrics
|
14
|
-
|
15
1
|
PATH
|
16
2
|
remote: .
|
17
3
|
specs:
|
18
|
-
puppet (8.1
|
4
|
+
puppet (8.3.1)
|
19
5
|
CFPropertyList (~> 2.2)
|
20
6
|
concurrent-ruby (~> 1.0)
|
21
7
|
deep_merge (~> 1.0)
|
@@ -31,35 +17,37 @@ GEM
|
|
31
17
|
remote: https://artifactory.delivery.puppetlabs.net/artifactory/api/gems/rubygems/
|
32
18
|
specs:
|
33
19
|
CFPropertyList (2.3.6)
|
34
|
-
addressable (2.8.
|
20
|
+
addressable (2.8.5)
|
35
21
|
public_suffix (>= 2.0.2, < 6.0)
|
36
22
|
apt_stage_artifacts (0.11.0)
|
37
23
|
docopt
|
38
24
|
artifactory (3.0.15)
|
39
25
|
ast (2.4.2)
|
26
|
+
base64 (0.1.1)
|
40
27
|
coderay (1.1.3)
|
41
28
|
concurrent-ruby (1.2.2)
|
42
29
|
crack (0.4.5)
|
43
30
|
rexml
|
44
|
-
csv (3.2.
|
31
|
+
csv (3.2.7)
|
45
32
|
declarative (0.0.20)
|
46
33
|
deep_merge (1.2.2)
|
47
34
|
diff-lcs (1.5.0)
|
48
|
-
digest-crc (0.6.
|
35
|
+
digest-crc (0.6.5)
|
49
36
|
rake (>= 12.0.0, < 14.0.0)
|
50
37
|
docopt (0.6.1)
|
51
38
|
erubi (1.12.0)
|
52
|
-
facter (4.
|
39
|
+
facter (4.5.0)
|
53
40
|
hocon (~> 1.3)
|
54
41
|
thor (>= 1.0.1, < 2.0)
|
55
|
-
faraday (2.7.
|
42
|
+
faraday (2.7.11)
|
43
|
+
base64
|
56
44
|
faraday-net_http (>= 2.0, < 3.1)
|
57
45
|
ruby2_keywords (>= 0.0.4)
|
58
46
|
faraday-net_http (3.0.2)
|
59
47
|
fast_gettext (2.3.0)
|
60
48
|
ffi (1.15.5)
|
61
49
|
forwardable (1.3.3)
|
62
|
-
gettext (3.4.
|
50
|
+
gettext (3.4.9)
|
63
51
|
erubi
|
64
52
|
locale (>= 2.0.5)
|
65
53
|
prime
|
@@ -69,7 +57,7 @@ GEM
|
|
69
57
|
fast_gettext (~> 2.1)
|
70
58
|
gettext (~> 3.4)
|
71
59
|
locale
|
72
|
-
google-apis-core (0.11.
|
60
|
+
google-apis-core (0.11.1)
|
73
61
|
addressable (~> 2.5, >= 2.5.1)
|
74
62
|
googleauth (>= 0.16.2, < 2.a)
|
75
63
|
httpclient (>= 2.8.1, < 3.a)
|
@@ -96,10 +84,9 @@ GEM
|
|
96
84
|
google-cloud-core (~> 1.6)
|
97
85
|
googleauth (>= 0.16.2, < 2.a)
|
98
86
|
mini_mime (~> 1.0)
|
99
|
-
googleauth (1.
|
87
|
+
googleauth (1.8.1)
|
100
88
|
faraday (>= 0.17.3, < 3.a)
|
101
89
|
jwt (>= 1.4, < 3.0)
|
102
|
-
memoist (~> 0.16)
|
103
90
|
multi_json (~> 1.11)
|
104
91
|
os (>= 0.9, < 2.0)
|
105
92
|
signet (>= 0.16, < 2.a)
|
@@ -115,18 +102,25 @@ GEM
|
|
115
102
|
addressable (>= 2.4)
|
116
103
|
jwt (2.7.1)
|
117
104
|
locale (2.1.3)
|
118
|
-
memoist (0.16.2)
|
119
105
|
memory_profiler (1.0.1)
|
120
106
|
method_source (1.0.0)
|
121
|
-
mini_mime (1.1.
|
107
|
+
mini_mime (1.1.5)
|
122
108
|
minitar (0.9)
|
123
|
-
msgpack (1.7.
|
109
|
+
msgpack (1.7.2)
|
124
110
|
multi_json (1.15.0)
|
125
111
|
mustache (1.1.1)
|
126
|
-
optimist (3.0
|
112
|
+
optimist (3.1.0)
|
127
113
|
os (1.1.4)
|
114
|
+
packaging (0.111.0)
|
115
|
+
apt_stage_artifacts
|
116
|
+
artifactory (~> 3)
|
117
|
+
csv (>= 3.1.5)
|
118
|
+
google-cloud-storage
|
119
|
+
googleauth
|
120
|
+
rake (>= 12.3)
|
121
|
+
release-metrics
|
128
122
|
parallel (1.23.0)
|
129
|
-
parser (3.2.2.
|
123
|
+
parser (3.2.2.4)
|
130
124
|
ast (~> 2.4.1)
|
131
125
|
racc
|
132
126
|
prime (0.1.2)
|
@@ -135,17 +129,17 @@ GEM
|
|
135
129
|
pry (0.14.2)
|
136
130
|
coderay (~> 1.1)
|
137
131
|
method_source (~> 1.0)
|
138
|
-
public_suffix (5.0.
|
139
|
-
puppet-resource_api (1.
|
132
|
+
public_suffix (5.0.3)
|
133
|
+
puppet-resource_api (1.9.0)
|
140
134
|
hocon (>= 1.0)
|
141
135
|
puppetserver-ca (2.6.0)
|
142
136
|
facter (>= 2.0.1, < 5)
|
143
137
|
racc (1.5.2)
|
144
138
|
rainbow (3.1.1)
|
145
139
|
rake (13.0.6)
|
146
|
-
rdiscount (2.2.7)
|
140
|
+
rdiscount (2.2.7.1)
|
147
141
|
rdoc (6.3.3)
|
148
|
-
regexp_parser (2.8.
|
142
|
+
regexp_parser (2.8.2)
|
149
143
|
release-metrics (1.1.0)
|
150
144
|
csv
|
151
145
|
docopt
|
@@ -154,7 +148,7 @@ GEM
|
|
154
148
|
trailblazer-option (>= 0.1.1, < 0.2.0)
|
155
149
|
uber (< 0.2.0)
|
156
150
|
retriable (3.1.2)
|
157
|
-
rexml (3.2.
|
151
|
+
rexml (3.2.6)
|
158
152
|
ronn (0.7.3)
|
159
153
|
hpricot (>= 0.8.2)
|
160
154
|
mustache (>= 0.7.0)
|
@@ -171,10 +165,10 @@ GEM
|
|
171
165
|
rspec-its (1.3.0)
|
172
166
|
rspec-core (>= 3.0.0)
|
173
167
|
rspec-expectations (>= 3.0.0)
|
174
|
-
rspec-mocks (3.12.
|
168
|
+
rspec-mocks (3.12.6)
|
175
169
|
diff-lcs (>= 1.2.0, < 2.0)
|
176
170
|
rspec-support (~> 3.12.0)
|
177
|
-
rspec-support (3.12.
|
171
|
+
rspec-support (3.12.1)
|
178
172
|
rubocop (1.28.0)
|
179
173
|
parallel (~> 1.10)
|
180
174
|
parser (>= 3.1.0.0)
|
@@ -184,7 +178,7 @@ GEM
|
|
184
178
|
rubocop-ast (>= 1.17.0, < 2.0)
|
185
179
|
ruby-progressbar (~> 1.7)
|
186
180
|
unicode-display_width (>= 1.4.0, < 3.0)
|
187
|
-
rubocop-ast (1.
|
181
|
+
rubocop-ast (1.30.0)
|
188
182
|
parser (>= 3.2.1.0)
|
189
183
|
rubocop-i18n (3.0.0)
|
190
184
|
rubocop (~> 1.0)
|
@@ -193,19 +187,19 @@ GEM
|
|
193
187
|
ruby2_keywords (0.0.5)
|
194
188
|
scanf (1.0.0)
|
195
189
|
semantic_puppet (1.1.0)
|
196
|
-
signet (0.
|
190
|
+
signet (0.18.0)
|
197
191
|
addressable (~> 2.8)
|
198
192
|
faraday (>= 0.17.5, < 3.a)
|
199
193
|
jwt (>= 1.5, < 3.0)
|
200
194
|
multi_json (~> 1.10)
|
201
195
|
singleton (0.1.1)
|
202
196
|
text (1.3.1)
|
203
|
-
thor (1.
|
197
|
+
thor (1.3.0)
|
204
198
|
trailblazer-option (0.1.2)
|
205
199
|
uber (0.1.0)
|
206
|
-
unicode-display_width (2.
|
207
|
-
vcr (6.
|
208
|
-
webmock (3.
|
200
|
+
unicode-display_width (2.5.0)
|
201
|
+
vcr (6.2.0)
|
202
|
+
webmock (3.19.1)
|
209
203
|
addressable (>= 2.8.0)
|
210
204
|
crack (>= 0.3.2)
|
211
205
|
hashdiff (>= 0.4.0, < 2.0.0)
|
@@ -218,7 +212,7 @@ PLATFORMS
|
|
218
212
|
DEPENDENCIES
|
219
213
|
diff-lcs (~> 1.3)
|
220
214
|
facter (~> 4.3)
|
221
|
-
ffi
|
215
|
+
ffi (= 1.15.5)
|
222
216
|
gettext-setup (~> 1.0)
|
223
217
|
hiera-eyaml
|
224
218
|
hocon (~> 1.0)
|
@@ -226,7 +220,7 @@ DEPENDENCIES
|
|
226
220
|
memory_profiler
|
227
221
|
minitar (~> 0.9)
|
228
222
|
msgpack (~> 1.2)
|
229
|
-
packaging
|
223
|
+
packaging (= 0.111.0)
|
230
224
|
pry
|
231
225
|
puppet!
|
232
226
|
puppet-resource_api (~> 1.5)
|
@@ -248,4 +242,4 @@ DEPENDENCIES
|
|
248
242
|
yard
|
249
243
|
|
250
244
|
BUNDLED WITH
|
251
|
-
2.4.
|
245
|
+
2.4.20
|
data/ext/project_data.yaml
CHANGED
@@ -39,11 +39,11 @@ gem_platform_dependencies:
|
|
39
39
|
CFPropertyList: '~> 2.2'
|
40
40
|
x86-mingw32:
|
41
41
|
gem_runtime_dependencies:
|
42
|
-
ffi:
|
42
|
+
ffi: '1.15.5'
|
43
43
|
minitar: '~> 0.9'
|
44
44
|
x64-mingw32:
|
45
45
|
gem_runtime_dependencies:
|
46
|
-
ffi:
|
46
|
+
ffi: '1.15.5'
|
47
47
|
minitar: '~> 0.9'
|
48
48
|
bundle_platforms:
|
49
49
|
universal-darwin: all
|
@@ -60,6 +60,11 @@ ACTIONS
|
|
60
60
|
the CSR. Otherwise a new key pair will be generated. If a CSR has already
|
61
61
|
been submitted with the given `certname`, then the operation will fail.
|
62
62
|
|
63
|
+
* generate_request:
|
64
|
+
Generate a certificate signing request (CSR). If
|
65
|
+
a private and public key pair already exist, they will be used to generate
|
66
|
+
the CSR. Otherwise a new key pair will be generated.
|
67
|
+
|
63
68
|
* download_cert:
|
64
69
|
Download a certificate for this host. If the current private key matches
|
65
70
|
the downloaded certificate, then the certificate will be saved and used
|
@@ -137,9 +142,21 @@ HELP
|
|
137
142
|
unless cert
|
138
143
|
raise Puppet::Error, _("The certificate for '%{name}' has not yet been signed") % { name: certname }
|
139
144
|
end
|
145
|
+
when 'generate_request'
|
146
|
+
generate_request(certname)
|
140
147
|
when 'verify'
|
141
148
|
verify(certname)
|
142
149
|
when 'clean'
|
150
|
+
possible_extra_args = command_line.args.drop(1)
|
151
|
+
unless possible_extra_args.empty?
|
152
|
+
raise Puppet::Error, _(<<END) % { args: possible_extra_args.join(' ')}
|
153
|
+
Extra arguments detected: %{args}
|
154
|
+
Did you mean to run:
|
155
|
+
puppetserver ca clean --certname <name>
|
156
|
+
Or:
|
157
|
+
puppet ssl clean --target <name>
|
158
|
+
END
|
159
|
+
end
|
143
160
|
clean(certname)
|
144
161
|
when 'bootstrap'
|
145
162
|
if !Puppet::Util::Log.sendlevel?(:info)
|
@@ -163,13 +180,7 @@ HELP
|
|
163
180
|
def submit_request(ssl_context)
|
164
181
|
key = @cert_provider.load_private_key(Puppet[:certname])
|
165
182
|
unless key
|
166
|
-
|
167
|
-
Puppet.info _("Creating a new EC SSL key for %{name} using curve %{curve}") % { name: Puppet[:certname], curve: Puppet[:named_curve] }
|
168
|
-
key = OpenSSL::PKey::EC.generate(Puppet[:named_curve])
|
169
|
-
else
|
170
|
-
Puppet.info _("Creating a new SSL key for %{name}") % { name: Puppet[:certname] }
|
171
|
-
key = OpenSSL::PKey::RSA.new(Puppet[:keylength].to_i)
|
172
|
-
end
|
183
|
+
key = create_key(Puppet[:certname])
|
173
184
|
@cert_provider.save_private_key(Puppet[:certname], key)
|
174
185
|
end
|
175
186
|
|
@@ -188,6 +199,20 @@ HELP
|
|
188
199
|
raise Puppet::Error.new(_("Failed to submit certificate request: %{message}") % { message: e.message }, e)
|
189
200
|
end
|
190
201
|
|
202
|
+
def generate_request(certname)
|
203
|
+
key = @cert_provider.load_private_key(certname)
|
204
|
+
unless key
|
205
|
+
key = create_key(certname)
|
206
|
+
@cert_provider.save_private_key(certname, key)
|
207
|
+
end
|
208
|
+
|
209
|
+
csr = @cert_provider.create_request(certname, key)
|
210
|
+
@cert_provider.save_request(certname, csr)
|
211
|
+
Puppet.notice _("Generated certificate request in '%{path}'") % { path: @cert_provider.to_path(Puppet[:requestdir], certname) }
|
212
|
+
rescue => e
|
213
|
+
raise Puppet::Error.new(_("Failed to generate certificate request: %{message}") % { message: e.message }, e)
|
214
|
+
end
|
215
|
+
|
191
216
|
def download_cert(ssl_context)
|
192
217
|
key = @cert_provider.load_private_key(Puppet[:certname])
|
193
218
|
|
@@ -286,4 +311,14 @@ END
|
|
286
311
|
def create_route(ssl_context)
|
287
312
|
@session.route_to(:ca, ssl_context: ssl_context)
|
288
313
|
end
|
314
|
+
|
315
|
+
def create_key(certname)
|
316
|
+
if Puppet[:key_type] == 'ec'
|
317
|
+
Puppet.info _("Creating a new EC SSL key for %{name} using curve %{curve}") % { name: certname, curve: Puppet[:named_curve] }
|
318
|
+
OpenSSL::PKey::EC.generate(Puppet[:named_curve])
|
319
|
+
else
|
320
|
+
Puppet.info _("Creating a new SSL key for %{name}") % { name: certname }
|
321
|
+
OpenSSL::PKey::RSA.new(Puppet[:keylength].to_i)
|
322
|
+
end
|
323
|
+
end
|
289
324
|
end
|
data/lib/puppet/application.rb
CHANGED
@@ -504,8 +504,12 @@ class Application
|
|
504
504
|
runtime_info = {
|
505
505
|
'puppet_version' => Puppet.version,
|
506
506
|
'ruby_version' => RUBY_VERSION,
|
507
|
-
'run_mode' => self.class.run_mode.name
|
507
|
+
'run_mode' => self.class.run_mode.name
|
508
508
|
}
|
509
|
+
unless Puppet::Util::Platform.jruby_fips?
|
510
|
+
runtime_info['openssl_version'] = "'#{OpenSSL::OPENSSL_VERSION}'"
|
511
|
+
runtime_info['openssl_fips'] = OpenSSL::OPENSSL_FIPS
|
512
|
+
end
|
509
513
|
runtime_info['default_encoding'] = Encoding.default_external
|
510
514
|
runtime_info.merge!(extra_info) unless extra_info.nil?
|
511
515
|
|
data/lib/puppet/defaults.rb
CHANGED
@@ -4,11 +4,7 @@ require_relative '../puppet/util/platform'
|
|
4
4
|
module Puppet
|
5
5
|
|
6
6
|
def self.default_diffargs
|
7
|
-
|
8
|
-
""
|
9
|
-
else
|
10
|
-
"-u"
|
11
|
-
end
|
7
|
+
'-u'
|
12
8
|
end
|
13
9
|
|
14
10
|
def self.default_digest_algorithm
|
@@ -1248,6 +1244,22 @@ EOT
|
|
1248
1244
|
unchanged on the server, then the agent run will continue using the
|
1249
1245
|
local CRL it already has.#{AS_DURATION}",
|
1250
1246
|
},
|
1247
|
+
:hostcert_renewal_interval => {
|
1248
|
+
:default => "30d",
|
1249
|
+
:type => :duration,
|
1250
|
+
:desc => "When the Puppet agent refreshes its client certificate.
|
1251
|
+
By default the client certificate will refresh 30 days before the certificate
|
1252
|
+
expires. If a different duration is specified, then the agent will refresh its
|
1253
|
+
client certificate whenever it next runs and if the client certificate expires
|
1254
|
+
within the duration specified.
|
1255
|
+
|
1256
|
+
In general, the duration should be greater than the `runinterval`.
|
1257
|
+
Setting it to 0 will disable automatic renewal.
|
1258
|
+
|
1259
|
+
If the agent downloads a new certificate, the agent will use it for subsequent
|
1260
|
+
network requests. If the refresh request fails, then the agent run will continue using the
|
1261
|
+
certificate it already has. #{AS_DURATION}",
|
1262
|
+
},
|
1251
1263
|
:keylength => {
|
1252
1264
|
:default => 4096,
|
1253
1265
|
:type => :integer,
|
data/lib/puppet/face/config.rb
CHANGED
@@ -82,7 +82,7 @@ Puppet::Face.define(:config, '0.0.1') do
|
|
82
82
|
end
|
83
83
|
|
84
84
|
when_rendering :console do |to_be_rendered|
|
85
|
-
output =
|
85
|
+
output = ''.dup
|
86
86
|
if to_be_rendered.keys.length > 1
|
87
87
|
to_be_rendered.keys.sort.each do |setting|
|
88
88
|
output << "#{setting} = #{to_be_rendered[setting]}\n"
|
data/lib/puppet/face/epp.rb
CHANGED
@@ -367,7 +367,7 @@ Puppet::Face.define(:epp, '0.0.1') do
|
|
367
367
|
end
|
368
368
|
|
369
369
|
def dump_parse(source, filename, options, show_filename = true)
|
370
|
-
output =
|
370
|
+
output = ''.dup
|
371
371
|
evaluating_parser = Puppet::Pops::Parser::EvaluatingParser::EvaluatingEppParser.new
|
372
372
|
begin
|
373
373
|
if options[:validate]
|
@@ -451,7 +451,7 @@ Puppet::Face.define(:epp, '0.0.1') do
|
|
451
451
|
|
452
452
|
def render_file(epp_template_name, compiler, options, show_filename, file_nbr)
|
453
453
|
template_args = get_values(compiler, options)
|
454
|
-
output =
|
454
|
+
output = ''.dup
|
455
455
|
begin
|
456
456
|
if show_filename && options[:header]
|
457
457
|
output << "\n" unless file_nbr == 1
|
@@ -74,7 +74,7 @@ Puppet::Face.define(:module, '1.0.0') do
|
|
74
74
|
environment = result[:environment]
|
75
75
|
modules_by_path = result[:modules_by_path]
|
76
76
|
|
77
|
-
output =
|
77
|
+
output = ''.dup
|
78
78
|
|
79
79
|
warn_unmet_dependencies(environment)
|
80
80
|
|
@@ -248,7 +248,7 @@ Puppet::Face.define(:module, '1.0.0') do
|
|
248
248
|
# Returns a Hash
|
249
249
|
#
|
250
250
|
def list_build_node(mod, parent, params)
|
251
|
-
str =
|
251
|
+
str = ''.dup
|
252
252
|
str << (mod.forge_name ? mod.forge_name.tr('/', '-') : mod.name)
|
253
253
|
str << ' (' + colorize(:cyan, mod.version ? "v#{mod.version}" : '???') + ')'
|
254
254
|
|
data/lib/puppet/face/parser.rb
CHANGED
@@ -174,7 +174,7 @@ Puppet::Face.define(:parser, '0.0.1') do
|
|
174
174
|
end
|
175
175
|
|
176
176
|
def dump_parse(source, filename, options, show_filename = true)
|
177
|
-
output =
|
177
|
+
output = ''.dup
|
178
178
|
evaluating_parser = Puppet::Pops::Parser::EvaluatingParser.new
|
179
179
|
begin
|
180
180
|
if options[:validate]
|
@@ -36,6 +36,21 @@ Puppet::Functions.create_function(:split) do
|
|
36
36
|
param 'Type[Regexp]', :pattern
|
37
37
|
end
|
38
38
|
|
39
|
+
dispatch :split_String_sensitive do
|
40
|
+
param 'Sensitive[String]', :sensitive
|
41
|
+
param 'String', :pattern
|
42
|
+
end
|
43
|
+
|
44
|
+
dispatch :split_Regexp_sensitive do
|
45
|
+
param 'Sensitive[String]', :sensitive
|
46
|
+
param 'Regexp', :pattern
|
47
|
+
end
|
48
|
+
|
49
|
+
dispatch :split_RegexpType_sensitive do
|
50
|
+
param 'Sensitive[String]', :sensitive
|
51
|
+
param 'Type[Regexp]', :pattern
|
52
|
+
end
|
53
|
+
|
39
54
|
def split_String(str, pattern)
|
40
55
|
str.split(Regexp.compile(pattern))
|
41
56
|
end
|
@@ -47,4 +62,16 @@ Puppet::Functions.create_function(:split) do
|
|
47
62
|
def split_RegexpType(str, pattern)
|
48
63
|
str.split(pattern.regexp)
|
49
64
|
end
|
50
|
-
|
65
|
+
|
66
|
+
def split_String_sensitive(sensitive, pattern)
|
67
|
+
Puppet::Pops::Types::PSensitiveType::Sensitive.new(split_String(sensitive.unwrap, pattern))
|
68
|
+
end
|
69
|
+
|
70
|
+
def split_Regexp_sensitive(sensitive, pattern)
|
71
|
+
Puppet::Pops::Types::PSensitiveType::Sensitive.new(split_Regexp(sensitive.unwrap, pattern))
|
72
|
+
end
|
73
|
+
|
74
|
+
def split_RegexpType_sensitive(sensitive, pattern)
|
75
|
+
Puppet::Pops::Types::PSensitiveType::Sensitive.new(split_RegexpType(sensitive.unwrap, pattern))
|
76
|
+
end
|
77
|
+
end
|
data/lib/puppet/http/client.rb
CHANGED
@@ -368,6 +368,7 @@ class Puppet::HTTP::Client
|
|
368
368
|
apply_auth(request, basic_auth) if redirects.zero?
|
369
369
|
|
370
370
|
# don't call return within the `request` block
|
371
|
+
close_and_sleep = nil
|
371
372
|
http.request(request) do |nethttp|
|
372
373
|
response = Puppet::HTTP::ResponseNetHTTP.new(request.uri, nethttp)
|
373
374
|
begin
|
@@ -381,12 +382,14 @@ class Puppet::HTTP::Client
|
|
381
382
|
interval = @retry_after_handler.retry_after_interval(request, response, retries)
|
382
383
|
retries += 1
|
383
384
|
if interval
|
384
|
-
|
385
|
-
|
386
|
-
|
385
|
+
close_and_sleep = proc do
|
386
|
+
if http.started?
|
387
|
+
Puppet.debug("Closing connection for #{Puppet::HTTP::Site.from_uri(request.uri)}")
|
388
|
+
http.finish
|
389
|
+
end
|
390
|
+
Puppet.warning(_("Sleeping for %{interval} seconds before retrying the request") % { interval: interval })
|
391
|
+
::Kernel.sleep(interval)
|
387
392
|
end
|
388
|
-
Puppet.warning(_("Sleeping for %{interval} seconds before retrying the request") % { interval: interval })
|
389
|
-
::Kernel.sleep(interval)
|
390
393
|
next
|
391
394
|
end
|
392
395
|
end
|
@@ -405,6 +408,10 @@ class Puppet::HTTP::Client
|
|
405
408
|
|
406
409
|
done = true
|
407
410
|
end
|
411
|
+
ensure
|
412
|
+
# If a server responded with a retry, make sure the connection is closed and then
|
413
|
+
# sleep the specified time.
|
414
|
+
close_and_sleep.call if close_and_sleep
|
408
415
|
end
|
409
416
|
end
|
410
417
|
|
@@ -104,4 +104,29 @@ class Puppet::HTTP::Service::Ca < Puppet::HTTP::Service
|
|
104
104
|
|
105
105
|
response
|
106
106
|
end
|
107
|
+
|
108
|
+
# Submit a POST request to send a certificate renewal request to the server
|
109
|
+
#
|
110
|
+
# @param [Puppet::SSL::SSLContext] ssl_context
|
111
|
+
#
|
112
|
+
# @return [Array<Puppet::HTTP::Response, String>] The request response
|
113
|
+
#
|
114
|
+
# @api public
|
115
|
+
def post_certificate_renewal(ssl_context)
|
116
|
+
headers = add_puppet_headers(HEADERS)
|
117
|
+
headers['Content-Type'] = 'text/plain'
|
118
|
+
|
119
|
+
response = @client.post(
|
120
|
+
with_base_url('/certificate_renewal'),
|
121
|
+
'', # Puppet::HTTP::Client.post requires a body, the API endpoint does not
|
122
|
+
headers: headers,
|
123
|
+
options: {ssl_context: ssl_context}
|
124
|
+
)
|
125
|
+
|
126
|
+
raise ArgumentError.new(_('SSL context must contain a client certificate.')) unless ssl_context.client_cert
|
127
|
+
|
128
|
+
process_response(response)
|
129
|
+
|
130
|
+
[response, response.body.to_s]
|
131
|
+
end
|
107
132
|
end
|
@@ -105,7 +105,7 @@ class Puppet::Node::Facts::Facter < Puppet::Indirector::Code
|
|
105
105
|
|
106
106
|
def find_with_options(request)
|
107
107
|
options = request.options
|
108
|
-
options_for_facter =
|
108
|
+
options_for_facter = ''.dup
|
109
109
|
options_for_facter += options[:user_query].join(' ')
|
110
110
|
options_for_facter += " --config #{options[:config_file]}" if options[:config_file]
|
111
111
|
options_for_facter += " --show-legacy" if options[:show_legacy]
|
@@ -58,7 +58,7 @@ module Puppet::FileBucketFile
|
|
58
58
|
end
|
59
59
|
# Setting hash's default value to [], needed by the following loop
|
60
60
|
bucket = Hash.new {[]}
|
61
|
-
msg =
|
61
|
+
msg = ''.dup
|
62
62
|
# Get all files with mtime between 'from' and 'to'
|
63
63
|
Pathname.new(request.options[:bucket_path]).find { |item|
|
64
64
|
if item.file? and item.basename.to_s == "paths"
|
@@ -13,7 +13,7 @@ class Puppet::InfoService::TaskInformationService
|
|
13
13
|
task.validate
|
14
14
|
{:module => {:name => task.module.name}, :name => task.name, :metadata => task.metadata}
|
15
15
|
rescue Puppet::Module::Task::Error => err
|
16
|
-
Puppet.log_exception(err
|
16
|
+
Puppet.log_exception(err)
|
17
17
|
nil
|
18
18
|
end
|
19
19
|
end
|
data/lib/puppet/module_tool.rb
CHANGED
@@ -70,7 +70,7 @@ module Puppet
|
|
70
70
|
# Builds a formatted tree from a list of node hashes containing +:text+
|
71
71
|
# and +:dependencies+ keys.
|
72
72
|
def self.format_tree(nodes, level = 0)
|
73
|
-
str =
|
73
|
+
str = ''.dup
|
74
74
|
nodes.each_with_index do |node, i|
|
75
75
|
last_node = nodes.length - 1 == i
|
76
76
|
deps = node[:dependencies] || []
|
@@ -156,7 +156,7 @@ Puppet::Network::FormatHandler.create(:console,
|
|
156
156
|
|
157
157
|
# Simple hash to table
|
158
158
|
if datum.is_a?(Hash) && datum.keys.all? { |x| x.is_a?(String) || x.is_a?(Numeric) }
|
159
|
-
output =
|
159
|
+
output = ''.dup
|
160
160
|
column_a = datum.empty? ? 2 : datum.map{ |k,v| k.to_s.length }.max + 2
|
161
161
|
datum.sort_by { |k,v| k.to_s } .each do |key, value|
|
162
162
|
output << key.to_s.ljust(column_a)
|
@@ -169,7 +169,7 @@ Puppet::Network::FormatHandler.create(:console,
|
|
169
169
|
|
170
170
|
# Print one item per line for arrays
|
171
171
|
if datum.is_a? Array
|
172
|
-
output =
|
172
|
+
output = ''.dup
|
173
173
|
datum.each do |item|
|
174
174
|
output << item.to_s
|
175
175
|
output << "\n"
|
@@ -227,7 +227,7 @@ Puppet::Network::FormatHandler.create(:flat,
|
|
227
227
|
end
|
228
228
|
|
229
229
|
def construct_output(data)
|
230
|
-
output =
|
230
|
+
output = ''.dup
|
231
231
|
data.each do |key, value|
|
232
232
|
output << "#{key}=#{value}"
|
233
233
|
output << "\n"
|
@@ -592,10 +592,12 @@ class Puppet::Node::Environment
|
|
592
592
|
if file == NO_MANIFEST
|
593
593
|
empty_parse_result
|
594
594
|
elsif File.directory?(file)
|
595
|
-
|
596
|
-
|
597
|
-
|
598
|
-
|
595
|
+
# JRuby does not properly perform Dir.glob operations with wildcards, (see PUP-11788 and https://github.com/jruby/jruby/issues/7836).
|
596
|
+
# We sort the results because Dir.glob order is inconsistent in Ruby < 3 (see PUP-10115).
|
597
|
+
parse_results = Puppet::FileSystem::PathPattern.absolute(File.join(file, '**/*')).glob.select {|globbed_file| globbed_file.end_with?('.pp')}.sort.map do | file_to_parse |
|
598
|
+
parser.file = file_to_parse
|
599
|
+
parser.parse
|
600
|
+
end
|
599
601
|
# Use a parser type specific merger to concatenate the results
|
600
602
|
Puppet::Parser::AST::Hostclass.new('', :code => Puppet::Parser::ParserFactory.code_merger.concatenate(parse_results))
|
601
603
|
else
|