puppet 6.24.0-x64-mingw32 → 7.0.0-x64-mingw32
Sign up to get free protection for your applications and to get access to all the features.
Potentially problematic release.
This version of puppet might be problematic. Click here for more details.
- checksums.yaml +4 -4
- data/CODEOWNERS +16 -2
- data/CONTRIBUTING.md +5 -5
- data/Gemfile +1 -3
- data/Gemfile.lock +35 -47
- data/README.md +5 -5
- data/conf/fileserver.conf +5 -10
- data/ext/build_defaults.yaml +1 -1
- data/ext/osx/file_mapping.yaml +0 -5
- data/ext/osx/puppet.plist +0 -2
- data/ext/project_data.yaml +1 -15
- data/ext/redhat/puppet.spec.erb +0 -1
- data/ext/windows/service/daemon.rb +6 -5
- data/install.rb +21 -17
- data/lib/puppet.rb +14 -23
- data/lib/puppet/application.rb +178 -108
- data/lib/puppet/application/agent.rb +4 -12
- data/lib/puppet/application/apply.rb +2 -4
- data/lib/puppet/application/device.rb +100 -106
- data/lib/puppet/application/filebucket.rb +13 -10
- data/lib/puppet/application/resource.rb +3 -17
- data/lib/puppet/application/script.rb +0 -2
- data/lib/puppet/application/ssl.rb +1 -13
- data/lib/puppet/application_support.rb +0 -7
- data/lib/puppet/configurer.rb +30 -45
- data/lib/puppet/configurer/downloader.rb +1 -2
- data/lib/puppet/configurer/plugin_handler.rb +21 -19
- data/lib/puppet/defaults.rb +100 -192
- data/lib/puppet/environments.rb +60 -84
- data/lib/puppet/face/facts.rb +5 -103
- data/lib/puppet/face/help.rb +1 -1
- data/lib/puppet/face/help/action.erb +0 -1
- data/lib/puppet/face/help/face.erb +0 -1
- data/lib/puppet/face/node/clean.rb +0 -11
- data/lib/puppet/face/plugin.rb +5 -8
- data/lib/puppet/ffi/windows.rb +12 -0
- data/lib/puppet/ffi/windows/api_types.rb +311 -0
- data/lib/puppet/ffi/windows/constants.rb +404 -0
- data/lib/puppet/ffi/windows/functions.rb +628 -0
- data/lib/puppet/ffi/windows/structs.rb +338 -0
- data/lib/puppet/file_serving/configuration.rb +0 -5
- data/lib/puppet/file_serving/configuration/parser.rb +3 -32
- data/lib/puppet/file_serving/fileset.rb +2 -14
- data/lib/puppet/file_serving/http_metadata.rb +1 -1
- data/lib/puppet/file_serving/mount.rb +1 -2
- data/lib/puppet/file_system/file_impl.rb +1 -1
- data/lib/puppet/file_system/memory_file.rb +1 -8
- data/lib/puppet/file_system/windows.rb +2 -4
- data/lib/puppet/forge.rb +3 -3
- data/lib/puppet/forge/repository.rb +0 -1
- data/lib/puppet/functions/all.rb +1 -1
- data/lib/puppet/functions/camelcase.rb +1 -1
- data/lib/puppet/functions/capitalize.rb +2 -2
- data/lib/puppet/functions/downcase.rb +2 -2
- data/lib/puppet/functions/empty.rb +0 -8
- data/lib/puppet/functions/get.rb +5 -5
- data/lib/puppet/functions/group_by.rb +5 -13
- data/lib/puppet/functions/lest.rb +1 -1
- data/lib/puppet/functions/new.rb +100 -100
- data/lib/puppet/functions/partition.rb +4 -12
- data/lib/puppet/functions/require.rb +5 -5
- data/lib/puppet/functions/sort.rb +3 -3
- data/lib/puppet/functions/strftime.rb +0 -1
- data/lib/puppet/functions/tree_each.rb +9 -7
- data/lib/puppet/functions/type.rb +4 -4
- data/lib/puppet/functions/unwrap.rb +2 -17
- data/lib/puppet/functions/upcase.rb +2 -2
- data/lib/puppet/generate/models/type/type.rb +4 -1
- data/lib/puppet/http.rb +22 -13
- data/lib/puppet/http/client.rb +164 -114
- data/lib/puppet/{network/resolver.rb → http/dns.rb} +2 -2
- data/lib/puppet/http/errors.rb +16 -0
- data/lib/puppet/http/external_client.rb +5 -7
- data/lib/puppet/{network/http → http}/factory.rb +8 -15
- data/lib/puppet/{network/http → http}/pool.rb +61 -26
- data/lib/puppet/{network/http/session.rb → http/pool_entry.rb} +2 -3
- data/lib/puppet/http/proxy.rb +137 -0
- data/lib/puppet/http/redirector.rb +4 -12
- data/lib/puppet/http/resolver.rb +5 -15
- data/lib/puppet/http/resolver/server_list.rb +10 -25
- data/lib/puppet/http/resolver/settings.rb +4 -7
- data/lib/puppet/http/resolver/srv.rb +7 -11
- data/lib/puppet/http/response.rb +36 -54
- data/lib/puppet/http/response_converter.rb +24 -0
- data/lib/puppet/http/response_net_http.rb +42 -0
- data/lib/puppet/http/retry_after_handler.rb +4 -13
- data/lib/puppet/http/service.rb +12 -26
- data/lib/puppet/http/service/ca.rb +11 -22
- data/lib/puppet/http/service/compiler.rb +22 -138
- data/lib/puppet/http/service/file_server.rb +19 -29
- data/lib/puppet/http/service/puppetserver.rb +26 -12
- data/lib/puppet/http/service/report.rb +8 -10
- data/lib/puppet/http/session.rb +11 -20
- data/lib/puppet/{network/http → http}/site.rb +1 -2
- data/lib/puppet/indirector/catalog/compiler.rb +0 -1
- data/lib/puppet/indirector/catalog/rest.rb +2 -4
- data/lib/puppet/indirector/facts/rest.rb +3 -22
- data/lib/puppet/indirector/file_bucket_file/rest.rb +3 -9
- data/lib/puppet/indirector/file_content/rest.rb +2 -6
- data/lib/puppet/indirector/file_metadata/rest.rb +3 -10
- data/lib/puppet/indirector/file_server.rb +1 -8
- data/lib/puppet/indirector/generic_http.rb +0 -11
- data/lib/puppet/indirector/node/rest.rb +2 -4
- data/lib/puppet/indirector/report/rest.rb +3 -8
- data/lib/puppet/indirector/request.rb +0 -101
- data/lib/puppet/indirector/resource/ral.rb +1 -6
- data/lib/puppet/indirector/rest.rb +12 -263
- data/lib/puppet/interface/documentation.rb +0 -1
- data/lib/puppet/module_tool/applications.rb +0 -1
- data/lib/puppet/module_tool/applications/installer.rb +2 -52
- data/lib/puppet/module_tool/errors/shared.rb +2 -34
- data/lib/puppet/network/authconfig.rb +2 -96
- data/lib/puppet/network/authorization.rb +13 -35
- data/lib/puppet/network/formats.rb +0 -67
- data/lib/puppet/network/http.rb +3 -3
- data/lib/puppet/network/http/api/indirected_routes.rb +2 -20
- data/lib/puppet/network/http/api/master/v3.rb +11 -13
- data/lib/puppet/network/http/connection.rb +247 -316
- data/lib/puppet/network/http/handler.rb +0 -1
- data/lib/puppet/network/http_pool.rb +16 -34
- data/lib/puppet/node.rb +1 -30
- data/lib/puppet/pal/json_catalog_encoder.rb +4 -0
- data/lib/puppet/pal/pal_impl.rb +3 -1
- data/lib/puppet/parser/ast/leaf.rb +2 -3
- data/lib/puppet/parser/ast/pops_bridge.rb +0 -38
- data/lib/puppet/parser/compiler.rb +0 -198
- data/lib/puppet/parser/compiler/catalog_validator/relationship_validator.rb +14 -39
- data/lib/puppet/parser/functions/fqdn_rand.rb +6 -14
- data/lib/puppet/parser/resource.rb +0 -69
- data/lib/puppet/parser/templatewrapper.rb +1 -1
- data/lib/puppet/pops/evaluator/deferred_resolver.rb +3 -5
- data/lib/puppet/pops/evaluator/evaluator_impl.rb +0 -5
- data/lib/puppet/pops/evaluator/runtime3_resource_support.rb +3 -3
- data/lib/puppet/pops/evaluator/runtime3_support.rb +1 -1
- data/lib/puppet/pops/issues.rb +0 -5
- data/lib/puppet/pops/loader/ruby_legacy_function_instantiator.rb +6 -8
- data/lib/puppet/pops/model/ast.pp +0 -42
- data/lib/puppet/pops/model/ast.rb +0 -290
- data/lib/puppet/pops/model/ast_transformer.rb +1 -1
- data/lib/puppet/pops/model/factory.rb +0 -45
- data/lib/puppet/pops/model/model_label_provider.rb +0 -5
- data/lib/puppet/pops/model/model_tree_dumper.rb +0 -22
- data/lib/puppet/pops/model/pn_transformer.rb +0 -16
- data/lib/puppet/pops/parser/egrammar.ra +0 -56
- data/lib/puppet/pops/parser/eparser.rb +1520 -1712
- data/lib/puppet/pops/parser/lexer2.rb +4 -4
- data/lib/puppet/pops/parser/parser_support.rb +0 -5
- data/lib/puppet/pops/resource/resource_type_impl.rb +2 -24
- data/lib/puppet/pops/types/p_sem_ver_type.rb +2 -8
- data/lib/puppet/pops/types/p_sensitive_type.rb +0 -10
- data/lib/puppet/pops/types/type_calculator.rb +0 -7
- data/lib/puppet/pops/types/type_mismatch_describer.rb +1 -1
- data/lib/puppet/pops/types/type_parser.rb +0 -4
- data/lib/puppet/pops/types/types.rb +0 -1
- data/lib/puppet/pops/validation/checker4_0.rb +9 -37
- data/lib/puppet/pops/validation/tasks_checker.rb +0 -12
- data/lib/puppet/pops/validation/validator_factory_4_0.rb +1 -2
- data/lib/puppet/property/list.rb +1 -1
- data/lib/puppet/provider.rb +0 -13
- data/lib/puppet/provider/exec/posix.rb +4 -16
- data/lib/puppet/provider/group/groupadd.rb +8 -13
- data/lib/puppet/provider/nameservice.rb +0 -18
- data/lib/puppet/provider/package/apt.rb +2 -34
- data/lib/puppet/provider/package/aptitude.rb +0 -6
- data/lib/puppet/provider/package/dnfmodule.rb +1 -1
- data/lib/puppet/provider/package/dpkg.rb +0 -10
- data/lib/puppet/provider/package/gem.rb +23 -3
- data/lib/puppet/provider/package/nim.rb +6 -11
- data/lib/puppet/provider/package/pip.rb +3 -16
- data/lib/puppet/provider/package/pkg.rb +0 -4
- data/lib/puppet/provider/package/portage.rb +1 -1
- data/lib/puppet/provider/package/puppet_gem.rb +1 -4
- data/lib/puppet/provider/parsedfile.rb +0 -3
- data/lib/puppet/provider/service/debian.rb +0 -2
- data/lib/puppet/provider/service/smf.rb +191 -73
- data/lib/puppet/provider/service/systemd.rb +4 -14
- data/lib/puppet/provider/service/windows.rb +0 -38
- data/lib/puppet/provider/user/aix.rb +2 -2
- data/lib/puppet/provider/user/directoryservice.rb +10 -33
- data/lib/puppet/provider/user/useradd.rb +8 -62
- data/lib/puppet/reference/configuration.rb +8 -7
- data/lib/puppet/reference/indirection.rb +1 -1
- data/lib/puppet/resource.rb +1 -89
- data/lib/puppet/resource/catalog.rb +1 -14
- data/lib/puppet/resource/type.rb +3 -119
- data/lib/puppet/resource/type_collection.rb +3 -48
- data/lib/puppet/runtime.rb +1 -2
- data/lib/puppet/settings.rb +80 -96
- data/lib/puppet/settings/environment_conf.rb +0 -1
- data/lib/puppet/settings/integer_setting.rb +17 -0
- data/lib/puppet/settings/port_setting.rb +15 -0
- data/lib/puppet/settings/priority_setting.rb +5 -4
- data/lib/puppet/ssl.rb +10 -6
- data/lib/puppet/ssl/base.rb +3 -5
- data/lib/puppet/ssl/certificate.rb +0 -6
- data/lib/puppet/ssl/certificate_request.rb +1 -12
- data/lib/puppet/ssl/certificate_signer.rb +6 -0
- data/lib/puppet/ssl/oids.rb +3 -1
- data/lib/puppet/ssl/ssl_provider.rb +17 -0
- data/lib/puppet/ssl/state_machine.rb +3 -1
- data/lib/puppet/ssl/verifier.rb +2 -0
- data/lib/puppet/test/test_helper.rb +1 -3
- data/lib/puppet/transaction.rb +1 -7
- data/lib/puppet/transaction/additional_resource_generator.rb +1 -1
- data/lib/puppet/transaction/report.rb +2 -4
- data/lib/puppet/type.rb +0 -76
- data/lib/puppet/type/exec.rb +3 -16
- data/lib/puppet/type/file.rb +6 -26
- data/lib/puppet/type/file/checksum.rb +1 -1
- data/lib/puppet/type/file/mode.rb +0 -6
- data/lib/puppet/type/file/selcontext.rb +1 -1
- data/lib/puppet/type/file/source.rb +1 -1
- data/lib/puppet/type/filebucket.rb +3 -3
- data/lib/puppet/type/package.rb +8 -16
- data/lib/puppet/type/service.rb +38 -18
- data/lib/puppet/type/tidy.rb +3 -22
- data/lib/puppet/type/user.rb +20 -38
- data/lib/puppet/util/autoload.rb +8 -1
- data/lib/puppet/util/execution.rb +0 -11
- data/lib/puppet/util/http_proxy.rb +2 -215
- data/lib/puppet/util/monkey_patches.rb +0 -53
- data/lib/puppet/util/posix.rb +5 -54
- data/lib/puppet/util/rdoc.rb +0 -7
- data/lib/puppet/util/retry_action.rb +1 -1
- data/lib/puppet/util/run_mode.rb +9 -1
- data/lib/puppet/util/selinux.rb +4 -30
- data/lib/puppet/util/symbolic_file_mode.rb +17 -29
- data/lib/puppet/util/windows.rb +3 -8
- data/lib/puppet/util/windows/adsi.rb +0 -46
- data/lib/puppet/util/windows/daemon.rb +360 -0
- data/lib/puppet/util/windows/error.rb +1 -0
- data/lib/puppet/util/windows/eventlog.rb +4 -9
- data/lib/puppet/util/windows/file.rb +8 -242
- data/lib/puppet/util/windows/monkey_patches/process.rb +414 -0
- data/lib/puppet/util/windows/principal.rb +2 -9
- data/lib/puppet/util/windows/process.rb +4 -226
- data/lib/puppet/util/windows/service.rb +9 -460
- data/lib/puppet/util/windows/sid.rb +2 -6
- data/lib/puppet/util/windows/string.rb +12 -13
- data/lib/puppet/util/yaml.rb +0 -22
- data/lib/puppet/vendor/require_vendored.rb +0 -1
- data/lib/puppet/version.rb +1 -1
- data/lib/puppet/x509.rb +5 -1
- data/lib/puppet/x509/cert_provider.rb +29 -1
- data/locales/puppet.pot +722 -1527
- data/man/man5/puppet.conf.5 +266 -354
- data/man/man8/puppet-agent.8 +2 -2
- data/man/man8/puppet-apply.8 +2 -2
- data/man/man8/puppet-catalog.8 +9 -9
- 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 +8 -51
- data/man/man8/puppet-filebucket.8 +4 -4
- data/man/man8/puppet-generate.8 +1 -1
- data/man/man8/puppet-help.8 +1 -1
- data/man/man8/puppet-lookup.8 +1 -1
- data/man/man8/puppet-module.8 +1 -58
- data/man/man8/puppet-node.8 +5 -5
- data/man/man8/puppet-parser.8 +1 -1
- data/man/man8/puppet-plugin.8 +1 -1
- data/man/man8/puppet-report.8 +5 -5
- data/man/man8/puppet-resource.8 +1 -1
- data/man/man8/puppet-script.8 +2 -2
- data/man/man8/puppet-ssl.8 +1 -5
- data/man/man8/puppet.8 +2 -2
- data/spec/fixtures/ssl/127.0.0.1-key.pem +57 -107
- data/spec/fixtures/ssl/127.0.0.1.pem +31 -52
- data/spec/fixtures/ssl/bad-basic-constraints.pem +35 -57
- data/spec/fixtures/ssl/bad-int-basic-constraints.pem +35 -57
- data/spec/fixtures/ssl/ca.pem +35 -57
- data/spec/fixtures/ssl/crl.pem +18 -28
- data/spec/fixtures/ssl/ec-key.pem +11 -11
- data/spec/fixtures/ssl/ec.pem +24 -33
- data/spec/fixtures/ssl/encrypted-ec-key.pem +12 -12
- data/spec/fixtures/ssl/encrypted-key.pem +58 -108
- data/spec/fixtures/ssl/intermediate-agent-crl.pem +19 -28
- data/spec/fixtures/ssl/intermediate-agent.pem +36 -57
- data/spec/fixtures/ssl/intermediate-crl.pem +21 -31
- data/spec/fixtures/ssl/intermediate.pem +36 -57
- data/spec/fixtures/ssl/pluto-key.pem +57 -107
- data/spec/fixtures/ssl/pluto.pem +30 -52
- data/spec/fixtures/ssl/request-key.pem +57 -107
- data/spec/fixtures/ssl/request.pem +26 -47
- data/spec/fixtures/ssl/revoked-key.pem +57 -107
- data/spec/fixtures/ssl/revoked.pem +30 -52
- data/spec/fixtures/ssl/signed-key.pem +57 -107
- data/spec/fixtures/ssl/signed.pem +30 -52
- data/spec/fixtures/ssl/tampered-cert.pem +30 -52
- data/spec/fixtures/ssl/tampered-csr.pem +26 -47
- data/spec/fixtures/ssl/unknown-127.0.0.1-key.pem +57 -107
- data/spec/fixtures/ssl/unknown-127.0.0.1.pem +29 -50
- data/spec/fixtures/ssl/unknown-ca-key.pem +57 -107
- data/spec/fixtures/ssl/unknown-ca.pem +33 -55
- data/spec/fixtures/unit/provider/service/smf/{svcs.out → svcs_instances.out} +0 -0
- data/spec/fixtures/unit/provider/user/aix/aix_passwd_file.out +0 -4
- data/spec/integration/application/agent_spec.rb +27 -171
- data/spec/integration/application/apply_spec.rb +1 -20
- data/spec/integration/application/filebucket_spec.rb +16 -27
- data/spec/integration/application/help_spec.rb +2 -0
- data/spec/integration/application/module_spec.rb +0 -21
- data/spec/integration/application/plugin_spec.rb +24 -2
- data/spec/integration/defaults_spec.rb +14 -3
- data/spec/integration/environments/settings_interpolation_spec.rb +4 -0
- data/spec/integration/http/client_spec.rb +0 -12
- data/spec/integration/indirector/direct_file_server_spec.rb +3 -1
- data/spec/integration/indirector/facts/facter_spec.rb +36 -90
- data/spec/integration/network/http_pool_spec.rb +3 -21
- data/spec/integration/parser/catalog_spec.rb +0 -38
- data/spec/integration/parser/node_spec.rb +0 -9
- data/spec/integration/parser/pcore_resource_spec.rb +0 -37
- data/spec/integration/resource/type_collection_spec.rb +6 -2
- data/spec/integration/transaction_spec.rb +9 -4
- data/spec/integration/type/exec_spec.rb +45 -70
- data/spec/integration/type/file_spec.rb +5 -4
- data/spec/integration/util/windows/adsi_spec.rb +1 -21
- data/spec/integration/util/windows/monkey_patches/process_spec.rb +231 -0
- data/spec/integration/util/windows/principal_spec.rb +0 -21
- data/spec/integration/util/windows/registry_spec.rb +10 -6
- data/spec/integration/util/windows/security_spec.rb +1 -1
- data/spec/lib/matchers/include.rb +27 -0
- data/spec/lib/matchers/include_spec.rb +32 -0
- data/spec/lib/puppet/test_ca.rb +2 -7
- data/spec/lib/puppet_spec/puppetserver.rb +1 -1
- data/spec/lib/puppet_spec/settings.rb +1 -1
- data/spec/spec_helper.rb +7 -12
- data/spec/unit/agent_spec.rb +6 -10
- data/spec/unit/application/agent_spec.rb +3 -7
- data/spec/unit/application/facts_spec.rb +12 -456
- data/spec/unit/application/filebucket_spec.rb +43 -39
- data/spec/unit/application/ssl_spec.rb +2 -25
- data/spec/unit/application_spec.rb +9 -51
- data/spec/unit/certificate_factory_spec.rb +1 -1
- data/spec/unit/configurer/downloader_spec.rb +6 -8
- data/spec/unit/configurer/plugin_handler_spec.rb +56 -18
- data/spec/unit/configurer_spec.rb +12 -32
- data/spec/unit/confine/feature_spec.rb +1 -1
- data/spec/unit/confine_spec.rb +2 -8
- data/spec/unit/context/trusted_information_spec.rb +2 -6
- data/spec/unit/defaults_spec.rb +68 -54
- data/spec/unit/environments_spec.rb +68 -259
- data/spec/unit/face/node_spec.rb +11 -0
- data/spec/unit/face/plugin_spec.rb +73 -33
- data/spec/unit/file_bucket/file_spec.rb +1 -1
- data/spec/unit/file_serving/configuration/parser_spec.rb +15 -18
- data/spec/unit/file_serving/configuration_spec.rb +6 -12
- data/spec/unit/file_serving/fileset_spec.rb +0 -60
- data/spec/unit/file_serving/metadata_spec.rb +3 -3
- data/spec/unit/file_serving/terminus_helper_spec.rb +4 -11
- data/spec/unit/file_system_spec.rb +0 -15
- data/spec/unit/forge/module_release_spec.rb +7 -2
- data/spec/unit/functions/assert_type_spec.rb +1 -1
- data/spec/unit/functions/camelcase_spec.rb +1 -1
- data/spec/unit/functions/capitalize_spec.rb +1 -1
- data/spec/unit/functions/downcase_spec.rb +1 -1
- data/spec/unit/functions/empty_spec.rb +0 -10
- data/spec/unit/functions/unwrap_spec.rb +0 -8
- data/spec/unit/functions/upcase_spec.rb +1 -1
- data/spec/unit/functions4_spec.rb +2 -2
- data/spec/unit/gettext/config_spec.rb +0 -12
- data/spec/unit/http/client_spec.rb +7 -8
- data/spec/unit/{network/resolver_spec.rb → http/dns_spec.rb} +3 -3
- data/spec/unit/http/external_client_spec.rb +4 -4
- data/spec/unit/{network/http → http}/factory_spec.rb +5 -30
- data/spec/unit/{network/http/session_spec.rb → http/pool_entry_spec.rb} +3 -3
- data/spec/unit/{network/http → http}/pool_spec.rb +12 -17
- data/spec/unit/{util/http_proxy_spec.rb → http/proxy_spec.rb} +2 -69
- data/spec/unit/http/resolver_spec.rb +13 -13
- data/spec/unit/http/service/compiler_spec.rb +0 -185
- data/spec/unit/http/service/file_server_spec.rb +3 -3
- data/spec/unit/http/service/puppetserver_spec.rb +34 -4
- data/spec/unit/http/service_spec.rb +0 -1
- data/spec/unit/http/session_spec.rb +16 -14
- data/spec/unit/{network/http → http}/site_spec.rb +3 -3
- data/spec/unit/indirector/catalog/compiler_spec.rb +10 -14
- data/spec/unit/indirector/face_spec.rb +1 -0
- data/spec/unit/indirector/facts/facter_spec.rb +3 -0
- data/spec/unit/indirector/file_bucket_file/file_spec.rb +5 -3
- data/spec/unit/indirector/file_bucket_file/selector_spec.rb +8 -26
- data/spec/unit/indirector/file_content/rest_spec.rb +0 -4
- data/spec/unit/indirector/file_metadata/rest_spec.rb +0 -4
- data/spec/unit/indirector/file_server_spec.rb +1 -15
- data/spec/unit/indirector/indirection_spec.rb +12 -8
- data/spec/unit/indirector/report/rest_spec.rb +2 -17
- data/spec/unit/indirector/request_spec.rb +0 -264
- data/spec/unit/indirector/resource/ral_spec.rb +75 -40
- data/spec/unit/indirector/rest_spec.rb +98 -752
- data/spec/unit/indirector_spec.rb +2 -2
- data/spec/unit/module_tool/applications/installer_spec.rb +0 -78
- data/spec/unit/network/authconfig_spec.rb +2 -129
- data/spec/unit/network/authorization_spec.rb +2 -55
- data/spec/unit/network/formats_spec.rb +4 -45
- data/spec/unit/network/http/api/indirected_routes_spec.rb +5 -92
- data/spec/unit/network/http/api/master/v3_spec.rb +28 -7
- data/spec/unit/network/http/api_spec.rb +10 -0
- data/spec/unit/network/http/connection_spec.rb +19 -41
- data/spec/unit/network/http/handler_spec.rb +0 -1
- data/spec/unit/network/http_pool_spec.rb +0 -4
- data/spec/unit/node/environment_spec.rb +33 -21
- data/spec/unit/node_spec.rb +2 -54
- data/spec/unit/parser/compiler_spec.rb +19 -3
- data/spec/unit/parser/functions/create_resources_spec.rb +2 -20
- data/spec/unit/parser/functions/fqdn_rand_spec.rb +1 -15
- data/spec/unit/parser/resource_spec.rb +8 -14
- data/spec/unit/parser/templatewrapper_spec.rb +5 -16
- data/spec/unit/pops/evaluator/evaluating_parser_spec.rb +4 -7
- data/spec/unit/pops/loaders/loaders_spec.rb +6 -21
- data/spec/unit/pops/parser/parse_application_spec.rb +4 -22
- data/spec/unit/pops/parser/parse_basic_expressions_spec.rb +0 -1
- data/spec/unit/pops/parser/parse_capabilities_spec.rb +8 -21
- data/spec/unit/pops/parser/parse_site_spec.rb +20 -24
- data/spec/unit/pops/resource/resource_type_impl_spec.rb +0 -71
- data/spec/unit/pops/serialization/to_from_hr_spec.rb +1 -1
- data/spec/unit/pops/types/p_sem_ver_type_spec.rb +0 -18
- data/spec/unit/pops/types/p_sensitive_type_spec.rb +0 -18
- data/spec/unit/pops/types/type_calculator_spec.rb +6 -6
- data/spec/unit/pops/types/type_factory_spec.rb +1 -1
- data/spec/unit/pops/validator/validator_spec.rb +61 -46
- data/spec/unit/pops/visitor_spec.rb +1 -1
- data/spec/unit/property_spec.rb +0 -1
- data/spec/unit/provider/group/groupadd_spec.rb +2 -5
- data/spec/unit/provider/nameservice_spec.rb +64 -122
- data/spec/unit/provider/package/apt_spec.rb +23 -28
- data/spec/unit/provider/package/aptitude_spec.rb +1 -1
- data/spec/unit/provider/package/base_spec.rb +5 -6
- data/spec/unit/provider/package/dnfmodule_spec.rb +1 -10
- data/spec/unit/provider/package/dpkg_spec.rb +0 -48
- data/spec/unit/provider/package/gem_spec.rb +32 -0
- data/spec/unit/provider/package/nim_spec.rb +0 -42
- data/spec/unit/provider/package/pacman_spec.rb +12 -18
- data/spec/unit/provider/package/pip_spec.rb +11 -43
- data/spec/unit/provider/package/pkgdmg_spec.rb +4 -0
- data/spec/unit/provider/package/puppet_gem_spec.rb +3 -2
- data/spec/unit/provider/parsedfile_spec.rb +0 -10
- data/spec/unit/provider/service/init_spec.rb +0 -1
- data/spec/unit/provider/service/openwrt_spec.rb +1 -3
- data/spec/unit/provider/service/smf_spec.rb +401 -165
- data/spec/unit/provider/service/systemd_spec.rb +8 -53
- data/spec/unit/provider/service/windows_spec.rb +0 -203
- data/spec/unit/provider/user/aix_spec.rb +0 -5
- data/spec/unit/provider/user/directoryservice_spec.rb +35 -67
- data/spec/unit/provider/user/hpux_spec.rb +1 -1
- data/spec/unit/provider/user/pw_spec.rb +0 -2
- data/spec/unit/provider/user/useradd_spec.rb +3 -71
- data/spec/unit/provider_spec.rb +8 -18
- data/spec/unit/resource/catalog_spec.rb +1 -1
- data/spec/unit/resource/type_collection_spec.rb +2 -22
- data/spec/unit/resource/type_spec.rb +1 -1
- data/spec/unit/resource_spec.rb +10 -67
- data/spec/unit/settings/http_extra_headers_spec.rb +2 -4
- data/spec/unit/settings/integer_setting_spec.rb +42 -0
- data/spec/unit/settings/port_setting_spec.rb +31 -0
- data/spec/unit/settings/priority_setting_spec.rb +4 -4
- data/spec/unit/settings_spec.rb +79 -110
- data/spec/unit/ssl/base_spec.rb +37 -3
- data/spec/unit/ssl/certificate_request_spec.rb +15 -45
- data/spec/unit/ssl/certificate_spec.rb +2 -11
- data/spec/unit/ssl/ssl_provider_spec.rb +2 -5
- data/spec/unit/ssl/state_machine_spec.rb +5 -20
- data/spec/unit/ssl/verifier_spec.rb +0 -21
- data/spec/unit/transaction/additional_resource_generator_spec.rb +9 -3
- data/spec/unit/transaction/event_manager_spec.rb +11 -14
- data/spec/unit/transaction/report_spec.rb +0 -2
- data/spec/unit/transaction/resource_harness_spec.rb +2 -2
- data/spec/unit/transaction_spec.rb +55 -96
- data/spec/unit/type/exec_spec.rb +29 -76
- data/spec/unit/type/file/checksum_spec.rb +6 -6
- data/spec/unit/type/file/content_spec.rb +2 -1
- data/spec/unit/type/file/ensure_spec.rb +1 -1
- data/spec/unit/type/file/mode_spec.rb +1 -1
- data/spec/unit/type/file/selinux_spec.rb +5 -3
- data/spec/unit/type/file/source_spec.rb +4 -5
- data/spec/unit/type/file_spec.rb +18 -6
- data/spec/unit/type/group_spec.rb +6 -13
- data/spec/unit/type/package_spec.rb +1 -1
- data/spec/unit/type/resources_spec.rb +7 -7
- data/spec/unit/type/service_spec.rb +189 -60
- data/spec/unit/type/tidy_spec.rb +8 -24
- data/spec/unit/type/user_spec.rb +0 -45
- data/spec/unit/type_spec.rb +22 -2
- data/spec/unit/util/at_fork_spec.rb +2 -2
- data/spec/unit/util/autoload_spec.rb +1 -5
- data/spec/unit/util/backups_spec.rb +2 -3
- data/spec/unit/util/execution_spec.rb +11 -44
- data/spec/unit/util/inifile_spec.rb +14 -6
- data/spec/unit/util/log_spec.rb +7 -8
- data/spec/unit/util/logging_spec.rb +3 -3
- data/spec/unit/util/monkey_patches_spec.rb +0 -6
- data/spec/unit/util/posix_spec.rb +15 -363
- data/spec/unit/util/run_mode_spec.rb +21 -121
- data/spec/unit/util/selinux_spec.rb +68 -163
- data/spec/unit/util/storage_spec.rb +1 -3
- data/spec/unit/util/suidmanager_spec.rb +41 -44
- data/spec/unit/util/windows/sid_spec.rb +0 -41
- data/spec/unit/util/windows/string_spec.rb +1 -3
- data/spec/unit/util/yaml_spec.rb +0 -54
- data/spec/unit/util_spec.rb +6 -31
- data/tasks/generate_cert_fixtures.rake +3 -12
- metadata +45 -253
- data/conf/auth.conf +0 -150
- data/lib/puppet/application/cert.rb +0 -76
- data/lib/puppet/application/key.rb +0 -4
- data/lib/puppet/application/man.rb +0 -4
- data/lib/puppet/application/status.rb +0 -4
- data/lib/puppet/face/key.rb +0 -16
- data/lib/puppet/face/man.rb +0 -145
- data/lib/puppet/face/module/build.rb +0 -14
- data/lib/puppet/face/module/generate.rb +0 -14
- data/lib/puppet/face/module/search.rb +0 -103
- data/lib/puppet/face/status.rb +0 -51
- data/lib/puppet/ffi/posix.rb +0 -10
- data/lib/puppet/ffi/posix/constants.rb +0 -14
- data/lib/puppet/ffi/posix/functions.rb +0 -24
- data/lib/puppet/indirector/certificate/file.rb +0 -9
- data/lib/puppet/indirector/certificate/rest.rb +0 -18
- data/lib/puppet/indirector/certificate_request/file.rb +0 -9
- data/lib/puppet/indirector/certificate_request/memory.rb +0 -7
- data/lib/puppet/indirector/certificate_request/rest.rb +0 -11
- data/lib/puppet/indirector/file_content/http.rb +0 -22
- data/lib/puppet/indirector/key/file.rb +0 -46
- data/lib/puppet/indirector/key/memory.rb +0 -7
- data/lib/puppet/indirector/ssl_file.rb +0 -162
- data/lib/puppet/indirector/status.rb +0 -3
- data/lib/puppet/indirector/status/local.rb +0 -12
- data/lib/puppet/indirector/status/rest.rb +0 -27
- data/lib/puppet/module_tool/applications/searcher.rb +0 -29
- data/lib/puppet/network/auth_config_parser.rb +0 -90
- data/lib/puppet/network/authstore.rb +0 -283
- data/lib/puppet/network/http/api/master/v3/authorization.rb +0 -18
- data/lib/puppet/network/http/api/master/v3/environment.rb +0 -88
- data/lib/puppet/network/http/base_pool.rb +0 -36
- data/lib/puppet/network/http/compression.rb +0 -127
- data/lib/puppet/network/http/connection_adapter.rb +0 -184
- data/lib/puppet/network/http/nocache_pool.rb +0 -28
- data/lib/puppet/network/rest_controller.rb +0 -2
- data/lib/puppet/network/rights.rb +0 -210
- data/lib/puppet/parser/compiler/catalog_validator/env_relationship_validator.rb +0 -66
- data/lib/puppet/parser/compiler/catalog_validator/site_validator.rb +0 -22
- data/lib/puppet/parser/environment_compiler.rb +0 -202
- data/lib/puppet/pops/types/enumeration.rb +0 -16
- data/lib/puppet/resource/capability_finder.rb +0 -154
- data/lib/puppet/rest/errors.rb +0 -15
- data/lib/puppet/rest/response.rb +0 -35
- data/lib/puppet/rest/route.rb +0 -85
- data/lib/puppet/rest/routes.rb +0 -135
- data/lib/puppet/settings/alias_setting.rb +0 -37
- data/lib/puppet/ssl/host.rb +0 -505
- data/lib/puppet/ssl/key.rb +0 -61
- data/lib/puppet/ssl/validator.rb +0 -61
- data/lib/puppet/ssl/validator/default_validator.rb +0 -209
- data/lib/puppet/ssl/validator/no_validator.rb +0 -22
- data/lib/puppet/ssl/verifier_adapter.rb +0 -58
- data/lib/puppet/status.rb +0 -40
- data/lib/puppet/util/connection.rb +0 -88
- data/lib/puppet/util/fact_dif.rb +0 -81
- data/lib/puppet/util/ssl.rb +0 -83
- data/lib/puppet/util/windows/api_types.rb +0 -309
- data/lib/puppet/util/windows/monkey_patches/dir.rb +0 -40
- data/lib/puppet/vendor/load_pathspec.rb +0 -1
- data/lib/puppet/vendor/pathspec/CHANGELOG.md +0 -2
- data/lib/puppet/vendor/pathspec/LICENSE +0 -201
- data/lib/puppet/vendor/pathspec/PUPPET_README.md +0 -6
- data/lib/puppet/vendor/pathspec/README.md +0 -53
- data/lib/puppet/vendor/pathspec/lib/pathspec.rb +0 -122
- data/lib/puppet/vendor/pathspec/lib/pathspec/gitignorespec.rb +0 -275
- data/lib/puppet/vendor/pathspec/lib/pathspec/regexspec.rb +0 -17
- data/lib/puppet/vendor/pathspec/lib/pathspec/spec.rb +0 -14
- data/man/man8/puppet-key.8 +0 -126
- data/man/man8/puppet-man.8 +0 -76
- data/man/man8/puppet-status.8 +0 -108
- data/spec/fixtures/integration/application/agent/cached_deferred_catalog.json +0 -91
- data/spec/fixtures/ssl/oid-key.pem +0 -117
- data/spec/fixtures/ssl/oid.pem +0 -69
- data/spec/fixtures/ssl/trusted_oid_mapping.yaml +0 -5
- data/spec/fixtures/unit/provider/service/systemd/list_unit_files_services_vendor_preset +0 -9
- data/spec/integration/application/resource_spec.rb +0 -64
- data/spec/integration/application/ssl_spec.rb +0 -20
- data/spec/integration/network/authconfig_spec.rb +0 -256
- data/spec/integration/util/windows/monkey_patches/dir_spec.rb +0 -11
- data/spec/unit/application/man_spec.rb +0 -52
- data/spec/unit/capability_spec.rb +0 -414
- data/spec/unit/face/key_spec.rb +0 -9
- data/spec/unit/face/module/search_spec.rb +0 -231
- data/spec/unit/face/status_spec.rb +0 -9
- data/spec/unit/indirector/certificate/file_spec.rb +0 -14
- data/spec/unit/indirector/certificate/rest_spec.rb +0 -61
- data/spec/unit/indirector/certificate_request/file_spec.rb +0 -14
- data/spec/unit/indirector/certificate_request/rest_spec.rb +0 -25
- data/spec/unit/indirector/key/file_spec.rb +0 -78
- data/spec/unit/indirector/ssl_file_spec.rb +0 -305
- data/spec/unit/indirector/status/local_spec.rb +0 -10
- data/spec/unit/indirector/status/rest_spec.rb +0 -50
- data/spec/unit/module_tool/applications/searcher_spec.rb +0 -38
- data/spec/unit/network/auth_config_parser_spec.rb +0 -115
- data/spec/unit/network/authstore_spec.rb +0 -422
- data/spec/unit/network/http/api/master/v3/authorization_spec.rb +0 -57
- data/spec/unit/network/http/api/master/v3/environment_spec.rb +0 -185
- data/spec/unit/network/http/compression_spec.rb +0 -240
- data/spec/unit/network/http/nocache_pool_spec.rb +0 -64
- data/spec/unit/network/http_spec.rb +0 -9
- data/spec/unit/network/rights_spec.rb +0 -439
- data/spec/unit/parser/environment_compiler_spec.rb +0 -730
- data/spec/unit/pops/evaluator/deferred_resolver_spec.rb +0 -20
- data/spec/unit/pops/types/enumeration_spec.rb +0 -51
- data/spec/unit/resource/capability_finder_spec.rb +0 -148
- data/spec/unit/rest/route_spec.rb +0 -132
- data/spec/unit/ssl/host_spec.rb +0 -645
- data/spec/unit/ssl/key_spec.rb +0 -173
- data/spec/unit/ssl/validator_spec.rb +0 -278
- data/spec/unit/status_spec.rb +0 -45
- data/spec/unit/util/ssl_spec.rb +0 -91
@@ -4,22 +4,14 @@
|
|
4
4
|
# the second containing the rest.
|
5
5
|
Puppet::Functions.create_function(:partition) do
|
6
6
|
# @param collection A collection of things to partition.
|
7
|
-
# @example Partition array of empty strings, results in e.g.
|
8
|
-
# ```puppet
|
7
|
+
# @example Partition array of empty strings, results in e.g. [[''], [b, c]]
|
9
8
|
# ['', b, c].partition |$s| { $s.empty }
|
10
|
-
#
|
11
|
-
# @example Partition array of strings using index, results in e.g. `[['', 'ab'], ['b']]`
|
12
|
-
# ```puppet
|
9
|
+
# @example Partition array of strings using index, results in e.g. [['', 'ab'], ['b']]
|
13
10
|
# ['', b, ab].partition |$i, $s| { $i == 2 or $s.empty }
|
14
|
-
#
|
15
|
-
# @example Partition hash of strings by key-value pair, results in e.g. `[[['b', []]], [['a', [1, 2]]]]`
|
16
|
-
# ```puppet
|
11
|
+
# @example Partition hash of strings by key-value pair, results in e.g. [[['b', []]], [['a', [1, 2]]]]
|
17
12
|
# { a => [1, 2], b => [] }.partition |$kv| { $kv[1].empty }
|
18
|
-
#
|
19
|
-
# @example Partition hash of strings by key and value, results in e.g. `[[['b', []]], [['a', [1, 2]]]]`
|
20
|
-
# ```puppet
|
13
|
+
# @example Partition hash of strings by key and value, results in e.g. [[['b', []]], [['a', [1, 2]]]]
|
21
14
|
# { a => [1, 2], b => [] }.partition |$k, $v| { $v.empty }
|
22
|
-
# ```
|
23
15
|
dispatch :partition_1 do
|
24
16
|
required_param 'Collection', :collection
|
25
17
|
block_param 'Callable[1,1]', :block
|
@@ -4,13 +4,13 @@
|
|
4
4
|
# The relationship metaparameters work well for specifying relationships
|
5
5
|
# between individual resources, but they can be clumsy for specifying
|
6
6
|
# relationships between classes. This function is a superset of the
|
7
|
-
#
|
7
|
+
# 'include' function, adding a class relationship so that the requiring
|
8
8
|
# class depends on the required class.
|
9
9
|
#
|
10
|
-
# Warning: using
|
10
|
+
# Warning: using require in place of include can lead to unwanted dependency cycles.
|
11
11
|
#
|
12
|
-
# For instance
|
13
|
-
# dependence cycle, because
|
12
|
+
# For instance the following manifest, with 'require' instead of 'include' would produce a nasty
|
13
|
+
# dependence cycle, because notify imposes a before between File[/foo] and Service[foo]:
|
14
14
|
#
|
15
15
|
# ```puppet
|
16
16
|
# class myservice {
|
@@ -32,7 +32,7 @@
|
|
32
32
|
# resource and relationship expressions.
|
33
33
|
#
|
34
34
|
# - Since 4.0.0 Class and Resource types, absolute names
|
35
|
-
# - Since 4.7.0 Returns an
|
35
|
+
# - Since 4.7.0 Returns an Array[Type[Class]] with references to the required classes
|
36
36
|
#
|
37
37
|
Puppet::Functions.create_function(:require, Puppet::Functions::InternalFunction) do
|
38
38
|
dispatch :require_impl do
|
@@ -2,9 +2,9 @@
|
|
2
2
|
# Please note: This function is based on Ruby String comparison and as such may not be entirely UTF8 compatible.
|
3
3
|
# To ensure compatibility please use this function with Ruby 2.4.0 or greater - https://bugs.ruby-lang.org/issues/10085.
|
4
4
|
#
|
5
|
-
# This function is compatible with the function
|
5
|
+
# This function is compatible with the function sort() in stdlib.
|
6
6
|
# * Comparison of characters in a string always uses a system locale and may not be what is expected for a particular locale
|
7
|
-
# * Sorting is based on Ruby's
|
7
|
+
# * Sorting is based on Ruby's <=> operator unless a lambda is given that performs the comparison.
|
8
8
|
# * comparison of strings is case dependent (use lambda with `compare($a,$b)` to ignore case)
|
9
9
|
# * comparison of mixed data types raises an error (if there is the need to sort mixed data types use a lambda)
|
10
10
|
#
|
@@ -49,7 +49,7 @@
|
|
49
49
|
# }
|
50
50
|
# })
|
51
51
|
# ```
|
52
|
-
# Would notice
|
52
|
+
# Would notice [2,3,'a','b']
|
53
53
|
#
|
54
54
|
# @since 6.0.0 - supporting a lambda to do compare
|
55
55
|
#
|
@@ -6,13 +6,13 @@
|
|
6
6
|
#
|
7
7
|
# 1. An `Array`, `Hash`, `Iterator`, or `Object` that the function will iterate over.
|
8
8
|
# 2. An optional hash with the options:
|
9
|
-
# * `include_containers` => `Optional[Boolean]` # default
|
10
|
-
# * `include_values` => `Optional[Boolean]` # default
|
11
|
-
# * `include_root` => `Optional[Boolean]` # default
|
9
|
+
# * `include_containers` => `Optional[Boolean]` # default true - if containers should be given to the lambda
|
10
|
+
# * `include_values` => `Optional[Boolean]` # default true - if non containers should be given to the lambda
|
11
|
+
# * `include_root` => `Optional[Boolean]` # default true - if the root container should be given to the lambda
|
12
12
|
# * `container_type` => `Optional[Type[Variant[Array, Hash, Object]]]` # a type that determines what a container is - can only
|
13
13
|
# be set to a type that matches the default `Variant[Array, Hash, Object]`.
|
14
14
|
# * `order` => `Enum[depth_first, breadth_first]` # default ´depth_first`, the order in which elements are visited
|
15
|
-
# * `include_refs` =>
|
15
|
+
# * `include_refs` => Optional[Boolean] # default `false`, if attributes in objects marked as bing of `reference` kind
|
16
16
|
# should be included.
|
17
17
|
# 3. An optional lambda, which the function calls for each element in the first argument. It must
|
18
18
|
# accept one or two arguments; either `$path`, and `$value`, or just `$value`.
|
@@ -46,12 +46,14 @@
|
|
46
46
|
# [1, [2, 3], 4]
|
47
47
|
# ```
|
48
48
|
#
|
49
|
-
#
|
49
|
+
# Results in:
|
50
|
+
#
|
51
|
+
# If containers are skipped:
|
50
52
|
#
|
51
53
|
# * `depth_first` order `1`, `2`, `3`, `4`
|
52
54
|
# * `breadth_first` order `1`, `4`,`2`, `3`
|
53
55
|
#
|
54
|
-
# If containers and root are included
|
56
|
+
# If containers and root, are included:
|
55
57
|
#
|
56
58
|
# * `depth_first` order `[1, [2, 3], 4]`, `1`, `[2, 3]`, `2`, `3`, `4`
|
57
59
|
# * `breadth_first` order `[1, [2, 3], 4]`, `1`, `[2, 3]`, `4`, `2`, `3`
|
@@ -94,7 +96,7 @@
|
|
94
96
|
#
|
95
97
|
# Any Puppet Type system data type can be used to filter what is
|
96
98
|
# considered to be a container, but it must be a narrower type than one of
|
97
|
-
# the default
|
99
|
+
# the default Array, Hash, Object types - for example it is not possible to make a
|
98
100
|
# `String` be a container type.
|
99
101
|
#
|
100
102
|
# @example Only `Array` as container type
|
@@ -35,10 +35,10 @@
|
|
35
35
|
#
|
36
36
|
# Would notice the four values:
|
37
37
|
#
|
38
|
-
# 1.
|
39
|
-
# 2.
|
40
|
-
# 3.
|
41
|
-
# 4.
|
38
|
+
# 1. 'Array[Numeric]'
|
39
|
+
# 2. 'Array[Numeric, 2, 2]'
|
40
|
+
# 3. 'Tuple[Float[3.14], Integer[42,42]]]'
|
41
|
+
# 4. 'Tuple[Float[3.14], Integer[42,42]]]'
|
42
42
|
#
|
43
43
|
# @since 4.4.0
|
44
44
|
#
|
@@ -1,5 +1,4 @@
|
|
1
1
|
# Unwraps a Sensitive value and returns the wrapped object.
|
2
|
-
# Returns the Value itself, if it is not Sensitive.
|
3
2
|
#
|
4
3
|
# @example Usage of unwrap
|
5
4
|
#
|
@@ -29,17 +28,12 @@
|
|
29
28
|
# @since 4.0.0
|
30
29
|
#
|
31
30
|
Puppet::Functions.create_function(:unwrap) do
|
32
|
-
dispatch :
|
31
|
+
dispatch :unwrap do
|
33
32
|
param 'Sensitive', :arg
|
34
33
|
optional_block_param
|
35
34
|
end
|
36
35
|
|
37
|
-
|
38
|
-
param 'Any', :arg
|
39
|
-
optional_block_param
|
40
|
-
end
|
41
|
-
|
42
|
-
def from_sensitive(arg)
|
36
|
+
def unwrap(arg)
|
43
37
|
unwrapped = arg.unwrap
|
44
38
|
if block_given?
|
45
39
|
yield(unwrapped)
|
@@ -47,13 +41,4 @@ Puppet::Functions.create_function(:unwrap) do
|
|
47
41
|
unwrapped
|
48
42
|
end
|
49
43
|
end
|
50
|
-
|
51
|
-
def from_any(arg)
|
52
|
-
unwrapped = arg
|
53
|
-
if block_given?
|
54
|
-
yield(unwrapped)
|
55
|
-
else
|
56
|
-
unwrapped
|
57
|
-
end
|
58
|
-
end
|
59
44
|
end
|
@@ -22,14 +22,14 @@
|
|
22
22
|
# 'hello'.upcase()
|
23
23
|
# upcase('hello')
|
24
24
|
# ```
|
25
|
-
# Would both result in
|
25
|
+
# Would both result in "HELLO"
|
26
26
|
#
|
27
27
|
# @example Converting an Array to upper case
|
28
28
|
# ```puppet
|
29
29
|
# ['a', 'b'].upcase()
|
30
30
|
# upcase(['a', 'b'])
|
31
31
|
# ```
|
32
|
-
# Would both result in
|
32
|
+
# Would both result in ['A', 'B']
|
33
33
|
#
|
34
34
|
# @example Converting a Hash to upper case
|
35
35
|
# ```puppet
|
@@ -49,7 +49,10 @@ module Puppet
|
|
49
49
|
]
|
50
50
|
end]
|
51
51
|
@isomorphic = type.isomorphic?
|
52
|
-
|
52
|
+
# continue to emit capability as false when rendering the ERB
|
53
|
+
# template, so that pcore modules generated prior to puppet7 can be
|
54
|
+
# read by puppet7 and vice-versa.
|
55
|
+
@capability = false
|
53
56
|
end
|
54
57
|
|
55
58
|
def render(template)
|
data/lib/puppet/http.rb
CHANGED
@@ -1,23 +1,25 @@
|
|
1
1
|
module Puppet
|
2
|
-
|
3
|
-
|
4
|
-
|
5
|
-
|
6
|
-
|
7
|
-
|
8
|
-
|
9
|
-
require 'puppet/network/http/pool'
|
10
|
-
require 'puppet/network/resolver'
|
11
|
-
end
|
12
|
-
end
|
13
|
-
|
14
|
-
# @api private
|
2
|
+
# Contains an HTTP client for making network requests to puppet and other
|
3
|
+
# HTTP servers.
|
4
|
+
#
|
5
|
+
# @see Puppet::HTTP::Client
|
6
|
+
# @see Puppet::HTTP::HTTPError
|
7
|
+
# @see Puppet::HTTP::Response
|
8
|
+
# @api public
|
15
9
|
module HTTP
|
16
10
|
ACCEPT_ENCODING = "gzip;q=1.0,deflate;q=0.6,identity;q=0.3".freeze
|
17
11
|
HEADER_PUPPET_VERSION = "X-Puppet-Version".freeze
|
18
12
|
|
19
13
|
require 'puppet/http/errors'
|
14
|
+
require 'puppet/http/site'
|
15
|
+
require 'puppet/http/pool_entry'
|
16
|
+
require 'puppet/http/proxy'
|
17
|
+
require 'puppet/http/factory'
|
18
|
+
require 'puppet/http/pool'
|
19
|
+
require 'puppet/http/dns'
|
20
20
|
require 'puppet/http/response'
|
21
|
+
require 'puppet/http/response_converter'
|
22
|
+
require 'puppet/http/response_net_http'
|
21
23
|
require 'puppet/http/service'
|
22
24
|
require 'puppet/http/service/ca'
|
23
25
|
require 'puppet/http/service/compiler'
|
@@ -34,4 +36,11 @@ module Puppet
|
|
34
36
|
require 'puppet/http/retry_after_handler'
|
35
37
|
require 'puppet/http/external_client'
|
36
38
|
end
|
39
|
+
|
40
|
+
# Legacy HTTP API
|
41
|
+
module Network
|
42
|
+
module HTTP
|
43
|
+
require 'puppet/network/http_pool'
|
44
|
+
end
|
45
|
+
end
|
37
46
|
end
|
data/lib/puppet/http/client.rb
CHANGED
@@ -1,23 +1,96 @@
|
|
1
|
+
# The HTTP client provides methods for making `GET`, `POST`, etc requests to
|
2
|
+
# HTTP(S) servers. It also provides methods for resolving Puppetserver REST
|
3
|
+
# service endpoints using SRV records and settings (such as `server_list`,
|
4
|
+
# `server`, `ca_server`, etc). Once a service endpoint has been resolved, there
|
5
|
+
# are methods for making REST requests (such as getting a node, sending facts,
|
6
|
+
# etc).
|
1
7
|
#
|
2
|
-
#
|
8
|
+
# The client uses persistent HTTP connections by default unless the `Connection:
|
9
|
+
# close` header is specified and supports streaming response bodies.
|
3
10
|
#
|
4
|
-
#
|
5
|
-
#
|
11
|
+
# By default the client only trusts the Puppet CA for HTTPS connections. However,
|
12
|
+
# if the `include_system_store` request option is set to true, then Puppet will
|
13
|
+
# trust certificates in the puppet-agent CA bundle.
|
6
14
|
#
|
15
|
+
# @example To access the HTTP client:
|
16
|
+
# client = Puppet.runtime[:http]
|
17
|
+
#
|
18
|
+
# @example To make an HTTP GET request:
|
19
|
+
# response = client.get(URI("http://www.example.com"))
|
20
|
+
#
|
21
|
+
# @example To make an HTTPS GET request, trusting the puppet CA and certs in Puppet's CA bundle:
|
22
|
+
# response = client.get(URI("https://www.example.com"), include_system_store: true)
|
23
|
+
#
|
24
|
+
# @example To use a URL containing special characters, such as spaces:
|
25
|
+
# response = client.get(URI(Puppet::Util.uri_encode("https://www.example.com/path to file")))
|
26
|
+
#
|
27
|
+
# @example To pass query parameters:
|
28
|
+
# response = client.get(URI("https://www.example.com"), query: {'q' => 'puppet'})
|
29
|
+
#
|
30
|
+
# @example To pass custom headers:
|
31
|
+
# response = client.get(URI("https://www.example.com"), headers: {'Accept-Content' => 'application/json'})
|
32
|
+
#
|
33
|
+
# @example To check if the response is successful (2xx):
|
34
|
+
# response = client.get(URI("http://www.example.com"))
|
35
|
+
# puts response.success?
|
36
|
+
#
|
37
|
+
# @example To get the response code and reason:
|
38
|
+
# response = client.get(URI("http://www.example.com"))
|
39
|
+
# unless response.success?
|
40
|
+
# puts "HTTP #{response.code} #{response.reason}"
|
41
|
+
# end
|
42
|
+
#
|
43
|
+
# @example To read response headers:
|
44
|
+
# response = client.get(URI("http://www.example.com"))
|
45
|
+
# puts response['Content-Type']
|
46
|
+
#
|
47
|
+
# @example To stream the response body:
|
48
|
+
# client.get(URI("http://www.example.com")) do |response|
|
49
|
+
# if response.success?
|
50
|
+
# response.read_body do |data|
|
51
|
+
# puts data
|
52
|
+
# end
|
53
|
+
# end
|
54
|
+
# end
|
55
|
+
#
|
56
|
+
# @example To handle exceptions:
|
57
|
+
# begin
|
58
|
+
# client.get(URI("https://www.example.com"))
|
59
|
+
# rescue Puppet::HTTP::ResponseError => e
|
60
|
+
# puts "HTTP #{e.response.code} #{e.response.reason}"
|
61
|
+
# rescue Puppet::HTTP::ConnectionError => e
|
62
|
+
# puts "Connection error #{e.message}"
|
63
|
+
# rescue Puppet::SSL::SSLError => e
|
64
|
+
# puts "SSL error #{e.message}"
|
65
|
+
# rescue Puppet::HTTP::HTTPError => e
|
66
|
+
# puts "General HTTP error #{e.message}"
|
67
|
+
# end
|
68
|
+
#
|
69
|
+
# @example To route to the `:puppet` service:
|
70
|
+
# session = client.create_session
|
71
|
+
# service = session.route_to(:puppet)
|
72
|
+
#
|
73
|
+
# @example To make a node request:
|
74
|
+
# node = service.get_node(Puppet[:certname], environment: 'production')
|
75
|
+
#
|
76
|
+
# @example To submit facts:
|
77
|
+
# facts = Puppet::Indirection::Facts.indirection.find(Puppet[:certname])
|
78
|
+
# service.put_facts(Puppet[:certname], environment: 'production', facts: facts)
|
79
|
+
#
|
80
|
+
# @example To submit a report to the `:report` service:
|
81
|
+
# report = Puppet::Transaction::Report.new
|
82
|
+
# service = session.route_to(:report)
|
83
|
+
# service.put_report(Puppet[:certname], report, environment: 'production')
|
84
|
+
#
|
85
|
+
# @api public
|
7
86
|
class Puppet::HTTP::Client
|
8
87
|
|
9
|
-
# @api private
|
10
|
-
# @return [Puppet::Network::HTTP::Pool] the pool instance associated with
|
11
|
-
# this client
|
12
88
|
attr_reader :pool
|
13
89
|
|
90
|
+
# Create a new http client instance. Use `Puppet.runtime[:http]` to get
|
91
|
+
# the current client instead of creating an instance of this class.
|
14
92
|
#
|
15
|
-
# @
|
16
|
-
#
|
17
|
-
# Create a new http client instance. The client contains a pool of persistent
|
18
|
-
# HTTP connections and creates HTTP sessions.
|
19
|
-
#
|
20
|
-
# @param [Puppet::Network::HTTP::Pool] pool pool of persistent Net::HTTP
|
93
|
+
# @param [Puppet::HTTP::Pool] pool pool of persistent Net::HTTP
|
21
94
|
# connections
|
22
95
|
# @param [Puppet::SSL::SSLContext] ssl_context ssl context to be used for
|
23
96
|
# connections
|
@@ -28,7 +101,7 @@ class Puppet::HTTP::Client
|
|
28
101
|
# @param [Integer] retry_limit number of HTTP reties allowed in a given
|
29
102
|
# request
|
30
103
|
#
|
31
|
-
def initialize(pool: Puppet::
|
104
|
+
def initialize(pool: Puppet::HTTP::Pool.new(Puppet[:http_keepalive_timeout]), ssl_context: nil, system_ssl_context: nil, redirect_limit: 10, retry_limit: 100)
|
32
105
|
@pool = pool
|
33
106
|
@default_headers = {
|
34
107
|
'X-Puppet-Version' => Puppet.version,
|
@@ -40,22 +113,19 @@ class Puppet::HTTP::Client
|
|
40
113
|
@retry_after_handler = Puppet::HTTP::RetryAfterHandler.new(retry_limit, Puppet[:runinterval])
|
41
114
|
end
|
42
115
|
|
43
|
-
#
|
44
|
-
# @api private
|
45
|
-
#
|
46
116
|
# Create a new HTTP session. A session is the object through which services
|
47
117
|
# may be connected to and accessed.
|
48
118
|
#
|
49
119
|
# @return [Puppet::HTTP::Session] the newly created HTTP session
|
50
120
|
#
|
121
|
+
# @api public
|
51
122
|
def create_session
|
52
123
|
Puppet::HTTP::Session.new(self, build_resolvers)
|
53
124
|
end
|
54
125
|
|
55
|
-
#
|
56
|
-
#
|
57
|
-
#
|
58
|
-
# Open a connection to the given URI
|
126
|
+
# Open a connection to the given URI. It is typically not necessary to call
|
127
|
+
# this method as the client will create connections as needed when a request
|
128
|
+
# is made.
|
59
129
|
#
|
60
130
|
# @param [URI] uri the connection destination
|
61
131
|
# @param [Hash] options
|
@@ -63,16 +133,12 @@ class Puppet::HTTP::Client
|
|
63
133
|
# be used for connections
|
64
134
|
# @option options [Boolean] :include_system_store (false) if we should include
|
65
135
|
# the system store for connection
|
66
|
-
#
|
67
|
-
# @yield [Net::HTTP] If a block is given, yields an active http connection
|
68
|
-
# from the pool
|
69
|
-
#
|
70
136
|
def connect(uri, options: {}, &block)
|
71
137
|
start = Time.now
|
72
138
|
verifier = nil
|
73
139
|
connected = false
|
74
140
|
|
75
|
-
site = Puppet::
|
141
|
+
site = Puppet::HTTP::Site.from_uri(uri)
|
76
142
|
if site.use_ssl?
|
77
143
|
ssl_context = options.fetch(:ssl_context, nil)
|
78
144
|
include_system_store = options.fetch(:include_system_store, false)
|
@@ -101,88 +167,73 @@ class Puppet::HTTP::Client
|
|
101
167
|
{uri: uri, elapsed: elapsed(start), message: e.message}, e, connected)
|
102
168
|
end
|
103
169
|
|
104
|
-
#
|
105
|
-
#
|
106
|
-
#
|
170
|
+
# These options apply to all HTTP request methods
|
171
|
+
#
|
172
|
+
# @!macro [new] request_options
|
173
|
+
# @param [Hash] options HTTP request options. Options not recognized by the
|
174
|
+
# HTTP implementation will be ignored.
|
175
|
+
# @option options [Puppet::SSL::SSLContext] :ssl_context (nil) ssl context to
|
176
|
+
# be used for connections
|
177
|
+
# @option options [Boolean] :include_system_store (false) if we should include
|
178
|
+
# the system store for connection
|
179
|
+
# @option options [Integer] :redirect_limit (10) The maximum number of HTTP
|
180
|
+
# redirections to allow for this request.
|
181
|
+
# @option options [Hash] :basic_auth A map of `:username` => `String` and
|
182
|
+
# `:password` => `String`
|
183
|
+
# @option options [String] :metric_id The metric id used to track metrics
|
184
|
+
# on requests.
|
185
|
+
|
107
186
|
# Submits a GET HTTP request to the given url
|
108
187
|
#
|
109
188
|
# @param [URI] url the location to submit the http request
|
110
189
|
# @param [Hash] headers merged with the default headers defined by the client
|
111
190
|
# @param [Hash] params encoded and set as the url query
|
112
|
-
#
|
113
|
-
# @option options [Puppet::SSL::SSLContext] :ssl_context (nil) ssl context to
|
114
|
-
# be used for connections
|
115
|
-
# @option options [Boolean] :include_system_store (false) if we should include
|
116
|
-
# the system store for connection
|
117
|
-
# @param options [Integer] :redirect_limit number of HTTP redirections to allow
|
118
|
-
# for this request.
|
191
|
+
# @!macro request_options
|
119
192
|
#
|
120
193
|
# @yield [Puppet::HTTP::Response] if a block is given yields the response
|
121
194
|
#
|
122
|
-
# @return [
|
195
|
+
# @return [Puppet::HTTP::Response] the response
|
123
196
|
#
|
197
|
+
# @api public
|
124
198
|
def get(url, headers: {}, params: {}, options: {}, &block)
|
125
199
|
url = encode_query(url, params)
|
126
200
|
|
127
201
|
request = Net::HTTP::Get.new(url, @default_headers.merge(headers))
|
128
202
|
|
129
|
-
execute_streaming(request, options: options)
|
130
|
-
if block_given?
|
131
|
-
yield response
|
132
|
-
else
|
133
|
-
response.body
|
134
|
-
end
|
135
|
-
end
|
203
|
+
execute_streaming(request, options: options, &block)
|
136
204
|
end
|
137
205
|
|
138
|
-
#
|
139
|
-
# @api private
|
140
|
-
#
|
141
206
|
# Submits a HEAD HTTP request to the given url
|
142
207
|
#
|
143
208
|
# @param [URI] url the location to submit the http request
|
144
209
|
# @param [Hash] headers merged with the default headers defined by the client
|
145
210
|
# @param [Hash] params encoded and set as the url query
|
146
|
-
#
|
147
|
-
# @option options [Puppet::SSL::SSLContext] :ssl_context (nil) ssl context to
|
148
|
-
# be used for connections
|
149
|
-
# @option options [Boolean] :include_system_store (false) if we should include
|
150
|
-
# the system store for connection
|
151
|
-
# @param options [Integer] :redirect_limit number of HTTP redirections to allow
|
152
|
-
# for this request.
|
211
|
+
# @!macro request_options
|
153
212
|
#
|
154
|
-
# @return [
|
213
|
+
# @return [Puppet::HTTP::Response] the response
|
155
214
|
#
|
215
|
+
# @api public
|
156
216
|
def head(url, headers: {}, params: {}, options: {})
|
157
217
|
url = encode_query(url, params)
|
158
218
|
|
159
219
|
request = Net::HTTP::Head.new(url, @default_headers.merge(headers))
|
160
220
|
|
161
|
-
execute_streaming(request, options: options)
|
162
|
-
response.body
|
163
|
-
end
|
221
|
+
execute_streaming(request, options: options)
|
164
222
|
end
|
165
223
|
|
166
|
-
#
|
167
|
-
# @api private
|
168
|
-
#
|
169
224
|
# Submits a PUT HTTP request to the given url
|
170
225
|
#
|
171
226
|
# @param [URI] url the location to submit the http request
|
172
227
|
# @param [String] body the body of the PUT request
|
173
|
-
# @param [Hash] headers merged with the default headers defined by the client
|
228
|
+
# @param [Hash] headers merged with the default headers defined by the client. The
|
229
|
+
# `Content-Type` header is required and should correspond to the type of data passed
|
230
|
+
# as the `body` argument.
|
174
231
|
# @param [Hash] params encoded and set as the url query
|
175
|
-
#
|
176
|
-
# @option options [String] :content_type the type of the body content
|
177
|
-
# @option options [Puppet::SSL::SSLContext] :ssl_context (nil) ssl context to
|
178
|
-
# be used for connections
|
179
|
-
# @option options [Boolean] :include_system_store (false) if we should include
|
180
|
-
# the system store for connection
|
181
|
-
# @param options [Integer] :redirect_limit number of HTTP redirections to allow
|
182
|
-
# for this request.
|
232
|
+
# @!macro request_options
|
183
233
|
#
|
184
|
-
# @return [
|
234
|
+
# @return [Puppet::HTTP::Response] the response
|
185
235
|
#
|
236
|
+
# @api public
|
186
237
|
def put(url, body, headers: {}, params: {}, options: {})
|
187
238
|
raise ArgumentError, "'put' requires a string 'body' argument" unless body.is_a?(String)
|
188
239
|
url = encode_query(url, params)
|
@@ -193,31 +244,24 @@ class Puppet::HTTP::Client
|
|
193
244
|
|
194
245
|
raise ArgumentError, "'put' requires a 'content-type' header" unless request['Content-Type']
|
195
246
|
|
196
|
-
execute_streaming(request, options: options)
|
197
|
-
response.body
|
198
|
-
end
|
247
|
+
execute_streaming(request, options: options)
|
199
248
|
end
|
200
249
|
|
201
|
-
#
|
202
|
-
# @api private
|
203
|
-
#
|
204
250
|
# Submits a POST HTTP request to the given url
|
205
251
|
#
|
206
252
|
# @param [URI] url the location to submit the http request
|
207
253
|
# @param [String] body the body of the POST request
|
208
|
-
# @param [Hash] headers merged with the default headers defined by the client
|
254
|
+
# @param [Hash] headers merged with the default headers defined by the client. The
|
255
|
+
# `Content-Type` header is required and should correspond to the type of data passed
|
256
|
+
# as the `body` argument.
|
209
257
|
# @param [Hash] params encoded and set as the url query
|
210
|
-
#
|
211
|
-
# @option options [String] :content_type the type of the body content
|
212
|
-
# @option options [Puppet::SSL::SSLContext] :ssl_context (nil) ssl context to
|
213
|
-
# be used for connections
|
214
|
-
# @option options [Boolean] :include_system_store (false) if we should include
|
215
|
-
# the system store for connection
|
216
|
-
# @param options [Integer] :redirect_limit number of HTTP redirections to allow
|
217
|
-
# for this request.
|
258
|
+
# @!macro request_options
|
218
259
|
#
|
219
|
-
# @
|
260
|
+
# @yield [Puppet::HTTP::Response] if a block is given yields the response
|
261
|
+
#
|
262
|
+
# @return [Puppet::HTTP::Response] the response
|
220
263
|
#
|
264
|
+
# @api public
|
221
265
|
def post(url, body, headers: {}, params: {}, options: {}, &block)
|
222
266
|
raise ArgumentError, "'post' requires a string 'body' argument" unless body.is_a?(String)
|
223
267
|
url = encode_query(url, params)
|
@@ -228,48 +272,32 @@ class Puppet::HTTP::Client
|
|
228
272
|
|
229
273
|
raise ArgumentError, "'post' requires a 'content-type' header" unless request['Content-Type']
|
230
274
|
|
231
|
-
execute_streaming(request, options: options)
|
232
|
-
if block_given?
|
233
|
-
yield response
|
234
|
-
else
|
235
|
-
response.body
|
236
|
-
end
|
237
|
-
end
|
275
|
+
execute_streaming(request, options: options, &block)
|
238
276
|
end
|
239
277
|
|
240
|
-
#
|
241
|
-
# @api private
|
242
|
-
#
|
243
|
-
# Submits a DELETE HTTP request to the given url
|
278
|
+
# Submits a DELETE HTTP request to the given url.
|
244
279
|
#
|
245
280
|
# @param [URI] url the location to submit the http request
|
246
281
|
# @param [Hash] headers merged with the default headers defined by the client
|
247
282
|
# @param [Hash] params encoded and set as the url query
|
248
|
-
#
|
249
|
-
# @option options [Puppet::SSL::SSLContext] :ssl_context (nil) ssl context to
|
250
|
-
# be used for connections
|
251
|
-
# @option options [Boolean] :include_system_store (false) if we should include
|
252
|
-
# the system store for connection
|
253
|
-
# @param options [Integer] :redirect_limit number of HTTP redirections to allow
|
254
|
-
# for this request.
|
283
|
+
# @!macro request_options
|
255
284
|
#
|
256
|
-
# @return [
|
285
|
+
# @return [Puppet::HTTP::Response] the response
|
257
286
|
#
|
287
|
+
# @api public
|
258
288
|
def delete(url, headers: {}, params: {}, options: {})
|
259
289
|
url = encode_query(url, params)
|
260
290
|
|
261
291
|
request = Net::HTTP::Delete.new(url, @default_headers.merge(headers))
|
262
292
|
|
263
|
-
execute_streaming(request, options: options)
|
264
|
-
response.body
|
265
|
-
end
|
293
|
+
execute_streaming(request, options: options)
|
266
294
|
end
|
267
295
|
|
296
|
+
# Close persistent connections in the pool.
|
268
297
|
#
|
269
|
-
# @
|
270
|
-
#
|
271
|
-
# Close persistent connections in the pool
|
298
|
+
# @return [void]
|
272
299
|
#
|
300
|
+
# @api public
|
273
301
|
def close
|
274
302
|
@pool.close
|
275
303
|
end
|
@@ -286,6 +314,21 @@ class Puppet::HTTP::Client
|
|
286
314
|
|
287
315
|
private
|
288
316
|
|
317
|
+
# Connect or borrow a connection from the pool to the host and port associated
|
318
|
+
# with the request's URL. Then execute the HTTP request, retrying and
|
319
|
+
# following redirects as needed, and return the HTTP response. The response
|
320
|
+
# body will always be fully drained/consumed when this method returns.
|
321
|
+
#
|
322
|
+
# If a block is provided, then the response will be yielded to the caller,
|
323
|
+
# allowing the response body to be streamed.
|
324
|
+
#
|
325
|
+
# If the request/response did not result in an exception and the caller did
|
326
|
+
# not ask for the connection to be closed (via Connection: close), then the
|
327
|
+
# connection will be returned to the pool.
|
328
|
+
#
|
329
|
+
# @yieldparam [Puppet::HTTP::Response] response The final response, after
|
330
|
+
# following redirects and retrying
|
331
|
+
# @return [Puppet::HTTP::Response]
|
289
332
|
def execute_streaming(request, options: {}, &block)
|
290
333
|
redirector = Puppet::HTTP::Redirector.new(options.fetch(:redirect_limit, @default_redirect_limit))
|
291
334
|
|
@@ -307,7 +350,7 @@ class Puppet::HTTP::Client
|
|
307
350
|
|
308
351
|
# don't call return within the `request` block
|
309
352
|
http.request(request) do |nethttp|
|
310
|
-
response = Puppet::HTTP::
|
353
|
+
response = Puppet::HTTP::ResponseNetHTTP.new(request.uri, nethttp)
|
311
354
|
begin
|
312
355
|
Puppet.debug("HTTP #{request.method.upcase} #{request.uri} returned #{response.code} #{response.reason}")
|
313
356
|
|
@@ -320,7 +363,7 @@ class Puppet::HTTP::Client
|
|
320
363
|
retries += 1
|
321
364
|
if interval
|
322
365
|
if http.started?
|
323
|
-
Puppet.debug("Closing connection for #{Puppet::
|
366
|
+
Puppet.debug("Closing connection for #{Puppet::HTTP::Site.from_uri(request.uri)}")
|
324
367
|
http.finish
|
325
368
|
end
|
326
369
|
Puppet.warning(_("Sleeping for %{interval} seconds before retrying the request") % { interval: interval })
|
@@ -329,8 +372,15 @@ class Puppet::HTTP::Client
|
|
329
372
|
end
|
330
373
|
end
|
331
374
|
|
332
|
-
|
375
|
+
if block_given?
|
376
|
+
yield response
|
377
|
+
else
|
378
|
+
response.body
|
379
|
+
end
|
333
380
|
ensure
|
381
|
+
# we need to make sure the response body is fully consumed before
|
382
|
+
# the connection is put back in the pool, otherwise the response
|
383
|
+
# for one request could leak into a future response.
|
334
384
|
response.drain
|
335
385
|
end
|
336
386
|
|