puppet 8.5.1 → 8.6.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (542) hide show
  1. checksums.yaml +4 -4
  2. data/Gemfile.lock +23 -20
  3. data/ext/windows/service/daemon.rb +49 -55
  4. data/lib/hiera/scope.rb +3 -3
  5. data/lib/hiera_puppet.rb +1 -1
  6. data/lib/puppet/agent/disabler.rb +1 -1
  7. data/lib/puppet/application/agent.rb +2 -2
  8. data/lib/puppet/application/apply.rb +2 -2
  9. data/lib/puppet/application/describe.rb +6 -6
  10. data/lib/puppet/application/device.rb +99 -100
  11. data/lib/puppet/application/doc.rb +1 -1
  12. data/lib/puppet/application/face_base.rb +7 -7
  13. data/lib/puppet/application/filebucket.rb +1 -1
  14. data/lib/puppet/application/lookup.rb +5 -5
  15. data/lib/puppet/application/resource.rb +10 -3
  16. data/lib/puppet/application/ssl.rb +3 -3
  17. data/lib/puppet/application.rb +16 -18
  18. data/lib/puppet/coercion.rb +1 -1
  19. data/lib/puppet/configurer/downloader.rb +9 -4
  20. data/lib/puppet/configurer/fact_handler.rb +12 -13
  21. data/lib/puppet/configurer.rb +16 -18
  22. data/lib/puppet/confine/feature.rb +1 -1
  23. data/lib/puppet/confine/variable.rb +1 -1
  24. data/lib/puppet/confine.rb +2 -2
  25. data/lib/puppet/confine_collection.rb +1 -1
  26. data/lib/puppet/confiner.rb +2 -2
  27. data/lib/puppet/daemon.rb +3 -3
  28. data/lib/puppet/datatypes.rb +5 -6
  29. data/lib/puppet/defaults.rb +14 -8
  30. data/lib/puppet/environments.rb +3 -7
  31. data/lib/puppet/error.rb +3 -3
  32. data/lib/puppet/external/dot.rb +42 -34
  33. data/lib/puppet/face/catalog/select.rb +1 -1
  34. data/lib/puppet/face/epp.rb +7 -9
  35. data/lib/puppet/face/help.rb +12 -12
  36. data/lib/puppet/face/module/changes.rb +1 -3
  37. data/lib/puppet/face/module/list.rb +37 -37
  38. data/lib/puppet/face/node/clean.rb +1 -1
  39. data/lib/puppet/face/parser.rb +6 -8
  40. data/lib/puppet/face/report.rb +5 -7
  41. data/lib/puppet/facter_impl.rb +1 -1
  42. data/lib/puppet/feature/base.rb +9 -11
  43. data/lib/puppet/feature/pe_license.rb +1 -1
  44. data/lib/puppet/feature/ssh.rb +1 -1
  45. data/lib/puppet/feature/telnet.rb +3 -5
  46. data/lib/puppet/feature/zlib.rb +1 -1
  47. data/lib/puppet/ffi/windows/constants.rb +1 -1
  48. data/lib/puppet/ffi/windows/functions.rb +2 -2
  49. data/lib/puppet/ffi/windows/structs.rb +3 -3
  50. data/lib/puppet/file_bucket/dipper.rb +4 -4
  51. data/lib/puppet/file_bucket/file.rb +4 -4
  52. data/lib/puppet/file_serving/base.rb +5 -5
  53. data/lib/puppet/file_serving/configuration/parser.rb +9 -9
  54. data/lib/puppet/file_serving/configuration.rb +3 -3
  55. data/lib/puppet/file_serving/fileset.rb +13 -13
  56. data/lib/puppet/file_serving/http_metadata.rb +1 -1
  57. data/lib/puppet/file_serving/metadata.rb +13 -9
  58. data/lib/puppet/file_serving/mount/file.rb +6 -6
  59. data/lib/puppet/file_serving/mount/locales.rb +2 -4
  60. data/lib/puppet/file_serving/mount/pluginfacts.rb +2 -4
  61. data/lib/puppet/file_serving/mount/plugins.rb +2 -4
  62. data/lib/puppet/file_serving/mount.rb +1 -1
  63. data/lib/puppet/file_system/file_impl.rb +3 -3
  64. data/lib/puppet/file_system/memory_impl.rb +1 -1
  65. data/lib/puppet/file_system/path_pattern.rb +1 -1
  66. data/lib/puppet/file_system/uniquefile.rb +17 -16
  67. data/lib/puppet/file_system/windows.rb +26 -18
  68. data/lib/puppet/forge/cache.rb +2 -2
  69. data/lib/puppet/forge/errors.rb +1 -1
  70. data/lib/puppet/forge/repository.rb +2 -2
  71. data/lib/puppet/forge.rb +13 -19
  72. data/lib/puppet/functions/abs.rb +2 -2
  73. data/lib/puppet/functions/camelcase.rb +1 -1
  74. data/lib/puppet/functions/compare.rb +2 -2
  75. data/lib/puppet/functions/contain.rb +1 -1
  76. data/lib/puppet/functions/defined.rb +2 -2
  77. data/lib/puppet/functions/dig.rb +1 -1
  78. data/lib/puppet/functions/eyaml_lookup_key.rb +11 -13
  79. data/lib/puppet/functions/get.rb +1 -1
  80. data/lib/puppet/functions/hocon_data.rb +3 -5
  81. data/lib/puppet/functions/import.rb +1 -1
  82. data/lib/puppet/functions/json_data.rb +4 -6
  83. data/lib/puppet/functions/max.rb +2 -2
  84. data/lib/puppet/functions/min.rb +2 -2
  85. data/lib/puppet/functions/new.rb +1 -1
  86. data/lib/puppet/functions/reduce.rb +6 -10
  87. data/lib/puppet/functions/regsubst.rb +2 -2
  88. data/lib/puppet/functions/require.rb +1 -1
  89. data/lib/puppet/functions/yaml_data.rb +11 -13
  90. data/lib/puppet/functions.rb +32 -37
  91. data/lib/puppet/generate/type.rb +2 -2
  92. data/lib/puppet/gettext/config.rb +9 -9
  93. data/lib/puppet/graph/rb_tree_map.rb +31 -23
  94. data/lib/puppet/graph/relationship_graph.rb +12 -12
  95. data/lib/puppet/graph/simple_graph.rb +8 -10
  96. data/lib/puppet/http/client.rb +1 -1
  97. data/lib/puppet/http/dns.rb +4 -4
  98. data/lib/puppet/http/external_client.rb +1 -1
  99. data/lib/puppet/http/factory.rb +1 -1
  100. data/lib/puppet/http/proxy.rb +15 -15
  101. data/lib/puppet/http/redirector.rb +6 -2
  102. data/lib/puppet/http/resolver.rb +2 -2
  103. data/lib/puppet/http/retry_after_handler.rb +2 -2
  104. data/lib/puppet/http/service/ca.rb +1 -1
  105. data/lib/puppet/http/service/compiler.rb +4 -4
  106. data/lib/puppet/http/service/file_server.rb +1 -1
  107. data/lib/puppet/http/service/report.rb +2 -2
  108. data/lib/puppet/http/service.rb +9 -13
  109. data/lib/puppet/http/session.rb +1 -1
  110. data/lib/puppet/http/site.rb +1 -1
  111. data/lib/puppet/indirector/catalog/compiler.rb +44 -45
  112. data/lib/puppet/indirector/catalog/rest.rb +7 -5
  113. data/lib/puppet/indirector/catalog/store_configs.rb +1 -1
  114. data/lib/puppet/indirector/exec.rb +2 -2
  115. data/lib/puppet/indirector/face.rb +7 -9
  116. data/lib/puppet/indirector/fact_search.rb +1 -1
  117. data/lib/puppet/indirector/facts/facter.rb +6 -6
  118. data/lib/puppet/indirector/facts/json.rb +1 -1
  119. data/lib/puppet/indirector/facts/store_configs.rb +1 -1
  120. data/lib/puppet/indirector/file_bucket_file/file.rb +17 -17
  121. data/lib/puppet/indirector/file_bucket_file/rest.rb +3 -3
  122. data/lib/puppet/indirector/file_content/rest.rb +1 -1
  123. data/lib/puppet/indirector/file_metadata/rest.rb +1 -1
  124. data/lib/puppet/indirector/hiera.rb +1 -1
  125. data/lib/puppet/indirector/indirection.rb +27 -29
  126. data/lib/puppet/indirector/json.rb +4 -4
  127. data/lib/puppet/indirector/memory.rb +2 -2
  128. data/lib/puppet/indirector/msgpack.rb +5 -5
  129. data/lib/puppet/indirector/node/store_configs.rb +1 -1
  130. data/lib/puppet/indirector/none.rb +1 -1
  131. data/lib/puppet/indirector/report/json.rb +1 -1
  132. data/lib/puppet/indirector/report/yaml.rb +1 -1
  133. data/lib/puppet/indirector/request.rb +4 -4
  134. data/lib/puppet/indirector/resource/ral.rb +2 -4
  135. data/lib/puppet/indirector/resource/store_configs.rb +1 -1
  136. data/lib/puppet/indirector/terminus.rb +4 -4
  137. data/lib/puppet/indirector/yaml.rb +3 -3
  138. data/lib/puppet/info_service/class_information_service.rb +5 -8
  139. data/lib/puppet/info_service/task_information_service.rb +6 -7
  140. data/lib/puppet/interface/action.rb +5 -5
  141. data/lib/puppet/interface/action_manager.rb +5 -5
  142. data/lib/puppet/interface/documentation.rb +5 -5
  143. data/lib/puppet/interface/face_collection.rb +7 -7
  144. data/lib/puppet/interface/option.rb +2 -2
  145. data/lib/puppet/interface/option_manager.rb +6 -6
  146. data/lib/puppet/interface.rb +4 -4
  147. data/lib/puppet/metatype/manager.rb +2 -2
  148. data/lib/puppet/module/plan.rb +10 -10
  149. data/lib/puppet/module/task.rb +8 -8
  150. data/lib/puppet/module.rb +39 -41
  151. data/lib/puppet/module_tool/applications/application.rb +10 -8
  152. data/lib/puppet/module_tool/applications/installer.rb +53 -50
  153. data/lib/puppet/module_tool/applications/unpacker.rb +6 -8
  154. data/lib/puppet/module_tool/applications/upgrader.rb +37 -34
  155. data/lib/puppet/module_tool/checksums.rb +2 -2
  156. data/lib/puppet/module_tool/dependency.rb +1 -1
  157. data/lib/puppet/module_tool/errors/base.rb +1 -1
  158. data/lib/puppet/module_tool/install_directory.rb +1 -1
  159. data/lib/puppet/module_tool/local_tarball.rb +3 -5
  160. data/lib/puppet/module_tool/metadata.rb +12 -8
  161. data/lib/puppet/module_tool/shared_behaviors.rb +27 -12
  162. data/lib/puppet/module_tool/tar/mini.rb +3 -3
  163. data/lib/puppet/module_tool.rb +4 -4
  164. data/lib/puppet/network/client_request.rb +5 -3
  165. data/lib/puppet/network/format.rb +2 -2
  166. data/lib/puppet/network/format_support.rb +1 -1
  167. data/lib/puppet/network/formats.rb +1 -1
  168. data/lib/puppet/network/http/api/indirected_routes.rb +24 -44
  169. data/lib/puppet/network/http/api/server/v3.rb +1 -1
  170. data/lib/puppet/network/http/connection.rb +1 -1
  171. data/lib/puppet/network/http/handler.rb +8 -12
  172. data/lib/puppet/network/http/request.rb +1 -1
  173. data/lib/puppet/network/http/route.rb +9 -9
  174. data/lib/puppet/node/environment.rb +21 -23
  175. data/lib/puppet/node/facts.rb +1 -1
  176. data/lib/puppet/node.rb +5 -5
  177. data/lib/puppet/pal/json_catalog_encoder.rb +1 -1
  178. data/lib/puppet/pal/pal_impl.rb +48 -50
  179. data/lib/puppet/pal/plan_signature.rb +1 -1
  180. data/lib/puppet/pal/task_signature.rb +1 -1
  181. data/lib/puppet/parameter/package_options.rb +1 -1
  182. data/lib/puppet/parameter/value.rb +2 -2
  183. data/lib/puppet/parameter/value_collection.rb +7 -7
  184. data/lib/puppet/parameter.rb +8 -9
  185. data/lib/puppet/parser/ast/block_expression.rb +2 -2
  186. data/lib/puppet/parser/ast/hostclass.rb +1 -1
  187. data/lib/puppet/parser/ast/pops_bridge.rb +3 -4
  188. data/lib/puppet/parser/ast/resource.rb +4 -4
  189. data/lib/puppet/parser/ast/resourceparam.rb +4 -4
  190. data/lib/puppet/parser/ast.rb +14 -15
  191. data/lib/puppet/parser/compiler.rb +26 -28
  192. data/lib/puppet/parser/functions/create_resources.rb +3 -3
  193. data/lib/puppet/parser/functions/fail.rb +1 -1
  194. data/lib/puppet/parser/functions/generate.rb +2 -2
  195. data/lib/puppet/parser/functions/tag.rb +1 -1
  196. data/lib/puppet/parser/functions.rb +2 -2
  197. data/lib/puppet/parser/relationship.rb +3 -1
  198. data/lib/puppet/parser/resource/param.rb +2 -2
  199. data/lib/puppet/parser/resource.rb +23 -23
  200. data/lib/puppet/parser/scope.rb +10 -10
  201. data/lib/puppet/parser/script_compiler.rb +1 -1
  202. data/lib/puppet/parser/templatewrapper.rb +1 -1
  203. data/lib/puppet/parser/type_loader.rb +10 -12
  204. data/lib/puppet/parser.rb +1 -1
  205. data/lib/puppet/pops/adaptable.rb +1 -1
  206. data/lib/puppet/pops/evaluator/access_operator.rb +8 -8
  207. data/lib/puppet/pops/evaluator/callable_signature.rb +4 -4
  208. data/lib/puppet/pops/evaluator/collector_transformer.rb +4 -4
  209. data/lib/puppet/pops/evaluator/collectors/abstract_collector.rb +7 -7
  210. data/lib/puppet/pops/evaluator/collectors/fixed_set_collector.rb +6 -6
  211. data/lib/puppet/pops/evaluator/compare_operator.rb +10 -10
  212. data/lib/puppet/pops/evaluator/deferred_resolver.rb +1 -1
  213. data/lib/puppet/pops/evaluator/epp_evaluator.rb +2 -2
  214. data/lib/puppet/pops/evaluator/evaluator_impl.rb +56 -60
  215. data/lib/puppet/pops/evaluator/relationship_operator.rb +2 -2
  216. data/lib/puppet/pops/evaluator/runtime3_converter.rb +3 -3
  217. data/lib/puppet/pops/evaluator/runtime3_support.rb +1 -1
  218. data/lib/puppet/pops/functions/dispatcher.rb +3 -3
  219. data/lib/puppet/pops/functions/function.rb +14 -16
  220. data/lib/puppet/pops/issue_reporter.rb +2 -2
  221. data/lib/puppet/pops/label_provider.rb +2 -2
  222. data/lib/puppet/pops/loader/dependency_loader.rb +3 -3
  223. data/lib/puppet/pops/loader/loader.rb +4 -4
  224. data/lib/puppet/pops/loader/loader_paths.rb +3 -3
  225. data/lib/puppet/pops/loader/module_loaders.rb +11 -11
  226. data/lib/puppet/pops/loader/ruby_data_type_instantiator.rb +1 -1
  227. data/lib/puppet/pops/loader/ruby_function_instantiator.rb +1 -1
  228. data/lib/puppet/pops/loader/ruby_legacy_function_instantiator.rb +5 -1
  229. data/lib/puppet/pops/loader/static_loader.rb +3 -3
  230. data/lib/puppet/pops/loaders.rb +3 -3
  231. data/lib/puppet/pops/lookup/data_dig_function_provider.rb +1 -1
  232. data/lib/puppet/pops/lookup/explainer.rb +2 -2
  233. data/lib/puppet/pops/lookup/global_data_provider.rb +1 -1
  234. data/lib/puppet/pops/lookup/hiera_config.rb +15 -11
  235. data/lib/puppet/pops/lookup/interpolation.rb +3 -3
  236. data/lib/puppet/pops/lookup/key_recorder.rb +1 -1
  237. data/lib/puppet/pops/lookup/location_resolver.rb +1 -1
  238. data/lib/puppet/pops/lookup/lookup_adapter.rb +7 -7
  239. data/lib/puppet/pops/lookup/sub_lookup.rb +1 -1
  240. data/lib/puppet/pops/merge_strategy.rb +6 -6
  241. data/lib/puppet/pops/migration/migration_checker.rb +1 -1
  242. data/lib/puppet/pops/model/ast_transformer.rb +9 -11
  243. data/lib/puppet/pops/model/factory.rb +4 -5
  244. data/lib/puppet/pops/parser/epp_parser.rb +2 -2
  245. data/lib/puppet/pops/parser/epp_support.rb +1 -1
  246. data/lib/puppet/pops/parser/evaluating_parser.rb +2 -2
  247. data/lib/puppet/pops/parser/heredoc_support.rb +4 -4
  248. data/lib/puppet/pops/parser/interpolation_support.rb +3 -3
  249. data/lib/puppet/pops/parser/lexer2.rb +20 -12
  250. data/lib/puppet/pops/parser/lexer_support.rb +1 -1
  251. data/lib/puppet/pops/parser/locator.rb +4 -4
  252. data/lib/puppet/pops/parser/parser_support.rb +12 -14
  253. data/lib/puppet/pops/parser/pn_parser.rb +3 -3
  254. data/lib/puppet/pops/parser/slurp_support.rb +8 -8
  255. data/lib/puppet/pops/patterns.rb +12 -12
  256. data/lib/puppet/pops/pcore.rb +1 -1
  257. data/lib/puppet/pops/pn.rb +2 -2
  258. data/lib/puppet/pops/puppet_stack.rb +1 -1
  259. data/lib/puppet/pops/resource/resource_type_impl.rb +1 -1
  260. data/lib/puppet/pops/serialization/abstract_reader.rb +2 -2
  261. data/lib/puppet/pops/serialization/abstract_writer.rb +3 -3
  262. data/lib/puppet/pops/time/timestamp.rb +1 -1
  263. data/lib/puppet/pops/types/class_loader.rb +4 -6
  264. data/lib/puppet/pops/types/iterable.rb +1 -1
  265. data/lib/puppet/pops/types/p_binary_type.rb +1 -1
  266. data/lib/puppet/pops/types/p_init_type.rb +1 -1
  267. data/lib/puppet/pops/types/p_object_type.rb +5 -5
  268. data/lib/puppet/pops/types/p_object_type_extension.rb +4 -6
  269. data/lib/puppet/pops/types/p_sem_ver_range_type.rb +1 -1
  270. data/lib/puppet/pops/types/p_sensitive_type.rb +1 -1
  271. data/lib/puppet/pops/types/p_timespan_type.rb +2 -2
  272. data/lib/puppet/pops/types/p_type_set_type.rb +10 -10
  273. data/lib/puppet/pops/types/p_uri_type.rb +4 -4
  274. data/lib/puppet/pops/types/recursion_guard.rb +4 -4
  275. data/lib/puppet/pops/types/ruby_generator.rb +2 -2
  276. data/lib/puppet/pops/types/string_converter.rb +12 -8
  277. data/lib/puppet/pops/types/tree_iterators.rb +4 -6
  278. data/lib/puppet/pops/types/type_calculator.rb +10 -10
  279. data/lib/puppet/pops/types/type_factory.rb +7 -3
  280. data/lib/puppet/pops/types/type_formatter.rb +22 -24
  281. data/lib/puppet/pops/types/type_mismatch_describer.rb +24 -24
  282. data/lib/puppet/pops/types/types.rb +28 -24
  283. data/lib/puppet/pops/utils.rb +38 -42
  284. data/lib/puppet/pops/validation/checker4_0.rb +10 -10
  285. data/lib/puppet/pops/validation/tasks_checker.rb +1 -1
  286. data/lib/puppet/pops/validation/validator_factory_4_0.rb +1 -1
  287. data/lib/puppet/pops/validation.rb +4 -4
  288. data/lib/puppet/pops/visitor.rb +2 -2
  289. data/lib/puppet/property/ensure.rb +12 -14
  290. data/lib/puppet/property/keyvalue.rb +4 -4
  291. data/lib/puppet/property/list.rb +4 -4
  292. data/lib/puppet/property/ordered_list.rb +1 -1
  293. data/lib/puppet/property.rb +31 -33
  294. data/lib/puppet/provider/exec.rb +2 -2
  295. data/lib/puppet/provider/file/posix.rb +19 -17
  296. data/lib/puppet/provider/file/windows.rb +13 -19
  297. data/lib/puppet/provider/group/directoryservice.rb +3 -2
  298. data/lib/puppet/provider/group/groupadd.rb +4 -4
  299. data/lib/puppet/provider/group/windows_adsi.rb +2 -2
  300. data/lib/puppet/provider/nameservice/directoryservice.rb +29 -29
  301. data/lib/puppet/provider/nameservice/objectadd.rb +2 -4
  302. data/lib/puppet/provider/nameservice/pw.rb +1 -2
  303. data/lib/puppet/provider/nameservice.rb +8 -8
  304. data/lib/puppet/provider/package/aix.rb +19 -19
  305. data/lib/puppet/provider/package/appdmg.rb +2 -2
  306. data/lib/puppet/provider/package/apple.rb +1 -1
  307. data/lib/puppet/provider/package/apt.rb +18 -18
  308. data/lib/puppet/provider/package/aptitude.rb +1 -3
  309. data/lib/puppet/provider/package/aptrpm.rb +9 -9
  310. data/lib/puppet/provider/package/blastwave.rb +10 -14
  311. data/lib/puppet/provider/package/dnfmodule.rb +3 -3
  312. data/lib/puppet/provider/package/dpkg.rb +11 -13
  313. data/lib/puppet/provider/package/fink.rb +14 -14
  314. data/lib/puppet/provider/package/freebsd.rb +1 -1
  315. data/lib/puppet/provider/package/gem.rb +12 -14
  316. data/lib/puppet/provider/package/macports.rb +2 -2
  317. data/lib/puppet/provider/package/nim.rb +10 -10
  318. data/lib/puppet/provider/package/openbsd.rb +22 -22
  319. data/lib/puppet/provider/package/opkg.rb +6 -6
  320. data/lib/puppet/provider/package/pacman.rb +35 -29
  321. data/lib/puppet/provider/package/pip.rb +25 -24
  322. data/lib/puppet/provider/package/pkg.rb +15 -15
  323. data/lib/puppet/provider/package/pkgdmg.rb +10 -10
  324. data/lib/puppet/provider/package/pkgin.rb +2 -2
  325. data/lib/puppet/provider/package/pkgng.rb +5 -5
  326. data/lib/puppet/provider/package/pkgutil.rb +17 -21
  327. data/lib/puppet/provider/package/portage.rb +59 -61
  328. data/lib/puppet/provider/package/ports.rb +12 -11
  329. data/lib/puppet/provider/package/portupgrade.rb +35 -35
  330. data/lib/puppet/provider/package/puppetserver_gem.rb +10 -9
  331. data/lib/puppet/provider/package/rpm.rb +26 -26
  332. data/lib/puppet/provider/package/rug.rb +7 -9
  333. data/lib/puppet/provider/package/sun.rb +4 -4
  334. data/lib/puppet/provider/package/up2date.rb +5 -7
  335. data/lib/puppet/provider/package/urpmi.rb +6 -6
  336. data/lib/puppet/provider/package/windows/exe_package.rb +7 -7
  337. data/lib/puppet/provider/package/windows/msi_package.rb +3 -3
  338. data/lib/puppet/provider/package/windows/package.rb +2 -2
  339. data/lib/puppet/provider/package/windows.rb +3 -5
  340. data/lib/puppet/provider/package/yum.rb +33 -37
  341. data/lib/puppet/provider/package/zypper.rb +12 -14
  342. data/lib/puppet/provider/package.rb +1 -1
  343. data/lib/puppet/provider/package_targetable.rb +1 -1
  344. data/lib/puppet/provider/parsedfile.rb +9 -9
  345. data/lib/puppet/provider/service/base.rb +16 -21
  346. data/lib/puppet/provider/service/bsd.rb +4 -4
  347. data/lib/puppet/provider/service/daemontools.rb +31 -31
  348. data/lib/puppet/provider/service/debian.rb +6 -6
  349. data/lib/puppet/provider/service/freebsd.rb +36 -36
  350. data/lib/puppet/provider/service/gentoo.rb +6 -6
  351. data/lib/puppet/provider/service/init.rb +19 -19
  352. data/lib/puppet/provider/service/launchd.rb +22 -22
  353. data/lib/puppet/provider/service/openbsd.rb +10 -10
  354. data/lib/puppet/provider/service/openrc.rb +1 -1
  355. data/lib/puppet/provider/service/openwrt.rb +3 -3
  356. data/lib/puppet/provider/service/rcng.rb +3 -3
  357. data/lib/puppet/provider/service/redhat.rb +4 -4
  358. data/lib/puppet/provider/service/runit.rb +6 -6
  359. data/lib/puppet/provider/service/service.rb +5 -7
  360. data/lib/puppet/provider/service/smf.rb +28 -27
  361. data/lib/puppet/provider/service/src.rb +7 -7
  362. data/lib/puppet/provider/service/systemd.rb +31 -37
  363. data/lib/puppet/provider/service/upstart.rb +17 -17
  364. data/lib/puppet/provider/service/windows.rb +7 -7
  365. data/lib/puppet/provider/user/aix.rb +4 -2
  366. data/lib/puppet/provider/user/directoryservice.rb +34 -36
  367. data/lib/puppet/provider/user/hpux.rb +10 -14
  368. data/lib/puppet/provider/user/pw.rb +1 -1
  369. data/lib/puppet/provider/user/user_role_add.rb +16 -18
  370. data/lib/puppet/provider/user/useradd.rb +7 -7
  371. data/lib/puppet/provider/user/windows_adsi.rb +1 -1
  372. data/lib/puppet/provider.rb +8 -8
  373. data/lib/puppet/reference/indirection.rb +3 -0
  374. data/lib/puppet/reference/metaparameter.rb +1 -1
  375. data/lib/puppet/reference/providers.rb +3 -3
  376. data/lib/puppet/reference/type.rb +1 -1
  377. data/lib/puppet/relationship.rb +4 -5
  378. data/lib/puppet/reports/http.rb +1 -1
  379. data/lib/puppet/reports/log.rb +2 -2
  380. data/lib/puppet/reports/store.rb +4 -4
  381. data/lib/puppet/reports.rb +2 -2
  382. data/lib/puppet/resource/catalog.rb +16 -16
  383. data/lib/puppet/resource/status.rb +3 -3
  384. data/lib/puppet/resource/type.rb +8 -8
  385. data/lib/puppet/resource/type_collection.rb +1 -1
  386. data/lib/puppet/resource.rb +41 -41
  387. data/lib/puppet/scheduler/scheduler.rb +1 -1
  388. data/lib/puppet/settings/alias_setting.rb +3 -5
  389. data/lib/puppet/settings/base_setting.rb +11 -11
  390. data/lib/puppet/settings/boolean_setting.rb +2 -2
  391. data/lib/puppet/settings/config_file.rb +5 -4
  392. data/lib/puppet/settings/duration_setting.rb +2 -2
  393. data/lib/puppet/settings/environment_conf.rb +3 -3
  394. data/lib/puppet/settings/file_or_directory_setting.rb +2 -2
  395. data/lib/puppet/settings/file_setting.rb +11 -11
  396. data/lib/puppet/settings/ini_file.rb +3 -3
  397. data/lib/puppet/settings/port_setting.rb +1 -1
  398. data/lib/puppet/settings/priority_setting.rb +2 -2
  399. data/lib/puppet/settings/ttl_setting.rb +2 -2
  400. data/lib/puppet/settings/value_translator.rb +8 -8
  401. data/lib/puppet/settings.rb +65 -70
  402. data/lib/puppet/ssl/base.rb +2 -4
  403. data/lib/puppet/ssl/certificate_request.rb +18 -22
  404. data/lib/puppet/ssl/certificate_request_attributes.rb +3 -3
  405. data/lib/puppet/ssl/oids.rb +2 -2
  406. data/lib/puppet/ssl/openssl_loader.rb +4 -4
  407. data/lib/puppet/syntax_checkers/base64.rb +3 -3
  408. data/lib/puppet/syntax_checkers/epp.rb +3 -3
  409. data/lib/puppet/syntax_checkers/json.rb +3 -3
  410. data/lib/puppet/syntax_checkers/pp.rb +3 -3
  411. data/lib/puppet/transaction/additional_resource_generator.rb +1 -1
  412. data/lib/puppet/transaction/event.rb +2 -2
  413. data/lib/puppet/transaction/event_manager.rb +5 -5
  414. data/lib/puppet/transaction/persistence.rb +12 -14
  415. data/lib/puppet/transaction/report.rb +4 -4
  416. data/lib/puppet/transaction/resource_harness.rb +2 -2
  417. data/lib/puppet/transaction.rb +14 -18
  418. data/lib/puppet/type/component.rb +3 -3
  419. data/lib/puppet/type/exec.rb +43 -45
  420. data/lib/puppet/type/file/checksum_value.rb +1 -1
  421. data/lib/puppet/type/file/content.rb +6 -6
  422. data/lib/puppet/type/file/ctime.rb +2 -2
  423. data/lib/puppet/type/file/data_sync.rb +3 -3
  424. data/lib/puppet/type/file/ensure.rb +16 -15
  425. data/lib/puppet/type/file/mode.rb +9 -9
  426. data/lib/puppet/type/file/mtime.rb +2 -2
  427. data/lib/puppet/type/file/selcontext.rb +14 -14
  428. data/lib/puppet/type/file/source.rb +19 -21
  429. data/lib/puppet/type/file/target.rb +11 -11
  430. data/lib/puppet/type/file.rb +21 -21
  431. data/lib/puppet/type/filebucket.rb +3 -3
  432. data/lib/puppet/type/group.rb +3 -3
  433. data/lib/puppet/type/notify.rb +2 -2
  434. data/lib/puppet/type/package.rb +4 -4
  435. data/lib/puppet/type/resources.rb +6 -6
  436. data/lib/puppet/type/schedule.rb +9 -9
  437. data/lib/puppet/type/service.rb +6 -8
  438. data/lib/puppet/type/tidy.rb +22 -24
  439. data/lib/puppet/type/user.rb +13 -13
  440. data/lib/puppet/type.rb +76 -88
  441. data/lib/puppet/util/at_fork/solaris.rb +33 -37
  442. data/lib/puppet/util/autoload.rb +2 -2
  443. data/lib/puppet/util/backups.rb +9 -9
  444. data/lib/puppet/util/character_encoding.rb +7 -6
  445. data/lib/puppet/util/checksums.rb +2 -2
  446. data/lib/puppet/util/classgen.rb +8 -8
  447. data/lib/puppet/util/colors.rb +1 -1
  448. data/lib/puppet/util/command_line/puppet_option_parser.rb +1 -1
  449. data/lib/puppet/util/command_line/trollop.rb +42 -46
  450. data/lib/puppet/util/command_line.rb +2 -2
  451. data/lib/puppet/util/constant_inflector.rb +2 -2
  452. data/lib/puppet/util/diff.rb +19 -21
  453. data/lib/puppet/util/docs.rb +2 -2
  454. data/lib/puppet/util/errors.rb +9 -9
  455. data/lib/puppet/util/execution.rb +32 -9
  456. data/lib/puppet/util/feature.rb +1 -1
  457. data/lib/puppet/util/fileparsing.rb +12 -16
  458. data/lib/puppet/util/filetype.rb +36 -40
  459. data/lib/puppet/util/inifile.rb +6 -12
  460. data/lib/puppet/util/ldap/connection.rb +1 -1
  461. data/lib/puppet/util/ldap/manager.rb +10 -12
  462. data/lib/puppet/util/lockfile.rb +6 -8
  463. data/lib/puppet/util/log/destination.rb +2 -2
  464. data/lib/puppet/util/log/destinations.rb +4 -4
  465. data/lib/puppet/util/log.rb +12 -9
  466. data/lib/puppet/util/logging.rb +11 -11
  467. data/lib/puppet/util/metric.rb +3 -3
  468. data/lib/puppet/util/monkey_patches.rb +5 -7
  469. data/lib/puppet/util/network_device/config.rb +3 -3
  470. data/lib/puppet/util/package/version/debian.rb +27 -28
  471. data/lib/puppet/util/package/version/pip.rb +5 -5
  472. data/lib/puppet/util/package/version/range/eq.rb +1 -1
  473. data/lib/puppet/util/package/version/rpm.rb +1 -1
  474. data/lib/puppet/util/package.rb +2 -2
  475. data/lib/puppet/util/pidlock.rb +2 -2
  476. data/lib/puppet/util/platform.rb +1 -1
  477. data/lib/puppet/util/plist.rb +8 -10
  478. data/lib/puppet/util/posix.rb +17 -17
  479. data/lib/puppet/util/profiler/aggregate.rb +1 -1
  480. data/lib/puppet/util/provider_features.rb +3 -3
  481. data/lib/puppet/util/rdoc/code_objects.rb +3 -3
  482. data/lib/puppet/util/rdoc/generators/puppet_generator.rb +63 -64
  483. data/lib/puppet/util/rdoc/generators/template/puppet/puppet.rb +23 -23
  484. data/lib/puppet/util/rdoc/parser/puppet_parser_core.rb +12 -12
  485. data/lib/puppet/util/rdoc/parser/puppet_parser_rdoc2.rb +1 -1
  486. data/lib/puppet/util/rdoc/parser.rb +1 -1
  487. data/lib/puppet/util/reference.rb +13 -9
  488. data/lib/puppet/util/retry_action.rb +1 -1
  489. data/lib/puppet/util/rpm_compare.rb +17 -18
  490. data/lib/puppet/util/rubygems.rb +1 -1
  491. data/lib/puppet/util/selinux.rb +7 -7
  492. data/lib/puppet/util/storage.rb +10 -12
  493. data/lib/puppet/util/suidmanager.rb +18 -19
  494. data/lib/puppet/util/symbolic_file_mode.rb +71 -75
  495. data/lib/puppet/util/tag_set.rb +2 -2
  496. data/lib/puppet/util/tagging.rb +8 -10
  497. data/lib/puppet/util/terminal.rb +4 -4
  498. data/lib/puppet/util/user_attr.rb +7 -7
  499. data/lib/puppet/util/watcher.rb +3 -5
  500. data/lib/puppet/util/windows/access_control_list.rb +1 -1
  501. data/lib/puppet/util/windows/adsi.rb +42 -42
  502. data/lib/puppet/util/windows/daemon.rb +64 -68
  503. data/lib/puppet/util/windows/error.rb +2 -2
  504. data/lib/puppet/util/windows/file.rb +18 -25
  505. data/lib/puppet/util/windows/monkey_patches/process.rb +1 -1
  506. data/lib/puppet/util/windows/principal.rb +8 -8
  507. data/lib/puppet/util/windows/process.rb +16 -28
  508. data/lib/puppet/util/windows/registry.rb +16 -15
  509. data/lib/puppet/util/windows/root_certs.rb +2 -2
  510. data/lib/puppet/util/windows/security.rb +31 -31
  511. data/lib/puppet/util/windows/service.rb +11 -11
  512. data/lib/puppet/util/windows/sid.rb +8 -8
  513. data/lib/puppet/util/windows/user.rb +18 -20
  514. data/lib/puppet/util/yaml.rb +1 -1
  515. data/lib/puppet/util.rb +55 -46
  516. data/lib/puppet/version.rb +2 -2
  517. data/lib/puppet/x509/pem_store.rb +1 -1
  518. data/lib/puppet.rb +3 -3
  519. data/man/man5/puppet.conf.5 +10 -2
  520. data/man/man8/puppet-agent.8 +1 -1
  521. data/man/man8/puppet-apply.8 +1 -1
  522. data/man/man8/puppet-catalog.8 +1 -1
  523. data/man/man8/puppet-config.8 +1 -1
  524. data/man/man8/puppet-describe.8 +1 -1
  525. data/man/man8/puppet-device.8 +1 -1
  526. data/man/man8/puppet-doc.8 +1 -1
  527. data/man/man8/puppet-epp.8 +1 -1
  528. data/man/man8/puppet-facts.8 +1 -1
  529. data/man/man8/puppet-filebucket.8 +1 -1
  530. data/man/man8/puppet-generate.8 +1 -1
  531. data/man/man8/puppet-help.8 +1 -1
  532. data/man/man8/puppet-lookup.8 +1 -1
  533. data/man/man8/puppet-module.8 +1 -1
  534. data/man/man8/puppet-node.8 +1 -1
  535. data/man/man8/puppet-parser.8 +1 -1
  536. data/man/man8/puppet-plugin.8 +1 -1
  537. data/man/man8/puppet-report.8 +1 -1
  538. data/man/man8/puppet-resource.8 +5 -1
  539. data/man/man8/puppet-script.8 +1 -1
  540. data/man/man8/puppet-ssl.8 +1 -1
  541. data/man/man8/puppet.8 +2 -2
  542. metadata +2 -2
@@ -16,9 +16,9 @@ class Puppet::Settings::IniFile
16
16
  config_fh.each_line do |line|
17
17
  case line.chomp
18
18
  when /^(\s*)\[([[:word:]]+)\](\s*)$/
19
- config.append(SectionLine.new($1, $2, $3))
19
+ config.append(SectionLine.new(::Regexp.last_match(1), ::Regexp.last_match(2), ::Regexp.last_match(3)))
20
20
  when /^(\s*)([[:word:]]+)(\s*=\s*)(.*?)(\s*)$/
21
- config.append(SettingLine.new($1, $2, $3, $4, $5))
21
+ config.append(SettingLine.new(::Regexp.last_match(1), ::Regexp.last_match(2), ::Regexp.last_match(3), ::Regexp.last_match(4), ::Regexp.last_match(5)))
22
22
  else
23
23
  config.append(Line.new(line))
24
24
  end
@@ -195,7 +195,7 @@ class Puppet::Settings::IniFile
195
195
  end
196
196
 
197
197
  def ==(other)
198
- super(other) && self.line_number == other.line_number
198
+ super(other) && line_number == other.line_number
199
199
  end
200
200
  end
201
201
 
@@ -4,7 +4,7 @@ class Puppet::Settings::PortSetting < Puppet::Settings::IntegerSetting
4
4
  def munge(value)
5
5
  value = super(value)
6
6
 
7
- if value < 0 || value > 65535
7
+ if value < 0 || value > 65_535
8
8
  raise Puppet::Settings::ValidationError, _("Value '%{value}' is not a valid port number for parameter: %{name}") % { value: value.inspect, name: @name }
9
9
  end
10
10
 
@@ -33,9 +33,9 @@ class Puppet::Settings::PrioritySetting < Puppet::Settings::BaseSetting
33
33
 
34
34
  if value.is_a?(Integer)
35
35
  value
36
- elsif (value.is_a?(String) and value =~ /\d+/)
36
+ elsif value.is_a?(String) and value =~ /\d+/
37
37
  value.to_i
38
- elsif (value.is_a?(String) and PRIORITY_MAP[value.to_sym])
38
+ elsif value.is_a?(String) and PRIORITY_MAP[value.to_sym]
39
39
  PRIORITY_MAP[value.to_sym]
40
40
  else
41
41
  raise Puppet::Settings::ValidationError, _("Invalid priority format '%{value}' for parameter: %{name}") % { value: value.inspect, name: @name }
@@ -44,8 +44,8 @@ class Puppet::Settings::TTLSetting < Puppet::Settings::BaseSetting
44
44
  elsif value == 'unlimited'
45
45
  Float::INFINITY
46
46
 
47
- elsif (value.is_a?(String) and value =~ FORMAT)
48
- $1.to_i * UNITMAP[$2 || 's']
47
+ elsif value.is_a?(String) and value =~ FORMAT
48
+ ::Regexp.last_match(1).to_i * UNITMAP[::Regexp.last_match(2) || 's']
49
49
  else
50
50
  raise Puppet::Settings::ValidationError, _("Invalid 'time to live' format '%{value}' for parameter: %{param_name}") % { value: value.inspect, param_name: param_name }
51
51
  end
@@ -4,13 +4,13 @@
4
4
  class Puppet::Settings::ValueTranslator
5
5
  def [](value)
6
6
  # Handle different data types correctly
7
- return case value
8
- when /^false$/i; false
9
- when /^true$/i; true
10
- when true; true
11
- when false; false
12
- else
13
- value.gsub(/^["']|["']$/, '').sub(/\s+$/, '')
14
- end
7
+ case value
8
+ when /^false$/i; false
9
+ when /^true$/i; true
10
+ when true; true
11
+ when false; false
12
+ else
13
+ value.gsub(/^["']|["']$/, '').sub(/\s+$/, '')
14
+ end
15
15
  end
16
16
  end
@@ -50,7 +50,7 @@ class Puppet::Settings
50
50
  REQUIRED_APP_SETTINGS = [:logdir, :confdir, :vardir, :codedir]
51
51
 
52
52
  # The acceptable sections of the puppet.conf configuration file.
53
- ALLOWED_SECTION_NAMES = ['main', 'server', 'master', 'agent', 'user'].freeze
53
+ ALLOWED_SECTION_NAMES = %w[main server master agent user].freeze
54
54
 
55
55
  NONE = 'none'
56
56
 
@@ -220,7 +220,7 @@ class Puppet::Settings
220
220
  # understand, and add them to the passed option list.
221
221
  def addargs(options)
222
222
  # Add all of the settings as valid options.
223
- self.each { |_name, setting|
223
+ each { |_name, setting|
224
224
  setting.getopt_args.each { |args| options << args }
225
225
  }
226
226
 
@@ -231,7 +231,7 @@ class Puppet::Settings
231
231
  # understand, and add them to the passed option list.
232
232
  def optparse_addargs(options)
233
233
  # Add all of the settings as valid options.
234
- self.each { |_name, setting|
234
+ each { |_name, setting|
235
235
  options << setting.optparse_args
236
236
  }
237
237
 
@@ -344,7 +344,7 @@ class Puppet::Settings
344
344
  option_parser.ignore_invalid_options = true
345
345
 
346
346
  # Add all global options to it.
347
- self.optparse_addargs([]).each do |option|
347
+ optparse_addargs([]).each do |option|
348
348
  option_parser.on(*option) do |arg|
349
349
  opt, val = Puppet::Settings.clean_opt(option[0], arg)
350
350
  handlearg(opt, val)
@@ -361,7 +361,7 @@ class Puppet::Settings
361
361
 
362
362
  # remove run_mode options from the arguments so that later parses don't think
363
363
  # it is an unknown option.
364
- while option_index = args.index('--run_mode') do # rubocop:disable Lint/AssignmentInCondition
364
+ while option_index = args.index('--run_mode') # rubocop:disable Lint/AssignmentInCondition
365
365
  args.delete_at option_index
366
366
  args.delete_at option_index
367
367
  end
@@ -421,7 +421,7 @@ class Puppet::Settings
421
421
  def create_ancestors(dir)
422
422
  parent_dir = File.dirname(dir)
423
423
 
424
- if !File.exist?(parent_dir)
424
+ unless File.exist?(parent_dir)
425
425
  FileUtils.mkdir_p(parent_dir)
426
426
  end
427
427
  end
@@ -429,13 +429,11 @@ class Puppet::Settings
429
429
 
430
430
  def call_hooks_deferred_to_application_initialization(options = {})
431
431
  @hooks_to_call_on_application_initialization.each do |setting|
432
- begin
433
- setting.handle(self.value(setting.name))
434
- rescue InterpolationError => err
435
- raise InterpolationError, err.message, err.backtrace unless options[:ignore_interpolation_dependency_errors]
436
- # swallow. We're not concerned if we can't call hooks because dependencies don't exist yet
437
- # we'll get another chance after application defaults are initialized
438
- end
432
+ setting.handle(value(setting.name))
433
+ rescue InterpolationError => err
434
+ raise InterpolationError, err.message, err.backtrace unless options[:ignore_interpolation_dependency_errors]
435
+ # swallow. We're not concerned if we can't call hooks because dependencies don't exist yet
436
+ # we'll get another chance after application defaults are initialized
439
437
  end
440
438
  end
441
439
  private :call_hooks_deferred_to_application_initialization
@@ -519,7 +517,7 @@ class Puppet::Settings
519
517
  def print_config_options
520
518
  if Puppet::Util::Log.sendlevel?(:info)
521
519
  Puppet::Util::Log.newdestination(:console)
522
- message = (_("Using --configprint is deprecated. Use 'puppet config <subcommand>' instead."))
520
+ message = _("Using --configprint is deprecated. Use 'puppet config <subcommand>' instead.")
523
521
  Puppet.deprecation_warning(message)
524
522
  end
525
523
 
@@ -622,7 +620,7 @@ class Puppet::Settings
622
620
 
623
621
  # Determine our environment, if we have one.
624
622
  if @config[:environment]
625
- env = self.value(:environment).to_sym
623
+ env = value(:environment).to_sym
626
624
  else
627
625
  env = NONE
628
626
  end
@@ -631,24 +629,24 @@ class Puppet::Settings
631
629
  value_sets = value_sets_for(env, preferred_run_mode)
632
630
  @config.values.select(&:has_hook?).each do |setting|
633
631
  value_sets.each do |source|
634
- if source.include?(setting.name)
635
- # We still have to use value to retrieve the value, since
636
- # we want the fully interpolated value, not $vardir/lib or whatever.
637
- # This results in extra work, but so few of the settings
638
- # will have associated hooks that it ends up being less work this
639
- # way overall.
640
- if setting.call_hook_on_initialize?
641
- @hooks_to_call_on_application_initialization |= [setting]
642
- else
643
- setting.handle(ChainedValues.new(
644
- preferred_run_mode,
645
- env,
646
- value_sets,
647
- @config
648
- ).interpolate(setting.name))
649
- end
650
- break
632
+ next unless source.include?(setting.name)
633
+
634
+ # We still have to use value to retrieve the value, since
635
+ # we want the fully interpolated value, not $vardir/lib or whatever.
636
+ # This results in extra work, but so few of the settings
637
+ # will have associated hooks that it ends up being less work this
638
+ # way overall.
639
+ if setting.call_hook_on_initialize?
640
+ @hooks_to_call_on_application_initialization |= [setting]
641
+ else
642
+ setting.handle(ChainedValues.new(
643
+ preferred_run_mode,
644
+ env,
645
+ value_sets,
646
+ @config
647
+ ).interpolate(setting.name))
651
648
  end
649
+ break
652
650
  end
653
651
  end
654
652
 
@@ -681,15 +679,15 @@ class Puppet::Settings
681
679
 
682
680
  def main_config_file
683
681
  if explicit_config_file?
684
- return self[:config]
682
+ self[:config]
685
683
  else
686
- return File.join(Puppet::Util::RunMode[:server].conf_dir, config_file_name)
684
+ File.join(Puppet::Util::RunMode[:server].conf_dir, config_file_name)
687
685
  end
688
686
  end
689
687
  private :main_config_file
690
688
 
691
689
  def user_config_file
692
- return File.join(Puppet::Util::RunMode[:user].conf_dir, config_file_name)
690
+ File.join(Puppet::Util::RunMode[:user].conf_dir, config_file_name)
693
691
  end
694
692
  private :user_config_file
695
693
 
@@ -708,7 +706,7 @@ class Puppet::Settings
708
706
  # This just means that the setting wasn't explicitly set on the command line, so we will ignore it and
709
707
  # fall through to the default name.
710
708
  end
711
- return self.class.default_config_file_name
709
+ self.class.default_config_file_name
712
710
  end
713
711
  private :config_file_name
714
712
 
@@ -783,9 +781,7 @@ class Puppet::Settings
783
781
  klass = StringSetting
784
782
  end
785
783
  hash[:settings] = self
786
- setting = klass.new(hash)
787
-
788
- setting
784
+ klass.new(hash)
789
785
  end
790
786
 
791
787
  # This has to be private, because it doesn't add the settings to @config
@@ -794,7 +790,7 @@ class Puppet::Settings
794
790
  # Iterate across all of the objects in a given section.
795
791
  def persection(section)
796
792
  section = section.to_sym
797
- self.each { |_name, obj|
793
+ each { |_name, obj|
798
794
  if obj.section == section
799
795
  yield obj
800
796
  end
@@ -842,10 +838,10 @@ class Puppet::Settings
842
838
 
843
839
  new = @used
844
840
  @used = []
845
- self.use(*new)
841
+ use(*new)
846
842
  end
847
843
 
848
- class SearchPathElement < Struct.new(:name, :type); end
844
+ SearchPathElement = Struct.new(:name, :type)
849
845
 
850
846
  # The order in which to search for values, without defaults.
851
847
  #
@@ -856,7 +852,7 @@ class Puppet::Settings
856
852
  def configsearchpath(environment = nil, run_mode = preferred_run_mode)
857
853
  searchpath = [
858
854
  SearchPathElement.new(:memory, :values),
859
- SearchPathElement.new(:cli, :values),
855
+ SearchPathElement.new(:cli, :values)
860
856
  ]
861
857
  searchpath << SearchPathElement.new(environment.intern, :environment) if environment
862
858
 
@@ -1060,7 +1056,7 @@ class Puppet::Settings
1060
1056
  end
1061
1057
 
1062
1058
  call.each do |setting|
1063
- setting.handle(self.value(setting.name))
1059
+ setting.handle(value(setting.name))
1064
1060
  end
1065
1061
  end
1066
1062
 
@@ -1072,7 +1068,7 @@ class Puppet::Settings
1072
1068
  @config.keys.find_all { |key| @config[key].is_a?(FileSetting) }.each do |key|
1073
1069
  file = @config[key]
1074
1070
  next if file.value.nil?
1075
- next unless (sections.nil? or sections.include?(file.section))
1071
+ next unless sections.nil? or sections.include?(file.section)
1076
1072
 
1077
1073
  resource = file.to_resource
1078
1074
  next unless resource
@@ -1091,7 +1087,7 @@ class Puppet::Settings
1091
1087
 
1092
1088
  # Convert our list of config settings into a configuration file.
1093
1089
  def to_config
1094
- str = %{The configuration file for #{Puppet.run_mode.name}. Note that this file
1090
+ str = %(The configuration file for #{Puppet.run_mode.name}. Note that this file
1095
1091
  is likely to have unused settings in it; any setting that's
1096
1092
  valid anywhere in Puppet can be in any config file, even if it's not used.
1097
1093
 
@@ -1103,7 +1099,7 @@ own configured state, so they can be used to make Puppet a bit more self-managin
1103
1099
  The file format supports octothorpe-commented lines, but not partial-line comments.
1104
1100
 
1105
1101
  Generated on #{Time.now}.
1106
- }.gsub(/^/, "# ")
1102
+ ).gsub(/^/, "# ")
1107
1103
 
1108
1104
  # Add a section heading that matches our name.
1109
1105
  str += "[#{preferred_run_mode}]\n"
@@ -1113,7 +1109,7 @@ Generated on #{Time.now}.
1113
1109
  end
1114
1110
  end
1115
1111
 
1116
- return str
1112
+ str
1117
1113
  end
1118
1114
 
1119
1115
  # Convert to a parseable manifest
@@ -1128,7 +1124,7 @@ Generated on #{Time.now}.
1128
1124
  # you can 'use' a section as many times as you want.
1129
1125
  def use(*sections)
1130
1126
  if Puppet[:settings_catalog]
1131
- sections = sections.collect { |s| s.to_sym }
1127
+ sections = sections.collect(&:to_sym)
1132
1128
  sections = sections.reject { |s| @used.include?(s) }
1133
1129
 
1134
1130
  Puppet.warning(":master section deprecated in favor of :server section") if sections.include?(:master)
@@ -1136,7 +1132,7 @@ Generated on #{Time.now}.
1136
1132
  # add :server if sections include :master or :master if sections include :server
1137
1133
  sections |= [:master, :server] if (sections & [:master, :server]).any?
1138
1134
 
1139
- sections = sections.collect { |s| s.to_sym }
1135
+ sections = sections.collect(&:to_sym)
1140
1136
  sections = sections.reject { |s| @used.include?(s) }
1141
1137
 
1142
1138
  return if sections.empty?
@@ -1153,7 +1149,7 @@ Generated on #{Time.now}.
1153
1149
  catalog.apply do |transaction|
1154
1150
  if transaction.any_failed?
1155
1151
  report = transaction.report
1156
- status_failures = report.resource_statuses.values.select { |r| r.failed? }
1152
+ status_failures = report.resource_statuses.values.select(&:failed?)
1157
1153
  status_fail_msg = status_failures
1158
1154
  .collect(&:events)
1159
1155
  .flatten
@@ -1251,9 +1247,9 @@ Generated on #{Time.now}.
1251
1247
  # in {https://projects.puppetlabs.com/issues/16637 #16637}
1252
1248
  def which_configuration_file
1253
1249
  if explicit_config_file? or Puppet.features.root? then
1254
- return main_config_file
1250
+ main_config_file
1255
1251
  else
1256
- return user_config_file
1252
+ user_config_file
1257
1253
  end
1258
1254
  end
1259
1255
 
@@ -1275,7 +1271,7 @@ Generated on #{Time.now}.
1275
1271
  def screen_non_puppet_conf_settings(puppet_conf)
1276
1272
  puppet_conf.sections.values.each do |section|
1277
1273
  forbidden = section.settings.select { |setting| Puppet::Settings::EnvironmentConf::ENVIRONMENT_CONF_ONLY_SETTINGS.include?(setting.name) }
1278
- raise(SettingsError, "Cannot set #{forbidden.map { |s| s.name }.join(", ")} settings in puppet.conf") if !forbidden.empty?
1274
+ raise(SettingsError, "Cannot set #{forbidden.map(&:name).join(', ')} settings in puppet.conf") unless forbidden.empty?
1279
1275
  end
1280
1276
  end
1281
1277
 
@@ -1369,7 +1365,7 @@ Generated on #{Time.now}.
1369
1365
  catalog.add_resource resource
1370
1366
  end
1371
1367
  group = setting.group
1372
- if group && !%w{root wheel}.include?(group) && catalog.resource(:group, group).nil?
1368
+ if group && !%w[root wheel].include?(group) && catalog.resource(:group, group).nil?
1373
1369
  catalog.add_resource Puppet::Resource.new(:group, group, :parameters => { :ensure => :present })
1374
1370
  end
1375
1371
  end
@@ -1383,7 +1379,7 @@ Generated on #{Time.now}.
1383
1379
  # Read the file in.
1384
1380
  # @api private
1385
1381
  def read_file(file)
1386
- return Puppet::FileSystem.read(file, :encoding => 'utf-8')
1382
+ Puppet::FileSystem.read(file, :encoding => 'utf-8')
1387
1383
  end
1388
1384
 
1389
1385
  # Private method for internal test use only; allows to do a comprehensive clear of all settings between tests.
@@ -1410,14 +1406,13 @@ Generated on #{Time.now}.
1410
1406
  # If they've specified neither, then the interpolation will fail and we'll
1411
1407
  # get an exception.
1412
1408
  #
1413
- begin
1414
- return true if self[:config]
1415
- rescue InterpolationError
1416
- # This means we failed to interpolate, which means that they didn't
1417
- # explicitly specify either :config or :confdir... so we'll fall out to
1418
- # the default value.
1419
- return false
1420
- end
1409
+
1410
+ true if self[:config]
1411
+ rescue InterpolationError
1412
+ # This means we failed to interpolate, which means that they didn't
1413
+ # explicitly specify either :config or :confdir... so we'll fall out to
1414
+ # the default value.
1415
+ false
1421
1416
  end
1422
1417
  private :explicit_config_file?
1423
1418
 
@@ -1448,7 +1443,7 @@ Generated on #{Time.now}.
1448
1443
  end
1449
1444
  if set
1450
1445
  value = set.lookup(name)
1451
- if !value.nil?
1446
+ unless value.nil?
1452
1447
  return value
1453
1448
  end
1454
1449
  end
@@ -1516,7 +1511,7 @@ Generated on #{Time.now}.
1516
1511
  when String
1517
1512
  failed_environment_interpolation = false
1518
1513
  interpolated_value = value.gsub(/\$(\w+)|\$\{(\w+)\}/) do |expression|
1519
- varname = $2 || $1
1514
+ varname = ::Regexp.last_match(2) || ::Regexp.last_match(1)
1520
1515
  interpolated_expression =
1521
1516
  if varname != ENVIRONMENT_SETTING || ok_to_interpolate_environment(setting_name)
1522
1517
  if varname == ENVIRONMENT_SETTING && @environment
@@ -1567,7 +1562,7 @@ Generated on #{Time.now}.
1567
1562
  def set(name, value)
1568
1563
  default = @defaults[name]
1569
1564
 
1570
- if !default
1565
+ unless default
1571
1566
  raise ArgumentError, _("Attempt to assign a value to unknown setting %{name}") % { name: name.inspect }
1572
1567
  end
1573
1568
 
@@ -1588,7 +1583,7 @@ Generated on #{Time.now}.
1588
1583
  end
1589
1584
 
1590
1585
  def inspect
1591
- %Q{<#{self.class}:#{self.object_id} @name="#{@name}" @values="#{@values}">}
1586
+ %Q(<#{self.class}:#{object_id} @name="#{@name}" @values="#{@values}">)
1592
1587
  end
1593
1588
  end
1594
1589
 
@@ -1612,7 +1607,7 @@ Generated on #{Time.now}.
1612
1607
  end
1613
1608
 
1614
1609
  def inspect
1615
- %Q{<#{self.class}:#{self.object_id} @name="#{@name}" @section="#{@section}">}
1610
+ %Q(<#{self.class}:#{object_id} @name="#{@name}" @section="#{@section}">)
1616
1611
  end
1617
1612
  end
1618
1613
 
@@ -1649,7 +1644,7 @@ Generated on #{Time.now}.
1649
1644
  end
1650
1645
 
1651
1646
  def inspect
1652
- %Q{<#{self.class}:#{self.object_id} @environment_name="#{@environment_name}" @conf="#{@conf}">}
1647
+ %Q(<#{self.class}:#{object_id} @environment_name="#{@environment_name}" @conf="#{@conf}">)
1653
1648
  end
1654
1649
  end
1655
1650
  end
@@ -17,7 +17,7 @@ class Puppet::SSL::Base
17
17
  end
18
18
 
19
19
  def self.to_multiple_s(instances)
20
- instances.collect { |inst| inst.to_s }.join(SEPARATOR)
20
+ instances.collect(&:to_s).join(SEPARATOR)
21
21
  end
22
22
 
23
23
  def self.wraps(klass)
@@ -119,9 +119,7 @@ class Puppet::SSL::Base
119
119
  end
120
120
 
121
121
  def digest(algorithm = nil)
122
- unless algorithm
123
- algorithm = digest_algorithm
124
- end
122
+ algorithm ||= digest_algorithm
125
123
 
126
124
  Puppet::SSL::Digest.new(algorithm, content.to_der)
127
125
  end
@@ -209,29 +209,27 @@ class Puppet::SSL::CertificateRequest < Puppet::SSL::Base
209
209
  # we need to prevent that field from being written to directly.
210
210
  PRIVATE_CSR_ATTRIBUTES = [
211
211
  'extReq', '1.2.840.113549.1.9.14',
212
- 'msExtReq', '1.3.6.1.4.1.311.2.1.14',
212
+ 'msExtReq', '1.3.6.1.4.1.311.2.1.14'
213
213
  ]
214
214
 
215
215
  def add_csr_attributes(csr, csr_attributes)
216
216
  csr_attributes.each do |oid, value|
217
- begin
218
- if PRIVATE_CSR_ATTRIBUTES.include? oid
219
- raise ArgumentError, _("Cannot specify CSR attribute %{oid}: conflicts with internally used CSR attribute") % { oid: oid }
220
- end
217
+ if PRIVATE_CSR_ATTRIBUTES.include? oid
218
+ raise ArgumentError, _("Cannot specify CSR attribute %{oid}: conflicts with internally used CSR attribute") % { oid: oid }
219
+ end
221
220
 
222
- encoded = OpenSSL::ASN1::PrintableString.new(value.to_s)
221
+ encoded = OpenSSL::ASN1::PrintableString.new(value.to_s)
223
222
 
224
- attr_set = OpenSSL::ASN1::Set.new([encoded])
225
- csr.add_attribute(OpenSSL::X509::Attribute.new(oid, attr_set))
226
- Puppet.debug("Added csr attribute: #{oid} => #{attr_set.inspect}")
227
- rescue OpenSSL::X509::AttributeError => e
228
- raise Puppet::Error, _("Cannot create CSR with attribute %{oid}: %{message}") % { oid: oid, message: e.message }, e.backtrace
229
- end
223
+ attr_set = OpenSSL::ASN1::Set.new([encoded])
224
+ csr.add_attribute(OpenSSL::X509::Attribute.new(oid, attr_set))
225
+ Puppet.debug("Added csr attribute: #{oid} => #{attr_set.inspect}")
226
+ rescue OpenSSL::X509::AttributeError => e
227
+ raise Puppet::Error, _("Cannot create CSR with attribute %{oid}: %{message}") % { oid: oid, message: e.message }, e.backtrace
230
228
  end
231
229
  end
232
230
 
233
231
  PRIVATE_EXTENSIONS = [
234
- 'subjectAltName', '2.5.29.17',
232
+ 'subjectAltName', '2.5.29.17'
235
233
  ]
236
234
 
237
235
  # @api private
@@ -240,16 +238,14 @@ class Puppet::SSL::CertificateRequest < Puppet::SSL::Base
240
238
 
241
239
  if options[:extension_requests]
242
240
  options[:extension_requests].each_pair do |oid, value|
243
- begin
244
- if PRIVATE_EXTENSIONS.include? oid
245
- raise Puppet::Error, _("Cannot specify CSR extension request %{oid}: conflicts with internally used extension request") % { oid: oid }
246
- end
247
-
248
- ext = OpenSSL::X509::Extension.new(oid, OpenSSL::ASN1::UTF8String.new(value.to_s).to_der, false)
249
- extensions << ext
250
- rescue OpenSSL::X509::ExtensionError => e
251
- raise Puppet::Error, _("Cannot create CSR with extension request %{oid}: %{message}") % { oid: oid, message: e.message }, e.backtrace
241
+ if PRIVATE_EXTENSIONS.include? oid
242
+ raise Puppet::Error, _("Cannot specify CSR extension request %{oid}: conflicts with internally used extension request") % { oid: oid }
252
243
  end
244
+
245
+ ext = OpenSSL::X509::Extension.new(oid, OpenSSL::ASN1::UTF8String.new(value.to_s).to_der, false)
246
+ extensions << ext
247
+ rescue OpenSSL::X509::ExtensionError => e
248
+ raise Puppet::Error, _("Cannot create CSR with extension request %{oid}: %{message}") % { oid: oid, message: e.message }, e.backtrace
253
249
  end
254
250
  end
255
251
 
@@ -23,18 +23,18 @@ class Puppet::SSL::CertificateRequestAttributes
23
23
  Puppet.info(_("csr_attributes file loading from %{path}") % { path: path })
24
24
  if Puppet::FileSystem.exist?(path)
25
25
  hash = Puppet::Util::Yaml.safe_load_file(path, [Symbol]) || {}
26
- if !hash.is_a?(Hash)
26
+ unless hash.is_a?(Hash)
27
27
  raise Puppet::Error, _("invalid CSR attributes, expected instance of Hash, received instance of %{klass}") % { klass: hash.class }
28
28
  end
29
29
 
30
30
  @custom_attributes = hash.delete('custom_attributes') || {}
31
31
  @extension_requests = hash.delete('extension_requests') || {}
32
- if not hash.keys.empty?
32
+ unless hash.keys.empty?
33
33
  raise Puppet::Error, _("unexpected attributes %{keys} in %{path}") % { keys: hash.keys.inspect, path: @path.inspect }
34
34
  end
35
35
 
36
36
  return true
37
37
  end
38
- return false
38
+ false
39
39
  end
40
40
  end
@@ -73,7 +73,7 @@ module Puppet::SSL::Oids
73
73
  ["1.3.6.1.4.1.34380.1.3.1", 'pp_authorization', 'Certificate Extension Authorization'],
74
74
  ["1.3.6.1.4.1.34380.1.3.2", 'pp_auth_auto_renew', 'Auto-Renew Certificate Attribute'],
75
75
  ["1.3.6.1.4.1.34380.1.3.13", 'pp_auth_role', 'Puppet Node Role Name for Authorization'],
76
- ["1.3.6.1.4.1.34380.1.3.39", 'pp_cli_auth', 'Puppetserver CA CLI Authorization'],
76
+ ["1.3.6.1.4.1.34380.1.3.39", 'pp_cli_auth', 'Puppetserver CA CLI Authorization']
77
77
  ]
78
78
 
79
79
  @did_register_puppet_oids = false
@@ -82,7 +82,7 @@ module Puppet::SSL::Oids
82
82
  # extensions. Without registering these OIDs, OpenSSL will fail when it
83
83
  # encounters such an extension in a CSR.
84
84
  def self.register_puppet_oids
85
- if !@did_register_puppet_oids
85
+ unless @did_register_puppet_oids
86
86
  PUPPET_OIDS.each do |oid_defn|
87
87
  OpenSSL::ASN1::ObjectId.register(*oid_defn)
88
88
  end
@@ -7,10 +7,7 @@ require_relative '../../puppet/util/platform'
7
7
  # core Puppet code to load correctly in JRuby environments that do not
8
8
  # have a functioning openssl (eg a FIPS enabled one).
9
9
 
10
- unless Puppet::Util::Platform.jruby_fips?
11
- require 'openssl'
12
- require 'net/https'
13
- else
10
+ if Puppet::Util::Platform.jruby_fips?
14
11
  # Even in JRuby we need to define the constants that are wrapped in
15
12
  # Indirections: Puppet::SSL::{Key, Certificate, CertificateRequest}
16
13
  module OpenSSL
@@ -23,4 +20,7 @@ else
23
20
  class Certificate; end
24
21
  end
25
22
  end
23
+ else
24
+ require 'openssl'
25
+ require 'net/https'
26
26
  end
@@ -16,9 +16,9 @@ class Puppet::SyntaxCheckers::Base64 < Puppet::Plugins::SyntaxCheckers::SyntaxCh
16
16
  # @api public
17
17
  #
18
18
  def check(text, syntax, acceptor, source_pos)
19
- raise ArgumentError.new(_("Base64 syntax checker: the text to check must be a String.")) unless text.is_a?(String)
20
- raise ArgumentError.new(_("Base64 syntax checker: the syntax identifier must be a String, e.g. json, data+json")) unless syntax.is_a?(String)
21
- raise ArgumentError.new(_("Base64 syntax checker: invalid Acceptor, got: '%{klass}'.") % { klass: acceptor.class.name }) unless acceptor.is_a?(Puppet::Pops::Validation::Acceptor)
19
+ raise ArgumentError, _("Base64 syntax checker: the text to check must be a String.") unless text.is_a?(String)
20
+ raise ArgumentError, _("Base64 syntax checker: the syntax identifier must be a String, e.g. json, data+json") unless syntax.is_a?(String)
21
+ raise ArgumentError, _("Base64 syntax checker: invalid Acceptor, got: '%{klass}'.") % { klass: acceptor.class.name } unless acceptor.is_a?(Puppet::Pops::Validation::Acceptor)
22
22
 
23
23
  cleaned_text = text.gsub(/[\r?\n[:blank:]]/, '')
24
24
  begin
@@ -15,9 +15,9 @@ class Puppet::SyntaxCheckers::EPP < Puppet::Plugins::SyntaxCheckers::SyntaxCheck
15
15
  # @api public
16
16
  #
17
17
  def check(text, syntax, acceptor, source_pos)
18
- raise ArgumentError.new(_("EPP syntax checker: the text to check must be a String.")) unless text.is_a?(String)
19
- raise ArgumentError.new(_("EPP syntax checker: the syntax identifier must be a String, e.g. pp")) unless syntax == 'epp'
20
- raise ArgumentError.new(_("EPP syntax checker: invalid Acceptor, got: '%{klass}'.") % { klass: acceptor.class.name }) unless acceptor.is_a?(Puppet::Pops::Validation::Acceptor)
18
+ raise ArgumentError, _("EPP syntax checker: the text to check must be a String.") unless text.is_a?(String)
19
+ raise ArgumentError, _("EPP syntax checker: the syntax identifier must be a String, e.g. pp") unless syntax == 'epp'
20
+ raise ArgumentError, _("EPP syntax checker: invalid Acceptor, got: '%{klass}'.") % { klass: acceptor.class.name } unless acceptor.is_a?(Puppet::Pops::Validation::Acceptor)
21
21
 
22
22
  begin
23
23
  Puppet::Pops::Parser::EvaluatingParser::EvaluatingEppParser.singleton.parse_string(text)
@@ -15,9 +15,9 @@ class Puppet::SyntaxCheckers::Json < Puppet::Plugins::SyntaxCheckers::SyntaxChec
15
15
  # @api public
16
16
  #
17
17
  def check(text, syntax, acceptor, source_pos)
18
- raise ArgumentError.new(_("Json syntax checker: the text to check must be a String.")) unless text.is_a?(String)
19
- raise ArgumentError.new(_("Json syntax checker: the syntax identifier must be a String, e.g. json, data+json")) unless syntax.is_a?(String)
20
- raise ArgumentError.new(_("Json syntax checker: invalid Acceptor, got: '%{klass}'.") % { klass: acceptor.class.name }) unless acceptor.is_a?(Puppet::Pops::Validation::Acceptor)
18
+ raise ArgumentError, _("Json syntax checker: the text to check must be a String.") unless text.is_a?(String)
19
+ raise ArgumentError, _("Json syntax checker: the syntax identifier must be a String, e.g. json, data+json") unless syntax.is_a?(String)
20
+ raise ArgumentError, _("Json syntax checker: invalid Acceptor, got: '%{klass}'.") % { klass: acceptor.class.name } unless acceptor.is_a?(Puppet::Pops::Validation::Acceptor)
21
21
 
22
22
  begin
23
23
  Puppet::Util::Json.load(text)