puppet 6.12.0-universal-darwin → 6.17.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.
Potentially problematic release.
This version of puppet might be problematic. Click here for more details.
- checksums.yaml +4 -4
- data/CODEOWNERS +2 -7
- data/CONTRIBUTING.md +7 -13
- data/Gemfile +4 -2
- data/Gemfile.lock +39 -36
- data/README.md +18 -25
- data/ext/project_data.yaml +1 -1
- data/ext/windows/service/daemon.rb +3 -3
- data/lib/puppet.rb +52 -13
- data/lib/puppet/agent.rb +20 -14
- data/lib/puppet/application/agent.rb +26 -17
- data/lib/puppet/application/describe.rb +7 -5
- data/lib/puppet/application/device.rb +2 -2
- data/lib/puppet/application/filebucket.rb +19 -15
- data/lib/puppet/application/plugin.rb +1 -0
- data/lib/puppet/application/resource.rb +1 -1
- data/lib/puppet/application/ssl.rb +4 -4
- data/lib/puppet/configurer.rb +65 -69
- data/lib/puppet/configurer/plugin_handler.rb +10 -1
- data/lib/puppet/confine.rb +1 -1
- data/lib/puppet/context/trusted_information.rb +14 -8
- data/lib/puppet/daemon.rb +13 -27
- data/lib/puppet/defaults.rb +154 -58
- data/lib/puppet/environments.rb +27 -20
- data/lib/puppet/face/facts.rb +8 -5
- data/lib/puppet/face/help.rb +29 -3
- data/lib/puppet/face/module/search.rb +5 -0
- data/lib/puppet/face/plugin.rb +2 -2
- data/lib/puppet/file_serving/http_metadata.rb +14 -2
- data/lib/puppet/file_serving/metadata.rb +4 -1
- data/lib/puppet/file_serving/terminus_selector.rb +7 -8
- data/lib/puppet/file_system/file_impl.rb +14 -10
- data/lib/puppet/file_system/memory_file.rb +6 -0
- data/lib/puppet/file_system/memory_impl.rb +13 -0
- data/lib/puppet/file_system/uniquefile.rb +12 -16
- data/lib/puppet/file_system/windows.rb +7 -10
- data/lib/puppet/forge.rb +1 -1
- data/lib/puppet/forge/cache.rb +1 -1
- data/lib/puppet/forge/repository.rb +4 -7
- data/lib/puppet/functions/call.rb +1 -1
- data/lib/puppet/functions/eyaml_lookup_key.rb +13 -8
- data/lib/puppet/functions/filter.rb +1 -0
- data/lib/puppet/functions/reduce.rb +2 -4
- data/lib/puppet/http.rb +5 -0
- data/lib/puppet/http/client.rb +293 -73
- data/lib/puppet/http/errors.rb +2 -0
- data/lib/puppet/http/external_client.rb +90 -0
- data/lib/puppet/http/redirector.rb +43 -7
- data/lib/puppet/http/resolver.rb +46 -3
- data/lib/puppet/http/resolver/server_list.rb +76 -16
- data/lib/puppet/http/resolver/settings.rb +23 -3
- data/lib/puppet/http/resolver/srv.rb +29 -3
- data/lib/puppet/http/response.rb +87 -1
- data/lib/puppet/http/retry_after_handler.rb +39 -0
- data/lib/puppet/http/service.rb +151 -7
- data/lib/puppet/http/service/ca.rb +76 -14
- data/lib/puppet/http/service/compiler.rb +319 -0
- data/lib/puppet/http/service/file_server.rb +206 -0
- data/lib/puppet/http/service/report.rb +49 -23
- data/lib/puppet/http/session.rb +103 -7
- data/lib/puppet/indirector.rb +1 -1
- data/lib/puppet/indirector/catalog/compiler.rb +10 -0
- data/lib/puppet/indirector/catalog/rest.rb +34 -0
- data/lib/puppet/indirector/facts/rest.rb +42 -0
- data/lib/puppet/indirector/file_bucket_file/file.rb +1 -1
- data/lib/puppet/indirector/file_bucket_file/rest.rb +48 -0
- data/lib/puppet/indirector/file_content/http.rb +5 -0
- data/lib/puppet/indirector/file_content/rest.rb +30 -0
- data/lib/puppet/indirector/file_metadata/http.rb +27 -8
- data/lib/puppet/indirector/file_metadata/rest.rb +52 -0
- data/lib/puppet/indirector/json.rb +1 -1
- data/lib/puppet/indirector/msgpack.rb +1 -1
- data/lib/puppet/indirector/node/rest.rb +24 -0
- data/lib/puppet/indirector/report/rest.rb +19 -0
- data/lib/puppet/indirector/report/yaml.rb +23 -0
- data/lib/puppet/indirector/request.rb +1 -1
- data/lib/puppet/indirector/rest.rb +12 -0
- data/lib/puppet/indirector/status/rest.rb +18 -0
- data/lib/puppet/loaders.rb +6 -0
- data/lib/puppet/metatype/manager.rb +80 -80
- data/lib/puppet/network/http/api/indirected_routes.rb +1 -1
- data/lib/puppet/network/http/api/master/v3/environment.rb +3 -0
- data/lib/puppet/network/http/base_pool.rb +7 -2
- data/lib/puppet/network/http/compression.rb +7 -0
- data/lib/puppet/network/http/connection.rb +6 -0
- data/lib/puppet/network/http/connection_adapter.rb +184 -0
- data/lib/puppet/network/http/nocache_pool.rb +2 -0
- data/lib/puppet/network/http/pool.rb +13 -6
- data/lib/puppet/network/http_pool.rb +2 -1
- data/lib/puppet/node/environment.rb +11 -1
- data/lib/puppet/pal/catalog_compiler.rb +5 -0
- data/lib/puppet/pal/pal_impl.rb +4 -29
- data/lib/puppet/parser/ast/leaf.rb +5 -5
- data/lib/puppet/parser/ast/pops_bridge.rb +6 -15
- data/lib/puppet/parser/compiler.rb +43 -33
- data/lib/puppet/parser/compiler/catalog_validator/env_relationship_validator.rb +2 -0
- data/lib/puppet/parser/compiler/catalog_validator/site_validator.rb +2 -0
- data/lib/puppet/parser/environment_compiler.rb +4 -1
- data/lib/puppet/parser/functions.rb +18 -13
- data/lib/puppet/parser/functions/filter.rb +1 -0
- data/lib/puppet/parser/resource.rb +3 -2
- data/lib/puppet/parser/resource/param.rb +6 -0
- data/lib/puppet/pops/evaluator/access_operator.rb +2 -2
- data/lib/puppet/pops/evaluator/evaluator_impl.rb +6 -6
- data/lib/puppet/pops/issues.rb +5 -0
- data/lib/puppet/pops/loader/puppet_plan_instantiator.rb +12 -3
- data/lib/puppet/pops/loaders.rb +7 -5
- data/lib/puppet/pops/parser/evaluating_parser.rb +5 -7
- data/lib/puppet/pops/resource/resource_type_impl.rb +2 -0
- data/lib/puppet/pops/types/p_object_type_extension.rb +10 -0
- data/lib/puppet/pops/types/type_calculator.rb +24 -0
- data/lib/puppet/pops/validation/checker4_0.rb +11 -1
- data/lib/puppet/pops/validation/tasks_checker.rb +5 -1
- data/lib/puppet/pops/validation/validator_factory_4_0.rb +1 -0
- data/lib/puppet/provider/aix_object.rb +4 -2
- data/lib/puppet/provider/group/aix.rb +1 -0
- data/lib/puppet/provider/group/groupadd.rb +57 -24
- data/lib/puppet/provider/group/windows_adsi.rb +3 -3
- data/lib/puppet/provider/package/aix.rb +17 -2
- data/lib/puppet/provider/package/apt.rb +78 -4
- data/lib/puppet/provider/package/aptitude.rb +1 -1
- data/lib/puppet/provider/package/dnfmodule.rb +69 -15
- data/lib/puppet/provider/package/dpkg.rb +14 -7
- data/lib/puppet/provider/package/fink.rb +20 -3
- data/lib/puppet/provider/package/gem.rb +41 -7
- data/lib/puppet/provider/package/openbsd.rb +13 -1
- data/lib/puppet/provider/package/pacman.rb +2 -5
- data/lib/puppet/provider/package/pip.rb +143 -48
- data/lib/puppet/provider/package/pip3.rb +0 -2
- data/lib/puppet/provider/package/pkg.rb +18 -5
- data/lib/puppet/provider/package/pkgdmg.rb +1 -1
- data/lib/puppet/provider/package/pkgng.rb +16 -4
- data/lib/puppet/provider/package/portage.rb +2 -2
- data/lib/puppet/provider/package/puppet_gem.rb +6 -2
- data/lib/puppet/provider/package/rpm.rb +6 -213
- data/lib/puppet/provider/package/yum.rb +109 -25
- data/lib/puppet/provider/package/zypper.rb +59 -1
- data/lib/puppet/provider/service/systemd.rb +22 -4
- data/lib/puppet/provider/service/windows.rb +23 -7
- data/lib/puppet/provider/user/aix.rb +1 -0
- data/lib/puppet/provider/user/directoryservice.rb +30 -5
- data/lib/puppet/provider/user/useradd.rb +22 -12
- data/lib/puppet/reports/http.rb +15 -9
- data/lib/puppet/reports/store.rb +1 -1
- data/lib/puppet/resource.rb +2 -1
- data/lib/puppet/resource/type.rb +8 -0
- data/lib/puppet/resource/type_collection.rb +20 -16
- data/lib/puppet/runtime.rb +31 -1
- data/lib/puppet/settings.rb +4 -0
- data/lib/puppet/settings/http_extra_headers_setting.rb +25 -0
- data/lib/puppet/ssl.rb +1 -0
- data/lib/puppet/ssl/certificate.rb +2 -1
- data/lib/puppet/ssl/host.rb +4 -4
- data/lib/puppet/ssl/oids.rb +1 -0
- data/lib/puppet/ssl/ssl_context.rb +2 -2
- data/lib/puppet/ssl/ssl_provider.rb +20 -1
- data/lib/puppet/ssl/state_machine.rb +81 -35
- data/lib/puppet/ssl/verifier_adapter.rb +9 -1
- data/lib/puppet/test/test_helper.rb +15 -11
- data/lib/puppet/transaction/report.rb +2 -2
- data/lib/puppet/transaction/resource_harness.rb +1 -1
- data/lib/puppet/trusted_external.rb +29 -1
- data/lib/puppet/type.rb +18 -6
- data/lib/puppet/type/file.rb +51 -13
- data/lib/puppet/type/file/checksum.rb +4 -4
- data/lib/puppet/type/file/source.rb +51 -60
- data/lib/puppet/type/group.rb +2 -2
- data/lib/puppet/type/package.rb +102 -10
- data/lib/puppet/type/service.rb +55 -8
- data/lib/puppet/type/user.rb +3 -28
- data/lib/puppet/util.rb +39 -15
- data/lib/puppet/util/at_fork.rb +1 -1
- data/lib/puppet/util/autoload.rb +4 -18
- data/lib/puppet/util/checksums.rb +19 -4
- data/lib/puppet/util/fileparsing.rb +2 -2
- data/lib/puppet/util/instance_loader.rb +14 -10
- data/lib/puppet/util/log/destinations.rb +2 -11
- data/lib/puppet/util/package/version/debian.rb +175 -0
- data/lib/puppet/util/package/version/gem.rb +15 -0
- data/lib/puppet/util/package/version/pip.rb +167 -0
- data/lib/puppet/util/package/version/range.rb +53 -0
- data/lib/puppet/util/package/version/range/eq.rb +14 -0
- data/lib/puppet/util/package/version/range/gt.rb +14 -0
- data/lib/puppet/util/package/version/range/gt_eq.rb +14 -0
- data/lib/puppet/util/package/version/range/lt.rb +14 -0
- data/lib/puppet/util/package/version/range/lt_eq.rb +14 -0
- data/lib/puppet/util/package/version/range/min_max.rb +21 -0
- data/lib/puppet/util/package/version/range/simple.rb +11 -0
- data/lib/puppet/util/package/version/rpm.rb +73 -0
- data/lib/puppet/util/pidlock.rb +36 -10
- data/lib/puppet/util/platform.rb +5 -0
- data/lib/puppet/util/plist.rb +6 -0
- data/lib/puppet/util/provider_features.rb +1 -1
- data/lib/puppet/util/reference.rb +1 -1
- data/lib/puppet/util/rpm_compare.rb +193 -0
- data/lib/puppet/util/storage.rb +0 -1
- data/lib/puppet/util/windows/adsi.rb +2 -2
- data/lib/puppet/util/windows/api_types.rb +45 -32
- data/lib/puppet/util/windows/eventlog.rb +1 -6
- data/lib/puppet/util/windows/principal.rb +8 -6
- data/lib/puppet/util/windows/process.rb +15 -14
- data/lib/puppet/util/windows/registry.rb +11 -11
- data/lib/puppet/util/windows/security.rb +1 -0
- data/lib/puppet/util/windows/service.rb +43 -26
- data/lib/puppet/util/windows/sid.rb +3 -3
- data/lib/puppet/util/windows/user.rb +23 -8
- data/lib/puppet/util/yaml.rb +1 -1
- data/lib/puppet/version.rb +1 -1
- data/locales/puppet.pot +707 -574
- data/man/man5/puppet.conf.5 +74 -14
- data/man/man8/puppet-agent.8 +7 -7
- 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 +2 -2
- 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 +17 -2
- data/man/man8/puppet-generate.8 +1 -1
- data/man/man8/puppet-help.8 +6 -3
- data/man/man8/puppet-key.8 +1 -1
- data/man/man8/puppet-lookup.8 +1 -1
- data/man/man8/puppet-man.8 +1 -1
- data/man/man8/puppet-module.8 +4 -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 +2 -2
- data/man/man8/puppet-status.8 +1 -1
- data/man/man8/puppet.8 +2 -2
- data/spec/fixtures/ssl/unknown-127.0.0.1-key.pem +67 -0
- data/spec/fixtures/ssl/unknown-127.0.0.1.pem +48 -0
- data/spec/fixtures/ssl/unknown-ca-key.pem +67 -0
- data/spec/fixtures/ssl/unknown-ca.pem +59 -0
- data/spec/fixtures/unit/provider/package/dnfmodule/{dnf-module-list-installed.txt → dnf-module-list.txt} +8 -0
- data/spec/fixtures/unit/provider/package/pkgng/pkg.version +2 -0
- data/spec/fixtures/unit/provider/package/yum/yum-check-update-subscription-manager.txt +9 -0
- data/spec/fixtures/unit/provider/package/zypper/zypper-search-uninstalled.out +13 -0
- data/spec/fixtures/unit/provider/service/systemd/list_unit_files_services +9 -0
- data/spec/fixtures/vcr/cassettes/Puppet_Type_File/when_sourcing/from_http/using_md5/should_fetch_if_not_on_the_local_disk.yml +1 -102
- data/spec/fixtures/vcr/cassettes/Puppet_Type_File/when_sourcing/from_http/using_md5/should_not_update_if_content_on_disk_is_up-to-date.yml +1 -106
- data/spec/fixtures/vcr/cassettes/Puppet_Type_File/when_sourcing/from_http/using_md5/should_update_if_content_differs_on_disk.yml +1 -106
- data/spec/fixtures/vcr/cassettes/Puppet_Type_File/when_sourcing/from_http/using_mtime/should_fetch_if_mtime_is_older_on_disk.yml +1 -102
- data/spec/fixtures/vcr/cassettes/Puppet_Type_File/when_sourcing/from_http/using_mtime/should_fetch_if_no_header_specified.yml +1 -98
- data/spec/fixtures/vcr/cassettes/Puppet_Type_File/when_sourcing/from_http/using_mtime/should_fetch_if_not_on_the_local_disk.yml +1 -102
- data/spec/fixtures/vcr/cassettes/Puppet_Type_File/when_sourcing/from_http/using_mtime/should_not_update_if_mtime_is_newer_on_disk.yml +1 -102
- data/spec/integration/application/agent_spec.rb +483 -0
- data/spec/integration/application/apply_spec.rb +132 -3
- data/spec/integration/application/filebucket_spec.rb +190 -0
- data/spec/integration/application/plugin_spec.rb +73 -0
- data/spec/integration/configurer_spec.rb +26 -7
- data/spec/integration/defaults_spec.rb +1 -2
- data/spec/integration/http/client_spec.rb +47 -37
- data/spec/integration/indirector/facts/facter_spec.rb +4 -0
- data/spec/integration/indirector/report/yaml.rb +83 -0
- data/spec/integration/module_tool/forge_spec.rb +2 -15
- data/spec/integration/network/http_pool_spec.rb +93 -20
- data/spec/integration/node/environment_spec.rb +15 -0
- data/spec/integration/parser/compiler_spec.rb +11 -0
- data/spec/integration/type/file_spec.rb +1 -1
- data/spec/integration/util/windows/adsi_spec.rb +6 -1
- data/spec/integration/util/windows/registry_spec.rb +7 -7
- data/spec/integration/util/windows/user_spec.rb +40 -5
- data/spec/lib/puppet/test_ca.rb +2 -2
- data/spec/lib/puppet_spec/https.rb +16 -7
- data/spec/lib/puppet_spec/puppetserver.rb +119 -0
- data/spec/shared_contexts/https.rb +29 -0
- data/spec/unit/agent_spec.rb +80 -26
- data/spec/unit/application/agent_spec.rb +9 -5
- data/spec/unit/application/apply_spec.rb +2 -12
- data/spec/unit/application/describe_spec.rb +88 -50
- data/spec/unit/application/device_spec.rb +2 -2
- data/spec/unit/application/filebucket_spec.rb +22 -2
- data/spec/unit/application/resource_spec.rb +2 -2
- data/spec/unit/configurer/fact_handler_spec.rb +4 -8
- data/spec/unit/configurer/plugin_handler_spec.rb +36 -19
- data/spec/unit/configurer_spec.rb +17 -18
- data/spec/unit/context/trusted_information_spec.rb +25 -2
- data/spec/unit/daemon_spec.rb +5 -64
- data/spec/unit/defaults_spec.rb +25 -2
- data/spec/unit/environments_spec.rb +65 -28
- data/spec/unit/face/facts_spec.rb +24 -20
- data/spec/unit/face/module/search_spec.rb +17 -0
- data/spec/unit/face/plugin_spec.rb +12 -10
- data/spec/unit/file_serving/http_metadata_spec.rb +37 -14
- data/spec/unit/file_serving/terminus_selector_spec.rb +45 -26
- data/spec/unit/file_system/uniquefile_spec.rb +11 -0
- data/spec/unit/file_system_spec.rb +26 -2
- data/spec/unit/functions/lookup_spec.rb +13 -0
- data/spec/unit/http/client_spec.rb +327 -35
- data/spec/unit/http/external_client_spec.rb +201 -0
- data/spec/unit/http/resolver_spec.rb +34 -2
- data/spec/unit/http/response_spec.rb +75 -0
- data/spec/unit/http/service/ca_spec.rb +53 -11
- data/spec/unit/http/service/compiler_spec.rb +627 -0
- data/spec/unit/http/service/file_server_spec.rb +308 -0
- data/spec/unit/http/service/report_spec.rb +27 -9
- data/spec/unit/http/service_spec.rb +98 -5
- data/spec/unit/http/session_spec.rb +190 -7
- data/spec/unit/indirector/catalog/compiler_spec.rb +47 -29
- data/spec/unit/indirector/catalog/rest_spec.rb +59 -2
- data/spec/unit/indirector/facts/rest_spec.rb +79 -24
- data/spec/unit/indirector/file_bucket_file/rest_spec.rb +82 -2
- data/spec/unit/indirector/file_content/rest_spec.rb +53 -2
- data/spec/unit/indirector/file_metadata/http_spec.rb +194 -0
- data/spec/unit/indirector/file_metadata/rest_spec.rb +110 -2
- data/spec/unit/indirector/node/rest_spec.rb +57 -2
- data/spec/unit/indirector/report/rest_spec.rb +58 -51
- data/spec/unit/indirector/request_spec.rb +1 -1
- data/spec/unit/indirector/resource/ral_spec.rb +7 -8
- data/spec/unit/indirector/rest_spec.rb +13 -0
- data/spec/unit/indirector/status/rest_spec.rb +43 -2
- data/spec/unit/interface_spec.rb +3 -3
- data/spec/unit/network/http/api/indirected_routes_spec.rb +2 -1
- data/spec/unit/network/http/connection_spec.rb +559 -175
- data/spec/unit/network/http/nocache_pool_spec.rb +25 -3
- data/spec/unit/network/http/pool_spec.rb +89 -11
- data/spec/unit/network/http_pool_spec.rb +63 -57
- data/spec/unit/network/http_spec.rb +1 -1
- data/spec/unit/node/environment_spec.rb +16 -0
- data/spec/unit/node/facts_spec.rb +2 -1
- data/spec/unit/node_spec.rb +7 -4
- data/spec/unit/parser/ast/block_expression_spec.rb +1 -1
- data/spec/unit/parser/environment_compiler_spec.rb +7 -0
- data/spec/unit/parser/scope_spec.rb +1 -1
- data/spec/unit/pops/evaluator/evaluating_parser_spec.rb +15 -1
- data/spec/unit/pops/loaders/loaders_spec.rb +1 -1
- data/spec/unit/pops/serialization/to_from_hr_spec.rb +6 -1
- data/spec/unit/pops/types/type_calculator_spec.rb +1 -11
- data/spec/unit/pops/validator/validator_spec.rb +7 -2
- data/spec/unit/provider/aix_object_spec.rb +16 -2
- data/spec/unit/provider/group/groupadd_spec.rb +181 -56
- data/spec/unit/provider/group/windows_adsi_spec.rb +43 -10
- data/spec/unit/provider/package/aix_spec.rb +29 -0
- data/spec/unit/provider/package/apt_spec.rb +43 -2
- data/spec/unit/provider/package/aptitude_spec.rb +1 -0
- data/spec/unit/provider/package/dnfmodule_spec.rb +76 -15
- data/spec/unit/provider/package/dpkg_spec.rb +28 -6
- data/spec/unit/provider/package/gem_spec.rb +40 -0
- data/spec/unit/provider/package/openbsd_spec.rb +17 -0
- data/spec/unit/provider/package/pacman_spec.rb +6 -21
- data/spec/unit/provider/package/pip_spec.rb +68 -19
- data/spec/unit/provider/package/pkg_spec.rb +15 -1
- data/spec/unit/provider/package/pkgdmg_spec.rb +1 -1
- data/spec/unit/provider/package/pkgng_spec.rb +38 -0
- data/spec/unit/provider/package/portage_spec.rb +5 -0
- data/spec/unit/provider/package/puppet_gem_spec.rb +8 -0
- data/spec/unit/provider/package/rpm_spec.rb +0 -212
- data/spec/unit/provider/package/yum_spec.rb +292 -0
- data/spec/unit/provider/package/zypper_spec.rb +84 -0
- data/spec/unit/provider/service/init_spec.rb +1 -0
- data/spec/unit/provider/service/openbsd_spec.rb +9 -0
- data/spec/unit/provider/service/openwrt_spec.rb +1 -0
- data/spec/unit/provider/service/redhat_spec.rb +9 -0
- data/spec/unit/provider/service/systemd_spec.rb +92 -12
- data/spec/unit/provider/service/windows_spec.rb +22 -14
- data/spec/unit/provider/user/directoryservice_spec.rb +41 -0
- data/spec/unit/provider/user/openbsd_spec.rb +1 -0
- data/spec/unit/provider/user/useradd_spec.rb +43 -24
- data/spec/unit/provider/user/windows_adsi_spec.rb +3 -3
- data/spec/unit/puppet_pal_2pec.rb +0 -26
- data/spec/unit/puppet_pal_catalog_spec.rb +46 -0
- data/spec/unit/puppet_spec.rb +47 -0
- data/spec/unit/reports/http_spec.rb +70 -52
- data/spec/unit/resource_spec.rb +3 -3
- data/spec/unit/settings/autosign_setting_spec.rb +1 -1
- data/spec/unit/settings/http_extra_headers_spec.rb +64 -0
- data/spec/unit/ssl/certificate_spec.rb +7 -0
- data/spec/unit/ssl/host_spec.rb +4 -2
- data/spec/unit/ssl/oids_spec.rb +1 -0
- data/spec/unit/ssl/ssl_provider_spec.rb +69 -43
- data/spec/unit/ssl/state_machine_spec.rb +99 -13
- data/spec/unit/test/test_helper_spec.rb +17 -0
- data/spec/unit/transaction/persistence_spec.rb +1 -10
- data/spec/unit/transaction/report_spec.rb +5 -1
- data/spec/unit/transaction_spec.rb +0 -2
- data/spec/unit/type/file/ensure_spec.rb +1 -2
- data/spec/unit/type/file/source_spec.rb +89 -38
- data/spec/unit/type/file_spec.rb +122 -96
- data/spec/unit/type/package_spec.rb +8 -0
- data/spec/unit/type/service_spec.rb +185 -8
- data/spec/unit/type/user_spec.rb +1 -2
- data/spec/unit/type_spec.rb +50 -0
- data/spec/unit/util/at_fork_spec.rb +3 -2
- data/spec/unit/util/autoload_spec.rb +2 -1
- data/spec/unit/util/checksums_spec.rb +16 -0
- data/spec/unit/util/log/destinations_spec.rb +1 -29
- data/spec/unit/util/package/version/debian_spec.rb +83 -0
- data/spec/unit/util/package/version/pip_spec.rb +464 -0
- data/spec/unit/util/package/version/range_spec.rb +175 -0
- data/spec/unit/util/package/version/rpm_spec.rb +121 -0
- data/spec/unit/util/pidlock_spec.rb +112 -42
- data/spec/unit/util/plist_spec.rb +20 -0
- data/spec/unit/util/rpm_compare_spec.rb +196 -0
- data/spec/unit/util/storage_spec.rb +1 -8
- data/spec/unit/util/windows/adsi_spec.rb +4 -4
- data/spec/unit/util/windows/api_types_spec.rb +104 -40
- data/spec/unit/util/windows/service_spec.rb +4 -4
- data/spec/unit/util/windows/sid_spec.rb +2 -2
- data/spec/unit/util_spec.rb +3 -3
- data/spec/unit/x509/cert_provider_spec.rb +1 -1
- data/tasks/generate_cert_fixtures.rake +15 -1
- data/tasks/manpages.rake +5 -35
- metadata +73 -12
- data/COMMITTERS.md +0 -244
- data/spec/integration/faces/plugin_spec.rb +0 -61
- data/spec/integration/test/test_helper_spec.rb +0 -31
    
        data/lib/puppet/agent.rb
    CHANGED
    
    | @@ -43,6 +43,7 @@ class Puppet::Agent | |
| 43 43 | 
             
                end
         | 
| 44 44 |  | 
| 45 45 | 
             
                result = nil
         | 
| 46 | 
            +
                wait_for_lock_deadline = nil
         | 
| 46 47 | 
             
                block_run = Puppet::Application.controlled_run do
         | 
| 47 48 | 
             
                  splay client_options.fetch :splay, Puppet[:splay]
         | 
| 48 49 | 
             
                  result = run_in_fork(should_fork) do
         | 
| @@ -60,16 +61,29 @@ class Puppet::Agent | |
| 60 61 | 
             
                          end
         | 
| 61 62 | 
             
                        end
         | 
| 62 63 | 
             
                      rescue Puppet::LockError
         | 
| 63 | 
            -
                         | 
| 64 | 
            -
                         | 
| 64 | 
            +
                        now = Time.now.to_i
         | 
| 65 | 
            +
                        wait_for_lock_deadline ||= now + Puppet[:maxwaitforlock]
         | 
| 66 | 
            +
             | 
| 67 | 
            +
                        if Puppet[:waitforlock] < 1
         | 
| 68 | 
            +
                          Puppet.notice _("Run of %{client_class} already in progress; skipping  (%{lockfile_path} exists)") % { client_class: client_class, lockfile_path: lockfile_path }
         | 
| 69 | 
            +
                          nil
         | 
| 70 | 
            +
                        elsif now >= wait_for_lock_deadline
         | 
| 71 | 
            +
                          Puppet.notice _("Exiting now because the maxwaitforlock timeout has been exceeded.")
         | 
| 72 | 
            +
                          nil
         | 
| 73 | 
            +
                        else
         | 
| 74 | 
            +
                          Puppet.info _("Another puppet instance is already running; --waitforlock flag used, waiting for running instance to finish.")
         | 
| 75 | 
            +
                          Puppet.info _("Will try again in %{time} seconds.") % {time: Puppet[:waitforlock]}
         | 
| 76 | 
            +
                          sleep Puppet[:waitforlock]
         | 
| 77 | 
            +
                          retry
         | 
| 78 | 
            +
                        end
         | 
| 65 79 | 
             
                      rescue RunTimeoutError => detail
         | 
| 66 80 | 
             
                        Puppet.log_exception(detail, _("Execution of %{client_class} did not complete within %{runtimeout} seconds and was terminated.") %
         | 
| 67 81 | 
             
                          {client_class: client_class,
         | 
| 68 82 | 
             
                          runtimeout: Puppet[:runtimeout]})
         | 
| 69 | 
            -
                         | 
| 83 | 
            +
                        nil
         | 
| 70 84 | 
             
                      rescue StandardError => detail
         | 
| 71 85 | 
             
                        Puppet.log_exception(detail, _("Could not run %{client_class}: %{detail}") % { client_class: client_class, detail: detail })
         | 
| 72 | 
            -
                         | 
| 86 | 
            +
                        nil
         | 
| 73 87 | 
             
                      end
         | 
| 74 88 | 
             
                    end
         | 
| 75 89 | 
             
                  end
         | 
| @@ -95,11 +109,9 @@ class Puppet::Agent | |
| 95 109 | 
             
                    atForkHandler.child
         | 
| 96 110 | 
             
                    $0 = _("puppet agent: applying configuration")
         | 
| 97 111 | 
             
                    begin
         | 
| 98 | 
            -
                      exit(yield)
         | 
| 99 | 
            -
                    rescue SystemExit
         | 
| 100 | 
            -
                      exit(-1)
         | 
| 112 | 
            +
                      exit(yield || 1)
         | 
| 101 113 | 
             
                    rescue NoMemoryError
         | 
| 102 | 
            -
                      exit( | 
| 114 | 
            +
                      exit(254)
         | 
| 103 115 | 
             
                    end
         | 
| 104 116 | 
             
                  end
         | 
| 105 117 | 
             
                ensure
         | 
| @@ -107,12 +119,6 @@ class Puppet::Agent | |
| 107 119 | 
             
                end
         | 
| 108 120 |  | 
| 109 121 | 
             
                exit_code = Process.waitpid2(child_pid)
         | 
| 110 | 
            -
                case exit_code[1].exitstatus
         | 
| 111 | 
            -
                when -1
         | 
| 112 | 
            -
                  raise SystemExit
         | 
| 113 | 
            -
                when -2
         | 
| 114 | 
            -
                  raise NoMemoryError
         | 
| 115 | 
            -
                end
         | 
| 116 122 | 
             
                exit_code[1].exitstatus
         | 
| 117 123 | 
             
              end
         | 
| 118 124 |  | 
| @@ -39,6 +39,7 @@ class Puppet::Application::Agent < Puppet::Application | |
| 39 39 | 
             
                  :graph => true,
         | 
| 40 40 | 
             
                  :fingerprint => false,
         | 
| 41 41 | 
             
                  :sourceaddress => nil,
         | 
| 42 | 
            +
                  :start_time => Time.now,
         | 
| 42 43 | 
             
                }.each do |opt,val|
         | 
| 43 44 | 
             
                  options[opt] = val
         | 
| 44 45 | 
             
                end
         | 
| @@ -90,7 +91,7 @@ puppet-agent(8) -- #{summary} | |
| 90 91 |  | 
| 91 92 | 
             
            SYNOPSIS
         | 
| 92 93 | 
             
            --------
         | 
| 93 | 
            -
            Retrieves the client configuration from the  | 
| 94 | 
            +
            Retrieves the client configuration from the Puppet master and applies it to
         | 
| 94 95 | 
             
            the local host.
         | 
| 95 96 |  | 
| 96 97 | 
             
            This service may be run as a daemon, run periodically using cron (or something
         | 
| @@ -164,13 +165,15 @@ when signing certificates). | |
| 164 165 | 
             
            only resources not tagged with the specified tags will be applied.
         | 
| 165 166 | 
             
            Values must be comma-separated.
         | 
| 166 167 |  | 
| 168 | 
            +
             | 
| 167 169 | 
             
            OPTIONS
         | 
| 168 170 | 
             
            -------
         | 
| 169 171 |  | 
| 170 172 | 
             
            Note that any Puppet setting that's valid in the configuration file is also a
         | 
| 171 173 | 
             
            valid long argument. For example, 'server' is a valid setting, so you can
         | 
| 172 | 
            -
            specify '--server <servername>' as an argument. Boolean settings  | 
| 173 | 
            -
            '--setting' and '--no-setting'  | 
| 174 | 
            +
            specify '--server <servername>' as an argument. Boolean settings accept a '--no-' 
         | 
| 175 | 
            +
            prefix to turn off a behavior, translating into '--setting' and '--no-setting' 
         | 
| 176 | 
            +
            pairs, such as `--daemonize` and `--no-daemonize`.
         | 
| 174 177 |  | 
| 175 178 | 
             
            See the configuration file documentation at
         | 
| 176 179 | 
             
            https://puppet.com/docs/puppet/latest/configuration.html for the
         | 
| @@ -237,15 +240,14 @@ generated by running puppet agent with '--genconfig'. | |
| 237 240 | 
             
            * --enable:
         | 
| 238 241 | 
             
              Enable working on the local system. This removes any lock file,
         | 
| 239 242 | 
             
              causing 'puppet agent' to start managing the local system again
         | 
| 240 | 
            -
               | 
| 241 | 
            -
              not start for another half hour | 
| 243 | 
            +
              However, it continues to use its normal scheduling, so it might
         | 
| 244 | 
            +
              not start for another half hour.
         | 
| 242 245 |  | 
| 243 246 | 
             
              'puppet agent' exits after executing this.
         | 
| 244 247 |  | 
| 245 248 | 
             
            *  --evaltrace:
         | 
| 246 249 | 
             
              Logs each resource as it is being evaluated. This allows you to interactively see exactly what is being done. (This is a Puppet setting, and can go in puppet.conf. Note the special 'no-' prefix for boolean settings on the command line.)
         | 
| 247 250 |  | 
| 248 | 
            -
             | 
| 249 251 | 
             
            * --fingerprint:
         | 
| 250 252 | 
             
              Display the current certificate or certificate signing request
         | 
| 251 253 | 
             
              fingerprint and then exit. Use the '--digest' option to change the
         | 
| @@ -256,7 +258,9 @@ generated by running puppet agent with '--genconfig'. | |
| 256 258 |  | 
| 257 259 | 
             
            * --job-id:
         | 
| 258 260 | 
             
              Attach the specified job id to the catalog request and the report used for
         | 
| 259 | 
            -
              this agent run. This option only works when '--onetime' is used.
         | 
| 261 | 
            +
              this agent run. This option only works when '--onetime' is used.  When using
         | 
| 262 | 
            +
              Puppet Enterprise this flag should not be used as the orchestrator sets the
         | 
| 263 | 
            +
              job-id for you and it must be unique.
         | 
| 260 264 |  | 
| 261 265 | 
             
            * --logdest:
         | 
| 262 266 | 
             
              Where to send log messages. Choose between 'syslog' (the POSIX syslog
         | 
| @@ -278,7 +282,7 @@ generated by running puppet agent with '--genconfig'. | |
| 278 282 |  | 
| 279 283 | 
             
            * --noop:
         | 
| 280 284 | 
             
              Use 'noop' mode where the daemon runs in a no-op or dry-run mode. This
         | 
| 281 | 
            -
              is useful for seeing what changes Puppet  | 
| 285 | 
            +
              is useful for seeing what changes Puppet would make without actually
         | 
| 282 286 | 
             
              executing the changes.
         | 
| 283 287 | 
             
              (This is a Puppet setting, and can go in puppet.conf. Note the special 'no-'
         | 
| 284 288 | 
             
              prefix for boolean settings on the command line.)
         | 
| @@ -302,8 +306,6 @@ generated by running puppet agent with '--genconfig'. | |
| 302 306 | 
             
            * --trace
         | 
| 303 307 | 
             
              Prints stack traces on some errors. (This is a Puppet setting, and can go in puppet.conf. Note the special 'no-' prefix for boolean settings on the command line.)
         | 
| 304 308 |  | 
| 305 | 
            -
             | 
| 306 | 
            -
             | 
| 307 309 | 
             
            * --verbose:
         | 
| 308 310 | 
             
              Turn on verbose reporting.
         | 
| 309 311 |  | 
| @@ -317,8 +319,7 @@ generated by running puppet agent with '--genconfig'. | |
| 317 319 | 
             
              it to sign a certificate request. This is useful for the initial setup
         | 
| 318 320 | 
             
              of a puppet client. You can turn off waiting for certificates by
         | 
| 319 321 | 
             
              specifying a time of 0.
         | 
| 320 | 
            -
              (This is a Puppet setting, and can go in puppet.conf. | 
| 321 | 
            -
              prefix for boolean settings on the command line.)
         | 
| 322 | 
            +
              (This is a Puppet setting, and can go in puppet.conf.)
         | 
| 322 323 |  | 
| 323 324 |  | 
| 324 325 | 
             
            EXAMPLE
         | 
| @@ -364,8 +365,17 @@ Copyright (c) 2011 Puppet Inc., LLC Licensed under the Apache 2.0 License | |
| 364 365 | 
             
                  daemon.set_signal_traps
         | 
| 365 366 |  | 
| 366 367 | 
             
                  log_config if Puppet[:daemonize]
         | 
| 367 | 
            -
             | 
| 368 | 
            -
                   | 
| 368 | 
            +
             | 
| 369 | 
            +
                  # run ssl state machine, waiting if needed
         | 
| 370 | 
            +
                  ssl_context = wait_for_certificates
         | 
| 371 | 
            +
             | 
| 372 | 
            +
                  # Each application is responsible for pushing loaders onto the context.
         | 
| 373 | 
            +
                  # Use the current environment that has already been established, though
         | 
| 374 | 
            +
                  # it may change later during the configurer run.
         | 
| 375 | 
            +
                  env = Puppet.lookup(:current_environment)
         | 
| 376 | 
            +
                  Puppet.override(ssl_context: ssl_context,
         | 
| 377 | 
            +
                                  current_environment: env,
         | 
| 378 | 
            +
                                  loaders: Puppet::Pops::Loaders.new(env, true)) do
         | 
| 369 379 | 
             
                    if Puppet[:onetime]
         | 
| 370 380 | 
             
                      onetime(daemon)
         | 
| 371 381 | 
             
                    else
         | 
| @@ -407,7 +417,7 @@ Copyright (c) 2011 Puppet Inc., LLC Licensed under the Apache 2.0 License | |
| 407 417 |  | 
| 408 418 | 
             
              def onetime(daemon)
         | 
| 409 419 | 
             
                begin
         | 
| 410 | 
            -
                  exitstatus = daemon.agent.run(:job_id => options[:job_id])
         | 
| 420 | 
            +
                  exitstatus = daemon.agent.run({:job_id => options[:job_id], :start_time => options[:start_time]})
         | 
| 411 421 | 
             
                rescue => detail
         | 
| 412 422 | 
             
                  Puppet.log_exception(detail)
         | 
| 413 423 | 
             
                end
         | 
| @@ -490,9 +500,8 @@ Copyright (c) 2011 Puppet Inc., LLC Licensed under the Apache 2.0 License | |
| 490 500 | 
             
              end
         | 
| 491 501 |  | 
| 492 502 | 
             
              def daemonize_process_when(should_daemonize)
         | 
| 493 | 
            -
                daemon = Puppet::Daemon.new(Puppet::Util::Pidlock.new(Puppet[:pidfile]))
         | 
| 503 | 
            +
                daemon = Puppet::Daemon.new(@agent, Puppet::Util::Pidlock.new(Puppet[:pidfile]))
         | 
| 494 504 | 
             
                daemon.argv = @argv
         | 
| 495 | 
            -
                daemon.agent = @agent
         | 
| 496 505 |  | 
| 497 506 | 
             
                daemon.daemonize if should_daemonize
         | 
| 498 507 |  | 
| @@ -67,13 +67,15 @@ class TypeDoc | |
| 67 67 | 
             
                @types.keys.sort_by(&:to_s).each do |name|
         | 
| 68 68 | 
             
                  type = @types[name]
         | 
| 69 69 | 
             
                  s = type.doc.gsub(/\s+/, " ")
         | 
| 70 | 
            -
                   | 
| 71 | 
            -
                  if n.nil?
         | 
| 70 | 
            +
                  if s.empty?
         | 
| 72 71 | 
             
                    s = ".. no documentation .."
         | 
| 73 | 
            -
                  elsif n > 45
         | 
| 74 | 
            -
                    s = s[0, 45] + " ..."
         | 
| 75 72 | 
             
                  else
         | 
| 76 | 
            -
                     | 
| 73 | 
            +
                    n = s.index(".") || s.length
         | 
| 74 | 
            +
                    if n > 45
         | 
| 75 | 
            +
                      s = s[0, 45] + " ..."
         | 
| 76 | 
            +
                    else
         | 
| 77 | 
            +
                      s = s[0, n]
         | 
| 78 | 
            +
                    end
         | 
| 77 79 | 
             
                  end
         | 
| 78 80 | 
             
                  printf "%-15s - %s\n", name, s
         | 
| 79 81 | 
             
                end
         | 
| @@ -194,7 +194,7 @@ you can specify '--server  | |
| 194 194 |  | 
| 195 195 | 
             
            * --resource:
         | 
| 196 196 | 
             
              Displays a resource state as Puppet code, roughly equivalent to
         | 
| 197 | 
            -
              `puppet resource`.  Can be  | 
| 197 | 
            +
              `puppet resource`.  Can be filtered by title. Requires --target be specified.
         | 
| 198 198 |  | 
| 199 199 | 
             
            * --target:
         | 
| 200 200 | 
             
              Target a specific device/certificate in the device.conf. Doing so will perform a
         | 
| @@ -259,7 +259,7 @@ Licensed under the Apache 2.0 License | |
| 259 259 | 
             
                    end
         | 
| 260 260 | 
             
                  end
         | 
| 261 261 | 
             
                  devices.collect do |devicename,device|
         | 
| 262 | 
            -
                    pool = Puppet | 
| 262 | 
            +
                    pool = Puppet.runtime[:http].pool
         | 
| 263 263 | 
             
                    Puppet.override(:http_pool => pool) do
         | 
| 264 264 | 
             
                      # TODO when we drop support for ruby < 2.5 we can remove the extra block here
         | 
| 265 265 | 
             
                      begin
         | 
| @@ -69,6 +69,19 @@ running as a user with valid Puppet certificates. Alternatively, you can | |
| 69 69 | 
             
            use your local file bucket by specifying '--local', or by specifying
         | 
| 70 70 | 
             
            '--bucket' with a local path.
         | 
| 71 71 |  | 
| 72 | 
            +
            > **Note**: Enabling and using the backup option, and by extension the 
         | 
| 73 | 
            +
              filebucket resource, requires appropriate planning and management to ensure 
         | 
| 74 | 
            +
              that sufficient disk space is available for the file backups. Generally, you 
         | 
| 75 | 
            +
              can implement this using one of the following two options:
         | 
| 76 | 
            +
              - Use a `find` command and `crontab` entry to retain only the last X days 
         | 
| 77 | 
            +
              of file backups. For example: 
         | 
| 78 | 
            +
             | 
| 79 | 
            +
              ```shell
         | 
| 80 | 
            +
              find /opt/puppetlabs/server/data/puppetserver/bucket -type f -mtime +45 -atime +45 -print0 | xargs -0 rm
         | 
| 81 | 
            +
              ```
         | 
| 82 | 
            +
             | 
| 83 | 
            +
              - Restrict the directory to a maximum size after which the oldest items are removed.
         | 
| 84 | 
            +
             | 
| 72 85 |  | 
| 73 86 | 
             
            OPTIONS
         | 
| 74 87 | 
             
            -------
         | 
| @@ -108,7 +121,7 @@ configuration options can also be generated by running puppet with | |
| 108 121 | 
             
              by default.
         | 
| 109 122 |  | 
| 110 123 | 
             
            * --server_list:
         | 
| 111 | 
            -
              A list of comma  | 
| 124 | 
            +
              A list of comma separated servers; only the first entry is used for file storage.
         | 
| 112 125 | 
             
              This setting takes precidence over `server`.
         | 
| 113 126 |  | 
| 114 127 | 
             
            * --server:
         | 
| @@ -279,7 +292,7 @@ Copyright (c) 2011 Puppet Inc., LLC Licensed under the Apache 2.0 License | |
| 279 292 | 
             
                  Puppet::Log.level = :info
         | 
| 280 293 | 
             
                end
         | 
| 281 294 |  | 
| 282 | 
            -
             | 
| 295 | 
            +
                exit(Puppet.settings.print_configs ? 0 : 1) if Puppet.settings.print_configs?
         | 
| 283 296 |  | 
| 284 297 | 
             
                require 'puppet/file_bucket/dipper'
         | 
| 285 298 | 
             
                begin
         | 
| @@ -287,19 +300,10 @@ Copyright (c) 2011 Puppet Inc., LLC Licensed under the Apache 2.0 License | |
| 287 300 | 
             
                    path = options[:bucket] || Puppet[:clientbucketdir]
         | 
| 288 301 | 
             
                    @client = Puppet::FileBucket::Dipper.new(:Path => path)
         | 
| 289 302 | 
             
                  else
         | 
| 290 | 
            -
                     | 
| 291 | 
            -
             | 
| 292 | 
            -
             | 
| 293 | 
            -
             | 
| 294 | 
            -
                      @client = Puppet::FileBucket::Dipper.new(
         | 
| 295 | 
            -
                        :Server => server[0],
         | 
| 296 | 
            -
                        :Port => server[1]
         | 
| 297 | 
            -
                      )
         | 
| 298 | 
            -
                    else
         | 
| 299 | 
            -
                      #TRANSLATORS 'server' is the name of a setting and should not be translated
         | 
| 300 | 
            -
                      Puppet.debug _("Selected server from the `server` setting: %{server}") % {server: Puppet[:server]}
         | 
| 301 | 
            -
                      @client = Puppet::FileBucket::Dipper.new(:Server => Puppet[:server])
         | 
| 302 | 
            -
                    end
         | 
| 303 | 
            +
                    session = Puppet.lookup(:http_session)
         | 
| 304 | 
            +
                    api = session.route_to(:puppet)
         | 
| 305 | 
            +
             | 
| 306 | 
            +
                    @client = Puppet::FileBucket::Dipper.new(Server: api.url.host, Port: api.url.port)
         | 
| 303 307 | 
             
                  end
         | 
| 304 308 | 
             
                rescue => detail
         | 
| 305 309 | 
             
                  Puppet.log_exception(detail)
         | 
| @@ -28,7 +28,7 @@ OPTIONS | |
| 28 28 | 
             
            -------
         | 
| 29 29 |  | 
| 30 30 | 
             
            * --help:
         | 
| 31 | 
            -
              Print this help  | 
| 31 | 
            +
              Print this help message.
         | 
| 32 32 |  | 
| 33 33 | 
             
            * --verbose:
         | 
| 34 34 | 
             
              Print extra information.
         | 
| @@ -90,7 +90,7 @@ HELP | |
| 90 90 | 
             
                @cert_provider = Puppet::X509::CertProvider.new
         | 
| 91 91 | 
             
                @ssl_provider = Puppet::SSL::SSLProvider.new
         | 
| 92 92 | 
             
                @machine = Puppet::SSL::StateMachine.new
         | 
| 93 | 
            -
                @session = Puppet.runtime[ | 
| 93 | 
            +
                @session = Puppet.runtime[:http].create_session
         | 
| 94 94 | 
             
              end
         | 
| 95 95 |  | 
| 96 96 | 
             
              def setup_logs
         | 
| @@ -182,7 +182,7 @@ HELP | |
| 182 182 | 
             
                route = create_route(ssl_context)
         | 
| 183 183 | 
             
                Puppet.info _("Downloading certificate '%{name}' from %{url}") % { name: Puppet[:certname], url: route.url }
         | 
| 184 184 |  | 
| 185 | 
            -
                x509 = route.get_certificate(Puppet[:certname], ssl_context: ssl_context)
         | 
| 185 | 
            +
                _, x509 = route.get_certificate(Puppet[:certname], ssl_context: ssl_context)
         | 
| 186 186 | 
             
                cert = OpenSSL::X509::Certificate.new(x509)
         | 
| 187 187 | 
             
                Puppet.notice _("Downloaded certificate '%{name}' with fingerprint %{fingerprint}") % { name: Puppet[:certname], fingerprint: fingerprint(cert) }
         | 
| 188 188 |  | 
| @@ -226,7 +226,7 @@ HELP | |
| 226 226 | 
             
                  begin
         | 
| 227 227 | 
             
                    ssl_context = @machine.ensure_ca_certificates
         | 
| 228 228 | 
             
                    route = create_route(ssl_context)
         | 
| 229 | 
            -
                    cert = route.get_certificate(certname, ssl_context: ssl_context)
         | 
| 229 | 
            +
                    _, cert = route.get_certificate(certname, ssl_context: ssl_context)
         | 
| 230 230 | 
             
                  rescue Puppet::HTTP::ResponseError => e
         | 
| 231 231 | 
             
                    if e.response.code.to_i != 404
         | 
| 232 232 | 
             
                      raise Puppet::Error.new(_("Failed to connect to the CA to determine if certificate %{certname} has been cleaned") % { certname: certname }, e)
         | 
    
        data/lib/puppet/configurer.rb
    CHANGED
    
    | @@ -1,7 +1,5 @@ | |
| 1 1 | 
             
            # The client for interacting with the puppetmaster config server.
         | 
| 2 | 
            -
            require 'sync'
         | 
| 3 2 | 
             
            require 'timeout'
         | 
| 4 | 
            -
            require 'puppet/network/http_pool'
         | 
| 5 3 | 
             
            require 'puppet/util'
         | 
| 6 4 | 
             
            require 'securerandom'
         | 
| 7 5 | 
             
            #require 'puppet/parser/script_compiler'
         | 
| @@ -65,7 +63,7 @@ class Puppet::Configurer | |
| 65 63 | 
             
              end
         | 
| 66 64 |  | 
| 67 65 | 
             
              # Get the remote catalog, yo.  Returns nil if no catalog can be found.
         | 
| 68 | 
            -
              def retrieve_catalog(query_options)
         | 
| 66 | 
            +
              def retrieve_catalog(facts, query_options)
         | 
| 69 67 | 
             
                query_options ||= {}
         | 
| 70 68 | 
             
                result = retrieve_catalog_from_cache(query_options) if Puppet[:use_cached_catalog]
         | 
| 71 69 | 
             
                if result
         | 
| @@ -73,7 +71,7 @@ class Puppet::Configurer | |
| 73 71 |  | 
| 74 72 | 
             
                  Puppet.info _("Using cached catalog from environment '%{environment}'") % { environment: result.environment }
         | 
| 75 73 | 
             
                else
         | 
| 76 | 
            -
                  result = retrieve_new_catalog(query_options)
         | 
| 74 | 
            +
                  result = retrieve_new_catalog(facts, query_options)
         | 
| 77 75 |  | 
| 78 76 | 
             
                  if !result
         | 
| 79 77 | 
             
                    if !Puppet[:usecacheonfailure]
         | 
| @@ -100,12 +98,11 @@ class Puppet::Configurer | |
| 100 98 | 
             
              end
         | 
| 101 99 |  | 
| 102 100 | 
             
              # Convert a plain resource catalog into our full host catalog.
         | 
| 103 | 
            -
              def convert_catalog(result, duration, options = {})
         | 
| 101 | 
            +
              def convert_catalog(result, duration, facts, options = {})
         | 
| 104 102 | 
             
                catalog = nil
         | 
| 105 103 |  | 
| 106 104 | 
             
                catalog_conversion_time = thinmark do
         | 
| 107 105 | 
             
                  # Will mutate the result and replace all Deferred values with resolved values
         | 
| 108 | 
            -
                  facts = options[:convert_with_facts]
         | 
| 109 106 | 
             
                  if facts
         | 
| 110 107 | 
             
                    Puppet::Pops::Evaluator::DeferredResolver.resolve_and_replace(facts, result)
         | 
| 111 108 | 
             
                  end
         | 
| @@ -134,6 +131,7 @@ class Puppet::Configurer | |
| 134 131 | 
             
                end
         | 
| 135 132 |  | 
| 136 133 | 
             
                facts_hash = {}
         | 
| 134 | 
            +
                facts = nil
         | 
| 137 135 | 
             
                if Puppet::Resource::Catalog.indirection.terminus_class == :rest
         | 
| 138 136 | 
             
                  # This is a bit complicated.  We need the serialized and escaped facts,
         | 
| 139 137 | 
             
                  # and we need to know which format they're encoded in.  Thus, we
         | 
| @@ -142,15 +140,14 @@ class Puppet::Configurer | |
| 142 140 | 
             
                  # facts_for_uploading may set Puppet[:node_name_value] as a side effect
         | 
| 143 141 | 
             
                  facter_time = thinmark do
         | 
| 144 142 | 
             
                    facts = find_facts
         | 
| 145 | 
            -
                    options[:convert_with_facts] =  facts
         | 
| 146 143 | 
             
                    facts_hash = encode_facts(facts) # encode for uploading # was: facts_for_uploading
         | 
| 147 144 | 
             
                  end
         | 
| 148 145 | 
             
                  options[:report].add_times(:fact_generation, facter_time) if options[:report]
         | 
| 149 146 | 
             
                end
         | 
| 150 | 
            -
                facts_hash
         | 
| 147 | 
            +
                [facts_hash, facts]
         | 
| 151 148 | 
             
              end
         | 
| 152 149 |  | 
| 153 | 
            -
              def prepare_and_retrieve_catalog(cached_catalog, options, query_options)
         | 
| 150 | 
            +
              def prepare_and_retrieve_catalog(cached_catalog, facts, options, query_options)
         | 
| 154 151 | 
             
                # set report host name now that we have the fact
         | 
| 155 152 | 
             
                options[:report].host = Puppet[:node_name_value]
         | 
| 156 153 |  | 
| @@ -166,7 +163,7 @@ class Puppet::Configurer | |
| 166 163 | 
             
                catalog = cached_catalog || options[:catalog]
         | 
| 167 164 | 
             
                unless catalog
         | 
| 168 165 | 
             
                  # retrieve_catalog returns resource catalog
         | 
| 169 | 
            -
                  catalog = retrieve_catalog(query_options)
         | 
| 166 | 
            +
                  catalog = retrieve_catalog(facts, query_options)
         | 
| 170 167 | 
             
                  Puppet.err _("Could not retrieve catalog; skipping run") unless catalog
         | 
| 171 168 | 
             
                end
         | 
| 172 169 | 
             
                catalog
         | 
| @@ -197,12 +194,12 @@ class Puppet::Configurer | |
| 197 194 | 
             
              # This just passes any options on to the catalog,
         | 
| 198 195 | 
             
              # which accepts :tags and :ignoreschedules.
         | 
| 199 196 | 
             
              def run(options = {})
         | 
| 200 | 
            -
                pool = Puppet | 
| 197 | 
            +
                pool = Puppet.runtime[:http].pool
         | 
| 201 198 | 
             
                # We create the report pre-populated with default settings for
         | 
| 202 199 | 
             
                # environment and transaction_uuid very early, this is to ensure
         | 
| 203 200 | 
             
                # they are sent regardless of any catalog compilation failures or
         | 
| 204 201 | 
             
                # exceptions.
         | 
| 205 | 
            -
                options[:report] ||= Puppet::Transaction::Report.new(nil, @environment, @transaction_uuid, @job_id)
         | 
| 202 | 
            +
                options[:report] ||= Puppet::Transaction::Report.new(nil, @environment, @transaction_uuid, @job_id, options[:start_time] || Time.now)
         | 
| 206 203 | 
             
                report = options[:report]
         | 
| 207 204 | 
             
                init_storage
         | 
| 208 205 |  | 
| @@ -211,13 +208,9 @@ class Puppet::Configurer | |
| 211 208 | 
             
                completed = nil
         | 
| 212 209 | 
             
                begin
         | 
| 213 210 | 
             
                  Puppet.override(:http_pool => pool) do
         | 
| 214 | 
            -
             | 
| 215 211 | 
             
                    # Skip failover logic if the server_list setting is empty
         | 
| 216 | 
            -
                     | 
| 217 | 
            -
             | 
| 218 | 
            -
                    else
         | 
| 219 | 
            -
                      do_failover = true
         | 
| 220 | 
            -
                    end
         | 
| 212 | 
            +
                    do_failover = Puppet.settings[:server_list] && !Puppet.settings[:server_list].empty?
         | 
| 213 | 
            +
             | 
| 221 214 | 
             
                    # When we are passed a catalog, that means we're in apply
         | 
| 222 215 | 
             
                    # mode. We shouldn't try to do any failover in that case.
         | 
| 223 216 | 
             
                    if options[:catalog].nil? && do_failover
         | 
| @@ -225,8 +218,6 @@ class Puppet::Configurer | |
| 225 218 | 
             
                      if server.nil?
         | 
| 226 219 | 
             
                        raise Puppet::Error, _("Could not select a functional puppet master from server_list: '%{server_list}'") % { server_list: Puppet.settings.value(:server_list, Puppet[:environment].to_sym, true) }
         | 
| 227 220 | 
             
                      else
         | 
| 228 | 
            -
                        #TRANSLATORS 'server_list' is the name of a setting and should not be translated
         | 
| 229 | 
            -
                        Puppet.debug _("Selected puppet server from the `server_list` setting: %{server}:%{port}") % { server: server, port: port }
         | 
| 230 221 | 
             
                        report.master_used = "#{server}:#{port}"
         | 
| 231 222 | 
             
                      end
         | 
| 232 223 | 
             
                      Puppet.override(server: server, serverport: port) do
         | 
| @@ -244,9 +235,13 @@ class Puppet::Configurer | |
| 244 235 | 
             
              end
         | 
| 245 236 |  | 
| 246 237 | 
             
              def run_internal(options)
         | 
| 247 | 
            -
                start = Time.now
         | 
| 248 238 | 
             
                report = options[:report]
         | 
| 249 239 |  | 
| 240 | 
            +
                if options[:start_time]
         | 
| 241 | 
            +
                  startup_time = Time.now - options[:start_time]
         | 
| 242 | 
            +
                  report.add_times(:startup_time, startup_time)
         | 
| 243 | 
            +
                end
         | 
| 244 | 
            +
             | 
| 250 245 | 
             
                # If a cached catalog is explicitly requested, attempt to retrieve it. Skip the node request,
         | 
| 251 246 | 
             
                # don't pluginsync and switch to the catalog's environment if we successfully retrieve it.
         | 
| 252 247 | 
             
                if Puppet[:use_cached_catalog]
         | 
| @@ -274,7 +269,7 @@ class Puppet::Configurer | |
| 274 269 |  | 
| 275 270 | 
             
                begin
         | 
| 276 271 | 
             
                  unless Puppet[:node_name_fact].empty?
         | 
| 277 | 
            -
                    query_options = get_facts(options)
         | 
| 272 | 
            +
                    query_options, facts = get_facts(options)
         | 
| 278 273 | 
             
                  end
         | 
| 279 274 |  | 
| 280 275 | 
             
                  configured_environment = Puppet[:environment] if Puppet.settings.set_by_config?(:environment)
         | 
| @@ -307,6 +302,16 @@ class Puppet::Configurer | |
| 307 302 | 
             
                          @environment = node.environment.to_s
         | 
| 308 303 | 
             
                          report.environment = @environment
         | 
| 309 304 | 
             
                          query_options = nil
         | 
| 305 | 
            +
                          facts = nil
         | 
| 306 | 
            +
             | 
| 307 | 
            +
                          new_env = Puppet::Node::Environment.remote(@environment)
         | 
| 308 | 
            +
                          Puppet.push_context(
         | 
| 309 | 
            +
                            {
         | 
| 310 | 
            +
                              current_environment: new_env,
         | 
| 311 | 
            +
                              loaders: Puppet::Pops::Loaders.new(new_env, true)
         | 
| 312 | 
            +
                            },
         | 
| 313 | 
            +
                            "Local node environment #{@environment} for configurer transaction"
         | 
| 314 | 
            +
                          )
         | 
| 310 315 | 
             
                        else
         | 
| 311 316 | 
             
                          Puppet.info _("Using configured environment '%{env}'") % { env: @environment }
         | 
| 312 317 | 
             
                        end
         | 
| @@ -317,25 +322,24 @@ class Puppet::Configurer | |
| 317 322 | 
             
                    end
         | 
| 318 323 | 
             
                  end
         | 
| 319 324 |  | 
| 320 | 
            -
                   | 
| 321 | 
            -
                   | 
| 322 | 
            -
             | 
| 323 | 
            -
             | 
| 324 | 
            -
                     | 
| 325 | 
            -
             | 
| 326 | 
            -
             | 
| 327 | 
            -
             | 
| 325 | 
            +
                  # This is to maintain compatibility with anyone using this class
         | 
| 326 | 
            +
                  # aside from agent, apply, device.
         | 
| 327 | 
            +
                  unless Puppet.lookup(:loaders) { nil }
         | 
| 328 | 
            +
                    new_env = Puppet::Node::Environment.remote(@environment)
         | 
| 329 | 
            +
                    Puppet.push_context(
         | 
| 330 | 
            +
                      {
         | 
| 331 | 
            +
                        current_environment: new_env,
         | 
| 332 | 
            +
                        loaders: Puppet::Pops::Loaders.new(new_env, true)
         | 
| 333 | 
            +
                      },
         | 
| 334 | 
            +
                      "Local node environment #{@environment} for configurer transaction"
         | 
| 335 | 
            +
                    )
         | 
| 328 336 | 
             
                  end
         | 
| 329 | 
            -
                  Puppet.push_context({
         | 
| 330 | 
            -
                    :current_environment => local_node_environment, 
         | 
| 331 | 
            -
                    :loaders => Puppet::Pops::Loaders.new(local_node_environment, true)
         | 
| 332 | 
            -
                  }, "Local node environment for configurer transaction")
         | 
| 333 337 |  | 
| 334 | 
            -
                  query_options = get_facts(options) unless query_options
         | 
| 338 | 
            +
                  query_options, facts = get_facts(options) unless query_options
         | 
| 335 339 | 
             
                  query_options[:configured_environment] = configured_environment
         | 
| 336 340 | 
             
                  options[:convert_for_node] = node
         | 
| 337 341 |  | 
| 338 | 
            -
                  catalog = prepare_and_retrieve_catalog(cached_catalog, options, query_options)
         | 
| 342 | 
            +
                  catalog = prepare_and_retrieve_catalog(cached_catalog, facts, options, query_options)
         | 
| 339 343 | 
             
                  unless catalog
         | 
| 340 344 | 
             
                    return nil
         | 
| 341 345 | 
             
                  end
         | 
| @@ -358,11 +362,11 @@ class Puppet::Configurer | |
| 358 362 | 
             
                    @environment = catalog.environment
         | 
| 359 363 | 
             
                    report.environment = @environment
         | 
| 360 364 |  | 
| 361 | 
            -
                    query_options = get_facts(options)
         | 
| 365 | 
            +
                    query_options, facts = get_facts(options)
         | 
| 362 366 | 
             
                    query_options[:configured_environment] = configured_environment
         | 
| 363 367 |  | 
| 364 368 | 
             
                    # if we get here, ignore the cached catalog
         | 
| 365 | 
            -
                    catalog = prepare_and_retrieve_catalog(nil, options, query_options)
         | 
| 369 | 
            +
                    catalog = prepare_and_retrieve_catalog(nil, facts, options, query_options)
         | 
| 366 370 | 
             
                    return nil unless catalog
         | 
| 367 371 | 
             
                    tries += 1
         | 
| 368 372 | 
             
                  end
         | 
| @@ -374,7 +378,7 @@ class Puppet::Configurer | |
| 374 378 | 
             
                  else
         | 
| 375 379 | 
             
                    # REMIND @duration is the time spent loading the last catalog, and doesn't
         | 
| 376 380 | 
             
                    # account for things like we failed to download and fell back to the cache
         | 
| 377 | 
            -
                    ral_catalog = convert_catalog(catalog, @duration, options)
         | 
| 381 | 
            +
                    ral_catalog = convert_catalog(catalog, @duration, facts, options)
         | 
| 378 382 |  | 
| 379 383 | 
             
                    # If not noop, commit the cached resource catalog (not ral catalog). Ideally
         | 
| 380 384 | 
             
                    # we'd just copy the downloaded response body, instead of serializing the
         | 
| @@ -410,7 +414,7 @@ class Puppet::Configurer | |
| 410 414 | 
             
                end
         | 
| 411 415 |  | 
| 412 416 | 
             
                report.cached_catalog_status ||= @cached_catalog_status
         | 
| 413 | 
            -
                report.add_times(:total, Time.now -  | 
| 417 | 
            +
                report.add_times(:total, Time.now - report.time)
         | 
| 414 418 | 
             
                report.finalize_report
         | 
| 415 419 | 
             
                Puppet::Util::Log.close(report)
         | 
| 416 420 | 
             
                send_report(report)
         | 
| @@ -419,21 +423,16 @@ class Puppet::Configurer | |
| 419 423 | 
             
              private :run_internal
         | 
| 420 424 |  | 
| 421 425 | 
             
              def find_functional_server
         | 
| 422 | 
            -
                 | 
| 423 | 
            -
                   | 
| 424 | 
            -
                   | 
| 425 | 
            -
                   | 
| 426 | 
            -
             | 
| 427 | 
            -
             | 
| 428 | 
            -
             | 
| 429 | 
            -
             | 
| 430 | 
            -
             | 
| 431 | 
            -
             | 
| 432 | 
            -
                                 { host: host, port: port, code: response.code, reason: response.message })
         | 
| 433 | 
            -
                  rescue => detail
         | 
| 434 | 
            -
                    #TRANSLATORS 'server_list' is the name of a setting and should not be translated
         | 
| 435 | 
            -
                    Puppet.debug _("Unable to connect to server from server_list setting: %{detail}") % {detail: detail}
         | 
| 436 | 
            -
                  end
         | 
| 426 | 
            +
                begin
         | 
| 427 | 
            +
                  session = Puppet.lookup(:http_session)
         | 
| 428 | 
            +
                  service = session.route_to(:puppet)
         | 
| 429 | 
            +
                  return [service.url.host, service.url.port]
         | 
| 430 | 
            +
                rescue Puppet::HTTP::ResponseError => e
         | 
| 431 | 
            +
                  Puppet.debug(_("Puppet server %{host}:%{port} is unavailable: %{code} %{reason}") %
         | 
| 432 | 
            +
                               { host: e.response.url.host, port: e.response.url.port, code: e.response.code, reason: e.response.reason })
         | 
| 433 | 
            +
                rescue => detail
         | 
| 434 | 
            +
                  #TRANSLATORS 'server_list' is the name of a setting and should not be translated
         | 
| 435 | 
            +
                  Puppet.debug _("Unable to connect to server from server_list setting: %{detail}") % {detail: detail}
         | 
| 437 436 | 
             
                end
         | 
| 438 437 | 
             
                [nil, nil]
         | 
| 439 438 | 
             
              end
         | 
| @@ -468,21 +467,17 @@ class Puppet::Configurer | |
| 468 467 | 
             
                ::Facter.clear
         | 
| 469 468 | 
             
                facts = find_facts
         | 
| 470 469 |  | 
| 471 | 
            -
                 | 
| 472 | 
            -
                 | 
| 473 | 
            -
             | 
| 470 | 
            +
                client = Puppet.runtime[:http]
         | 
| 471 | 
            +
                session = client.create_session
         | 
| 472 | 
            +
                puppet = session.route_to(:puppet)
         | 
| 474 473 |  | 
| 475 | 
            -
             | 
| 476 | 
            -
             | 
| 477 | 
            -
             | 
| 478 | 
            -
                                server: server})
         | 
| 474 | 
            +
                Puppet.info(_("Uploading facts for %{node} to %{server}") % {
         | 
| 475 | 
            +
                              node: facts.name,
         | 
| 476 | 
            +
                              server: puppet.url.hostname})
         | 
| 479 477 |  | 
| 480 | 
            -
             | 
| 478 | 
            +
                puppet.put_facts(facts.name, facts: facts, environment: Puppet.lookup(:current_environment).name.to_s)
         | 
| 481 479 |  | 
| 482 | 
            -
             | 
| 483 | 
            -
                ensure
         | 
| 484 | 
            -
                  Puppet::Node::Facts.indirection.terminus_class = saved_fact_terminus
         | 
| 485 | 
            -
                end
         | 
| 480 | 
            +
                return true
         | 
| 486 481 | 
             
              rescue => detail
         | 
| 487 482 | 
             
                Puppet.log_exception(detail, _("Failed to submit facts: %{detail}") %
         | 
| 488 483 | 
             
                                             { detail: detail })
         | 
| @@ -521,7 +516,7 @@ class Puppet::Configurer | |
| 521 516 | 
             
                return nil
         | 
| 522 517 | 
             
              end
         | 
| 523 518 |  | 
| 524 | 
            -
              def retrieve_new_catalog(query_options)
         | 
| 519 | 
            +
              def retrieve_new_catalog(facts, query_options)
         | 
| 525 520 | 
             
                result = nil
         | 
| 526 521 | 
             
                @duration = thinmark do
         | 
| 527 522 | 
             
                  result = Puppet::Resource::Catalog.indirection.find(
         | 
| @@ -531,7 +526,8 @@ class Puppet::Configurer | |
| 531 526 | 
             
                      # don't update cache until after environment converges
         | 
| 532 527 | 
             
                      :ignore_cache_save => true,
         | 
| 533 528 | 
             
                      :environment       => Puppet::Node::Environment.remote(@environment),
         | 
| 534 | 
            -
                      :fail_on_404       => true
         | 
| 529 | 
            +
                      :fail_on_404       => true,
         | 
| 530 | 
            +
                      :facts_for_catalog => facts
         | 
| 535 531 | 
             
                    )
         | 
| 536 532 | 
             
                  )
         | 
| 537 533 | 
             
                end
         |